import React from 'react' import Color from 'color' import ChromePicker from 'react-color/lib/components/chrome/Chrome' import PropTypes from 'prop-types' function formatColor(color) { const rgb = color.rgb return `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${rgb.a})` } /*** Number fields with support for min, max and units and documentation*/ class ColorField extends React.Component { static propTypes = { onChange: PropTypes.func.isRequired, name: PropTypes.string.isRequired, value: PropTypes.string, doc: PropTypes.string, style: PropTypes.object, default: PropTypes.string, } constructor(props) { super(props) this.state = { pickerOpened: false, } } //TODO: I much rather would do this with absolute positioning //but I am too stupid to get it to work together with fixed position //and scrollbars so I have to fallback to JavaScript calcPickerOffset() { const elem = this.colorInput if(elem) { const pos = elem.getBoundingClientRect() return { top: pos.top, left: pos.left + 196, } } else { return { top: 160, left: 555, } } } togglePicker() { this.setState({ pickerOpened: !this.state.pickerOpened }) } get color() { // Catch invalid color. try { return Color(this.props.value).rgb() } catch(err) { console.warn("Error parsing color: ", err); return Color("rgb(255,255,255)"); } } render() { const offset = this.calcPickerOffset() var currentColor = this.color.object() currentColor = { r: currentColor.r, g: currentColor.g, b: currentColor.b, // Rename alpha -> a for ChromePicker a: currentColor.alpha } const picker =
this.props.onChange(formatColor(c))} />
var swatchStyle = { backgroundColor: this.props.value }; return
{this.state.pickerOpened && picker}
this.colorInput = input} onClick={this.togglePicker.bind(this)} style={this.props.style} name={this.props.name} placeholder={this.props.default} value={this.props.value ? this.props.value : ""} onChange={(e) => this.props.onChange(e.target.value)} />
} } export default ColorField