import React from 'react'; import classNames from 'classnames'; function prefixClsFn(prefixCls, ...args) { return args.map((s) => { return prefixCls + '-' + s; }).join(' '); } class FormItem extends React.Component { _getLayoutClass(colDef) { if (!colDef) { return ''; } const { span, offset } = colDef; const col = span ? 'col-' + span : ''; const offsetCol = offset ? ' col-offset-' + offset : ''; return col + offsetCol; } getHelpMsg() { const context = this.context; const props = this.props; if (props.help === undefined && context.form) { return (context.form.getFieldError(props.id) || []).join(', '); } return props.help; } renderHelp() { const props = this.props; const prefixCls = props.prefixCls; const help = this.getHelpMsg(); return (
{ help }
); } getValidateStatus() { const { isFieldValidating, getFieldError, getFieldValue } = this.context.form; const field = this.props.id; if (isFieldValidating(field)) { return 'validating'; } else if (!!getFieldError(field)) { return 'error'; } else if (getFieldValue(field) !== undefined) { return 'success'; } } renderValidateWrapper(c1, c2 ,c3) { let classes = ''; const form = this.context.form; const props = this.props; const validateStatus = (props.validateStatus === undefined && form) ? this.getValidateStatus() : props.validateStatus; if (validateStatus) { classes = classNames( { 'has-feedback': props.hasFeedback, 'has-success': validateStatus === 'success', 'has-warning': validateStatus === 'warning', 'has-error': validateStatus === 'error', 'is-validating': validateStatus === 'validating', } ); } return (
{c1}{c2}{c3}
); } renderWrapper(children) { const wrapperCol = this.props.wrapperCol; return (
{children}
); } isRequired() { const options = this.props.options; if (options === undefined) return false; const allRules = (options.validate || []).concat({ rules: options.rules || [], }); return allRules.some((item) => { return item.rules.some((rule) => rule.required); }); } renderLabel() { const props = this.props; const labelCol = props.labelCol; const required = props.required === undefined ? this.isRequired() : props.required; return props.label ? ( ) : null; } renderChildren() { const context = this.context; const props = this.props; let children = props.children; if (context.form && props.id && props.options) { children = React.cloneElement( React.Children.only(children), { ...context.form.getFieldProps(props.id, props.options), id: props.id } ); } return [ this.renderLabel(), this.renderWrapper( this.renderValidateWrapper( children, this.renderHelp(), props.extra ) ), ]; } renderFormItem(children) { const props = this.props; const prefixCls = props.prefixCls; const itemClassName = { [`${prefixCls}-item`]: true, [`${prefixCls}-item-with-help`]: !!props.help, [`${props.className}`]: !!props.className, }; return (
{children}
); } render() { const children = this.renderChildren(); return this.renderFormItem(children); } } FormItem.propTypes = { prefixCls: React.PropTypes.string, label: React.PropTypes.node, labelCol: React.PropTypes.object, help: React.PropTypes.oneOfType([React.PropTypes.node, React.PropTypes.bool]), validateStatus: React.PropTypes.oneOf(['', 'success', 'warning', 'error', 'validating']), hasFeedback: React.PropTypes.bool, wrapperCol: React.PropTypes.object, className: React.PropTypes.string, id: React.PropTypes.string, options: React.PropTypes.object, children: React.PropTypes.node, }; FormItem.defaultProps = { hasFeedback: false, prefixCls: 'ant-form', }; FormItem.contextTypes = { form: React.PropTypes.object, }; module.exports = FormItem;