// Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 import * as React from 'react'; import { WrappedFieldProps } from 'redux-form'; import { ArvadosTheme } from '~/common/custom-theme'; import { TextField as MaterialTextField, StyleRulesCallback, WithStyles, withStyles } from '@material-ui/core'; import RichTextEditor from 'react-rte'; type CssRules = 'textField'; const styles: StyleRulesCallback = (theme: ArvadosTheme) => ({ textField: { marginBottom: theme.spacing.unit * 3 }, }); export const TextField = withStyles(styles)((props: WrappedFieldProps & WithStyles & { label?: string, autoFocus?: boolean, required?: boolean }) => ); interface RichEditorTextFieldData { label?: string; } type RichEditorTextFieldProps = RichEditorTextFieldData & WrappedFieldProps & WithStyles; export const RichEditorTextField = withStyles(styles)( class RichEditorTextField extends React.Component { state = { value: RichTextEditor.createValueFromString(this.props.input.value, 'html') }; onChange = (value: any) => { this.setState({ value }); this.props.input.onChange(value.toString('html')); } render() { return ; } } ); type DataTextFieldProps = WrappedFieldProps & WithStyles; export const DataTextField = withStyles(styles) ((props: DataTextFieldProps) => );