X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/a2bf1ed3a15cf55e426c51ad8e6febd7ff2e3020..c93fca2c9be41ca963a0271dd373cc1a40cba196:/src/store/trash/trash-actions.ts diff --git a/src/store/trash/trash-actions.ts b/src/store/trash/trash-actions.ts index 5cf952eb1f..b810b1e490 100644 --- a/src/store/trash/trash-actions.ts +++ b/src/store/trash/trash-actions.ts @@ -10,12 +10,14 @@ import { trashPanelActions } from "~/store/trash-panel/trash-panel-action"; import { activateSidePanelTreeItem, loadSidePanelTreeProjects } from "~/store/side-panel-tree/side-panel-tree-actions"; import { projectPanelActions } from "~/store/project-panel/project-panel-action"; import { ResourceKind } from "~/models/resource"; +import { navigateToTrash } from '~/store/navigation/navigation-action'; +import { matchCollectionRoute } from '~/routes/routes'; export const toggleProjectTrashed = (uuid: string, ownerUuid: string, isTrashed: boolean) => async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository): Promise => { try { if (isTrashed) { - dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Restoring from trash..." })); + dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Restoring from trash...", kind: SnackbarKind.INFO })); await services.groupsService.untrash(uuid); dispatch(activateSidePanelTreeItem(uuid)); dispatch(trashPanelActions.REQUEST_ITEMS()); @@ -25,8 +27,9 @@ export const toggleProjectTrashed = (uuid: string, ownerUuid: string, isTrashed: kind: SnackbarKind.SUCCESS })); } else { - dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Moving to trash..." })); + dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Moving to trash...", kind: SnackbarKind.INFO })); await services.groupsService.trash(uuid); + dispatch(projectPanelActions.REQUEST_ITEMS()); dispatch(loadSidePanelTreeProjects(ownerUuid)); dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Added to trash", @@ -46,8 +49,12 @@ export const toggleCollectionTrashed = (uuid: string, isTrashed: boolean) => async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository): Promise => { try { if (isTrashed) { - dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Restoring from trash..." })); + const { location } = getState().router; + dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Restoring from trash...", kind: SnackbarKind.INFO })); await services.collectionService.untrash(uuid); + if (matchCollectionRoute(location ? location.pathname : '')) { + dispatch(navigateToTrash); + } dispatch(trashPanelActions.REQUEST_ITEMS()); dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Restored from trash", @@ -55,7 +62,7 @@ export const toggleCollectionTrashed = (uuid: string, isTrashed: boolean) => kind: SnackbarKind.SUCCESS })); } else { - dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Moving to trash..." })); + dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Moving to trash...", kind: SnackbarKind.INFO })); await services.collectionService.trash(uuid); dispatch(projectPanelActions.REQUEST_ITEMS()); dispatch(snackbarActions.OPEN_SNACKBAR({