import React from 'react'; import rcUtil from 'rc-util'; const cx = rcUtil.classSet; 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; } renderHelp() { const prefixCls = this.props.prefixCls; return (
{this.props.help}
); } renderValidateWrapper(c1, c2) { let classes = ''; if (this.props.validateStatus) { classes = cx( { 'has-feedback': this.props.hasFeedback, 'has-success': this.props.validateStatus === 'success', 'has-warning': this.props.validateStatus === 'warning', 'has-error': this.props.validateStatus === 'error', 'is-validating': this.props.validateStatus === 'validating', } ); } return (
{c1} {c2}
); } renderWrapper(children) { const wrapperCol = this.props.wrapperCol; return (
{children}
); } renderLabel() { const labelCol = this.props.labelCol; const required = this.props.required ? 'required' : ''; return this.props.label ? ( ) : null; } renderChildren() { return [ this.renderLabel(), this.renderWrapper( this.renderValidateWrapper( this.props.children, this.renderHelp() ) ), ]; } // 判断是否要 `.ant-form-item-compact` 样式类 _isCompact(children) { const compactControls = ['checkbox', 'radio', 'radio-group', 'static', 'file']; let isCompact = false; if (!Array.isArray(children)) { children = [children]; } children.map((child, i) => { const type = child.props && child.props.type; let prefixCls = child.props && child.props.prefixCls; prefixCls = prefixCls ? prefixCls.substring(prefixCls.indexOf('-') + 1) : ''; if ((type && compactControls.indexOf(type) > -1) || (prefixCls && compactControls.indexOf(prefixCls) > -1)) { isCompact = true; } else if (child.props && typeof child.props.children === 'object') { isCompact = this._isCompact(child.props.children); } }); return isCompact; } renderFormItem(children) { const props = this.props; const prefixCls = props.prefixCls; const itemClassName = { [`${prefixCls}-item`]: true, [`${prefixCls}-item-compact`]: this._isCompact(props.children), }; 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.node, validateStatus: React.PropTypes.oneOf(['', 'success', 'warning', 'error', 'validating']), hasFeedback: React.PropTypes.bool, wrapperCol: React.PropTypes.object, className: React.PropTypes.string, children: React.PropTypes.node, }; FormItem.defaultProps = { hasFeedback: false, required: false, prefixCls: 'ant-form', }; module.exports = FormItem;