X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/e5b901f7d6f87b56f43d3dbe002c9c90a3d41349..dd89200ad6fdbfa337fdbab5f54def8712c6746c:/src/store/project/project-action.ts diff --git a/src/store/project/project-action.ts b/src/store/project/project-action.ts index 728b1cc9..20b255ca 100644 --- a/src/store/project/project-action.ts +++ b/src/store/project/project-action.ts @@ -1,30 +1,52 @@ // Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 - -import { Project } from "../../models/project"; import { default as unionize, ofType, UnionOf } from "unionize"; -import { projectService } from "../../services/services"; + +import { ProjectResource } from "~/models/project"; import { Dispatch } from "redux"; +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(), +export const projectActions = unionize({ + OPEN_PROJECT_CREATOR: ofType<{ ownerUuid: string }>(), + CLOSE_PROJECT_CREATOR: ofType<{}>(), + CREATE_PROJECT: ofType>(), + CREATE_PROJECT_SUCCESS: ofType(), REMOVE_PROJECT: ofType(), - PROJECTS_REQUEST: ofType(), - PROJECTS_SUCCESS: ofType<{ projects: Project[], parentItemId?: string }>(), - TOGGLE_PROJECT_TREE_ITEM: ofType() + PROJECTS_REQUEST: ofType(), + PROJECTS_SUCCESS: ofType<{ projects: ProjectResource[], parentItemId?: string }>(), + TOGGLE_PROJECT_TREE_ITEM_OPEN: ofType(), + TOGGLE_PROJECT_TREE_ITEM_ACTIVE: ofType(), + RESET_PROJECT_TREE_ACTIVITY: ofType() }, { tag: 'type', value: 'payload' }); -export const getProjectList = (parentUuid?: string) => (dispatch: Dispatch): Promise => { - dispatch(actions.PROJECTS_REQUEST()); - return projectService.getProjectList(parentUuid).then(projects => { - dispatch(actions.PROJECTS_SUCCESS({projects, parentItemId: parentUuid})); +export const getProjectList = (parentUuid: string = '') => (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + dispatch(projectActions.PROJECTS_REQUEST(parentUuid)); + return services.projectService.list({ + filters: FilterBuilder + .create() + .addEqual("ownerUuid", parentUuid) + }).then(({ items: projects }) => { + dispatch(projectActions.PROJECTS_SUCCESS({ projects, parentItemId: parentUuid })); + dispatch(checkPresenceInFavorites(projects.map(project => project.uuid))); return projects; }); }; -export type ProjectAction = UnionOf; -export default actions; +export const createProject = (project: Partial) => + (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;