X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/4407b22fba72783a428ebbaf165cc579ea4c5a23..d6d85de50096eb0053d58c5022fd4e949c830929:/src/store/project/project-action.ts diff --git a/src/store/project/project-action.ts b/src/store/project/project-action.ts index dae245cf..53e09cc6 100644 --- a/src/store/project/project-action.ts +++ b/src/store/project/project-action.ts @@ -1,55 +1,79 @@ // Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 -import { default as unionize, ofType, UnionOf } from "unionize"; -import { ProjectResource } from "../../models/project"; -import { projectService } from "../../services/services"; +import { unionize, ofType, UnionOf } from '~/common/unionize'; +import { ProjectResource } from "~/models/project"; import { Dispatch } from "redux"; -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 { updateFavorites } from "../favorites/favorites-actions"; +import { ServiceRepository } from "~/services/services"; +import { projectPanelActions } from "~/store/project-panel/project-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>(), CREATE_PROJECT_SUCCESS: ofType(), - CREATE_PROJECT_ERROR: ofType(), + OPEN_PROJECT_UPDATER: ofType<{ uuid: string }>(), + CLOSE_PROJECT_UPDATER: ofType<{}>(), + UPDATE_PROJECT_SUCCESS: ofType(), REMOVE_PROJECT: 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, getState: () => RootState) => { - dispatch(projectActions.PROJECTS_REQUEST(parentUuid)); - return projectService.list({ - filters: FilterBuilder - .create() - .addEqual("ownerUuid", parentUuid) - }).then(({ items: projects }) => { - dispatch(projectActions.PROJECTS_SUCCESS({ projects, parentItemId: parentUuid })); - const { user } = getState().auth; - dispatch(checkPresenceInFavorites(user ? user.uuid : "", projects.map(project => project.uuid))); - return projects; - }); -}; +}); + +export const PROJECT_FORM_NAME = 'projectEditDialog'; + +export const getProjectList = (parentUuid: string = '') => + (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + dispatch(projectActions.PROJECTS_REQUEST(parentUuid)); + return services.projectService.list({ + filters: new FilterBuilder() + .addEqual("ownerUuid", parentUuid) + .getFilters() + }).then(({ items: projects }) => { + dispatch(projectActions.PROJECTS_SUCCESS({ projects, parentItemId: parentUuid })); + dispatch(updateFavorites(projects.map(project => project.uuid))); + return projects; + }); + }; export const createProject = (project: Partial) => - (dispatch: Dispatch, getState: () => RootState) => { + (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { const { ownerUuid } = getState().projects.creator; const projectData = { ownerUuid, ...project }; dispatch(projectActions.CREATE_PROJECT(projectData)); - return projectService + return services.projectService .create(projectData) - .then(project => dispatch(projectActions.CREATE_PROJECT_SUCCESS(project))) - .catch(() => dispatch(projectActions.CREATE_PROJECT_ERROR("Could not create a project"))); + .then(project => dispatch(projectActions.CREATE_PROJECT_SUCCESS(project))); + }; + +export const updateProject = (project: Partial) => + (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + const { uuid } = getState().projects.updater; + return services.projectService + .update(uuid, project) + .then(project => { + dispatch(projectActions.UPDATE_PROJECT_SUCCESS(project)); + dispatch(projectPanelActions.REQUEST_ITEMS()); + dispatch(getProjectList(project.ownerUuid)); + 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;