maputnik/src/components/inputs/InputBlock.jsx

58 lines
1.4 KiB
React
Raw Normal View History

import React from 'react'
import PropTypes from 'prop-types'
2017-01-11 13:34:38 +01:00
import classnames from 'classnames'
2017-01-09 16:45:59 +01:00
import DocLabel from '../fields/DocLabel'
/** Wrap a component with a label */
class InputBlock extends React.Component {
static propTypes = {
label: PropTypes.oneOfType([
PropTypes.string,
PropTypes.element,
2017-01-11 13:34:38 +01:00
]).isRequired,
doc: PropTypes.string,
action: PropTypes.element,
children: PropTypes.node.isRequired,
style: PropTypes.object,
2017-11-08 09:47:36 +01:00
onChange: PropTypes.func,
}
onChange(e) {
const value = e.target.value
return this.props.onChange(value === "" ? null: value)
}
render() {
2017-01-11 11:35:33 +01:00
return <div style={this.props.style}
2017-01-11 13:34:38 +01:00
className={classnames({
"maputnik-input-block": true,
"maputnik-action-block": this.props.action
})}
2017-01-10 21:28:30 +01:00
>
2017-01-09 16:45:59 +01:00
{this.props.doc &&
2017-01-11 13:34:38 +01:00
<div className="maputnik-input-block-label">
<DocLabel
label={this.props.label}
doc={this.props.doc}
/>
</div>
2017-01-09 16:45:59 +01:00
}
{!this.props.doc &&
2017-01-11 11:35:33 +01:00
<label className="maputnik-input-block-label">
2016-12-31 12:17:02 +01:00
{this.props.label}
</label>
2017-01-09 16:45:59 +01:00
}
2017-01-11 13:34:38 +01:00
{this.props.action &&
<div className="maputnik-input-block-action">
{this.props.action}
</div>
}
<div className="maputnik-input-block-content">
{this.props.children}
</div>
</div>
}
}
export default InputBlock