UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

273 lines (272 loc) 45.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.LegendColorDisplayFactory = LegendColorDisplayFactory; exports.LegendRowEditorFactory = LegendRowEditorFactory; exports.LegendRowFactory = LegendRowFactory; exports.ResetColorLabelFactory = ResetColorLabelFactory; exports["default"] = void 0; exports.useLayerColorLegends = useLayerColorLegends; var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireWildcard(require("styled-components")); var _constants = require("@kepler.gl/constants"); var _utils = require("@kepler.gl/utils"); var _icons = require("./icons"); var _styledComponents2 = require("./styled-components"); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6; // 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; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } var ROW_H = 15; var GAP = 2; var RECT_W = 20; var stopClickPropagation = function stopClickPropagation(e) { return e.stopPropagation(); }; var inputCss = (0, _styledComponents.css)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n input {\n pointer-events: none;\n }\n"]))); var StyledLegend = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n ", ";\n overflow: auto;\n margin-bottom: ", "px;\n display: grid;\n grid-row-gap: ", "px;\n padding: 2px 0;\n\n ", "\n"])), function (props) { return props.theme.sidePanelScrollBar; }, function (props) { return props.isExpanded ? '' : "max-height: 156px;"; }, GAP, GAP, function (props) { return props.disableEdit ? inputCss : ''; }); var StyledLegendRow = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n height: 20px;\n"]))); function ResetColorLabelFactory() { return (0, _styledComponents["default"])(_icons.Reset)(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n cursor: pointer;\n\n &:hover {\n color: ", ";\n }\n "])), function (props) { return props.theme.labelColorLT; }, function (props) { return props.theme.panelHeaderIconHover; }); } var StyleInlineInput = (0, _styledComponents["default"])(_styledComponents2.InlineInput)(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 9.5px;\n line-height: ", "px;\n height: ", "px;\n color: ", ";\n width: unset;\n padding: 2px;\n flex: 1;\n margin: 0 ", "px;\n :hover {\n height: ", "px;\n }\n"])), ROW_H, ROW_H, function (props) { return props.theme.textColor; }, GAP, ROW_H); function LegendRowEditorFactory() { var LegendRowEditor = function LegendRowEditor(_ref) { var color = _ref.color, label = _ref.label, onEdit = _ref.onEdit, _ref$disabled = _ref.disabled, disabled = _ref$disabled === void 0 ? false : _ref$disabled; var onChange = (0, _react.useCallback)(function (event) { return onEdit(event.target.value); }, [onEdit]); return /*#__PURE__*/_react["default"].createElement(StyleInlineInput, { type: "text", className: "legend__label__title__editor", value: label, onClick: stopClickPropagation, onChange: onChange, disabled: disabled, id: "".concat(color, ":input-legend-label") }); }; LegendRowEditor.displayName = 'LegendRowEditor'; return LegendRowEditor; } var LegendRowStyle = { width: "".concat(RECT_W, "px"), height: "".concat(ROW_H, "px") }; function LegendColorDisplayFactory() { var LegendColorDisplay = function LegendColorDisplay(_ref2) { var color = _ref2.color; var style = (0, _react.useMemo)(function () { return _objectSpread(_objectSpread({}, LegendRowStyle), {}, { backgroundColor: color, marginRight: "".concat(GAP, "px") }); }, [color]); return /*#__PURE__*/_react["default"].createElement("div", { style: style, className: "legend-row-color" }); }; return LegendColorDisplay; } var StyledLabel = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 10px;\n color: ", ";\n padding-left: 2px;\n"])), function (props) { return props.theme.textColor; }); LegendRowFactory.deps = [LegendColorDisplayFactory, LegendRowEditorFactory, ResetColorLabelFactory]; function LegendRowFactory(LegendColorDisplay, LegendRowEditor, ResetColorLabel) { var LegendRow = function LegendRow(_ref3) { var _ref3$label = _ref3.label, label = _ref3$label === void 0 ? '' : _ref3$label, displayLabel = _ref3.displayLabel, color = _ref3.color, onUpdateLabel = _ref3.onUpdateLabel, onResetLabel = _ref3.onResetLabel; var onEdit = (0, _react.useCallback)(function (newLabel) { return onUpdateLabel && onUpdateLabel(color, newLabel); }, [color, onUpdateLabel]); var onReset = (0, _react.useCallback)(function () { return onResetLabel && onResetLabel(color); }, [color, onResetLabel]); var value = displayLabel ? label.toString() : ''; return /*#__PURE__*/_react["default"].createElement(StyledLegendRow, null, /*#__PURE__*/_react["default"].createElement(LegendColorDisplay, { color: color }), onUpdateLabel ? /*#__PURE__*/_react["default"].createElement(LegendRowEditor, { disabled: !onUpdateLabel, label: value, color: color, onEdit: onEdit }) : /*#__PURE__*/_react["default"].createElement(StyledLabel, null, value), onResetLabel ? /*#__PURE__*/_react["default"].createElement(ResetColorLabel, { onClick: onReset, height: "16px" }) : null); }; LegendRow.displayName = 'LegendRow'; return LegendRow; } var overrideColorLegends = function overrideColorLegends(colorLegends, overrides) { var data = overrides.data, labels = overrides.labels; var newColorLegends = (0, _toConsumableArray2["default"])(colorLegends); data.forEach(function (datum, index) { var currentIndex = colorLegends.findIndex(function (d) { return d.data === datum; }); if (currentIndex !== -1) { newColorLegends[currentIndex] = { label: labels[index], data: datum, override: true }; newColorLegends[currentIndex].label = labels[index]; } else { newColorLegends.push({ data: datum, label: labels[index], override: true }); } }); return newColorLegends; }; /** * Overrides legend labels with color legends. * @param param0 Legend info and override parameters. * @returns Original or overriden lenends. */ function overrideByCustomLegend(_ref4) { var colorLegends = _ref4.colorLegends, currentLegends = _ref4.currentLegends; if (colorLegends && (0, _utils.isObject)(colorLegends)) { // override labels with color legends var data = Object.keys(colorLegends); var labels = Object.values(colorLegends); return overrideColorLegends(currentLegends, { data: data, labels: labels }); } return currentLegends; } function useLayerColorLegends(layer, scaleType, domain, range, isFixed, fieldType, labelFormat, mapState) { var scale = (0, _react.useMemo)(function () { return (0, _utils.getLayerColorScale)({ range: range, domain: domain, scaleType: scaleType, isFixed: isFixed, layer: layer }); }, [range, domain, scaleType, isFixed, layer]); var scaleByZoom = (0, _react.useMemo)(function () { return (0, _utils.getVisualChannelScaleByZoom)({ scale: scale, layer: layer, mapState: mapState }); }, [scale, layer, mapState]); var currentLegends = (0, _react.useMemo)(function () { if (scaleType === _constants.SCALE_TYPES.customOrdinal && range !== null && range !== void 0 && range.colorMap) { var colorBreaks = (0, _utils.colorMapToCategoricalColorBreaks)(range.colorMap); return colorBreaks === null || colorBreaks === void 0 ? void 0 : colorBreaks.map(function (cb) { return { data: cb.data, label: Array.isArray(cb.label) ? cb.label.length > 5 ? "".concat(cb.label.length, " selected") : cb.label : cb.label || '' }; }); } return (0, _utils.getLegendOfScale)({ scale: scaleByZoom, scaleType: scaleType, labelFormat: labelFormat, fieldType: fieldType }); }, [range, scaleByZoom, scaleType, labelFormat, fieldType]); var LegendsWithCustomLegends = (0, _react.useMemo)(function () { return overrideByCustomLegend({ colorLegends: range === null || range === void 0 ? void 0 : range.colorLegends, currentLegends: currentLegends }); }, [range === null || range === void 0 ? void 0 : range.colorLegends, currentLegends]); return LegendsWithCustomLegends || []; } ColorLegendFactory.deps = [LegendRowFactory]; function ColorLegendFactory(LegendRow) { var ColorLegend = function ColorLegend(_ref5) { var layer = _ref5.layer, isFixed = _ref5.isFixed, isExpanded = _ref5.isExpanded, domain = _ref5.domain, range = _ref5.range, labelFormat = _ref5.labelFormat, scaleType = _ref5.scaleType, fieldType = _ref5.fieldType, mapState = _ref5.mapState, onUpdateColorLegend = _ref5.onUpdateColorLegend, _ref5$displayLabel = _ref5.displayLabel, displayLabel = _ref5$displayLabel === void 0 ? true : _ref5$displayLabel, _ref5$disableEdit = _ref5.disableEdit, disableEdit = _ref5$disableEdit === void 0 ? false : _ref5$disableEdit; var _ref6 = range || {}, colorLegends = _ref6.colorLegends; var legends = useLayerColorLegends(layer, scaleType, domain, range, isFixed, fieldType, labelFormat, mapState); var onUpdateLabel = (0, _react.useCallback)(function (color, newValue) { if (onUpdateColorLegend) { onUpdateColorLegend(_objectSpread(_objectSpread({}, colorLegends), {}, (0, _defineProperty2["default"])({}, color, newValue))); } }, [onUpdateColorLegend, colorLegends]); var onResetLabel = (0, _react.useCallback)(function (color) { /* eslint-disable no-unused-vars */ // @ts-ignore var _ = colorLegends[color], rest = (0, _objectWithoutProperties2["default"])(colorLegends, [color].map(_toPropertyKey)); if (onUpdateColorLegend && rest) { onUpdateColorLegend(rest); } /* eslint-enable no-unused-vars */ }, [onUpdateColorLegend, colorLegends]); return /*#__PURE__*/_react["default"].createElement(StyledLegend, { className: "styled-color-legend", disableEdit: disableEdit, isExpanded: isExpanded }, legends.map(function (legend, i) { return /*#__PURE__*/_react["default"].createElement(LegendRow, { key: "".concat(legend.data, "-").concat(i), label: legend.label, displayLabel: displayLabel, color: legend.data, onUpdateLabel: !disableEdit ? onUpdateLabel : undefined, onResetLabel: legend.override && !disableEdit ? onResetLabel : undefined }); })); }; return /*#__PURE__*/_react["default"].memo(ColorLegend); } var _default = exports["default"] = ColorLegendFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_constants","_utils","_icons","_styledComponents2","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","_toPropertyKey","_toPrimitive","Symbol","toPrimitive","TypeError","String","Number","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","ROW_H","GAP","RECT_W","stopClickPropagation","stopPropagation","inputCss","css","_taggedTemplateLiteral2","StyledLegend","styled","div","props","theme","sidePanelScrollBar","isExpanded","disableEdit","StyledLegendRow","ResetColorLabelFactory","Reset","labelColorLT","panelHeaderIconHover","StyleInlineInput","InlineInput","textColor","LegendRowEditorFactory","LegendRowEditor","_ref","color","label","onEdit","_ref$disabled","disabled","onChange","useCallback","event","target","value","createElement","type","className","onClick","id","concat","displayName","LegendRowStyle","width","height","LegendColorDisplayFactory","LegendColorDisplay","_ref2","style","useMemo","backgroundColor","marginRight","StyledLabel","LegendRowFactory","deps","ResetColorLabel","LegendRow","_ref3","_ref3$label","displayLabel","onUpdateLabel","onResetLabel","newLabel","onReset","toString","overrideColorLegends","colorLegends","overrides","data","labels","newColorLegends","_toConsumableArray2","datum","index","currentIndex","findIndex","d","override","overrideByCustomLegend","_ref4","currentLegends","isObject","values","useLayerColorLegends","layer","scaleType","domain","range","isFixed","fieldType","labelFormat","mapState","scale","getLayerColorScale","scaleByZoom","getVisualChannelScaleByZoom","SCALE_TYPES","customOrdinal","colorMap","colorBreaks","colorMapToCategoricalColorBreaks","map","cb","Array","isArray","getLegendOfScale","LegendsWithCustomLegends","ColorLegendFactory","ColorLegend","_ref5","onUpdateColorLegend","_ref5$displayLabel","_ref5$disableEdit","_ref6","legends","newValue","_","rest","_objectWithoutProperties2","legend","key","undefined","React","memo","_default","exports"],"sources":["../../src/common/color-legend.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo} from 'react';\nimport styled, {css} from 'styled-components';\n\nimport {SCALE_TYPES} from '@kepler.gl/constants';\nimport {Layer} from '@kepler.gl/layers';\nimport {ColorRange, HexColor, MapState} from '@kepler.gl/types';\nimport {\n  getLayerColorScale,\n  getLegendOfScale,\n  getVisualChannelScaleByZoom,\n  colorMapToCategoricalColorBreaks,\n  isObject\n} from '@kepler.gl/utils';\n\nimport {Reset} from './icons';\nimport {InlineInput} from './styled-components';\n\nconst ROW_H = 15;\nconst GAP = 2;\nconst RECT_W = 20;\n\nconst stopClickPropagation = e => e.stopPropagation();\n\nconst inputCss = css`\n  input {\n    pointer-events: none;\n  }\n`;\nconst StyledLegend = styled.div<{disableEdit: boolean; isExpanded?: boolean}>`\n  ${props => props.theme.sidePanelScrollBar};\n  ${props => (props.isExpanded ? '' : `max-height: 156px;`)};\n  overflow: auto;\n  margin-bottom: ${GAP}px;\n  display: grid;\n  grid-row-gap: ${GAP}px;\n  padding: 2px 0;\n\n  ${props => (props.disableEdit ? inputCss : '')}\n`;\n\nconst StyledLegendRow = styled.div`\n  display: flex;\n  align-items: center;\n  height: 20px;\n`;\n\nexport function ResetColorLabelFactory() {\n  return styled(Reset)`\n    color: ${props => props.theme.labelColorLT};\n    cursor: pointer;\n\n    &:hover {\n      color: ${props => props.theme.panelHeaderIconHover};\n    }\n  `;\n}\n\nconst StyleInlineInput = styled(InlineInput)`\n  font-size: 9.5px;\n  line-height: ${ROW_H}px;\n  height: ${ROW_H}px;\n  color: ${props => props.theme.textColor};\n  width: unset;\n  padding: 2px;\n  flex: 1;\n  margin: 0 ${GAP}px;\n  :hover {\n    height: ${ROW_H}px;\n  }\n`;\n\nexport type LegendRowEditorProps = {\n  color: string;\n  label: string;\n  customLabel?: string;\n  onEdit: (newValue: string) => void;\n  disabled?: boolean;\n};\nexport function LegendRowEditorFactory() {\n  const LegendRowEditor: React.FC<LegendRowEditorProps> = ({\n    color,\n    label,\n    onEdit,\n    disabled = false\n  }) => {\n    const onChange = useCallback(event => onEdit(event.target.value), [onEdit]);\n    return (\n      <StyleInlineInput\n        type=\"text\"\n        className=\"legend__label__title__editor\"\n        value={label}\n        onClick={stopClickPropagation}\n        onChange={onChange}\n        disabled={disabled}\n        id={`${color}:input-legend-label`}\n      />\n    );\n  };\n\n  LegendRowEditor.displayName = 'LegendRowEditor';\n  return LegendRowEditor;\n}\n\nconst LegendRowStyle = {\n  width: `${RECT_W}px`,\n  height: `${ROW_H}px`\n};\n\nexport function LegendColorDisplayFactory() {\n  const LegendColorDisplay = ({color}) => {\n    const style = useMemo(\n      () => ({...LegendRowStyle, backgroundColor: color, marginRight: `${GAP}px`}),\n      [color]\n    );\n    return <div style={style} className=\"legend-row-color\" />;\n  };\n\n  return LegendColorDisplay;\n}\n\nconst StyledLabel = styled.div`\n  font-size: 10px;\n  color: ${props => props.theme.textColor};\n  padding-left: 2px;\n`;\n\nexport type LegendRowProps = {\n  label: string;\n  customLabel?: string;\n  displayLabel?: boolean;\n  color: string;\n  onUpdateLabel?: (selectedColor: string, newLabel: string) => void;\n  onResetLabel?: (color: string) => void;\n  disableEdit?: boolean;\n};\n\nLegendRowFactory.deps = [LegendColorDisplayFactory, LegendRowEditorFactory, ResetColorLabelFactory];\nexport function LegendRowFactory(\n  LegendColorDisplay: ReturnType<typeof LegendColorDisplayFactory>,\n  LegendRowEditor: ReturnType<typeof LegendRowEditorFactory>,\n  ResetColorLabel: ReturnType<typeof ResetColorLabelFactory>\n) {\n  const LegendRow: React.FC<LegendRowProps> = ({\n    label = '',\n    displayLabel,\n    color,\n    onUpdateLabel,\n    onResetLabel\n  }) => {\n    const onEdit = useCallback(\n      newLabel => onUpdateLabel && onUpdateLabel(color, newLabel),\n      [color, onUpdateLabel]\n    );\n    const onReset = useCallback(() => onResetLabel && onResetLabel(color), [color, onResetLabel]);\n    const value = displayLabel ? label.toString() : '';\n    return (\n      <StyledLegendRow>\n        <LegendColorDisplay color={color} />\n        {onUpdateLabel ? (\n          <LegendRowEditor disabled={!onUpdateLabel} label={value} color={color} onEdit={onEdit} />\n        ) : (\n          <StyledLabel>{value}</StyledLabel>\n        )}\n        {onResetLabel ? <ResetColorLabel onClick={onReset} height=\"16px\" /> : null}\n      </StyledLegendRow>\n    );\n  };\n  LegendRow.displayName = 'LegendRow';\n  return LegendRow;\n}\n\nconst overrideColorLegends = (colorLegends, overrides) => {\n  const {data, labels} = overrides;\n\n  const newColorLegends = [...colorLegends];\n\n  data.forEach((datum, index) => {\n    const currentIndex = colorLegends.findIndex(d => d.data === datum);\n    if (currentIndex !== -1) {\n      newColorLegends[currentIndex] = {\n        label: labels[index],\n        data: datum,\n        override: true\n      };\n      newColorLegends[currentIndex].label = labels[index];\n    } else {\n      newColorLegends.push({\n        data: datum,\n        label: labels[index],\n        override: true\n      });\n    }\n  });\n\n  return newColorLegends;\n};\n\ntype OverrideByCustomLegendOptions = {\n  /**\n   * Legend parameters to override\n   */\n  colorLegends?: Record<string, any>;\n  /**\n   * Original Legends\n   */\n  currentLegends?: ReturnType<typeof getLegendOfScale>;\n};\n\n/**\n * Overrides legend labels with color legends.\n * @param param0 Legend info and override parameters.\n * @returns Original or overriden lenends.\n */\nfunction overrideByCustomLegend({colorLegends, currentLegends}: OverrideByCustomLegendOptions) {\n  if (colorLegends && isObject(colorLegends)) {\n    // override labels with color legends\n    const data = Object.keys(colorLegends);\n    const labels = Object.values(colorLegends);\n\n    return overrideColorLegends(currentLegends, {data, labels});\n  }\n\n  return currentLegends;\n}\n\nexport function useLayerColorLegends(\n  layer: ColorLegendProps['layer'],\n  scaleType: ColorLegendProps['scaleType'],\n  domain: ColorLegendProps['domain'],\n  range: ColorLegendProps['range'],\n  isFixed: ColorLegendProps['isFixed'],\n  fieldType: ColorLegendProps['fieldType'],\n  labelFormat: ColorLegendProps['labelFormat'],\n  mapState: ColorLegendProps['mapState']\n): Legend[] {\n  const scale = useMemo(\n    () => getLayerColorScale({range, domain, scaleType, isFixed, layer}),\n    [range, domain, scaleType, isFixed, layer]\n  );\n\n  const scaleByZoom = useMemo(\n    () => getVisualChannelScaleByZoom({scale, layer, mapState}),\n    [scale, layer, mapState]\n  );\n\n  const currentLegends = useMemo(() => {\n    if (scaleType === SCALE_TYPES.customOrdinal && range?.colorMap) {\n      const colorBreaks = colorMapToCategoricalColorBreaks(range.colorMap);\n      return colorBreaks?.map(cb => {\n        return {\n          data: cb.data,\n          label: Array.isArray(cb.label)\n            ? cb.label.length > 5\n              ? `${cb.label.length} selected`\n              : cb.label\n            : cb.label || ''\n        };\n      });\n    }\n    return getLegendOfScale({scale: scaleByZoom, scaleType, labelFormat, fieldType});\n  }, [range, scaleByZoom, scaleType, labelFormat, fieldType]);\n\n  const LegendsWithCustomLegends = useMemo(\n    () =>\n      overrideByCustomLegend({\n        colorLegends: range?.colorLegends,\n        currentLegends\n      }),\n    [range?.colorLegends, currentLegends]\n  );\n\n  return LegendsWithCustomLegends || [];\n}\n\nexport type ColorLegendProps = {\n  layer: Layer;\n  scaleType: string;\n  domain: number[] | string[];\n  fieldType?: string | null;\n  range?: ColorRange | null;\n  labelFormat?: (n: any) => string;\n  displayLabel?: boolean;\n  disableEdit?: boolean;\n  mapState?: MapState;\n  isFixed?: boolean;\n  isExpanded?: boolean;\n  onUpdateColorLegend?: (colorLegends: {[key: HexColor]: string}) => void;\n};\n\nexport type Legend = {\n  data: string;\n  label: string;\n  override?: boolean;\n};\n\nColorLegendFactory.deps = [LegendRowFactory];\nfunction ColorLegendFactory(LegendRow: ReturnType<typeof LegendRowFactory>) {\n  const ColorLegend: React.FC<ColorLegendProps> = ({\n    layer,\n    isFixed,\n    isExpanded,\n    domain,\n    range,\n    labelFormat,\n    scaleType,\n    fieldType,\n    mapState,\n    onUpdateColorLegend,\n    displayLabel = true,\n    disableEdit = false\n  }) => {\n    const {colorLegends} = range || {};\n\n    const legends = useLayerColorLegends(\n      layer,\n      scaleType,\n      domain,\n      range,\n      isFixed,\n      fieldType,\n      labelFormat,\n      mapState\n    );\n\n    const onUpdateLabel = useCallback(\n      (color, newValue) => {\n        if (onUpdateColorLegend) {\n          onUpdateColorLegend({\n            ...colorLegends,\n            [color]: newValue\n          });\n        }\n      },\n      [onUpdateColorLegend, colorLegends]\n    );\n\n    const onResetLabel = useCallback(\n      color => {\n        /* eslint-disable no-unused-vars */\n        // @ts-ignore\n        const {[color]: _, ...rest} = colorLegends;\n        if (onUpdateColorLegend && rest) {\n          onUpdateColorLegend(rest);\n        }\n        /* eslint-enable no-unused-vars */\n      },\n      [onUpdateColorLegend, colorLegends]\n    );\n\n    return (\n      <StyledLegend\n        className=\"styled-color-legend\"\n        disableEdit={disableEdit}\n        isExpanded={isExpanded}\n      >\n        {legends.map((legend, i) => (\n          <LegendRow\n            key={`${legend.data}-${i}`}\n            label={legend.label}\n            displayLabel={displayLabel}\n            color={legend.data}\n            onUpdateLabel={!disableEdit ? onUpdateLabel : undefined}\n            onResetLabel={legend.override && !disableEdit ? onResetLabel : undefined}\n          />\n        ))}\n      </StyledLegend>\n    );\n  };\n\n  return React.memo(ColorLegend);\n}\n\nexport default ColorLegendFactory;\n"],"mappings":"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","ignoreList":[]}