Reload project tree and project panel after project creation
[arvados-workbench2.git] / src / views-components / create-project-dialog / create-project-dialog.tsx
index c1d4e06324cfbfd8d1f86fd2384bd6ad41f51745..701ceee107d3e2fcf8d5e22a8f1861126d732ada 100644 (file)
@@ -6,18 +6,29 @@ 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 } from "../../store/project/project-action";
+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";
 
 const mapStateToProps = (state: RootState) => ({
     open: state.projects.creator.opened
 });
 
+const submit = (data: { name: string, description: string }) =>
+    (dispatch: Dispatch, getState: () => RootState) => {
+        const { ownerUuid } = getState().projects.creator;
+        dispatch<any>(createProject(data)).then(() => {
+            dispatch(dataExplorerActions.REQUEST_ITEMS({ id: PROJECT_PANEL_ID }));
+            dispatch<any>(getProjectList(ownerUuid));
+        });
+    };
+
 const mapDispatchToProps = (dispatch: Dispatch) => ({
     handleClose: () => {
         dispatch(actions.CLOSE_PROJECT_CREATOR());
     },
     onSubmit: (data: { name: string, description: string }) => {
-        dispatch<any>(createProject(data));
+        dispatch<any>(submit(data));
     }
 });