Extract major components from workbench
[arvados-workbench2.git] / src / store / project / project-action.ts
index 2017658916cbfe7f5bc408c5eaaea4d547e6cc20..da58ed28859a7bd4d94816b0fb7ed0f94d6ec79a 100644 (file)
@@ -1,8 +1,8 @@
 // Copyright (C) The Arvados Authors. All rights reserved.
 //
 // SPDX-License-Identifier: AGPL-3.0
-import { default as unionize, ofType, UnionOf } from "unionize";
 
+import { unionize, ofType, UnionOf } from '~/common/unionize';
 import { ProjectResource } from "~/models/project";
 import { Dispatch } from "redux";
 import { FilterBuilder } from "~/common/api/filter-builder";
@@ -10,14 +10,15 @@ import { RootState } from "../store";
 import { checkPresenceInFavorites } from "../favorites/favorites-actions";
 import { ServiceRepository } from "~/services/services";
 import { projectPanelActions } from "~/store/project-panel/project-panel-action";
-import { updateDetails } from "~/store/details-panel/details-panel-action";
+import { resourcesActions } from "~/store/resources/resources-actions";
+import { reset } from 'redux-form';
 
 export const projectActions = unionize({
     OPEN_PROJECT_CREATOR: ofType<{ ownerUuid: string }>(),
     CLOSE_PROJECT_CREATOR: ofType<{}>(),
     CREATE_PROJECT: ofType<Partial<ProjectResource>>(),
     CREATE_PROJECT_SUCCESS: ofType<ProjectResource>(),
-    OPEN_PROJECT_UPDATER: ofType<{ uuid: string}>(),
+    OPEN_PROJECT_UPDATER: ofType<{ uuid: string }>(),
     CLOSE_PROJECT_UPDATER: ofType<{}>(),
     UPDATE_PROJECT_SUCCESS: ofType<ProjectResource>(),
     REMOVE_PROJECT: ofType<string>(),
@@ -26,14 +27,11 @@ export const projectActions = unionize({
     TOGGLE_PROJECT_TREE_ITEM_OPEN: ofType<string>(),
     TOGGLE_PROJECT_TREE_ITEM_ACTIVE: ofType<string>(),
     RESET_PROJECT_TREE_ACTIVITY: ofType<string>()
-}, {
-    tag: 'type',
-    value: 'payload'
 });
 
 export const PROJECT_FORM_NAME = 'projectEditDialog';
 
-export const getProjectList = (parentUuid: string = '') => 
+export const getProjectList = (parentUuid: string = '') =>
     (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => {
         dispatch(projectActions.PROJECTS_REQUEST(parentUuid));
         return services.projectService.list({
@@ -66,8 +64,16 @@ export const updateProject = (project: Partial<ProjectResource>) =>
                 dispatch(projectActions.UPDATE_PROJECT_SUCCESS(project));
                 dispatch(projectPanelActions.REQUEST_ITEMS());
                 dispatch<any>(getProjectList(project.ownerUuid));
-                dispatch<any>(updateDetails(project));
+                dispatch(resourcesActions.SET_RESOURCES([project]));
             });
     };
 
+export const PROJECT_CREATE_DIALOG = "projectCreateDialog";
+
+export const openProjectCreator = (ownerUuid: string) =>
+    (dispatch: Dispatch) => {
+        dispatch(reset(PROJECT_CREATE_DIALOG));
+        dispatch(projectActions.OPEN_PROJECT_CREATOR({ ownerUuid }));
+    };
+
 export type ProjectAction = UnionOf<typeof projectActions>;