X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/97937a780bdb4ff67f334a1817d405dec1b2773c..5627bf1a83323d2b0364cb069564998eb8c6ca7a:/src/store/project/project-action.ts diff --git a/src/store/project/project-action.ts b/src/store/project/project-action.ts index 96ad6285..4f03ae1c 100644 --- a/src/store/project/project-action.ts +++ b/src/store/project/project-action.ts @@ -1,73 +1,38 @@ // Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 -import { default as unionize, ofType, UnionOf } from "unionize"; +import { unionize, ofType, UnionOf } from '~/common/unionize'; 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 { updateFavorites } from "../favorites/favorites-actions"; import { ServiceRepository } from "~/services/services"; -import { projectPanelActions } from "~/store/project-panel/project-panel-action"; -import { updateDetails } from "~/store/details-panel/details-panel-action"; +import { resourcesActions } from '~/store/resources/resources-actions'; export const projectActions = unionize({ - OPEN_PROJECT_CREATOR: ofType<{ ownerUuid: string }>(), - CLOSE_PROJECT_CREATOR: ofType<{}>(), - CREATE_PROJECT: ofType>(), - CREATE_PROJECT_SUCCESS: 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 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: FilterBuilder - .create() + filters: new FilterBuilder() .addEqual("ownerUuid", parentUuid) + .getFilters() }).then(({ items: projects }) => { dispatch(projectActions.PROJECTS_SUCCESS({ projects, parentItemId: parentUuid })); - dispatch(checkPresenceInFavorites(projects.map(project => project.uuid))); + dispatch(updateFavorites(projects.map(project => project.uuid))); + dispatch(resourcesActions.SET_RESOURCES(projects)); return projects; }); }; -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 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(updateDetails(project)); - }); - }; - export type ProjectAction = UnionOf;