X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/3015426750f11fdc97d55a29f2a662e2f272f5d4..0240e28950f94b0911f2b22d55cc719d94bdff0e:/src/store/project/project-action.ts diff --git a/src/store/project/project-action.ts b/src/store/project/project-action.ts index b2c6b0373b..c1a002f98a 100644 --- a/src/store/project/project-action.ts +++ b/src/store/project/project-action.ts @@ -3,19 +3,57 @@ // SPDX-License-Identifier: AGPL-3.0 import { default as unionize, ofType, UnionOf } from "unionize"; -import { Project } from "../../models/project"; +import { Project, 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({ - CREATE_PROJECT: ofType(), + 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_REQUEST: ofType(), PROJECTS_SUCCESS: ofType<{ projects: Project[], parentItemId?: string }>(), TOGGLE_PROJECT_TREE_ITEM_OPEN: ofType(), TOGGLE_PROJECT_TREE_ITEM_ACTIVE: ofType(), + RESET_PROJECT_TREE_ACTIVITY: ofType() }, { - tag: 'type', - value: 'payload' -}); + tag: 'type', + value: 'payload' + }); + +export const getProjectList = (parentUuid: string = '') => (dispatch: Dispatch) => { + dispatch(actions.PROJECTS_REQUEST(parentUuid)); + return projectService.list({ + filters: FilterBuilder + .create() + .addEqual("ownerUuid", parentUuid) + }).then(listResults => { + const projects = listResults.items.map(item => ({ + ...item, + kind: getResourceKind(item.kind) + })); + dispatch(actions.PROJECTS_SUCCESS({ projects, parentItemId: parentUuid })); + return projects; + }); +}; + +export const createProject = (project: Partial) => + (dispatch: Dispatch, getState: () => RootState) => { + const { ownerUuid } = getState().projects.creator; + const projectData = { ownerUuid, ...project }; + dispatch(actions.CREATE_PROJECT(projectData)); + return projectService + .create(projectData) + .then(project => dispatch(actions.CREATE_PROJECT_SUCCESS(project))) + .catch(() => dispatch(actions.CREATE_PROJECT_ERROR("Could not create a project"))); + }; export type ProjectAction = UnionOf; export default actions;