X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/1933452553965a2066191eccaaa40943d6d5c5d8..109103ee47da299c04ffdcabebc38bcd665555d9:/src/store/project/project-action.ts diff --git a/src/store/project/project-action.ts b/src/store/project/project-action.ts index 184922e3ec..2d59a4842b 100644 --- a/src/store/project/project-action.ts +++ b/src/store/project/project-action.ts @@ -3,22 +3,21 @@ // SPDX-License-Identifier: AGPL-3.0 import { default as unionize, ofType, UnionOf } from "unionize"; -import { Project, ProjectResource } from "../../models/project"; +import { ProjectResource } from "../../models/project"; import { projectService } from "../../services/services"; import { Dispatch } from "redux"; -import { getResourceKind } from "../../models/resource"; import FilterBuilder from "../../common/api/filter-builder"; -import { ThunkAction } from "../../../node_modules/redux-thunk"; +import { RootState } from "../store"; const actions = unionize({ - OPEN_PROJECT_CREATOR: ofType<{ownerUuid: string}>(), + OPEN_PROJECT_CREATOR: ofType<{ ownerUuid: string }>(), CLOSE_PROJECT_CREATOR: ofType<{}>(), CREATE_PROJECT: ofType>(), CREATE_PROJECT_SUCCESS: ofType(), CREATE_PROJECT_ERROR: ofType(), REMOVE_PROJECT: ofType(), PROJECTS_REQUEST: ofType(), - PROJECTS_SUCCESS: ofType<{ projects: Project[], parentItemId?: string }>(), + PROJECTS_SUCCESS: ofType<{ projects: ProjectResource[], parentItemId?: string }>(), TOGGLE_PROJECT_TREE_ITEM_OPEN: ofType(), TOGGLE_PROJECT_TREE_ITEM_ACTIVE: ofType(), RESET_PROJECT_TREE_ACTIVITY: ofType() @@ -33,23 +32,21 @@ export const getProjectList = (parentUuid: string = '') => (dispatch: Dispatch) filters: FilterBuilder .create() .addEqual("ownerUuid", parentUuid) - }).then(listResults => { - const projects = listResults.items.map(item => ({ - ...item, - kind: getResourceKind(item.kind) - })); + }).then(({ items: projects }) => { dispatch(actions.PROJECTS_SUCCESS({ projects, parentItemId: parentUuid })); return projects; }); }; export const createProject = (project: Partial) => - (dispatch: Dispatch) => { - dispatch(actions.CREATE_PROJECT(project)); + (dispatch: Dispatch, getState: () => RootState) => { + const { ownerUuid } = getState().projects.creator; + const projectData = { ownerUuid, ...project }; + dispatch(actions.CREATE_PROJECT(projectData)); return projectService - .create(project) + .create(projectData) .then(project => dispatch(actions.CREATE_PROJECT_SUCCESS(project))) - .catch(() => dispatch(actions.CREATE_PROJECT_ERROR("Could not create a project"))); + .catch((response) => dispatch(actions.CREATE_PROJECT_ERROR(response.response.data.errors))); }; export type ProjectAction = UnionOf;