X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/25216cc7acedc987c26a159f0b640210c0ef101e..2a7fd99c212c33a1ec9911f8529fa5afc59a7bb2:/src/store/trash/trash-actions.ts diff --git a/src/store/trash/trash-actions.ts b/src/store/trash/trash-actions.ts index 85ffd4a0be..9672642287 100644 --- a/src/store/trash/trash-actions.ts +++ b/src/store/trash/trash-actions.ts @@ -2,86 +2,95 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { Dispatch } from "redux"; -import { RootState } from "store/store"; -import { ServiceRepository } from "services/services"; -import { snackbarActions, SnackbarKind } from "store/snackbar/snackbar-actions"; -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 { Dispatch } from 'redux'; +import { RootState } from 'store/store'; +import { ServiceRepository } from 'services/services'; +import { snackbarActions, SnackbarKind } from 'store/snackbar/snackbar-actions'; +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 { navigateTo, navigateToTrash } from 'store/navigation/navigation-action'; import { matchCollectionRoute } from 'routes/routes'; -export const toggleProjectTrashed = (uuid: string, ownerUuid: string, isTrashed: boolean) => +export const toggleProjectTrashed = + (uuid: string, ownerUuid: string, isTrashed: boolean, isMulti: boolean) => async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository): Promise => { let errorMessage = ''; let successMessage = ''; try { if (isTrashed) { - errorMessage = "Could not restore project from trash"; - successMessage = "Restored from trash"; + errorMessage = 'Could not restore project from trash'; + successMessage = 'Restored from trash'; await services.groupsService.untrash(uuid); - dispatch(navigateTo(uuid)); + dispatch(isMulti ? navigateToTrash : navigateTo(uuid)); dispatch(activateSidePanelTreeItem(uuid)); } else { - errorMessage = "Could not move project to trash"; - successMessage = "Added to trash"; + errorMessage = 'Could not move project to trash'; + successMessage = 'Added to trash'; await services.groupsService.trash(uuid); dispatch(loadSidePanelTreeProjects(ownerUuid)); dispatch(navigateTo(ownerUuid)); } } catch (e) { - dispatch(snackbarActions.OPEN_SNACKBAR({ - message: errorMessage, - kind: SnackbarKind.ERROR - })); + dispatch( + snackbarActions.OPEN_SNACKBAR({ + message: errorMessage, + kind: SnackbarKind.ERROR, + }) + ); } - dispatch(snackbarActions.OPEN_SNACKBAR({ - message: successMessage, - hideDuration: 2000, - kind: SnackbarKind.SUCCESS - })); + dispatch( + snackbarActions.OPEN_SNACKBAR({ + message: successMessage, + hideDuration: 2000, + kind: SnackbarKind.SUCCESS, + }) + ); }; -export const toggleCollectionTrashed = (uuid: string, isTrashed: boolean) => +export const toggleCollectionTrashed = + (uuid: string, isTrashed: boolean) => async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository): Promise => { let errorMessage = ''; let successMessage = ''; try { if (isTrashed) { const { location } = getState().router; - errorMessage = "Could not restore collection from trash"; - successMessage = "Restored from trash"; + errorMessage = 'Could not restore collection from trash'; + successMessage = 'Restored from trash'; await services.collectionService.untrash(uuid); if (matchCollectionRoute(location ? location.pathname : '')) { dispatch(navigateToTrash); } dispatch(trashPanelActions.REQUEST_ITEMS()); } else { - errorMessage = "Could not move collection to trash"; - successMessage = "Added to trash"; + errorMessage = 'Could not move collection to trash'; + successMessage = 'Added to trash'; await services.collectionService.trash(uuid); dispatch(projectPanelActions.REQUEST_ITEMS()); } } catch (e) { - dispatch(snackbarActions.OPEN_SNACKBAR({ - message: errorMessage, - kind: SnackbarKind.ERROR - })); + dispatch( + snackbarActions.OPEN_SNACKBAR({ + message: errorMessage, + kind: SnackbarKind.ERROR, + }) + ); } - dispatch(snackbarActions.OPEN_SNACKBAR({ - message: successMessage, - hideDuration: 2000, - kind: SnackbarKind.SUCCESS - })); + dispatch( + snackbarActions.OPEN_SNACKBAR({ + message: successMessage, + hideDuration: 2000, + kind: SnackbarKind.SUCCESS, + }) + ); }; -export const toggleTrashed = (kind: ResourceKind, uuid: string, ownerUuid: string, isTrashed: boolean) => - (dispatch: Dispatch) => { - if (kind === ResourceKind.PROJECT) { - dispatch(toggleProjectTrashed(uuid, ownerUuid, isTrashed!!)); - } else if (kind === ResourceKind.COLLECTION) { - dispatch(toggleCollectionTrashed(uuid, isTrashed!!)); - } - }; +export const toggleTrashed = (kind: ResourceKind, uuid: string, ownerUuid: string, isTrashed: boolean) => (dispatch: Dispatch) => { + if (kind === ResourceKind.PROJECT) { + dispatch(toggleProjectTrashed(uuid, ownerUuid, isTrashed!!, false)); + } else if (kind === ResourceKind.COLLECTION) { + dispatch(toggleCollectionTrashed(uuid, isTrashed!!)); + } +};