X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/5627bf1a83323d2b0364cb069564998eb8c6ca7a..eec72fb6bd94a219b07370120e2c2af67d562a05:/src/store/projects/project-update-actions.ts diff --git a/src/store/projects/project-update-actions.ts b/src/store/projects/project-update-actions.ts index e674d296..34ea42f5 100644 --- a/src/store/projects/project-update-actions.ts +++ b/src/store/projects/project-update-actions.ts @@ -5,15 +5,12 @@ import { Dispatch } from "redux"; import { initialize, startSubmit, stopSubmit } from 'redux-form'; import { RootState } from "~/store/store"; -import { updateDetails } from "~/store/details-panel/details-panel-action"; import { dialogActions } from "~/store/dialog/dialog-actions"; -import { snackbarActions } from "~/store/snackbar/snackbar-actions"; -import { ContextMenuResource } from '~/store/context-menu/context-menu-reducer'; -import { getCommonResourceServiceError, CommonResourceServiceError } from "~/common/api/common-resource-service"; +import { getCommonResourceServiceError, CommonResourceServiceError } from "~/services/common-service/common-resource-service"; import { ServiceRepository } from "~/services/services"; import { ProjectResource } from '~/models/project'; -import { getProjectList } from '~/store/project/project-action'; -import { projectPanelActions } from '~/store/project-panel/project-panel-action'; +import { ContextMenuResource } from "~/store/context-menu/context-menu-actions"; +import { getResource } from '~/store/resources/resources'; export interface ProjectUpdateFormDialogData { uuid: string; @@ -24,34 +21,25 @@ export interface ProjectUpdateFormDialogData { export const PROJECT_UPDATE_FORM_NAME = 'projectUpdateFormName'; export const openProjectUpdateDialog = (resource: ContextMenuResource) => - (dispatch: Dispatch) => { - dispatch(initialize(PROJECT_UPDATE_FORM_NAME, resource)); + (dispatch: Dispatch, getState: () => RootState) => { + const project = getResource(resource.uuid)(getState().resources); + dispatch(initialize(PROJECT_UPDATE_FORM_NAME, project)); dispatch(dialogActions.OPEN_DIALOG({ id: PROJECT_UPDATE_FORM_NAME, data: {} })); }; -export const editProject = (data: ProjectUpdateFormDialogData) => - async (dispatch: Dispatch) => { - await dispatch(updateProject(data)); - dispatch(snackbarActions.OPEN_SNACKBAR({ - message: "Project has been successfully updated.", - hideDuration: 2000 - })); - }; - export const updateProject = (project: Partial) => async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { const uuid = project.uuid || ''; dispatch(startSubmit(PROJECT_UPDATE_FORM_NAME)); try { const updatedProject = await services.projectService.update(uuid, project); - dispatch(projectPanelActions.REQUEST_ITEMS()); - dispatch(getProjectList(updatedProject.ownerUuid)); - dispatch(updateDetails(updatedProject)); dispatch(dialogActions.CLOSE_DIALOG({ id: PROJECT_UPDATE_FORM_NAME })); + return updatedProject; } catch (e) { const error = getCommonResourceServiceError(e); if (error === CommonResourceServiceError.UNIQUE_VIOLATION) { dispatch(stopSubmit(PROJECT_UPDATE_FORM_NAME, { name: 'Project with the same name already exists.' })); } + return ; } - }; \ No newline at end of file + };