UNPKG

react-chips-devitjobs

Version:

A flexible and easy to use Chips component for React

138 lines (111 loc) 4.96 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); 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 _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _radium = require('radium'); var _radium2 = _interopRequireDefault(_radium); var _reactThemeable = require('react-themeable'); var _reactThemeable2 = _interopRequireDefault(_reactThemeable); var _theme = require('./theme'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } var Chip = function Chip(_ref) { var selected = _ref.selected, theme = _ref.theme, onRemove = _ref.onRemove, children = _ref.children; // if someone provided a theme, try and merge between the original and provided var mergedTheme = deepMerge(_theme.chipTheme, theme); var themr = (0, _reactThemeable2.default)(mergedTheme); return _react2.default.createElement( 'div', themr(1, 'chip', selected ? 'chipSelected' : ''), children, _react2.default.createElement( 'span', _extends({}, themr(2, 'chipRemove'), { onClick: onRemove }), ' \xD7' ) ); }; Chip.propTypes = { theme: _propTypes2.default.object, selected: _propTypes2.default.bool, onRemove: _propTypes2.default.func }; Chip.defaultProps = { theme: _theme.chipTheme, selected: false }; // from https://stackoverflow.com/a/49798508/1824521 var deepMerge = function deepMerge() { for (var _len = arguments.length, sources = Array(_len), _key = 0; _key < _len; _key++) { sources[_key] = arguments[_key]; } var acc = {}; var _iteratorNormalCompletion = true; var _didIteratorError = false; var _iteratorError = undefined; try { for (var _iterator = sources[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) { var source = _step.value; if (source instanceof Array) { if (!(acc instanceof Array)) { acc = []; } acc = [].concat(_toConsumableArray(acc), _toConsumableArray(source)); } else if (source instanceof Object) { var _iteratorNormalCompletion2 = true; var _didIteratorError2 = false; var _iteratorError2 = undefined; try { for (var _iterator2 = Object.entries(source)[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) { var _step2$value = _slicedToArray(_step2.value, 2), key = _step2$value[0], value = _step2$value[1]; if (value instanceof Object && key in acc) { value = deepMerge(acc[key], value); } acc = _extends({}, acc, _defineProperty({}, key, value)); } } catch (err) { _didIteratorError2 = true; _iteratorError2 = err; } finally { try { if (!_iteratorNormalCompletion2 && _iterator2.return) { _iterator2.return(); } } finally { if (_didIteratorError2) { throw _iteratorError2; } } } } } } catch (err) { _didIteratorError = true; _iteratorError = err; } finally { try { if (!_iteratorNormalCompletion && _iterator.return) { _iterator.return(); } } finally { if (_didIteratorError) { throw _iteratorError; } } } return acc; }; exports.default = (0, _radium2.default)(Chip);