X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/40952ad86a823635968c9abc5d6feacef316cffd..4927f812339c86a8d84354c4080c5a12a3d9ef2b:/src/views/collection-panel/collection-tag-form.tsx diff --git a/src/views/collection-panel/collection-tag-form.tsx b/src/views/collection-panel/collection-tag-form.tsx index 89cf880a..9aa88128 100644 --- a/src/views/collection-panel/collection-tag-form.tsx +++ b/src/views/collection-panel/collection-tag-form.tsx @@ -5,31 +5,38 @@ import * as React from 'react'; import { reduxForm, Field, reset } from 'redux-form'; import { compose, Dispatch } from 'redux'; -import { ArvadosTheme } from '../../common/custom-theme'; -import { StyleRulesCallback, withStyles, WithStyles, TextField, Button, CircularProgress } from '@material-ui/core'; -import { TagProperty } from '../../models/tag'; -import { createCollectionTag, COLLECTION_TAG_FORM_NAME } from '../../store/collection-panel/collection-panel-action'; -import { TAG_VALUE_VALIDATION, TAG_KEY_VALIDATION } from '../../validators/validators'; +import { ArvadosTheme } from '~/common/custom-theme'; +import { StyleRulesCallback, withStyles, WithStyles, Button, CircularProgress, Grid, Typography } from '@material-ui/core'; +import { TagProperty } from '~/models/tag'; +import { TextField } from '~/components/text-field/text-field'; +import { createCollectionTag, COLLECTION_TAG_FORM_NAME } from '~/store/collection-panel/collection-panel-action'; +import { TAG_VALUE_VALIDATION, TAG_KEY_VALIDATION } from '~/validators/validators'; -type CssRules = 'form' | 'textField' | 'buttonWrapper' | 'saveButton' | 'circularProgress'; +type CssRules = 'root' | 'keyField' | 'valueField' | 'buttonWrapper' | 'saveButton' | 'circularProgress'; const styles: StyleRulesCallback = (theme: ArvadosTheme) => ({ - form: { - marginBottom: theme.spacing.unit * 4 + root: { + width: '100%', + display: 'flex' }, - textField: { - marginRight: theme.spacing.unit + keyField: { + width: '25%', + marginRight: theme.spacing.unit * 3 + }, + valueField: { + width: '40%', + marginRight: theme.spacing.unit * 3 }, buttonWrapper: { + paddingTop: '14px', position: 'relative', - display: 'inline-block' }, saveButton: { boxShadow: 'none' }, circularProgress: { position: 'absolute', - top: 0, + top: -9, bottom: 0, left: 0, right: 0, @@ -47,46 +54,38 @@ interface CollectionTagFormActionProps { handleSubmit: any; } -interface TextFieldProps { - label: string; - floatinglabeltext: string; - className?: string; - input?: string; - meta?: any; -} - type CollectionTagFormProps = CollectionTagFormDataProps & CollectionTagFormActionProps & WithStyles; export const CollectionTagForm = compose( - reduxForm({ - form: COLLECTION_TAG_FORM_NAME, + reduxForm({ + form: COLLECTION_TAG_FORM_NAME, onSubmit: (data: TagProperty, dispatch: Dispatch) => { dispatch(createCollectionTag(data)); dispatch(reset(COLLECTION_TAG_FORM_NAME)); - } + } }), withStyles(styles))( - - class CollectionTagForm extends React.Component { + + class CollectionTagForm extends React.Component { render() { const { classes, submitting, pristine, invalid, handleSubmit } = this.props; return ( -
- - + +
+ +
+
+ +