kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
243 lines (242 loc) • 40.2 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.PaletteConfig = exports.ColorPaletteItem = exports.ALL_TYPES = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _constants = require("@kepler.gl/constants");
var _localization = require("@kepler.gl/localization");
var _utils = require("@kepler.gl/utils");
var _itemSelector = _interopRequireDefault(require("../../common/item-selector/item-selector"));
var _styledComponents2 = require("../../common/styled-components");
var _switch = _interopRequireDefault(require("../../common/switch"));
var _colorPalette = _interopRequireDefault(require("./color-palette"));
var _customPalette = _interopRequireDefault(require("./custom-palette"));
var _d3Array = require("d3-array");
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
// @ts-ignore cant concat 'all' to PALETTE_TYPES values
var ALL_TYPES = exports.ALL_TYPES = Object.values(_constants.PALETTE_TYPES).concat(['all']);
var MAX_STEPS = 20;
var ALL_STEPS = (0, _d3Array.range)(2, MAX_STEPS + 1, 1);
var StyledColorConfig = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding: 12px 12px 0 12px;\n"])));
var StyledColorRangeSelector = _styledComponents["default"].div.attrs({
className: 'color-range-selector'
})(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n padding-bottom: 12px;\n"])));
var StyledColorPalette = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0 8px 8px 8px;\n"])));
var StyledPaletteConfig = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 8px;\n display: flex;\n justify-content: space-between;\n align-items: center;\n\n .color-palette__config__select {\n width: 40%;\n display: flex;\n flex-direction: row-reverse;\n\n .item-selector {\n width: 100%;\n }\n }\n"])));
var CONFIG_SETTINGS = {
type: {
type: 'select',
options: ALL_TYPES
},
steps: {
type: 'select',
options: ALL_STEPS,
disabled: function disabled(colorRange) {
return (0, _utils.hasColorMap)(colorRange);
},
reason: 'color.disableStepReason'
},
reversed: {
type: 'switch',
options: [true, false]
},
colorBlindSafe: {
type: 'switch',
options: [true, false]
},
custom: {
label: 'customPalette',
type: 'switch',
options: [true, false]
}
};
var displayOption = function displayOption(d) {
return (0, _utils.capitalizeFirstLetter)(d);
};
var getOptionValue = function getOptionValue(d) {
return d;
};
var noop = function noop() {
// do nothing
};
ColorRangeSelectorFactory.deps = [_customPalette["default"]];
function ColorRangeSelectorFactory(CustomPalette) {
var ColorRangeSelector = function ColorRangeSelector(_ref) {
var _ref$colorPalettes = _ref.colorPalettes,
colorPalettes = _ref$colorPalettes === void 0 ? _constants.KEPLER_COLOR_PALETTES : _ref$colorPalettes,
colorPaletteUI = _ref.colorPaletteUI,
_ref$setColorPaletteU = _ref.setColorPaletteUI,
setColorPaletteUI = _ref$setColorPaletteU === void 0 ? noop : _ref$setColorPaletteU,
_ref$onSelectColorRan = _ref.onSelectColorRange,
onSelectColorRange = _ref$onSelectColorRan === void 0 ? noop : _ref$onSelectColorRan,
selectedColorRange = _ref.selectedColorRange;
var customPalette = colorPaletteUI.customPalette,
showSketcher = colorPaletteUI.showSketcher,
colorRangeConfig = colorPaletteUI.colorRangeConfig;
var type = colorRangeConfig.type,
steps = colorRangeConfig.steps,
colorBlindSafe = colorRangeConfig.colorBlindSafe,
reversed = colorRangeConfig.reversed;
var filteredColorPalettes = (0, _react.useMemo)(function () {
var _colorPalettes$filter;
return (_colorPalettes$filter = colorPalettes === null || colorPalettes === void 0 ? void 0 : colorPalettes.filter(function (palette) {
return (0, _utils.paletteIsType)(palette, type) && (0, _utils.paletteIsSteps)(palette, steps) && (0, _utils.paletteIsColorBlindSafe)(palette, colorBlindSafe);
})) !== null && _colorPalettes$filter !== void 0 ? _colorPalettes$filter : [];
}, [colorPalettes, colorBlindSafe, steps, type]);
var _updateConfig = (0, _react.useCallback)(function (_ref2) {
var key = _ref2.key,
value = _ref2.value;
setColorPaletteUI({
colorRangeConfig: (0, _defineProperty2["default"])({}, key, value)
});
}, [setColorPaletteUI]);
var _onCustomPaletteCancel = (0, _react.useCallback)(function () {
setColorPaletteUI({
showSketcher: false,
colorRangeConfig: {
custom: false
}
});
}, [setColorPaletteUI]);
var _onApply = (0, _react.useCallback)(function (e) {
return onSelectColorRange(customPalette, e);
}, [customPalette, onSelectColorRange]);
var _onSelectPalette = (0, _react.useCallback)(function (colorPalette, e) {
var newColorRange = (0, _utils.updateColorRangeBySelectedPalette)(selectedColorRange, colorPalette, {
steps: steps,
reversed: reversed
});
onSelectColorRange(newColorRange, e);
}, [selectedColorRange, reversed, steps, onSelectColorRange]);
return /*#__PURE__*/_react["default"].createElement(StyledColorRangeSelector, null, /*#__PURE__*/_react["default"].createElement(StyledColorConfig, null, (colorRangeConfig.custom ? ['custom'] : Object.keys(colorRangeConfig)).map(function (key) {
return CONFIG_SETTINGS[key] ? /*#__PURE__*/_react["default"].createElement(PaletteConfig, {
key: key,
prop: key,
label: CONFIG_SETTINGS[key].label || key,
config: CONFIG_SETTINGS[key],
value: colorRangeConfig[key],
onChange: _updateConfig,
disabled: CONFIG_SETTINGS[key].disabled ? CONFIG_SETTINGS[key].disabled(selectedColorRange) : false,
reason: CONFIG_SETTINGS[key].reason
}) : null;
})), colorRangeConfig.custom ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(StyledColorPalette, null, /*#__PURE__*/_react["default"].createElement(_colorPalette["default"], {
colors: customPalette.colors
})), /*#__PURE__*/_react["default"].createElement(CustomPalette, {
customPalette: customPalette,
showSketcher: showSketcher,
onApply: _onApply,
setColorPaletteUI: setColorPaletteUI,
onCancel: _onCustomPaletteCancel
})) : /*#__PURE__*/_react["default"].createElement("div", {
className: "color-palette__group"
}, filteredColorPalettes.map(function (colorPalette, i) {
return /*#__PURE__*/_react["default"].createElement(ColorPaletteItem, {
key: "".concat(colorPalette.name, "-").concat(i),
colorPalette: colorPalette,
selectedColorRange: selectedColorRange,
onSelect: _onSelectPalette,
reversed: reversed,
steps: steps
});
})));
};
return ColorRangeSelector;
}
var PaletteConfig = exports.PaletteConfig = function PaletteConfig(_ref3) {
var prop = _ref3.prop,
label = _ref3.label,
value = _ref3.value,
_ref3$config = _ref3.config,
type = _ref3$config.type,
options = _ref3$config.options,
onChange = _ref3.onChange,
disabled = _ref3.disabled,
reason = _ref3.reason;
var updateSelect = (0, _react.useCallback)(function (val) {
return onChange({
key: prop,
value: val
});
}, [onChange, prop]);
var updateSwitch = (0, _react.useCallback)(function () {
return onChange({
key: prop,
value: !value
});
}, [onChange, prop, value]);
return /*#__PURE__*/_react["default"].createElement(StyledPaletteConfig, {
className: "color-palette__config",
onClick: function onClick(e) {
return e.stopPropagation();
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "color-palette__config__label"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "color.".concat(label)
}))), /*#__PURE__*/_react["default"].createElement("div", {
className: "color-palette__config__select",
"data-tip": true,
"data-for": "color-range-config-".concat(prop)
}, type === 'select' && /*#__PURE__*/_react["default"].createElement(_itemSelector["default"], {
selectedItems: value,
options: options,
multiSelect: false,
searchable: false,
onChange: updateSelect,
disabled: disabled,
inputTheme: "secondary",
displayOption: displayOption,
getOptionValue: getOptionValue
}), type === 'switch' && /*#__PURE__*/_react["default"].createElement(_switch["default"], {
checked: Boolean(value),
id: "".concat(label, "-toggle"),
onChange: updateSwitch,
disabled: disabled,
secondary: true
}), disabled && reason ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.Tooltip, {
id: "color-range-config-".concat(prop),
place: "right"
}, /*#__PURE__*/_react["default"].createElement("div", {
style: {
maxWidth: '214px'
}
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: reason
}))) : null));
};
var StyledColorRange = _styledComponents["default"].div.attrs({
className: 'color-palette-outer'
})(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0 8px;\n &:hover {\n background-color: ", ";\n cursor: pointer;\n }\n"])), function (props) {
return props.theme.panelBackgroundHover;
});
var ColorPaletteItem = exports.ColorPaletteItem = function ColorPaletteItem(_ref4) {
var colorPalette = _ref4.colorPalette,
steps = _ref4.steps,
selectedColorRange = _ref4.selectedColorRange,
onSelect = _ref4.onSelect,
reversed = _ref4.reversed;
var colors = (0, _react.useMemo)(function () {
return colorPalette.colors(steps);
}, [colorPalette, steps]);
var onClick = (0, _react.useCallback)(function (e) {
return onSelect(colorPalette, e);
}, [colorPalette, onSelect]);
return /*#__PURE__*/_react["default"].createElement(StyledColorRange, {
onClick: onClick
}, /*#__PURE__*/_react["default"].createElement(_colorPalette["default"], {
colors: colors,
isReversed: reversed,
isSelected: colorPalette.name === selectedColorRange.name
}));
};
var _default = exports["default"] = ColorRangeSelectorFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_constants","_localization","_utils","_itemSelector","_styledComponents2","_switch","_colorPalette","_customPalette","_d3Array","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ALL_TYPES","exports","values","PALETTE_TYPES","concat","MAX_STEPS","ALL_STEPS","range","StyledColorConfig","styled","div","_taggedTemplateLiteral2","StyledColorRangeSelector","attrs","className","StyledColorPalette","StyledPaletteConfig","CONFIG_SETTINGS","type","options","steps","disabled","colorRange","hasColorMap","reason","reversed","colorBlindSafe","custom","label","displayOption","d","capitalizeFirstLetter","getOptionValue","noop","ColorRangeSelectorFactory","deps","CustomPaletteFactory","CustomPalette","ColorRangeSelector","_ref","_ref$colorPalettes","colorPalettes","KEPLER_COLOR_PALETTES","colorPaletteUI","_ref$setColorPaletteU","setColorPaletteUI","_ref$onSelectColorRan","onSelectColorRange","selectedColorRange","customPalette","showSketcher","colorRangeConfig","filteredColorPalettes","useMemo","_colorPalettes$filter","filter","palette","paletteIsType","paletteIsSteps","paletteIsColorBlindSafe","_updateConfig","useCallback","_ref2","key","value","_defineProperty2","_onCustomPaletteCancel","_onApply","_onSelectPalette","colorPalette","newColorRange","updateColorRangeBySelectedPalette","createElement","keys","map","PaletteConfig","prop","config","onChange","Fragment","colors","onApply","onCancel","ColorPaletteItem","name","onSelect","_ref3","_ref3$config","updateSelect","val","updateSwitch","onClick","stopPropagation","PanelLabel","FormattedMessage","id","selectedItems","multiSelect","searchable","inputTheme","checked","Boolean","secondary","Tooltip","place","style","maxWidth","StyledColorRange","props","theme","panelBackgroundHover","_ref4","isReversed","isSelected","_default"],"sources":["../../../src/side-panel/layer-panel/color-range-selector.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {MouseEvent, useCallback, useMemo} from 'react';\nimport styled from 'styled-components';\nimport {KEPLER_COLOR_PALETTES, PALETTE_TYPES, ColorPalette} from '@kepler.gl/constants';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {ColorRange, ColorUI, NestedPartial} from '@kepler.gl/types';\nimport {\n  hasColorMap,\n  updateColorRangeBySelectedPalette,\n  paletteIsSteps,\n  paletteIsType,\n  paletteIsColorBlindSafe\n} from '@kepler.gl/utils';\nimport ItemSelector from '../../common/item-selector/item-selector';\nimport {PanelLabel, Tooltip} from '../../common/styled-components';\nimport Switch from '../../common/switch';\nimport ColorPalettePanel from './color-palette';\nimport CustomPaletteFactory from './custom-palette';\n\nimport {capitalizeFirstLetter} from '@kepler.gl/utils';\nimport {range} from 'd3-array';\n\ntype ColorRangeSelectorProps = {\n  colorPalettes?: ColorPalette[];\n  colorPaletteUI: ColorUI;\n  selectedColorRange: ColorRange;\n  onSelectColorRange: (p: ColorRange, e: MouseEvent) => void;\n  setColorPaletteUI: (newConfig: NestedPartial<ColorUI>) => void;\n};\n\ntype PaletteConfigProps = {\n  label: string;\n  value: string | number | boolean;\n  config: {\n    type: string;\n    options: (string | number | boolean)[];\n  };\n  onChange: (v: any) => void;\n  disabled?: boolean;\n  prop: string;\n  reason?: string;\n};\n\n// @ts-ignore cant concat 'all' to PALETTE_TYPES values\nexport const ALL_TYPES = Object.values(PALETTE_TYPES).concat(['all']);\nconst MAX_STEPS = 20;\nconst ALL_STEPS = range(2, MAX_STEPS + 1, 1);\n\nconst StyledColorConfig = styled.div`\n  padding: 12px 12px 0 12px;\n`;\n\nconst StyledColorRangeSelector = styled.div.attrs({\n  className: 'color-range-selector'\n})`\n  padding-bottom: 12px;\n`;\nconst StyledColorPalette = styled.div`\n  padding: 0 8px 8px 8px;\n`;\n\nconst StyledPaletteConfig = styled.div`\n  margin-bottom: 8px;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n\n  .color-palette__config__select {\n    width: 40%;\n    display: flex;\n    flex-direction: row-reverse;\n\n    .item-selector {\n      width: 100%;\n    }\n  }\n`;\n\nconst CONFIG_SETTINGS = {\n  type: {\n    type: 'select',\n    options: ALL_TYPES\n  },\n  steps: {\n    type: 'select',\n    options: ALL_STEPS,\n    disabled: colorRange => hasColorMap(colorRange),\n    reason: 'color.disableStepReason'\n  },\n  reversed: {\n    type: 'switch',\n    options: [true, false]\n  },\n  colorBlindSafe: {\n    type: 'switch',\n    options: [true, false]\n  },\n  custom: {\n    label: 'customPalette',\n    type: 'switch',\n    options: [true, false]\n  }\n};\nconst displayOption = d => capitalizeFirstLetter(d);\nconst getOptionValue = d => d;\nconst noop = () => {\n  // do nothing\n};\n\nColorRangeSelectorFactory.deps = [CustomPaletteFactory];\nfunction ColorRangeSelectorFactory(\n  CustomPalette: ReturnType<typeof CustomPaletteFactory>\n): React.FC<ColorRangeSelectorProps> {\n  const ColorRangeSelector: React.FC<ColorRangeSelectorProps> = ({\n    colorPalettes = KEPLER_COLOR_PALETTES,\n    colorPaletteUI,\n    setColorPaletteUI = noop,\n    onSelectColorRange = noop,\n    selectedColorRange\n  }) => {\n    const {customPalette, showSketcher, colorRangeConfig} = colorPaletteUI;\n    const {type, steps, colorBlindSafe, reversed} = colorRangeConfig;\n\n    const filteredColorPalettes = useMemo(() => {\n      return (\n        colorPalettes?.filter(\n          palette =>\n            paletteIsType(palette, type) &&\n            paletteIsSteps(palette, steps) &&\n            paletteIsColorBlindSafe(palette, colorBlindSafe)\n        ) ?? []\n      );\n    }, [colorPalettes, colorBlindSafe, steps, type]);\n\n    const _updateConfig = useCallback(\n      ({key, value}) => {\n        setColorPaletteUI({colorRangeConfig: {[key]: value}});\n      },\n      [setColorPaletteUI]\n    );\n\n    const _onCustomPaletteCancel = useCallback(() => {\n      setColorPaletteUI({\n        showSketcher: false,\n        colorRangeConfig: {custom: false}\n      });\n    }, [setColorPaletteUI]);\n\n    const _onApply = useCallback(\n      e => onSelectColorRange(customPalette, e),\n      [customPalette, onSelectColorRange]\n    );\n\n    const _onSelectPalette = useCallback(\n      (colorPalette, e) => {\n        const newColorRange = updateColorRangeBySelectedPalette(selectedColorRange, colorPalette, {\n          steps,\n          reversed\n        });\n\n        onSelectColorRange(newColorRange, e);\n      },\n      [selectedColorRange, reversed, steps, onSelectColorRange]\n    );\n    return (\n      <StyledColorRangeSelector>\n        <StyledColorConfig>\n          {(colorRangeConfig.custom ? ['custom'] : Object.keys(colorRangeConfig)).map(key =>\n            CONFIG_SETTINGS[key] ? (\n              <PaletteConfig\n                key={key}\n                prop={key}\n                label={CONFIG_SETTINGS[key].label || key}\n                config={CONFIG_SETTINGS[key]}\n                value={colorRangeConfig[key]}\n                onChange={_updateConfig}\n                disabled={\n                  CONFIG_SETTINGS[key].disabled\n                    ? CONFIG_SETTINGS[key].disabled(selectedColorRange)\n                    : false\n                }\n                reason={CONFIG_SETTINGS[key].reason}\n              />\n            ) : null\n          )}\n        </StyledColorConfig>\n        {colorRangeConfig.custom ? (\n          <>\n            <StyledColorPalette>\n              <ColorPalettePanel colors={customPalette.colors} />\n            </StyledColorPalette>\n            <CustomPalette\n              customPalette={customPalette}\n              showSketcher={showSketcher}\n              onApply={_onApply}\n              setColorPaletteUI={setColorPaletteUI}\n              onCancel={_onCustomPaletteCancel}\n            />\n          </>\n        ) : (\n          <div className=\"color-palette__group\">\n            {filteredColorPalettes.map((colorPalette, i) => (\n              <ColorPaletteItem\n                key={`${colorPalette.name}-${i}`}\n                colorPalette={colorPalette}\n                selectedColorRange={selectedColorRange}\n                onSelect={_onSelectPalette}\n                reversed={reversed}\n                steps={steps}\n              />\n            ))}\n          </div>\n        )}\n      </StyledColorRangeSelector>\n    );\n  };\n\n  return ColorRangeSelector;\n}\n\nexport const PaletteConfig: React.FC<PaletteConfigProps> = ({\n  prop,\n  label,\n  value,\n  config: {type, options},\n  onChange,\n  disabled,\n  reason\n}) => {\n  const updateSelect = useCallback(val => onChange({key: prop, value: val}), [onChange, prop]);\n  const updateSwitch = useCallback(\n    () => onChange({key: prop, value: !value}),\n    [onChange, prop, value]\n  );\n\n  return (\n    <StyledPaletteConfig className=\"color-palette__config\" onClick={e => e.stopPropagation()}>\n      <div className=\"color-palette__config__label\">\n        <PanelLabel>\n          <FormattedMessage id={`color.${label}`} />\n        </PanelLabel>\n      </div>\n      <div\n        className=\"color-palette__config__select\"\n        data-tip\n        data-for={`color-range-config-${prop}`}\n      >\n        {type === 'select' && (\n          <ItemSelector\n            selectedItems={value}\n            options={options}\n            multiSelect={false}\n            searchable={false}\n            onChange={updateSelect}\n            disabled={disabled}\n            inputTheme=\"secondary\"\n            displayOption={displayOption}\n            getOptionValue={getOptionValue}\n          />\n        )}\n        {type === 'switch' && (\n          <Switch\n            checked={Boolean(value)}\n            id={`${label}-toggle`}\n            onChange={updateSwitch}\n            disabled={disabled}\n            secondary\n          />\n        )}\n        {disabled && reason ? (\n          <Tooltip id={`color-range-config-${prop}`} place=\"right\">\n            <div style={{maxWidth: '214px'}}>\n              <FormattedMessage id={reason} />\n            </div>\n          </Tooltip>\n        ) : null}\n      </div>\n    </StyledPaletteConfig>\n  );\n};\nconst StyledColorRange = styled.div.attrs({\n  className: 'color-palette-outer'\n})`\n  padding: 0 8px;\n  &:hover {\n    background-color: ${props => props.theme.panelBackgroundHover};\n    cursor: pointer;\n  }\n`;\n\ntype ColorPaletteItemProps = {\n  reversed?: boolean;\n  selected?: ColorRange;\n  colorPalette: ColorPalette;\n  selectedColorRange: ColorRange;\n  onSelect: (colorPalette: ColorPalette, e: MouseEvent) => void;\n  steps: number;\n};\n\nexport const ColorPaletteItem: React.FC<ColorPaletteItemProps> = ({\n  colorPalette,\n  steps,\n  selectedColorRange,\n  onSelect,\n  reversed\n}) => {\n  const colors = useMemo(() => colorPalette.colors(steps), [colorPalette, steps]);\n  const onClick = useCallback(e => onSelect(colorPalette, e), [colorPalette, onSelect]);\n  return (\n    <StyledColorRange onClick={onClick}>\n      <ColorPalettePanel\n        colors={colors}\n        isReversed={reversed}\n        isSelected={colorPalette.name === selectedColorRange.name}\n      />\n    </StyledColorRange>\n  );\n};\n\nexport default ColorRangeSelectorFactory;\n"],"mappings":"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","ignoreList":[]}