2615721c3775ffc512d17d0494033184a982ccd1
[arvados-workbench2.git] / src / views-components / dialog-create / dialog-collection-create.tsx
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import * as React from 'react';
6 import { InjectedFormProps, Field } from 'redux-form';
7 import { WithDialogProps } from 'store/dialog/with-dialog';
8 import { CollectionCreateFormDialogData } from 'store/collections/collection-create-actions';
9 import { FormDialog } from 'components/form-dialog/form-dialog';
10 import { CollectionNameField, CollectionDescriptionField } from 'views-components/form-fields/collection-form-fields';
11 import { FileUploaderField } from '../file-uploader/file-uploader';
12 import { ResourceParentField } from '../form-fields/resource-form-fields';
13
14 type DialogCollectionProps = WithDialogProps<{}> & InjectedFormProps<CollectionCreateFormDialogData>;
15
16 export const DialogCollectionCreate = (props: DialogCollectionProps) =>
17     <FormDialog
18         dialogTitle='New collection'
19         formFields={CollectionAddFields}
20         submitLabel='Create a Collection'
21         {...props}
22     />;
23
24 const CollectionAddFields = () => <span>
25     <ResourceParentField />
26     <CollectionNameField />
27     <CollectionDescriptionField />
28     <Field
29         name='files'
30         label='Files'
31         component={FileUploaderField} />
32 </span>;
33