kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
290 lines (237 loc) • 28.1 kB
JavaScript
;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _lodash = _interopRequireDefault(require("lodash.uniq"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _itemSelector = _interopRequireDefault(require("../../common/item-selector/item-selector"));
var _styledComponents2 = require("../../common/styled-components");
var _rangeSlider = _interopRequireDefault(require("../../common/range-slider"));
var _switch = _interopRequireDefault(require("../../common/switch"));
var _colorPalette = _interopRequireDefault(require("./color-palette"));
var _colorRanges = require("../../../constants/color-ranges");
var _dataUtils = require("../../../utils/data-utils");
function _templateObject4() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0 8px;\n :hover {\n background-color: ", ";\n cursor: pointer;\n }\n"]);
_templateObject4 = function _templateObject4() {
return data;
};
return data;
}
function _templateObject3() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 8px;\n display: flex;\n justify-content: space-between;\n align-items: center;\n .color-palette__config__label {\n flex-grow: 1;\n }\n .color-palette__config__select {\n flex-grow: 1;\n }\n .item-selector .item-selector__dropdown {\n ", ";\n }\n"]);
_templateObject3 = function _templateObject3() {
return data;
};
return data;
}
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _templateObject2() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n padding-bottom: 12px;\n"]);
_templateObject2 = function _templateObject2() {
return data;
};
return data;
}
function _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n padding: 12px 12px 0 12px;\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
var ALL_TYPES = (0, _lodash["default"])(_colorRanges.COLOR_RANGES.map(function (c) {
return c.type;
}).concat(['all']));
var ALL_STEPS = (0, _lodash["default"])(_colorRanges.COLOR_RANGES.map(function (d) {
return d.colors.length;
})).sort(_dataUtils.numberSort);
var StyledColorConfig = _styledComponents["default"].div(_templateObject());
var ColorRangeSelector = _styledComponents["default"].div(_templateObject2());
var ColorRangeSelect =
/*#__PURE__*/
function (_Component) {
(0, _inherits2["default"])(ColorRangeSelect, _Component);
function ColorRangeSelect() {
var _getPrototypeOf2;
var _this;
(0, _classCallCheck2["default"])(this, ColorRangeSelect);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(ColorRangeSelect)).call.apply(_getPrototypeOf2, [this].concat(args)));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", {
config: {
type: {
type: 'select',
value: 'all',
options: ALL_TYPES
},
steps: {
type: 'select',
value: 6,
options: ALL_STEPS
},
reversed: {
type: 'switch',
value: false,
options: [true, false]
}
}
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_updateConfig", function (_ref) {
var key = _ref.key,
value = _ref.value;
var currentValue = _this.state.config[key].value;
if (value !== currentValue) {
_this.setState({
config: _objectSpread({}, _this.state.config, (0, _defineProperty2["default"])({}, key, _objectSpread({}, _this.state.config[key], {
value: value
})))
});
}
});
return _this;
}
(0, _createClass2["default"])(ColorRangeSelect, [{
key: "render",
value: function render() {
var _this2 = this;
var config = this.state.config;
return _react["default"].createElement(ColorRangeSelector, {
className: "color-range-selector"
}, _react["default"].createElement(StyledColorConfig, null, Object.keys(config).map(function (key) {
return _react["default"].createElement(PaletteConfig, {
key: key,
label: key,
config: config[key],
onChange: function onChange(value) {
return _this2._updateConfig({
key: key,
value: value
});
}
});
})), _react["default"].createElement(ColorPaletteGroup, {
config: config,
colorRanges: this.props.colorRanges,
onSelect: this.props.onSelectColorRange,
selected: this.props.selectedColorRange
}));
}
}]);
return ColorRangeSelect;
}(_react.Component);
exports["default"] = ColorRangeSelect;
(0, _defineProperty2["default"])(ColorRangeSelect, "propTypes", {
colorRanges: _propTypes["default"].arrayOf(_propTypes["default"].any),
selectedColorRange: _propTypes["default"].object,
onSelectColorRange: _propTypes["default"].func.isRequired
});
(0, _defineProperty2["default"])(ColorRangeSelect, "defaultProps", {
colorRanges: _colorRanges.COLOR_RANGES,
onSelectColorRange: function onSelectColorRange() {}
});
var StyledPaletteConfig = _styledComponents["default"].div(_templateObject3(), function (props) {
return props.theme.secondaryInput;
});
var PaletteConfig = function PaletteConfig(_ref2) {
var category = _ref2.category,
label = _ref2.label,
_ref2$config = _ref2.config,
type = _ref2$config.type,
value = _ref2$config.value,
options = _ref2$config.options,
_onChange = _ref2.onChange;
return _react["default"].createElement(StyledPaletteConfig, {
className: "color-palette__config",
onClick: function onClick(e) {
return e.stopPropagation();
}
}, _react["default"].createElement("div", {
className: "color-palette__config__label"
}, _react["default"].createElement(_styledComponents2.PanelLabel, null, label)), type === 'select' && _react["default"].createElement("div", {
className: "color-palette__config__select"
}, _react["default"].createElement(_itemSelector["default"], {
selectedItems: value,
options: options,
multiSelect: false,
searchable: false,
onChange: _onChange
})), type === 'slider' && _react["default"].createElement("div", {
className: "color-palette__config__slider"
}, _react["default"].createElement("div", {
className: "color-palette__config__slider__slider"
}, _react["default"].createElement(_rangeSlider["default"], {
range: options,
value0: options[0],
value1: value,
step: 1,
isRanged: false,
showInput: false,
onChange: function onChange(val) {
return _onChange(val[1]);
}
})), _react["default"].createElement("div", {
className: "color-palette__config__slider__number"
}, value)), type === 'switch' && _react["default"].createElement(_switch["default"], {
checked: value,
id: "".concat(category, "-").concat(label, "-toggle"),
onChange: function onChange() {
return _onChange(!value);
},
secondary: true
}));
};
var StyledColorRange = _styledComponents["default"].div(_templateObject4(), function (props) {
return props.theme.panelBackgroundHover;
});
var ColorPaletteGroup = function ColorPaletteGroup(_ref3) {
var _ref3$config = _ref3.config,
config = _ref3$config === void 0 ? {} : _ref3$config,
onSelect = _ref3.onSelect,
selected = _ref3.selected,
colorRanges = _ref3.colorRanges;
var steps = config.steps,
reversed = config.reversed,
type = config.type;
var filtered = colorRanges.filter(function (colorRange) {
var isType = !type || type.value === 'all' || type.value === colorRange.type;
var isStep = !steps || Number(steps.value) === colorRange.colors.length;
return isType && isStep;
});
var isReversed = Boolean(reversed && reversed.value);
return _react["default"].createElement("div", {
className: "color-palette__group"
}, filtered.map(function (colorRange) {
return _react["default"].createElement(StyledColorRange, {
className: "color-ranges",
key: colorRange.name,
onClick: function onClick(e) {
return onSelect(_objectSpread({}, colorRange, {
reversed: isReversed,
colors: isReversed ? colorRange.colors.slice().reverse() : colorRange.colors
}), e);
}
}, _react["default"].createElement(_colorPalette["default"], {
colors: colorRange.colors,
isReversed: isReversed,
isSelected: colorRange.name === selected.name && isReversed === Boolean(selected.reversed)
}));
}));
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/color-range-selector.js"],"names":["ALL_TYPES","COLOR_RANGES","map","c","type","concat","ALL_STEPS","d","colors","length","sort","numberSort","StyledColorConfig","styled","div","ColorRangeSelector","ColorRangeSelect","config","value","options","steps","reversed","key","currentValue","state","setState","Object","keys","_updateConfig","props","colorRanges","onSelectColorRange","selectedColorRange","Component","PropTypes","arrayOf","any","object","func","isRequired","StyledPaletteConfig","theme","secondaryInput","PaletteConfig","category","label","onChange","e","stopPropagation","val","StyledColorRange","panelBackgroundHover","ColorPaletteGroup","onSelect","selected","filtered","filter","colorRange","isType","isStep","Number","isReversed","Boolean","name","slice","reverse"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,SAAS,GAAG,wBAAKC,0BAAaC,GAAb,CAAiB,UAAAC,CAAC;AAAA,SAAIA,CAAC,CAACC,IAAN;AAAA,CAAlB,EAA8BC,MAA9B,CAAqC,CAAC,KAAD,CAArC,CAAL,CAAlB;AACA,IAAMC,SAAS,GAAG,wBAAKL,0BAAaC,GAAb,CAAiB,UAAAK,CAAC;AAAA,SAAIA,CAAC,CAACC,MAAF,CAASC,MAAb;AAAA,CAAlB,CAAL,EAA6CC,IAA7C,CAAkDC,qBAAlD,CAAlB;;AAEA,IAAMC,iBAAiB,GAAGC,6BAAOC,GAAV,mBAAvB;;AAIA,IAAMC,kBAAkB,GAAGF,6BAAOC,GAAV,oBAAxB;;IAGqBE,gB;;;;;;;;;;;;;;;;;8FAYX;AACNC,MAAAA,MAAM,EAAE;AACNb,QAAAA,IAAI,EAAE;AACJA,UAAAA,IAAI,EAAE,QADF;AAEJc,UAAAA,KAAK,EAAE,KAFH;AAGJC,UAAAA,OAAO,EAAEnB;AAHL,SADA;AAMNoB,QAAAA,KAAK,EAAE;AACLhB,UAAAA,IAAI,EAAE,QADD;AAELc,UAAAA,KAAK,EAAE,CAFF;AAGLC,UAAAA,OAAO,EAAEb;AAHJ,SAND;AAWNe,QAAAA,QAAQ,EAAE;AACRjB,UAAAA,IAAI,EAAE,QADE;AAERc,UAAAA,KAAK,EAAE,KAFC;AAGRC,UAAAA,OAAO,EAAE,CAAC,IAAD,EAAO,KAAP;AAHD;AAXJ;AADF,K;sGAoBQ,gBAAkB;AAAA,UAAhBG,GAAgB,QAAhBA,GAAgB;AAAA,UAAXJ,KAAW,QAAXA,KAAW;AAChC,UAAMK,YAAY,GAAG,MAAKC,KAAL,CAAWP,MAAX,CAAkBK,GAAlB,EAAuBJ,KAA5C;;AACA,UAAIA,KAAK,KAAKK,YAAd,EAA4B;AAC1B,cAAKE,QAAL,CAAc;AACZR,UAAAA,MAAM,oBACD,MAAKO,KAAL,CAAWP,MADV,uCAEHK,GAFG,oBAGC,MAAKE,KAAL,CAAWP,MAAX,CAAkBK,GAAlB,CAHD;AAIFJ,YAAAA,KAAK,EAALA;AAJE;AADM,SAAd;AASD;AACF,K;;;;;;6BAEQ;AAAA;;AAAA,UACAD,MADA,GACU,KAAKO,KADf,CACAP,MADA;AAEP,aACE,gCAAC,kBAAD;AAAoB,QAAA,SAAS,EAAC;AAA9B,SACE,gCAAC,iBAAD,QACGS,MAAM,CAACC,IAAP,CAAYV,MAAZ,EAAoBf,GAApB,CAAwB,UAAAoB,GAAG;AAAA,eAC1B,gCAAC,aAAD;AACE,UAAA,GAAG,EAAEA,GADP;AAEE,UAAA,KAAK,EAAEA,GAFT;AAGE,UAAA,MAAM,EAAEL,MAAM,CAACK,GAAD,CAHhB;AAIE,UAAA,QAAQ,EAAE,kBAAAJ,KAAK;AAAA,mBAAI,MAAI,CAACU,aAAL,CAAmB;AAACN,cAAAA,GAAG,EAAHA,GAAD;AAAMJ,cAAAA,KAAK,EAALA;AAAN,aAAnB,CAAJ;AAAA;AAJjB,UAD0B;AAAA,OAA3B,CADH,CADF,EAWE,gCAAC,iBAAD;AACE,QAAA,MAAM,EAAED,MADV;AAEE,QAAA,WAAW,EAAE,KAAKY,KAAL,CAAWC,WAF1B;AAGE,QAAA,QAAQ,EAAE,KAAKD,KAAL,CAAWE,kBAHvB;AAIE,QAAA,QAAQ,EAAE,KAAKF,KAAL,CAAWG;AAJvB,QAXF,CADF;AAoBD;;;EArE2CC,gB;;;iCAAzBjB,gB,eACA;AACjBc,EAAAA,WAAW,EAAEI,sBAAUC,OAAV,CAAkBD,sBAAUE,GAA5B,CADI;AAEjBJ,EAAAA,kBAAkB,EAAEE,sBAAUG,MAFb;AAGjBN,EAAAA,kBAAkB,EAAEG,sBAAUI,IAAV,CAAeC;AAHlB,C;iCADAvB,gB,kBAOG;AACpBc,EAAAA,WAAW,EAAE7B,yBADO;AAEpB8B,EAAAA,kBAAkB,EAAE,8BAAM,CAAE;AAFR,C;;AAiExB,IAAMS,mBAAmB,GAAG3B,6BAAOC,GAAV,qBAYnB,UAAAe,KAAK;AAAA,SAAIA,KAAK,CAACY,KAAN,CAAYC,cAAhB;AAAA,CAZc,CAAzB;;AAgBA,IAAMC,aAAa,GAAG,SAAhBA,aAAgB;AAAA,MACpBC,QADoB,SACpBA,QADoB;AAAA,MAEpBC,KAFoB,SAEpBA,KAFoB;AAAA,2BAGpB5B,MAHoB;AAAA,MAGXb,IAHW,gBAGXA,IAHW;AAAA,MAGLc,KAHK,gBAGLA,KAHK;AAAA,MAGEC,OAHF,gBAGEA,OAHF;AAAA,MAIpB2B,SAJoB,SAIpBA,QAJoB;AAAA,SAMpB,gCAAC,mBAAD;AACE,IAAA,SAAS,EAAC,uBADZ;AAEE,IAAA,OAAO,EAAE,iBAAAC,CAAC;AAAA,aAAIA,CAAC,CAACC,eAAF,EAAJ;AAAA;AAFZ,KAIE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE,gCAAC,6BAAD,QAAaH,KAAb,CADF,CAJF,EAOGzC,IAAI,KAAK,QAAT,IACC;AAAK,IAAA,SAAS,EAAC;AAAf,KACE,gCAAC,wBAAD;AACE,IAAA,aAAa,EAAEc,KADjB;AAEE,IAAA,OAAO,EAAEC,OAFX;AAGE,IAAA,WAAW,EAAE,KAHf;AAIE,IAAA,UAAU,EAAE,KAJd;AAKE,IAAA,QAAQ,EAAE2B;AALZ,IADF,CARJ,EAkBG1C,IAAI,KAAK,QAAT,IACC;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE,gCAAC,uBAAD;AACE,IAAA,KAAK,EAAEe,OADT;AAEE,IAAA,MAAM,EAAEA,OAAO,CAAC,CAAD,CAFjB;AAGE,IAAA,MAAM,EAAED,KAHV;AAIE,IAAA,IAAI,EAAE,CAJR;AAKE,IAAA,QAAQ,EAAE,KALZ;AAME,IAAA,SAAS,EAAE,KANb;AAOE,IAAA,QAAQ,EAAE,kBAAA+B,GAAG;AAAA,aAAIH,SAAQ,CAACG,GAAG,CAAC,CAAD,CAAJ,CAAZ;AAAA;AAPf,IADF,CADF,EAYE;AAAK,IAAA,SAAS,EAAC;AAAf,KAAwD/B,KAAxD,CAZF,CAnBJ,EAkCGd,IAAI,KAAK,QAAT,IACC,gCAAC,kBAAD;AACE,IAAA,OAAO,EAAEc,KADX;AAEE,IAAA,EAAE,YAAK0B,QAAL,cAAiBC,KAAjB,YAFJ;AAGE,IAAA,QAAQ,EAAE;AAAA,aAAMC,SAAQ,CAAC,CAAC5B,KAAF,CAAd;AAAA,KAHZ;AAIE,IAAA,SAAS;AAJX,IAnCJ,CANoB;AAAA,CAAtB;;AAmDA,IAAMgC,gBAAgB,GAAGrC,6BAAOC,GAAV,qBAGE,UAAAe,KAAK;AAAA,SAAIA,KAAK,CAACY,KAAN,CAAYU,oBAAhB;AAAA,CAHP,CAAtB;;AAQA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAoB,QAAoD;AAAA,2BAAlDnC,MAAkD;AAAA,MAAlDA,MAAkD,6BAAzC,EAAyC;AAAA,MAArCoC,QAAqC,SAArCA,QAAqC;AAAA,MAA3BC,QAA2B,SAA3BA,QAA2B;AAAA,MAAjBxB,WAAiB,SAAjBA,WAAiB;AAAA,MACrEV,KADqE,GAC5CH,MAD4C,CACrEG,KADqE;AAAA,MAC9DC,QAD8D,GAC5CJ,MAD4C,CAC9DI,QAD8D;AAAA,MACpDjB,IADoD,GAC5Ca,MAD4C,CACpDb,IADoD;AAG5E,MAAMmD,QAAQ,GAAGzB,WAAW,CAAC0B,MAAZ,CAAmB,UAAAC,UAAU,EAAI;AAChD,QAAMC,MAAM,GACV,CAACtD,IAAD,IAASA,IAAI,CAACc,KAAL,KAAe,KAAxB,IAAiCd,IAAI,CAACc,KAAL,KAAeuC,UAAU,CAACrD,IAD7D;AAEA,QAAMuD,MAAM,GAAG,CAACvC,KAAD,IAAUwC,MAAM,CAACxC,KAAK,CAACF,KAAP,CAAN,KAAwBuC,UAAU,CAACjD,MAAX,CAAkBC,MAAnE;AAEA,WAAOiD,MAAM,IAAIC,MAAjB;AACD,GANgB,CAAjB;AAQA,MAAME,UAAU,GAAGC,OAAO,CAACzC,QAAQ,IAAIA,QAAQ,CAACH,KAAtB,CAA1B;AAEA,SACE;AAAK,IAAA,SAAS,EAAC;AAAf,KACGqC,QAAQ,CAACrD,GAAT,CAAa,UAAAuD,UAAU;AAAA,WACtB,gCAAC,gBAAD;AACE,MAAA,SAAS,EAAC,cADZ;AAEE,MAAA,GAAG,EAAEA,UAAU,CAACM,IAFlB;AAGE,MAAA,OAAO,EAAE,iBAAAhB,CAAC;AAAA,eACRM,QAAQ,mBAEDI,UAFC;AAGJpC,UAAAA,QAAQ,EAAEwC,UAHN;AAIJrD,UAAAA,MAAM,EAAEqD,UAAU,GACdJ,UAAU,CAACjD,MAAX,CAAkBwD,KAAlB,GAA0BC,OAA1B,EADc,GAEdR,UAAU,CAACjD;AANX,YAQNuC,CARM,CADA;AAAA;AAHZ,OAgBE,gCAAC,wBAAD;AACE,MAAA,MAAM,EAAEU,UAAU,CAACjD,MADrB;AAEE,MAAA,UAAU,EAAEqD,UAFd;AAGE,MAAA,UAAU,EACRJ,UAAU,CAACM,IAAX,KAAoBT,QAAQ,CAACS,IAA7B,IACAF,UAAU,KAAKC,OAAO,CAACR,QAAQ,CAACjC,QAAV;AAL1B,MAhBF,CADsB;AAAA,GAAvB,CADH,CADF;AA+BD,CA5CD","sourcesContent":["// Copyright (c) 2019 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport uniq from 'lodash.uniq';\nimport styled from 'styled-components';\nimport ItemSelector from 'components/common/item-selector/item-selector';\nimport {PanelLabel} from 'components/common/styled-components';\nimport RangeSlider from 'components/common/range-slider';\nimport Switch from 'components/common/switch';\nimport ColorPalette from './color-palette';\n\nimport {COLOR_RANGES} from 'constants/color-ranges';\nimport {numberSort} from 'utils/data-utils';\n\nconst ALL_TYPES = uniq(COLOR_RANGES.map(c => c.type).concat(['all']));\nconst ALL_STEPS = uniq(COLOR_RANGES.map(d => d.colors.length)).sort(numberSort);\n\nconst StyledColorConfig = styled.div`\n  padding: 12px 12px 0 12px;\n`;\n\nconst ColorRangeSelector = styled.div`\n  padding-bottom: 12px;\n`;\nexport default class ColorRangeSelect extends Component {\n  static propTypes = {\n    colorRanges: PropTypes.arrayOf(PropTypes.any),\n    selectedColorRange: PropTypes.object,\n    onSelectColorRange: PropTypes.func.isRequired\n  };\n\n  static defaultProps = {\n    colorRanges: COLOR_RANGES,\n    onSelectColorRange: () => {}\n  };\n\n  state = {\n    config: {\n      type: {\n        type: 'select',\n        value: 'all',\n        options: ALL_TYPES\n      },\n      steps: {\n        type: 'select',\n        value: 6,\n        options: ALL_STEPS\n      },\n      reversed: {\n        type: 'switch',\n        value: false,\n        options: [true, false]\n      }\n    }\n  };\n\n  _updateConfig = ({key, value}) => {\n    const currentValue = this.state.config[key].value;\n    if (value !== currentValue) {\n      this.setState({\n        config: {\n          ...this.state.config,\n          [key]: {\n            ...this.state.config[key],\n            value\n          }\n        }\n      });\n    }\n  };\n\n  render() {\n    const {config} = this.state;\n    return (\n      <ColorRangeSelector className=\"color-range-selector\">\n        <StyledColorConfig>\n          {Object.keys(config).map(key => (\n            <PaletteConfig\n              key={key}\n              label={key}\n              config={config[key]}\n              onChange={value => this._updateConfig({key, value})}\n            />\n          ))}\n        </StyledColorConfig>\n        <ColorPaletteGroup\n          config={config}\n          colorRanges={this.props.colorRanges}\n          onSelect={this.props.onSelectColorRange}\n          selected={this.props.selectedColorRange}\n        />\n      </ColorRangeSelector>\n    );\n  }\n}\n\nconst StyledPaletteConfig = styled.div`\n  margin-bottom: 8px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  .color-palette__config__label {\n    flex-grow: 1;\n  }\n  .color-palette__config__select {\n    flex-grow: 1;\n  }\n  .item-selector .item-selector__dropdown {\n    ${props => props.theme.secondaryInput};\n  }\n`;\n\nconst PaletteConfig = ({\n  category,\n  label,\n  config: {type, value, options},\n  onChange\n}) => (\n  <StyledPaletteConfig\n    className=\"color-palette__config\"\n    onClick={e => e.stopPropagation()}\n  >\n    <div className=\"color-palette__config__label\">\n      <PanelLabel>{label}</PanelLabel>\n    </div>\n    {type === 'select' && (\n      <div className=\"color-palette__config__select\">\n        <ItemSelector\n          selectedItems={value}\n          options={options}\n          multiSelect={false}\n          searchable={false}\n          onChange={onChange}\n        />\n      </div>\n    )}\n    {type === 'slider' && (\n      <div className=\"color-palette__config__slider\">\n        <div className=\"color-palette__config__slider__slider\">\n          <RangeSlider\n            range={options}\n            value0={options[0]}\n            value1={value}\n            step={1}\n            isRanged={false}\n            showInput={false}\n            onChange={val => onChange(val[1])}\n          />\n        </div>\n        <div className=\"color-palette__config__slider__number\">{value}</div>\n      </div>\n    )}\n    {type === 'switch' && (\n      <Switch\n        checked={value}\n        id={`${category}-${label}-toggle`}\n        onChange={() => onChange(!value)}\n        secondary\n      />\n    )}\n  </StyledPaletteConfig>\n);\n\nconst StyledColorRange = styled.div`\n  padding: 0 8px;\n  :hover {\n    background-color: ${props => props.theme.panelBackgroundHover};\n    cursor: pointer;\n  }\n`;\n\nconst ColorPaletteGroup = ({config = {}, onSelect, selected, colorRanges}) => {\n  const {steps, reversed, type} = config;\n\n  const filtered = colorRanges.filter(colorRange => {\n    const isType =\n      !type || type.value === 'all' || type.value === colorRange.type;\n    const isStep = !steps || Number(steps.value) === colorRange.colors.length;\n\n    return isType && isStep;\n  });\n\n  const isReversed = Boolean(reversed && reversed.value);\n\n  return (\n    <div className=\"color-palette__group\">\n      {filtered.map(colorRange => (\n        <StyledColorRange\n          className=\"color-ranges\"\n          key={colorRange.name}\n          onClick={e =>\n            onSelect(\n              {\n                ...colorRange,\n                reversed: isReversed,\n                colors: isReversed\n                  ? colorRange.colors.slice().reverse()\n                  : colorRange.colors\n              },\n              e\n            )\n          }\n        >\n          <ColorPalette\n            colors={colorRange.colors}\n            isReversed={isReversed}\n            isSelected={\n              colorRange.name === selected.name &&\n              isReversed === Boolean(selected.reversed)\n            }\n          />\n        </StyledColorRange>\n      ))}\n    </div>\n  );\n};\n"]}