@reduxjs/toolkit#Dispatch TypeScript Examples

The following examples show how to use @reduxjs/toolkit#Dispatch. You can vote up the ones you like or vote down the ones you don't like, and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: schedulerEntriesActions.ts    From asynqmon with MIT License 6 votes vote down vote up
export function listSchedulerEntriesAsync() {
  return async (dispatch: Dispatch<SchedulerEntriesActionTypes>) => {
    dispatch({ type: LIST_SCHEDULER_ENTRIES_BEGIN });
    try {
      const response = await listSchedulerEntries();
      dispatch({
        type: LIST_SCHEDULER_ENTRIES_SUCCESS,
        payload: response,
      });
    } catch (error) {
      console.error(
        `listSchedulerEnqueueEventsAsync: ${toErrorStringWithHttpStatus(error)}`
      );
      dispatch({
        type: LIST_SCHEDULER_ENTRIES_ERROR,
        error: toErrorString(error),
      });
    }
  };
}
Example #2
Source File: schedulerEntriesActions.ts    From asynqmon with MIT License 6 votes vote down vote up
export function listSchedulerEnqueueEventsAsync(entryId: string) {
  return async (dispatch: Dispatch<SchedulerEntriesActionTypes>) => {
    dispatch({ type: LIST_SCHEDULER_ENQUEUE_EVENTS_BEGIN, entryId });
    try {
      const response = await listSchedulerEnqueueEvents(entryId);
      dispatch({
        type: LIST_SCHEDULER_ENQUEUE_EVENTS_SUCCESS,
        payload: response,
        entryId,
      });
    } catch (error) {
      console.error(
        "listSchedulerEnqueueEventsAsync: ",
        toErrorStringWithHttpStatus(error)
      );
      dispatch({
        type: LIST_SCHEDULER_ENQUEUE_EVENTS_ERROR,
        error: toErrorString(error),
        entryId,
      });
    }
  };
}
Example #3
Source File: index.ts    From ant-simple-draw with MIT License 6 votes vote down vote up
saveLocally = () => (dispatch: Dispatch, getState: () => storeType) =>
  Promise.resolve().then(() => {
    if (!getState().component.componentDataList.length) {
      return;
    }
    sessionStorage.setItem('componentDataList', getState().component.componentDataList);
    sessionStorage.setItem('canvasInformation', getState().config.canvasInformation);
    sessionStorage.setItem('config', getState().config);
  })
Example #4
Source File: component.ts    From ant-simple-draw with MIT License 6 votes vote down vote up
upComponentAction = () => (dispatch: Dispatch, getState: () => storeType) => {
  const { curComponentIndex, componentDataList } = getState().component;
  // 上移图层 当前index,表示元素在数组中越往后
  if (curComponentIndex < componentDataList.length - 1) {
    dispatch(
      upDownHandle({
        curComponentIndex,
        displacementIndex: curComponentIndex + 1,
      }),
    );
  }
}
Example #5
Source File: component.ts    From ant-simple-draw with MIT License 6 votes vote down vote up
downComponentAction = () => (dispatch: Dispatch, getState: () => storeType) => {
  // 下移图层 index,表示元素在数组中越往前
  const { curComponentIndex } = getState().component;
  if (curComponentIndex > 0) {
    dispatch(
      upDownHandle({
        curComponentIndex: curComponentIndex,
        displacementIndex: curComponentIndex - 1,
      }),
    );
  }
}
Example #6
Source File: copy.ts    From ant-simple-draw with MIT License 6 votes vote down vote up
paste =
  (isContextMenuMouse: boolean) => (dispatch: Dispatch, getState: () => storeType) => {
    if (!getState().copys.copyData!) {
      return;
    }
    dispatch(
      pasteAction({
        isContextMenuMouse,
        top: getState().contextMenu.top,
        left: getState().contextMenu.left,
      }),
    );
    dispatch(addComponent(getState().copys.copyData!));
    if (getState().copys.isCut) {
      // 要清空
      dispatch(changeCopyDataAction(null));
      dispatch(changeCutStatusAction(false));
    }
  }
Example #7
Source File: copy.ts    From ant-simple-draw with MIT License 6 votes vote down vote up
cut = () => (dispatch: Dispatch<any>, getState: () => storeType) => {
  if (!getState().component.curComponent) {
    return;
  }
  dispatch(copy());
  dispatch(deleteComponentAction([getState().component.curComponent?.componentId!]));
  dispatch(changeCutStatusAction(true));
  // 防止多次剪切操作,导致触发剪贴功能
  dispatch(curComponentAction(null));
}
Example #8
Source File: snapshot.ts    From ant-simple-draw with MIT License 6 votes vote down vote up
undo = () => (dispatch: Dispatch, getState: () => storeType) => {
  if (getState().snapshot.snapshotIndex >= 0) {
    dispatch(undoAction());
    const componentData: templateDataType[] =
      getState().snapshot.snapshotData[getState().snapshot.snapshotIndex] || [];
    if (getState().component.curComponent) {
      // 如果当前组件不在 componentData 中,则置空
      let needClean = !componentData.find(
        (item) => getState().component.curComponent?.componentId === item.componentId,
      );
      if (needClean) {
        dispatch(curComponentAction(null));
      }
    }
    dispatch(setComponentDataListAction(componentData));
  }
}
Example #9
Source File: snapshot.ts    From ant-simple-draw with MIT License 6 votes vote down vote up
redo = () => (dispatch: Dispatch, getState: () => storeType) => {
  if (getState().snapshot.snapshotIndex < getState().snapshot.snapshotData.length - 1) {
    dispatch(redoAction());
    dispatch(
      setComponentDataListAction(
        getState().snapshot.snapshotData[getState().snapshot.snapshotIndex],
      ),
    );
  }
}
Example #10
Source File: SettingsSlice.tsx    From sapio-studio with Mozilla Public License 2.0 6 votes vote down vote up
export async function poll_settings(dispatch: Dispatch) {
    dispatch(
        load_settings({
            settings: {
                display: (await window.electron.load_settings_sync(
                    'display'
                )) as unknown as any,
                bitcoin: (await window.electron.load_settings_sync(
                    'bitcoin'
                )) as unknown as any,
            },
        })
    );
}
Example #11
Source File: media-session.ts    From webminidisc with GNU General Public License v2.0 5 votes vote down vote up
constructor(appStore: AppStore) {
        this.dispatch = appStore.dispatch.bind(appStore) as Dispatch<any>;
        this.subscribe = appStore.subscribe.bind(appStore);
        this.getState = appStore.getState.bind(appStore);
    }
Example #12
Source File: media-session.ts    From webminidisc with GNU General Public License v2.0 5 votes vote down vote up
private dispatch: Dispatch<any>;
Example #13
Source File: index.ts    From glide-frontend with GNU General Public License v3.0 5 votes vote down vote up
fetchAchievements = (account: string) => async (dispatch: Dispatch) => {
  try {
    const achievements = await getAchievements(account)
    dispatch(setAchievements(achievements))
  } catch (error) {
    console.error(error)
  }
}
Example #14
Source File: component.ts    From ant-simple-draw with MIT License 5 votes vote down vote up
setShapeStyleAction =
  (val: MergeCSSProperties) => (dispatch: Dispatch, getState: () => storeType) => {
    dispatch(setShapeStyle(val));
    dispatch(getCanvasConfigInformationAction(getState().config));
  }
Example #15
Source File: copy.ts    From ant-simple-draw with MIT License 5 votes vote down vote up
copy = () => (dispatch: Dispatch, getState: () => storeType) => {
  const { component } = getState();
  if (component.curComponent) {
    dispatch(copyAction(component.curComponent));
  }
}
Example #16
Source File: snapshot.ts    From ant-simple-draw with MIT License 5 votes vote down vote up
recordSnapshot = () => (dispatch: Dispatch, getState: () => storeType) => {
  const { component } = getState();
  dispatch(recordSnapshotAction(component.componentDataList));
}