X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/7df4149100f41cc8d4a5438630ba95a1d72409a1..10ce16c28de952f6533ca3cc9df909269e3d2a53:/src/views-components/create-project-dialog/create-project-dialog.tsx diff --git a/src/views-components/create-project-dialog/create-project-dialog.tsx b/src/views-components/create-project-dialog/create-project-dialog.tsx index 2f3e0b7fe3..43621bf73c 100644 --- a/src/views-components/create-project-dialog/create-project-dialog.tsx +++ b/src/views-components/create-project-dialog/create-project-dialog.tsx @@ -4,8 +4,10 @@ import { connect } from "react-redux"; import { Dispatch } from "redux"; +import { SubmissionError } from "redux-form"; + import { RootState } from "../../store/store"; -import { DialogProjectCreate as DialogProjectCreateComponent } from "../dialog-create/dialog-project-create"; +import DialogProjectCreate from "../dialog-create/dialog-project-create"; import { projectActions, createProject, getProjectList } from "../../store/project/project-action"; import { dataExplorerActions } from "../../store/data-explorer/data-explorer-action"; import { PROJECT_PANEL_ID } from "../../views/project-panel/project-panel"; @@ -14,10 +16,10 @@ const mapStateToProps = (state: RootState) => ({ open: state.projects.creator.opened }); -const submit = (data: { name: string, description: string }) => +export const addProject = (data: { name: string, description: string }) => (dispatch: Dispatch, getState: () => RootState) => { const { ownerUuid } = getState().projects.creator; - dispatch(createProject(data)).then(() => { + return dispatch(createProject(data)).then(() => { dispatch(dataExplorerActions.REQUEST_ITEMS({ id: PROJECT_PANEL_ID })); dispatch(getProjectList(ownerUuid)); }); @@ -28,8 +30,11 @@ const mapDispatchToProps = (dispatch: Dispatch) => ({ dispatch(projectActions.CLOSE_PROJECT_CREATOR()); }, onSubmit: (data: { name: string, description: string }) => { - dispatch(submit(data)); + return dispatch(addProject(data)) + .catch((e: any) => { + throw new SubmissionError({ name: e.errors.join("").includes("UniqueViolation") ? "Project with this name already exists." : "" }); + }); } }); -export const CreateProjectDialog = connect(mapStateToProps, mapDispatchToProps)(DialogProjectCreateComponent); +export const CreateProjectDialog = connect(mapStateToProps, mapDispatchToProps)(DialogProjectCreate);