houdini/javascripts/src/components/common/fields.tsx

19 lines
939 B
TypeScript
Raw Normal View History

// License: LGPL-3.0-or-later
import * as React from 'react';
import {observer} from "mobx-react";
import {Field} from "../../../../types/mobx-react-form";
import LabeledFieldComponent from "./LabeledFieldComponent";
import {injectIntl, InjectedIntl} from 'react-intl';
2018-06-29 12:42:56 -05:00
import {HoudiniField} from "../../lib/houdini_form";
export const BasicField = injectIntl(observer((props:{field:Field, intl?:InjectedIntl, wrapperClassName?:string}) =>{
2018-06-29 12:42:56 -05:00
let field = props.field as HoudiniField
return <LabeledFieldComponent
2018-06-29 12:42:56 -05:00
inputId={props.field.id} labelText={field.label} inError={field.hasError} error={field.error}
inStickyError={field.hasServerError} stickyError={field.serverError}
className={props.wrapperClassName} >
<input {...props.field.bind()} placeholder={field.placeholder ? props.intl.formatMessage({id:field.placeholder}) : undefined} className="form-control"/>
</LabeledFieldComponent>
}))