9737858a3f385ca5552b1e65a077c273e5fb5ccb
[arvados-workbench2.git] / src / views-components / dialog-update / dialog-project-update.tsx
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import React from 'react';
6 import { InjectedFormProps } from 'redux-form';
7 import { WithDialogProps } from 'store/dialog/with-dialog';
8 import { ProjectUpdateFormDialogData, PROJECT_UPDATE_FORM_NAME } from 'store/projects/project-update-actions';
9 import { FormDialog } from 'components/form-dialog/form-dialog';
10 import { ProjectNameField, ProjectDescriptionField, UsersField } from 'views-components/form-fields/project-form-fields';
11 import { GroupClass } from 'models/group';
12 import { FormGroup, FormLabel } from '@material-ui/core';
13 import { UpdateProjectPropertiesForm } from 'views-components/project-properties/update-project-properties-form';
14 import { resourcePropertiesList } from 'views-components/resource-properties/resource-properties-list';
15
16 type DialogProjectProps = WithDialogProps<{sourcePanel: GroupClass, create?: boolean}> & InjectedFormProps<ProjectUpdateFormDialogData>;
17
18 export const DialogProjectUpdate = (props: DialogProjectProps) => {
19     let title = 'Edit Project';
20     let fields = ProjectEditFields;
21     const sourcePanel = props.data.sourcePanel || '';
22     const create = !!props.data.create;
23
24     if (sourcePanel === GroupClass.ROLE) {
25         title = create ? 'Create Group' : 'Edit Group';
26         fields = create ? GroupAddFields : ProjectEditFields;
27     }
28
29     return <FormDialog
30         dialogTitle={title}
31         formFields={fields}
32         submitLabel='Save'
33         {...props}
34     />;
35 };
36
37 const UpdateProjectPropertiesList = resourcePropertiesList(PROJECT_UPDATE_FORM_NAME);
38
39 // Also used as "Group Edit Fields"
40 const ProjectEditFields = () => <span>
41     <ProjectNameField />
42     <ProjectDescriptionField />
43     <FormLabel>Properties</FormLabel>
44     <FormGroup>
45         <UpdateProjectPropertiesForm />
46         <UpdateProjectPropertiesList />
47     </FormGroup>
48 </span>;
49
50 const GroupAddFields = () => <span>
51     <ProjectNameField />
52     <UsersField />
53     <ProjectDescriptionField />
54 </span>;