kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
236 lines (232 loc) • 42.4 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"] = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
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 _utils = require("@kepler.gl/utils");
var _colorBreaksPanel = _interopRequireDefault(require("./color-breaks-panel"));
var _dropdownSelect = _interopRequireDefault(require("../../common/item-selector/dropdown-select"));
var _accessor = _interopRequireDefault(require("../../common/item-selector/accessor"));
var _dropdownList = _interopRequireDefault(require("../../common/item-selector/dropdown-list"));
var _lazyTippy = _interopRequireDefault(require("../../map/lazy-tippy"));
var _typeahead = _interopRequireDefault(require("../../common/item-selector/typeahead"));
var _excluded = ["layer", "field", "dataset", "onSelect", "scaleType", "domain", "aggregatedBins", "range", "setColorUI", "colorUIConfig", "channelKey"],
_excluded2 = ["colorMap"];
var _templateObject, _templateObject2, _templateObject3, _templateObject4; // 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; }
// 'tippy-js'
var HISTOGRAM_BINS = 30;
var DropdownPropContext = /*#__PURE__*/_react["default"].createContext({});
var POPPER_OPTIONS = {
modifiers: [
// zero offsets since they are already added in VerticalToolbar
{
name: 'offset',
options: {
offset: [0, 0]
}
}]
};
var DropdownBottom = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n border-top: 1px solid\n ", ";\n"])), function (props) {
return props.light ? props.theme.dropdownListBorderTopLT : props.theme.dropdownListBorderTop;
});
var StyledScaleSelectDropdown = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n box-shadow: ", ";\n .list-selector {\n box-shadow: none;\n border-top: 0;\n }\n .list__item {\n padding: 4px 9px;\n }\n"])), function (props) {
return props.theme.dropdownListShadow;
});
var DropdownWrapper = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n border: 0;\n width: 100%;\n left: 0;\n z-index: ", ";\n position: absolute;\n margin-top: ", "px;\n"])), function (props) {
return props.theme.dropdownWrapperZ;
}, function (props) {
return props.theme.dropdownWapperMargin;
});
var StyledColorScaleSelector = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n position: relative;\n .typeahead {\n // adds padding to bottom of dropdown\n margin-bottom: 40px;\n }\n [data-tippy-root] {\n width: 100%;\n }\n"])));
function hideTippy(tippyInstance) {
if (tippyInstance) {
tippyInstance.hide();
}
}
ColorScaleSelectorFactory.deps = [_colorBreaksPanel["default"]];
function ColorScaleSelectorFactory(ColorBreaksPanel) {
var ColorScaleSelectDropdown = function ColorScaleSelectDropdown(props) {
return /*#__PURE__*/_react["default"].createElement(StyledScaleSelectDropdown, null, /*#__PURE__*/_react["default"].createElement(_dropdownList["default"], props), /*#__PURE__*/_react["default"].createElement(DropdownPropContext.Consumer, null, function (context) {
return /*#__PURE__*/_react["default"].createElement(DropdownBottom, null, /*#__PURE__*/_react["default"].createElement(ColorBreaksPanel, context));
}));
};
var ColorScaleSelector = function ColorScaleSelector(_ref) {
var _colorUIConfig$colorR, _field$filterProps;
var layer = _ref.layer,
field = _ref.field,
dataset = _ref.dataset,
onSelect = _ref.onSelect,
scaleType = _ref.scaleType,
domain = _ref.domain,
aggregatedBins = _ref.aggregatedBins,
range = _ref.range,
setColorUI = _ref.setColorUI,
colorUIConfig = _ref.colorUIConfig,
channelKey = _ref.channelKey,
dropdownSelectProps = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
var displayOption = _accessor["default"].generateOptionToStringFor(dropdownSelectProps.displayOption);
var getOptionValue = (0, _react.useMemo)(function () {
return _accessor["default"].generateOptionToStringFor(dropdownSelectProps.getOptionValue);
}, [dropdownSelectProps.getOptionValue]);
var _useState = (0, _react.useState)(),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
tippyInstance = _useState2[0],
setTippyInstance = _useState2[1];
var isEditingColorBreaks = colorUIConfig === null || colorUIConfig === void 0 || (_colorUIConfig$colorR = colorUIConfig.colorRangeConfig) === null || _colorUIConfig$colorR === void 0 ? void 0 : _colorUIConfig$colorR.customBreaks;
var colorScale = (0, _react.useMemo)(function () {
return (0, _utils.getLayerColorScale)({
range: range,
domain: domain,
scaleType: scaleType,
layer: layer
});
}, [range, domain, scaleType, layer]);
var colorBreaks = (0, _react.useMemo)(function () {
var _field$type;
return colorScale ? (0, _utils.getLegendOfScale)({
scale: colorScale.byZoom && domain ? colorScale((domain === null || domain === void 0 ? void 0 : domain.length) - 1) : colorScale,
scaleType: scaleType,
fieldType: (_field$type = field === null || field === void 0 ? void 0 : field.type) !== null && _field$type !== void 0 ? _field$type : _constants.ALL_FIELD_TYPES.real
}) : null;
}, [colorScale, scaleType, field === null || field === void 0 ? void 0 : field.type, domain]);
var columnStats = field === null || field === void 0 || (_field$filterProps = field.filterProps) === null || _field$filterProps === void 0 ? void 0 : _field$filterProps.columnStats;
var fieldValueAccessor = (0, _react.useMemo)(function () {
return field ? function (idx) {
return dataset.getValue(field.name, idx);
} : function (idx) {
return dataset.dataContainer.rowAsArray(idx);
};
}, [dataset, field]);
// aggregatedBins should be the raw data
var allBins = (0, _react.useMemo)(function () {
if (aggregatedBins) {
return (0, _utils.histogramFromValues)(Object.values(aggregatedBins).map(function (bin) {
return bin.i;
}), HISTOGRAM_BINS, function (idx) {
return aggregatedBins[idx].value;
});
}
return columnStats !== null && columnStats !== void 0 && columnStats.bins ? columnStats === null || columnStats === void 0 ? void 0 : columnStats.bins : (0, _utils.histogramFromValues)(dataset.allIndexes, HISTOGRAM_BINS, fieldValueAccessor);
}, [aggregatedBins, columnStats, dataset, fieldValueAccessor]);
var histogramDomain = (0, _react.useMemo)(function () {
return (0, _utils.getHistogramDomain)({
aggregatedBins: aggregatedBins,
columnStats: columnStats,
dataset: dataset,
fieldValueAccessor: fieldValueAccessor
});
}, [dataset, fieldValueAccessor, aggregatedBins, columnStats]);
var ordinalDomain = (0, _react.useMemo)(function () {
return layer.config[layer.visualChannels[channelKey].domain] || [];
}, [channelKey, layer.config, layer.visualChannels]);
var isFiltered = aggregatedBins ? false : dataset.filteredIndexForDomain.length !== dataset.allIndexes.length;
// get filteredBins (not apply to aggregate layer)
var filteredBins = (0, _react.useMemo)(function () {
if (!isFiltered) {
return allBins;
}
// get threholds
var filterEmptyBins = false;
var threholds = allBins.map(function (b) {
return b.x0;
});
return (0, _utils.histogramFromThreshold)(threholds, dataset.filteredIndexForDomain, fieldValueAccessor, filterEmptyBins);
}, [dataset, fieldValueAccessor, allBins, isFiltered]);
var onSelectScale = (0, _react.useCallback)(function (val) {
// highlight selected option
if (!val || isEditingColorBreaks) return;
var selectedScale = getOptionValue(val);
if (selectedScale === _constants.SCALE_TYPES.custom) {
var customPalette = (0, _utils.initCustomPaletteByCustomScale)({
scale: selectedScale,
field: field,
range: range,
colorBreaks: colorBreaks
});
setColorUI({
showColorChart: true,
colorRangeConfig: {
customBreaks: true
},
customPalette: customPalette
});
onSelect(selectedScale, customPalette);
} else if ((0, _utils.hasColorMap)(range) && selectedScale !== _constants.SCALE_TYPES.customOrdinal) {
// not custom
// remove colorMap
// eslint-disable-next-line no-unused-vars
var _ = range.colorMap,
newRange = (0, _objectWithoutProperties2["default"])(range, _excluded2);
onSelect(selectedScale, newRange);
} else {
onSelect(selectedScale);
}
}, [isEditingColorBreaks, field, setColorUI, onSelect, range, getOptionValue, colorBreaks]);
var onApply = (0, _react.useCallback)(function () {
onSelect(scaleType, colorUIConfig.customPalette);
hideTippy(tippyInstance);
}, [onSelect, colorUIConfig.customPalette, tippyInstance, scaleType]);
var onCancel = (0, _react.useCallback)(function () {
hideTippy(tippyInstance);
}, [tippyInstance]);
var isCustomBreaks = scaleType === _constants.SCALE_TYPES.custom || scaleType === _constants.SCALE_TYPES.customOrdinal;
return /*#__PURE__*/_react["default"].createElement(DropdownPropContext.Provider, {
value: {
setColorUI: setColorUI,
colorField: field,
dataset: dataset,
colorUIConfig: colorUIConfig,
colorBreaks: colorBreaks,
isCustomBreaks: isCustomBreaks,
allBins: allBins,
filteredBins: filteredBins,
isFiltered: isFiltered,
histogramDomain: histogramDomain,
ordinalDomain: ordinalDomain,
onScaleChange: onSelect,
onApply: onApply,
onCancel: onCancel
}
}, /*#__PURE__*/_react["default"].createElement(StyledColorScaleSelector, null, /*#__PURE__*/_react["default"].createElement(_lazyTippy["default"], {
trigger: "click",
placement: "bottom-start",
appendTo: "parent",
interactive: true,
hideOnClick: !isEditingColorBreaks,
onCreate: setTippyInstance,
popperOptions: POPPER_OPTIONS,
render: function render(attrs) {
return /*#__PURE__*/_react["default"].createElement(DropdownWrapper, attrs, !dropdownSelectProps.disabled && /*#__PURE__*/_react["default"].createElement(_typeahead["default"], (0, _extends2["default"])({}, dropdownSelectProps, {
displayOption: displayOption
// @ts-ignore
,
getOptionValue: getOptionValue,
onOptionSelected: onSelectScale,
customListComponent: ColorScaleSelectDropdown,
searchable: false,
showOptionsWhenEmpty: true
})));
}
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "dropdown-select"
}, /*#__PURE__*/_react["default"].createElement(_dropdownSelect["default"], (0, _extends2["default"])({}, dropdownSelectProps, {
displayOption: displayOption,
value: dropdownSelectProps.selectedItems[0]
}))))));
};
return ColorScaleSelector;
}
var _default = exports["default"] = ColorScaleSelectorFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_constants","_utils","_colorBreaksPanel","_dropdownSelect","_accessor","_dropdownList","_lazyTippy","_typeahead","_excluded","_excluded2","_templateObject","_templateObject2","_templateObject3","_templateObject4","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","HISTOGRAM_BINS","DropdownPropContext","React","createContext","POPPER_OPTIONS","modifiers","name","options","offset","DropdownBottom","styled","div","_taggedTemplateLiteral2","props","light","theme","dropdownListBorderTopLT","dropdownListBorderTop","StyledScaleSelectDropdown","dropdownListShadow","DropdownWrapper","dropdownWrapperZ","dropdownWapperMargin","StyledColorScaleSelector","hideTippy","tippyInstance","hide","ColorScaleSelectorFactory","deps","ColorBreaksPanelFactory","ColorBreaksPanel","ColorScaleSelectDropdown","createElement","Consumer","context","ColorScaleSelector","_ref","_colorUIConfig$colorR","_field$filterProps","layer","field","dataset","onSelect","scaleType","domain","aggregatedBins","range","setColorUI","colorUIConfig","channelKey","dropdownSelectProps","_objectWithoutProperties2","displayOption","Accessor","generateOptionToStringFor","getOptionValue","useMemo","_useState","useState","_useState2","_slicedToArray2","setTippyInstance","isEditingColorBreaks","colorRangeConfig","customBreaks","colorScale","getLayerColorScale","colorBreaks","_field$type","getLegendOfScale","scale","byZoom","length","fieldType","type","ALL_FIELD_TYPES","real","columnStats","filterProps","fieldValueAccessor","idx","getValue","dataContainer","rowAsArray","allBins","histogramFromValues","values","map","bin","value","bins","allIndexes","histogramDomain","getHistogramDomain","ordinalDomain","config","visualChannels","isFiltered","filteredIndexForDomain","filteredBins","filterEmptyBins","threholds","b","x0","histogramFromThreshold","onSelectScale","useCallback","val","selectedScale","SCALE_TYPES","custom","customPalette","initCustomPaletteByCustomScale","showColorChart","hasColorMap","customOrdinal","_","colorMap","newRange","onApply","onCancel","isCustomBreaks","Provider","colorField","onScaleChange","trigger","placement","appendTo","interactive","hideOnClick","onCreate","popperOptions","render","attrs","disabled","_extends2","onOptionSelected","customListComponent","searchable","showOptionsWhenEmpty","className","selectedItems","_default","exports"],"sources":["../../../src/side-panel/layer-panel/color-scale-selector.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo, useState} from 'react';\nimport styled from 'styled-components';\n\nimport {ALL_FIELD_TYPES, SCALE_TYPES} from '@kepler.gl/constants';\nimport {AggregatedBin, Layer, VisualChannelDomain} from '@kepler.gl/layers';\nimport {KeplerTable} from '@kepler.gl/table';\nimport {ColorRange, ColorUI, Field} from '@kepler.gl/types';\nimport {\n  getLayerColorScale,\n  getLegendOfScale,\n  initCustomPaletteByCustomScale,\n  histogramFromValues,\n  histogramFromThreshold,\n  getHistogramDomain,\n  hasColorMap\n} from '@kepler.gl/utils';\n\nimport ColorBreaksPanelFactory, {ColorBreaksPanelProps} from './color-breaks-panel';\nimport {SetColorUIFunc} from './custom-palette';\nimport DropdownSelect from '../../common/item-selector/dropdown-select';\nimport Accessor from '../../common/item-selector/accessor';\nimport DropdownList from '../../common/item-selector/dropdown-list';\nimport LazyTippy from '../../map/lazy-tippy';\nimport Typeahead from '../../common/item-selector/typeahead';\n\ntype TippyInstance = any; // 'tippy-js'\n\nconst HISTOGRAM_BINS = 30;\n\nexport type ScaleOption = {\n  label: string;\n  value: string;\n};\nexport type OnSelectFunc = (v: string, visConfg?: Record<string, any>) => void;\n\nexport type ContextProps = ColorBreaksPanelProps;\n\nexport type ColorScaleSelectorProps = {\n  layer: Layer;\n  field: Field;\n  dataset: KeplerTable;\n  scaleType: string;\n  domain: VisualChannelDomain;\n  range: ColorRange;\n  onSelect: OnSelectFunc;\n  setColorUI: SetColorUIFunc;\n  colorUIConfig: ColorUI;\n  options: ScaleOption[];\n  disabled?: boolean;\n  selectedItems: ScaleOption[];\n  multiSelect: boolean;\n  searchable: boolean;\n  displayOption: string;\n  getOptionValue: string;\n  aggregatedBins?: AggregatedBin[];\n  channelKey: string;\n};\n\nconst DropdownPropContext = React.createContext({});\nconst POPPER_OPTIONS = {\n  modifiers: [\n    // zero offsets since they are already added in VerticalToolbar\n    {name: 'offset', options: {offset: [0, 0]}}\n  ]\n};\n\nconst DropdownBottom = styled.div<{light?: boolean}>`\n  border-top: 1px solid\n    ${props =>\n      props.light ? props.theme.dropdownListBorderTopLT : props.theme.dropdownListBorderTop};\n`;\n\nconst StyledScaleSelectDropdown = styled.div`\n  box-shadow: ${props => props.theme.dropdownListShadow};\n  .list-selector {\n    box-shadow: none;\n    border-top: 0;\n  }\n  .list__item {\n    padding: 4px 9px;\n  }\n`;\nconst DropdownWrapper = styled.div`\n  border: 0;\n  width: 100%;\n  left: 0;\n  z-index: ${props => props.theme.dropdownWrapperZ};\n  position: absolute;\n  margin-top: ${props => props.theme.dropdownWapperMargin}px;\n`;\n\nconst StyledColorScaleSelector = styled.div`\n  position: relative;\n  .typeahead {\n    // adds padding to bottom of dropdown\n    margin-bottom: 40px;\n  }\n  [data-tippy-root] {\n    width: 100%;\n  }\n`;\n\nfunction hideTippy(tippyInstance) {\n  if (tippyInstance) {\n    tippyInstance.hide();\n  }\n}\nColorScaleSelectorFactory.deps = [ColorBreaksPanelFactory];\n\nfunction ColorScaleSelectorFactory(\n  ColorBreaksPanel: ReturnType<typeof ColorBreaksPanelFactory>\n): React.FC<ColorScaleSelectorProps> {\n  const ColorScaleSelectDropdown = props => (\n    <StyledScaleSelectDropdown>\n      <DropdownList {...props} />\n      <DropdownPropContext.Consumer>\n        {(context: any) => (\n          <DropdownBottom>\n            <ColorBreaksPanel {...context} />\n          </DropdownBottom>\n        )}\n      </DropdownPropContext.Consumer>\n    </StyledScaleSelectDropdown>\n  );\n\n  const ColorScaleSelector: React.FC<ColorScaleSelectorProps> = ({\n    layer,\n    field,\n    dataset,\n    onSelect,\n    scaleType,\n    domain,\n    aggregatedBins,\n    range,\n    setColorUI,\n    colorUIConfig,\n    channelKey,\n    ...dropdownSelectProps\n  }) => {\n    const displayOption = Accessor.generateOptionToStringFor(dropdownSelectProps.displayOption);\n    const getOptionValue = useMemo(\n      () => Accessor.generateOptionToStringFor(dropdownSelectProps.getOptionValue),\n      [dropdownSelectProps.getOptionValue]\n    );\n    const [tippyInstance, setTippyInstance] = useState<TippyInstance>();\n    const isEditingColorBreaks = colorUIConfig?.colorRangeConfig?.customBreaks;\n    const colorScale = useMemo(\n      () =>\n        getLayerColorScale({\n          range,\n          domain,\n          scaleType,\n          layer\n        }),\n      [range, domain, scaleType, layer]\n    );\n\n    const colorBreaks = useMemo(() => {\n      return colorScale\n        ? getLegendOfScale({\n            scale: colorScale.byZoom && domain ? colorScale(domain?.length - 1) : colorScale,\n            scaleType,\n            fieldType: field?.type ?? ALL_FIELD_TYPES.real\n          })\n        : null;\n    }, [colorScale, scaleType, field?.type, domain]);\n\n    const columnStats = field?.filterProps?.columnStats;\n\n    const fieldValueAccessor = useMemo(() => {\n      return field\n        ? idx => dataset.getValue(field.name, idx)\n        : idx => dataset.dataContainer.rowAsArray(idx);\n    }, [dataset, field]);\n\n    // aggregatedBins should be the raw data\n    const allBins = useMemo(() => {\n      if (aggregatedBins) {\n        return histogramFromValues(\n          Object.values(aggregatedBins).map(bin => bin.i),\n          HISTOGRAM_BINS,\n          idx => aggregatedBins[idx].value\n        );\n      }\n      return columnStats?.bins\n        ? columnStats?.bins\n        : histogramFromValues(dataset.allIndexes, HISTOGRAM_BINS, fieldValueAccessor);\n    }, [aggregatedBins, columnStats, dataset, fieldValueAccessor]);\n\n    const histogramDomain = useMemo(() => {\n      return getHistogramDomain({aggregatedBins, columnStats, dataset, fieldValueAccessor});\n    }, [dataset, fieldValueAccessor, aggregatedBins, columnStats]);\n\n    const ordinalDomain = useMemo(() => {\n      return layer.config[layer.visualChannels[channelKey].domain] || [];\n    }, [channelKey, layer.config, layer.visualChannels]);\n\n    const isFiltered = aggregatedBins\n      ? false\n      : dataset.filteredIndexForDomain.length !== dataset.allIndexes.length;\n\n    // get filteredBins (not apply to aggregate layer)\n    const filteredBins = useMemo(() => {\n      if (!isFiltered) {\n        return allBins;\n      }\n      // get threholds\n      const filterEmptyBins = false;\n      const threholds = allBins.map(b => b.x0);\n      return histogramFromThreshold(\n        threholds,\n        dataset.filteredIndexForDomain,\n        fieldValueAccessor,\n        filterEmptyBins\n      );\n    }, [dataset, fieldValueAccessor, allBins, isFiltered]);\n\n    const onSelectScale = useCallback(\n      val => {\n        // highlight selected option\n        if (!val || isEditingColorBreaks) return;\n        const selectedScale = getOptionValue(val);\n        if (selectedScale === SCALE_TYPES.custom) {\n          const customPalette = initCustomPaletteByCustomScale({\n            scale: selectedScale,\n            field,\n            range,\n            colorBreaks\n          });\n          setColorUI({\n            showColorChart: true,\n            colorRangeConfig: {\n              customBreaks: true\n            },\n            customPalette\n          });\n          onSelect(selectedScale, customPalette);\n        } else if (hasColorMap(range) && selectedScale !== SCALE_TYPES.customOrdinal) {\n          // not custom\n          // remove colorMap\n          // eslint-disable-next-line no-unused-vars\n          const {colorMap: _, ...newRange} = range;\n          onSelect(selectedScale, newRange);\n        } else {\n          onSelect(selectedScale);\n        }\n      },\n      [isEditingColorBreaks, field, setColorUI, onSelect, range, getOptionValue, colorBreaks]\n    );\n\n    const onApply = useCallback(() => {\n      onSelect(scaleType, colorUIConfig.customPalette);\n      hideTippy(tippyInstance);\n    }, [onSelect, colorUIConfig.customPalette, tippyInstance, scaleType]);\n\n    const onCancel = useCallback(() => {\n      hideTippy(tippyInstance);\n    }, [tippyInstance]);\n\n    const isCustomBreaks =\n      scaleType === SCALE_TYPES.custom || scaleType === SCALE_TYPES.customOrdinal;\n\n    return (\n      <DropdownPropContext.Provider\n        value={{\n          setColorUI,\n          colorField: field,\n          dataset,\n          colorUIConfig,\n          colorBreaks,\n          isCustomBreaks,\n          allBins,\n          filteredBins,\n          isFiltered,\n          histogramDomain,\n          ordinalDomain,\n          onScaleChange: onSelect,\n          onApply,\n          onCancel\n        }}\n      >\n        <StyledColorScaleSelector>\n          <LazyTippy\n            trigger=\"click\"\n            placement=\"bottom-start\"\n            appendTo=\"parent\"\n            interactive={true}\n            hideOnClick={!isEditingColorBreaks}\n            onCreate={setTippyInstance}\n            popperOptions={POPPER_OPTIONS}\n            render={attrs => (\n              <DropdownWrapper {...attrs}>\n                {/* @ts-ignore*/}\n                {!dropdownSelectProps.disabled && (\n                  <Typeahead\n                    {...dropdownSelectProps}\n                    displayOption={displayOption}\n                    // @ts-ignore\n                    getOptionValue={getOptionValue}\n                    onOptionSelected={onSelectScale}\n                    customListComponent={ColorScaleSelectDropdown}\n                    searchable={false}\n                    showOptionsWhenEmpty\n                  />\n                )}\n              </DropdownWrapper>\n            )}\n          >\n            <div className=\"dropdown-select\">\n              {/* @ts-ignore*/}\n              <DropdownSelect\n                {...dropdownSelectProps}\n                displayOption={displayOption}\n                value={dropdownSelectProps.selectedItems[0]}\n              />\n            </div>\n          </LazyTippy>\n        </StyledColorScaleSelector>\n      </DropdownPropContext.Provider>\n    );\n  };\n  return ColorScaleSelector;\n}\nexport default ColorScaleSelectorFactory;\n"],"mappings":"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","ignoreList":[]}