Merge branch '21128-toolbar-context-menu'
[arvados-workbench2.git] / src / store / collections / collection-move-actions.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { Dispatch } from "redux";
6 import { dialogActions } from "store/dialog/dialog-actions";
7 import { startSubmit, stopSubmit, initialize, FormErrors } from "redux-form";
8 import { ServiceRepository } from "services/services";
9 import { RootState } from "store/store";
10 import { getCommonResourceServiceError, CommonResourceServiceError } from "services/common-service/common-resource-service";
11 import { snackbarActions, SnackbarKind } from "store/snackbar/snackbar-actions";
12 import { projectPanelActions } from "store/project-panel/project-panel-action-bind";
13 import { MoveToFormDialogData } from "store/move-to-dialog/move-to-dialog";
14 import { resetPickerProjectTree } from "store/project-tree-picker/project-tree-picker-actions";
15 import { progressIndicatorActions } from "store/progress-indicator/progress-indicator-actions";
16 import { initProjectsTreePicker } from "store/tree-picker/tree-picker-actions";
17 import { getResource } from "store/resources/resources";
18 import { CollectionResource } from "models/collection";
19
20 export const COLLECTION_MOVE_FORM_NAME = "collectionMoveFormName";
21
22 export const openMoveCollectionDialog = (resource: { name: string; uuid: string }) => (dispatch: Dispatch) => {
23     dispatch<any>(resetPickerProjectTree());
24     dispatch<any>(initProjectsTreePicker(COLLECTION_MOVE_FORM_NAME));
25     dispatch(initialize(COLLECTION_MOVE_FORM_NAME, resource));
26     dispatch(dialogActions.OPEN_DIALOG({ id: COLLECTION_MOVE_FORM_NAME, data: {} }));
27 };
28
29 export const moveCollection =
30     (resource: MoveToFormDialogData) => async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => {
31         dispatch(startSubmit(COLLECTION_MOVE_FORM_NAME));
32         let cachedCollection = getResource<CollectionResource>(resource.uuid)(getState().resources);
33         try {
34             dispatch(progressIndicatorActions.START_WORKING(COLLECTION_MOVE_FORM_NAME));
35             if (!cachedCollection) {
36                 cachedCollection = await services.collectionService.get(resource.uuid);
37             }
38             const collection = await services.collectionService.update(resource.uuid, { ownerUuid: resource.ownerUuid });
39             dispatch(projectPanelActions.REQUEST_ITEMS());
40             dispatch(dialogActions.CLOSE_DIALOG({ id: COLLECTION_MOVE_FORM_NAME }));
41             dispatch(progressIndicatorActions.STOP_WORKING(COLLECTION_MOVE_FORM_NAME));
42             return { ...cachedCollection, ...collection };
43         } catch (e) {
44             const error = getCommonResourceServiceError(e);
45             if (error === CommonResourceServiceError.UNIQUE_NAME_VIOLATION) {
46                 dispatch(
47                     stopSubmit(COLLECTION_MOVE_FORM_NAME, {
48                         ownerUuid: "A collection with the same name already exists in the target project.",
49                     } as FormErrors)
50                 );
51             } else {
52                 dispatch(dialogActions.CLOSE_DIALOG({ id: COLLECTION_MOVE_FORM_NAME }));
53                 dispatch(snackbarActions.OPEN_SNACKBAR({ message: "Could not move the collection.", hideDuration: 2000, kind: SnackbarKind.ERROR }));
54             }
55             dispatch(progressIndicatorActions.STOP_WORKING(COLLECTION_MOVE_FORM_NAME));
56             return;
57         }
58     };