當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript Module.createAction方法代碼示例

本文整理匯總了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 }),
});
開發者ID:Mehuge,項目名稱:Camelot-Unchained,代碼行數:30,代碼來源:job.ts

示例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) => {
開發者ID:Mehuge,項目名稱:Camelot-Unchained,代碼行數:31,代碼來源:layout.ts

示例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();
開發者ID:Mehuge,項目名稱:Camelot-Unchained,代碼行數:30,代碼來源:filterButtonState.ts

示例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);
      }
    };
  },
});
開發者ID:codecorsair,項目名稱:Camelot-Unchained,代碼行數:30,代碼來源:controller.ts

示例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;
開發者ID:JoelTerMeer,項目名稱:Camelot-Unchained,代碼行數:31,代碼來源:banesAndBoons.ts

示例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();
開發者ID:Mehuge,項目名稱:Camelot-Unchained,代碼行數:30,代碼來源:inventoryState.ts

示例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());
      }
    };
  }
}
開發者ID:Shane7,項目名稱:Camelot-Unchained,代碼行數:30,代碼來源:layout.ts

示例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();
開發者ID:Mehuge,項目名稱:Camelot-Unchained,代碼行數:30,代碼來源:recipes.ts

示例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 };
  },
});
開發者ID:Mehuge,項目名稱:Camelot-Unchained,代碼行數:30,代碼來源:ui.ts

示例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) => {
開發者ID:JoelTerMeer,項目名稱:Camelot-Unchained,代碼行數:31,代碼來源:layout.ts


注:本文中的redux-typed-modules.Module.createAction方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。