Extract collection form components
[arvados-workbench2.git] / src / views-components / collection-partial-copy-dialog / collection-partial-copy-dialog.tsx
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { Dispatch, compose } from "redux";
6 import { reduxForm, reset, startSubmit, stopSubmit } from "redux-form";
7 import { withDialog } from "~/store/dialog/with-dialog";
8 import { dialogActions } from "~/store/dialog/dialog-actions";
9 import { loadProjectTreePickerProjects } from "../project-tree-picker/project-tree-picker";
10 import { CollectionPartialCopyFormDialog } from "~/views-components/form-dialog/collection-form-dialog";
11
12 export const COLLECTION_PARTIAL_COPY = 'COLLECTION_PARTIAL_COPY';
13
14 export const openCollectionPartialCopyDialog = () =>
15     (dispatch: Dispatch) => {
16         dispatch(reset(COLLECTION_PARTIAL_COPY));
17         dispatch<any>(loadProjectTreePickerProjects(''));
18         dispatch(dialogActions.OPEN_DIALOG({ id: COLLECTION_PARTIAL_COPY, data: {} }));
19     };
20
21
22 export const CollectionPartialCopyDialog = compose(
23     withDialog(COLLECTION_PARTIAL_COPY),
24     reduxForm({
25         form: COLLECTION_PARTIAL_COPY,
26         onSubmit: (data, dispatch) => {
27             dispatch(startSubmit(COLLECTION_PARTIAL_COPY));
28             setTimeout(() => dispatch(stopSubmit(COLLECTION_PARTIAL_COPY, { name: 'Invalid name' })), 2000);
29         }
30     }))(CollectionPartialCopyFormDialog);