import React, { useState } from 'react'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { FormattedMessage } from 'react-intl'; import PropTypes from 'prop-types'; import classNames from 'classnames'; import { v4 as uuidv4 } from 'uuid'; export const FormPropTypes = { label: PropTypes.oneOfType([ PropTypes.string, PropTypes.object, PropTypes.node, ]), }; export const InputContainer = (props) => { const containerClass = classNames('input', { 'with_label': props.label, 'required': props.required, 'boolean': props.type === 'checkbox', 'field_with_errors': props.error, }, props.extraClass); return (
{props.children} {props.hint && {props.hint}}
); }; InputContainer.propTypes = { label: FormPropTypes.label, hint: PropTypes.node, required: PropTypes.bool, type: PropTypes.string, children: PropTypes.node, extraClass: PropTypes.string, error: PropTypes.bool, }; export const LabelInputContainer = ({ label, hint, children, ...props }) => { const [id] = useState(uuidv4()); const childrenWithProps = React.Children.map(children, child => ( React.cloneElement(child, { id: id, key: id }) )); return (
{childrenWithProps}
{hint && {hint}}
); }; LabelInputContainer.propTypes = { label: FormPropTypes.label.isRequired, hint: PropTypes.node, children: PropTypes.node, }; export const LabelInput = ({ label, dispatch, ...props }) => ( ); LabelInput.propTypes = { label: FormPropTypes.label.isRequired, dispatch: PropTypes.func, }; export const LabelTextarea = ({ label, dispatch, ...props }) => (