X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/9f0ec4b2faba84dad403a710ffd8d3567a4344af..d6a65f155ca546aea3a777e73076c2c80f2c88cc:/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 eb69837626..43f56ed894 100644 --- a/src/views-components/create-project-dialog/create-project-dialog.tsx +++ b/src/views-components/create-project-dialog/create-project-dialog.tsx @@ -3,34 +3,42 @@ // SPDX-License-Identifier: AGPL-3.0 import { connect } from "react-redux"; -import { Dispatch } from "../../../node_modules/redux"; -import { RootState } from "../../store/store"; -import DialogProjectCreate from "../dialog-create/dialog-project-create"; -import actions, { 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"; +import { Dispatch } from "redux"; +import { SubmissionError } from "redux-form"; + +import { RootState } from "~/store/store"; +import { DialogProjectCreate } from "../dialog-create/dialog-project-create"; +import { projectActions, createProject, getProjectList } from "~/store/project/project-action"; +import { projectPanelActions } from "~/store/project-panel/project-panel-action"; +import { snackbarActions } from "~/store/snackbar/snackbar-actions"; const mapStateToProps = (state: RootState) => ({ - open: state.projects.creator.opened, - pending: state.projects.creator.pending, + open: state.projects.creator.opened }); -const submit = (data: { name: string, description: string }) => +const addProject = (data: { name: string, description: string }) => (dispatch: Dispatch, getState: () => RootState) => { const { ownerUuid } = getState().projects.creator; - dispatch(createProject(data)).then(() => { - dispatch(dataExplorerActions.REQUEST_ITEMS({ id: PROJECT_PANEL_ID })); + return dispatch(createProject(data)).then(() => { + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: "Project has been successfully created.", + hideDuration: 2000 + })); + dispatch(projectPanelActions.REQUEST_ITEMS()); dispatch(getProjectList(ownerUuid)); }); }; const mapDispatchToProps = (dispatch: Dispatch) => ({ handleClose: () => { - dispatch(actions.CLOSE_PROJECT_CREATOR()); + 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 default connect(mapStateToProps, mapDispatchToProps)(DialogProjectCreate); +export const CreateProjectDialog = connect(mapStateToProps, mapDispatchToProps)(DialogProjectCreate);