mirror of
https://github.com/ascribe/onion.git
synced 2025-01-05 11:25:09 +01:00
Small cleanup for renderChildren()
This commit is contained in:
parent
65f7d02e6d
commit
34f3bdcc4e
@ -250,12 +250,15 @@ let Form = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
renderChildren() {
|
renderChildren() {
|
||||||
return ReactAddons.Children.map(this.props.children, (child, i) => {
|
const { children, disabled } = this.props;
|
||||||
|
|
||||||
|
return ReactAddons.Children.map(children, (child, i) => {
|
||||||
if (child) {
|
if (child) {
|
||||||
return React.cloneElement(child, {
|
return React.cloneElement(child, {
|
||||||
handleChange: this.handleChangeChild,
|
|
||||||
ref: (ref) => {
|
ref: (ref) => {
|
||||||
|
if (child.props.name) {
|
||||||
this._refs[child.props.name] = ref;
|
this._refs[child.props.name] = ref;
|
||||||
|
}
|
||||||
|
|
||||||
// Since refs will be overwritten by this functions return statement,
|
// Since refs will be overwritten by this functions return statement,
|
||||||
// we still want to be able to define refs for nested `Form` or `Property`
|
// we still want to be able to define refs for nested `Form` or `Property`
|
||||||
@ -265,10 +268,11 @@ let Form = React.createClass({
|
|||||||
child.ref(ref);
|
child.ref(ref);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
key: i,
|
|
||||||
// We need this in order to make editable be overridable when setting it directly
|
// We need this in order to make editable be overridable when setting it directly
|
||||||
// on Property
|
// on Property
|
||||||
editable: child.props.overrideForm ? child.props.editable : !this.props.disabled
|
editable: child.props.overrideForm ? child.props.editable : !disabled,
|
||||||
|
handleChange: this.handleChangeChild,
|
||||||
|
key: i
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -263,17 +263,13 @@ const Property = React.createClass({
|
|||||||
},
|
},
|
||||||
|
|
||||||
renderChildren(style) {
|
renderChildren(style) {
|
||||||
|
const { checkboxLabel, children, editable, name } = this.props;
|
||||||
|
|
||||||
// Input's props should only be cloned and propagated down the tree,
|
// Input's props should only be cloned and propagated down the tree,
|
||||||
// if the component is actually being shown (!== 'expanded === false')
|
// if the component is actually being shown (!== 'expanded === false')
|
||||||
if((this.state.expanded && this.props.checkboxLabel) || !this.props.checkboxLabel) {
|
if ((this.state.expanded && checkboxLabel) || !checkboxLabel) {
|
||||||
return ReactAddons.Children.map(this.props.children, (child) => {
|
return ReactAddons.Children.map(children, (child) => {
|
||||||
const childWithProps = React.cloneElement(child, {
|
const childWithProps = React.cloneElement(child, {
|
||||||
style,
|
|
||||||
onChange: this.handleChange,
|
|
||||||
onFocus: this.handleFocus,
|
|
||||||
onBlur: this.handleBlur,
|
|
||||||
setWarning: this.setWarning,
|
|
||||||
disabled: !this.props.editable,
|
|
||||||
ref: (ref) => {
|
ref: (ref) => {
|
||||||
this._refs.input = ref;
|
this._refs.input = ref;
|
||||||
|
|
||||||
@ -285,8 +281,14 @@ const Property = React.createClass({
|
|||||||
child.ref(ref);
|
child.ref(ref);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
name: this.props.name,
|
name,
|
||||||
setExpanded: this.setExpanded
|
style,
|
||||||
|
disabled: !editable,
|
||||||
|
onBlur: this.handleBlur,
|
||||||
|
onChange: this.handleChange,
|
||||||
|
onFocus: this.handleFocus,
|
||||||
|
setExpanded: this.setExpanded,
|
||||||
|
setWarning: this.setWarning
|
||||||
});
|
});
|
||||||
|
|
||||||
return childWithProps;
|
return childWithProps;
|
||||||
|
Loading…
Reference in New Issue
Block a user