Merge pull request #360 from marzeelabs/feature/#359_list_children_metadata
#359 - Handle metadata for all children of a list field
This commit is contained in:
@ -89,17 +89,21 @@ export default class ListControl extends Component {
|
|||||||
|
|
||||||
handleChangeFor(index) {
|
handleChangeFor(index) {
|
||||||
return (newValue, newMetadata) => {
|
return (newValue, newMetadata) => {
|
||||||
const { value, onChange } = this.props;
|
const { value, metadata, onChange, forID } = this.props;
|
||||||
const parsedValue = (this.valueType === valueTypes.SINGLE) ? newValue.first() : newValue;
|
const parsedValue = (this.valueType === valueTypes.SINGLE) ? newValue.first() : newValue;
|
||||||
onChange(value.set(index, parsedValue), newMetadata);
|
const parsedMetadata = {
|
||||||
|
[forID]: Object.assign(metadata ? metadata.toJS() : {}, newMetadata ? newMetadata[forID] : {}),
|
||||||
|
};
|
||||||
|
onChange(value.set(index, parsedValue), parsedMetadata);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
handleRemove(index) {
|
handleRemove(index) {
|
||||||
return (e) => {
|
return (e) => {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
const { value, onChange } = this.props;
|
const { value, metadata, onChange, forID } = this.props;
|
||||||
onChange(value.remove(index));
|
const parsedMetadata = { [forID]: metadata.removeIn(value.get(index).valueSeq()) };
|
||||||
|
onChange(value.remove(index), parsedMetadata);
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user