import React, { Component, PropTypes } from 'react'; import ImmutablePropTypes from 'react-immutable-proptypes'; import { resolveWidget } from '../Widgets'; import styles from './ControlPane.css'; function isHidden(field) { return field.get('widget') === 'hidden'; } export default class ControlPane extends Component { controlFor(field) { const { entry, fieldsMetaData, getMedia, onChange, onAddMedia, onRemoveMedia } = this.props; const widget = resolveWidget(field.get('widget')); const fieldName = field.get('name'); const value = entry.getIn(['data', fieldName]); const metadata = fieldsMetaData.get(fieldName); if (entry.size === 0 || entry.get('partial') === true) return null; return (
{ React.createElement(widget.control, { field, value, metadata, onChange: (newValue, newMetadata) => onChange(fieldName, newValue, newMetadata), onAddMedia, onRemoveMedia, getMedia, }) }
); } render() { const { collection, fields } = this.props; if (!collection || !fields) { return null; } return (
{ fields.map((field) => { if (isHidden(field)) { return null; } return
{this.controlFor(field)}
; }) }
); } } ControlPane.propTypes = { collection: ImmutablePropTypes.map.isRequired, entry: ImmutablePropTypes.map.isRequired, fields: ImmutablePropTypes.list.isRequired, fieldsMetaData: ImmutablePropTypes.map.isRequired, getMedia: PropTypes.func.isRequired, onAddMedia: PropTypes.func.isRequired, onChange: PropTypes.func.isRequired, onRemoveMedia: PropTypes.func.isRequired, };