refs #master Merge branch 'origin/master' into 13856-upload-component
[arvados-workbench2.git] / src / store / project / project-action.ts
index 516934969310fa7c5331d49719b190c5fc8d990b..2f9963bf9b3510f8b726475ba2fa35eee7864f58 100644 (file)
@@ -3,17 +3,21 @@
 // SPDX-License-Identifier: AGPL-3.0
 import { default as unionize, ofType, UnionOf } from "unionize";
 
-import { Project, ProjectResource } from "../../models/project";
-import { projectService } from "../../services/services";
+import { ProjectResource } from "../../models/project";
 import { Dispatch } from "redux";
-import { getResourceKind } from "../../models/resource";
-import FilterBuilder from "../../common/api/filter-builder";
+import { FilterBuilder } from "../../common/api/filter-builder";
+import { RootState } from "../store";
+import { checkPresenceInFavorites } from "../favorites/favorites-actions";
+import { ServiceRepository } from "../../services/services";
 
-const actions = unionize({
-    CREATE_PROJECT: ofType<Project>(),
+export const projectActions = unionize({
+    OPEN_PROJECT_CREATOR: ofType<{ ownerUuid: string }>(),
+    CLOSE_PROJECT_CREATOR: ofType<{}>(),
+    CREATE_PROJECT: ofType<Partial<ProjectResource>>(),
+    CREATE_PROJECT_SUCCESS: ofType<ProjectResource>(),
     REMOVE_PROJECT: ofType<string>(),
     PROJECTS_REQUEST: ofType<string>(),
-    PROJECTS_SUCCESS: ofType<{ projects: Project[], parentItemId?: string }>(),
+    PROJECTS_SUCCESS: ofType<{ projects: ProjectResource[], parentItemId?: string }>(),
     TOGGLE_PROJECT_TREE_ITEM_OPEN: ofType<string>(),
     TOGGLE_PROJECT_TREE_ITEM_ACTIVE: ofType<string>(),
     RESET_PROJECT_TREE_ACTIVITY: ofType<string>()
@@ -22,21 +26,27 @@ const actions = unionize({
         value: 'payload'
     });
 
-export const getProjectList = (parentUuid: string = '') => (dispatch: Dispatch) => {
-    dispatch(actions.PROJECTS_REQUEST(parentUuid));
-    return projectService.list({
+export const getProjectList = (parentUuid: string = '') => (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => {
+    dispatch(projectActions.PROJECTS_REQUEST(parentUuid));
+    return services.projectService.list({
         filters: FilterBuilder
             .create<ProjectResource>()
             .addEqual("ownerUuid", parentUuid)
-    }).then(listResults => {
-        const projects = listResults.items.map(item => ({
-            ...item,
-            kind: getResourceKind(item.kind)
-        }));
-        dispatch(actions.PROJECTS_SUCCESS({ projects, parentItemId: parentUuid }));
+    }).then(({ items: projects }) => {
+        dispatch(projectActions.PROJECTS_SUCCESS({ projects, parentItemId: parentUuid }));
+        dispatch<any>(checkPresenceInFavorites(projects.map(project => project.uuid)));
         return projects;
     });
 };
 
-export type ProjectAction = UnionOf<typeof actions>;
-export default actions;
+export const createProject = (project: Partial<ProjectResource>) =>
+    (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => {
+        const { ownerUuid } = getState().projects.creator;
+        const projectData = { ownerUuid, ...project };
+        dispatch(projectActions.CREATE_PROJECT(projectData));
+        return services.projectService
+            .create(projectData)
+            .then(project => dispatch(projectActions.CREATE_PROJECT_SUCCESS(project)));
+    };
+
+export type ProjectAction = UnionOf<typeof projectActions>;