maputnik/src/components/inputs/InputBlock.jsx

47 lines
996 B
React
Raw Normal View History

import React from 'react'
import input from '../../config/input'
2016-12-21 16:11:08 +01:00
import { margins } from '../../config/scales'
/** Wrap a component with a label */
class InputBlock extends React.Component {
static propTypes = {
label: React.PropTypes.string.isRequired,
children: React.PropTypes.element.isRequired,
2016-12-24 17:24:24 +01:00
style: React.PropTypes.object,
}
onChange(e) {
const value = e.target.value
return this.props.onChange(value === "" ? null: value)
}
2016-12-31 12:17:02 +01:00
renderChildren() {
return React.Children.map(this.props.children, child => {
return React.cloneElement(child, {
style: {
...child.props.style,
width: '50%',
}
})
})
}
render() {
return <div style={{
2016-12-31 12:17:02 +01:00
...input.property,
2016-12-24 17:24:24 +01:00
...this.props.style,
}}>
2016-12-31 12:17:02 +01:00
<label
style={{
...input.label,
width: '50%',
}}>
{this.props.label}
</label>
{this.renderChildren()}
</div>
}
}
export default InputBlock