rc-color-picker
Version:
color-picker ui component for react
282 lines (219 loc) • 8.88 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _reactDom = require('react-dom');
var _reactDom2 = _interopRequireDefault(_reactDom);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _rcTrigger = require('rc-trigger');
var _rcTrigger2 = _interopRequireDefault(_rcTrigger);
var _Panel = require('./Panel');
var _Panel2 = _interopRequireDefault(_Panel);
var _placements = require('./placements');
var _placements2 = _interopRequireDefault(_placements);
var _colr = require('colr');
var _colr2 = _interopRequireDefault(_colr);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : _defaults(subClass, superClass); }
var colr = new _colr2["default"]();
function refFn(field, component) {
this[field] = component;
}
function prevent(e) {
e.preventDefault();
}
var ColorPicker = function (_React$Component) {
_inherits(ColorPicker, _React$Component);
function ColorPicker(props) {
_classCallCheck(this, ColorPicker);
var _this = _possibleConstructorReturn(this, _React$Component.call(this, props));
var alpha = typeof props.alpha === 'undefined' ? props.defaultAlpha : Math.min(props.alpha, props.defaultAlpha);
_this.state = {
color: props.color || props.defaultColor,
alpha: alpha,
open: false
};
var events = ['onTriggerClick', 'onChange', 'onBlur', 'getPickerElement', 'getRootDOMNode', 'getTriggerDOMNode', 'onVisibleChange', 'setOpen', 'open', 'close', 'focus'];
events.forEach(function (e) {
_this[e] = _this[e].bind(_this);
});
_this.savePickerPanelRef = refFn.bind(_this, 'pickerPanelInstance');
_this.saveTriggerRef = refFn.bind(_this, 'triggerInstance');
return _this;
}
ColorPicker.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {
if (nextProps.color) {
this.setState({
color: nextProps.color
});
}
if (nextProps.alpha !== null && nextProps.alpha !== undefined) {
this.setState({
alpha: nextProps.alpha
});
}
};
ColorPicker.prototype.onTriggerClick = function onTriggerClick() {
this.setState({
open: !this.state.open
});
};
ColorPicker.prototype.onChange = function onChange(colors) {
var _this2 = this;
this.setState(_extends({}, colors), function () {
_this2.props.onChange(_this2.state);
});
};
ColorPicker.prototype.onBlur = function onBlur() {
this.setOpen(false);
};
ColorPicker.prototype.onVisibleChange = function onVisibleChange(open) {
var _this3 = this;
this.setOpen(open, function () {
if (open) {
_reactDom2["default"].findDOMNode(_this3.pickerPanelInstance).focus();
}
});
};
ColorPicker.prototype.setOpen = function setOpen(open, callback) {
var _this4 = this;
var _props = this.props,
onOpen = _props.onOpen,
onClose = _props.onClose;
if (this.state.open !== open) {
this.setState({
open: open
}, function () {
if (typeof callback === 'function') {
callback();
}
if (_this4.state.open) {
onOpen(_this4.state);
} else {
onClose(_this4.state);
}
});
}
};
ColorPicker.prototype.getRootDOMNode = function getRootDOMNode() {
return _reactDom2["default"].findDOMNode(this);
};
ColorPicker.prototype.getTriggerDOMNode = function getTriggerDOMNode() {
return _reactDom2["default"].findDOMNode(this.triggerInstance);
};
ColorPicker.prototype.getPickerElement = function getPickerElement() {
// const state = this.state;
return _react2["default"].createElement(_Panel2["default"], {
ref: this.savePickerPanelRef,
defaultColor: this.state.color,
alpha: this.state.alpha,
prefixCls: this.props.prefixCls + '-panel',
onChange: this.onChange,
onBlur: this.onBlur,
mode: this.props.mode,
className: this.props.className
});
};
ColorPicker.prototype.open = function open(callback) {
this.setOpen(true, callback);
};
ColorPicker.prototype.close = function close(callback) {
this.setOpen(false, callback);
};
ColorPicker.prototype.focus = function focus() {
if (!this.state.open) {
_reactDom2["default"].findDOMNode(this).focus();
}
};
ColorPicker.prototype.render = function render() {
var props = this.props;
var state = this.state;
var classes = [props.prefixCls + '-wrap', props.className];
if (state.open) {
classes.push(props.prefixCls + '-open');
}
var children = props.children;
var RGBA = colr.fromHex(this.state.color).toRgbArray();
RGBA.push(this.state.alpha / 100);
if (children) {
children = _react2["default"].cloneElement(children, {
ref: this.saveTriggerRef,
unselectable: true,
style: {
backgroundColor: 'rgba(' + RGBA.join(',') + ')'
},
onClick: this.onTriggerClick,
onMouseDown: prevent
});
}
var prefixCls = props.prefixCls,
placement = props.placement,
style = props.style,
getCalendarContainer = props.getCalendarContainer,
align = props.align,
animation = props.animation,
disabled = props.disabled,
transitionName = props.transitionName;
return _react2["default"].createElement(
'div',
{ className: classes.join(' ') },
_react2["default"].createElement(
_rcTrigger2["default"],
{
popup: this.getPickerElement(),
popupAlign: align,
builtinPlacements: _placements2["default"],
popupPlacement: placement,
action: disabled ? [] : ['click'],
destroyPopupOnHide: true,
getPopupContainer: getCalendarContainer,
popupStyle: style,
popupAnimation: animation,
popupTransitionName: transitionName,
popupVisible: state.open,
onPopupVisibleChange: this.onVisibleChange,
prefixCls: prefixCls
},
children
)
);
};
return ColorPicker;
}(_react2["default"].Component);
exports["default"] = ColorPicker;
ColorPicker.propTypes = {
defaultColor: _propTypes2["default"].string,
defaultAlpha: _propTypes2["default"].number,
// can custom
color: _propTypes2["default"].string,
alpha: _propTypes2["default"].number,
onChange: _propTypes2["default"].func,
onOpen: _propTypes2["default"].func,
onClose: _propTypes2["default"].func,
prefixCls: _propTypes2["default"].string.isRequired,
children: _propTypes2["default"].node.isRequired,
mode: _propTypes2["default"].oneOf(['RGB', 'HSL', 'HSB']),
placement: _propTypes2["default"].oneOf(['topLeft', 'topRight', 'bottomLeft', 'bottomRight']),
style: _propTypes2["default"].object,
className: _propTypes2["default"].string
};
ColorPicker.defaultProps = {
defaultColor: '#F00',
defaultAlpha: 100,
onChange: function onChange() {},
onOpen: function onOpen() {},
onClose: function onClose() {},
prefixCls: 'rc-color-picker',
children: _react2["default"].createElement('span', { className: 'rc-color-picker-trigger' }),
placement: 'topLeft',
style: {},
className: ''
};
module.exports = exports['default'];