本文整理匯總了TypeScript中redux-typed-modules.Module.createAction方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Module.createAction方法的具體用法?TypeScript Module.createAction怎麽用?TypeScript Module.createAction使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類redux-typed-modules.Module
的用法示例。
在下文中一共展示了Module.createAction方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: Module
outputItems: [],
name: null,
message: null,
itemCount: undefined,
count: 0,
};
};
const module = new Module({
initialState: initialState(),
actionExtraData: () => ({ when: new Date() }),
});
export const setJobType = module.createAction({
type: 'crafting/job/set-job',
action: (jobType: string) => ({ jobType }),
reducer: (s, a) => ({ type: a.jobType }),
});
export const setStatus = module.createAction({
type: 'crafting/job/set-status',
action: (status: string) => ({ status }),
reducer: (s, a) => ({ status: a.status }),
});
export const setCount = module.createAction({
type: 'crafting/job/set-count',
action: (count: number) => ({ count }),
reducer: (s, a) => ({ count: a.count || 0 }),
});
示例2: initialize
const screen: Size = { width: window.innerWidth, height: window.innerHeight };
return {
...state,
lastScreenSize: screen,
};
},
});
/////////////////////////////////
// Actions
/////////////////////////////////
// NO OP -- #TODO: do I really need this?
const init = module.createAction({
type: 'layout/INITIALIZE',
action: () => null,
reducer: s => s,
});
// Async init - allows window onresize to dispatch actions
export function initialize() {
return (dispatch: (action: any) => any) => {
dispatch(init());
window.onresize = () => {
if (window.innerWidth >= 640 && window.innerHeight >= 480) {
dispatch(resize());
}
};
// hook up to event triggers
game.on('navigate', (name: string) => {
示例3: getInitialState
SET_FILTER_BUTTONS: 'charactersheets-inventory-SET_FILTER_BUTTONS',
};
export interface FilterButtonState {
filterButtons: InventoryFilterButton[];
}
export function getInitialState() {
const initialState: FilterButtonState = {
filterButtons: defaultFilterButtonIcons,
};
return initialState;
}
export const module = new Module({
initialState: getInitialState(),
});
export const setFilterButtons = module.createAction({
type: types.SET_FILTER_BUTTONS,
action: (action: { filterButtons: InventoryFilterButton[] }) => action,
reducer: (state, action) => {
const filterButtons = action.filterButtons;
return {
filterButtons,
};
},
});
export default module.createReducer();
示例4: get
// Initialize patcher signalr connections
export const initialize = module.createAction({
type: 'controller/initialize',
action: () => {
Object.defineProperty(client, 'accessToken', { get() { return patcher.getAccessToken(); } });
return (dispatch: (action: ControllerAction) => any) => {
dispatch(reset() as ControllerAction);
dispatch(initSignalR() as ControllerAction);
registerPatcherHubEvents(dispatch);
dispatch(getChannels());
// update channel info on a timer...
if (channelUpdateInterval === null) {
channelUpdateInterval = setInterval(() => dispatch(getChannels()), 500);
}
try {
// Connect to patcher api server signalr patcher hub
startPatcherSignalR(dispatch).then((ok) => {
if (ok) {
// Connect to other server's signalr pathcer hubs.
startOtherSignalR(dispatch);
}
});
} catch (e) {
console.error(e);
dispatch(initSignalRFailed() as ControllerAction);
}
};
},
});
示例5: Module
};
return initialState;
}
export const module = new Module({
initialState: getInitialState(),
});
export const onSelectBane = module.createAction({
type: 'cu-character-creation/banes-and-boons/ON_SELECT_BANE',
action: (action: { bane: BanesAndBoonsInfo }) => action,
reducer: (state, action) => {
const addedBanes = state.addedBanes;
const traits = state.traits;
addedBanes[action.bane.id] = action.bane.id;
traits[action.bane.id] = { ...action.bane, selected: true };
return {
traits,
addedBanes,
totalPoints: state.totalPoints + action.bane.points,
};
},
});
export const onSelectBoon = module.createAction({
type: 'cu-character-creation/banes-and-boons/ON_SELECT_BOON',
action: (action: { boon: BanesAndBoonsInfo }) => action,
reducer: (state, action) => {
const addedBoons = state.addedBoons;
const traits = state.traits;
addedBoons[action.boon.id] = action.boon.id;
示例6: getInitialState
stack?: InventoryItem.Fragment[];
}
export interface InventoryState {
itemSlots: ItemSlot[];
}
export function getInitialState() {
const initialState: InventoryState = {
itemSlots: [],
};
return initialState;
}
export const module = new Module({
initialState: getInitialState(),
});
export const setItemSlots = module.createAction({
type: types.SET_ITEM_SLOTS,
action: (action: { itemSlots: ItemSlot[] }) => action,
reducer: (state, action) => {
const { itemSlots } = action;
return {
itemSlots,
};
},
});
export default module.createReducer();
示例7: initialize
const screen: Size = { width: window.innerWidth, height: window.innerHeight };
return {
...state,
lastScreenSize: screen
}
}
});
/////////////////////////////////
// Actions
/////////////////////////////////
// NO OP -- #TODO: do I really need this?
const init = module.createAction({
type: 'layout/INITIALIZE',
action: () => null,
reducer: s => s
});
// Async init - allows window onresize to dispatch actions
export function initialize() {
return (dispatch: (action: any) => any) => {
dispatch(init());
window.onresize = () => {
if (window.innerWidth >= 640 && window.innerHeight >= 480) {
dispatch(resize());
}
};
}
}
示例8: switch
});
}
export const gotVoxRecipes = module.createAction({
type: 'crafting/recipes/got-recipes',
action: (recipeType: string, recipes: VoxRecipe[]) => ({
recipeType,
recipes,
}),
reducer: (s, a) => {
const type = a.recipeType;
switch (type) {
case 'grind':
case 'shape':
case 'block':
case 'make':
const mappedVoxRecipes = mapVoxRecipesToRecipes(a.recipes);
return { [type]: mappedVoxRecipes.sort((a, b) => a.name.localeCompare(b.name)) };
case 'purify': {
const mappedPurifyRecipes = mapPurifyRecipesToRecipes(a.recipes);
return { [type]: mappedPurifyRecipes.sort((a, b) => a.name.localeCompare(b.name)) };
}
}
console.error('CRAFTING: illegal recipe type ' + type);
return {};
},
});
export default module.createReducer();
示例9: Module
};
const module = new Module({
initialState: initialState(),
actionExtraData: () => {
return {
when: new Date(),
};
},
});
export const setUIMode = module.createAction({
type: 'crafting/ui/mode',
action: (mode: string) => {
return { mode };
},
reducer: (s, a) => {
return { mode: a.mode };
},
});
export const setRemaining = module.createAction({
type: 'crafting/ui/crafting-progress',
action: (remaining: number) => {
return { remaining };
},
reducer: (s, a) => {
return { remaining: a.remaining };
},
});
示例10: initialize
const screen: Size = { width: window.innerWidth, height: window.innerHeight };
return {
...state,
lastScreenSize: screen,
};
},
});
/////////////////////////////////
// Actions
/////////////////////////////////
// NO OP -- #TODO: do I really need this?
const init = module.createAction({
type: 'layout/INITIALIZE',
action: () => null,
reducer: s => s,
});
// Async init - allows window onresize to dispatch actions
export function initialize() {
return (dispatch: (action: any) => any) => {
dispatch(init());
window.onresize = () => {
if (window.innerWidth >= 640 && window.innerHeight >= 480) {
// dispatch(resize());
}
};
// hook up to event triggers
events.on('hudnav--navigate', (name: string) => {