kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
273 lines (272 loc) • 46.3 kB
JavaScript
;
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-y: auto;\n overflow-x: hidden;\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 min-width: 0;\n"])));
function ResetColorLabelFactory() {
return (0, _styledComponents["default"])(_icons.Reset)(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n cursor: pointer;\n flex-shrink: 0;\n margin-left: ", "px;\n\n &:hover {\n color: ", ";\n }\n "])), function (props) {
return props.theme.labelColorLT;
}, GAP, 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 min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\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 flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\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 ? String(label !== null && label !== void 0 ? label : '') : '';
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","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-y: auto;\n  overflow-x: hidden;\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  min-width: 0;\n`;\n\nexport function ResetColorLabelFactory() {\n  return styled(Reset)`\n    color: ${props => props.theme.labelColorLT};\n    cursor: pointer;\n    flex-shrink: 0;\n    margin-left: ${GAP}px;\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  min-width: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\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  flex: 1;\n  min-width: 0;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\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 ? String(label ?? '') : '';\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":";;;;;;;;;;;;;;;;;AAGA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAF,uBAAA,CAAAC,OAAA;AAEA,IAAAE,UAAA,GAAAF,OAAA;AAGA,IAAAG,MAAA,GAAAH,OAAA;AAQA,IAAAI,MAAA,GAAAJ,OAAA;AACA,IAAAK,kBAAA,GAAAL,OAAA;AAAgD,IAAAM,eAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAAAC,gBAAA,EAlBhD;AACA;AAAA,SAAAC,yBAAAC,CAAA,6BAAAC,OAAA,mBAAAC,CAAA,OAAAD,OAAA,IAAAE,CAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,CAAA,WAAAA,CAAA,GAAAG,CAAA,GAAAD,CAAA,KAAAF,CAAA;AAAA,SAAAd,wBAAAc,CAAA,EAAAE,CAAA,SAAAA,CAAA,IAAAF,CAAA,IAAAA,CAAA,CAAAI,UAAA,SAAAJ,CAAA,eAAAA,CAAA,gBAAAK,OAAA,CAAAL,CAAA,0BAAAA,CAAA,sBAAAA,CAAA,QAAAG,CAAA,GAAAJ,wBAAA,CAAAG,CAAA,OAAAC,CAAA,IAAAA,CAAA,CAAAG,GAAA,CAAAN,CAAA,UAAAG,CAAA,CAAAI,GAAA,CAAAP,CAAA,OAAAQ,CAAA,KAAAC,SAAA,UAAAC,CAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,CAAA,IAAAd,CAAA,oBAAAc,CAAA,OAAAC,cAAA,CAAAC,IAAA,CAAAhB,CAAA,EAAAc,CAAA,SAAAG,CAAA,GAAAP,CAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAc,CAAA,UAAAG,CAAA,KAAAA,CAAA,CAAAV,GAAA,IAAAU,CAAA,CAAAC,GAAA,IAAAP,MAAA,CAAAC,cAAA,CAAAJ,CAAA,EAAAM,CAAA,EAAAG,CAAA,IAAAT,CAAA,CAAAM,CAAA,IAAAd,CAAA,CAAAc,CAAA,YAAAN,CAAA,cAAAR,CAAA,EAAAG,CAAA,IAAAA,CAAA,CAAAe,GAAA,CAAAlB,CAAA,EAAAQ,CAAA,GAAAA,CAAA;AAAA,SAAAW,eAAAhB,CAAA,QAAAc,CAAA,GAAAG,YAAA,CAAAjB,CAAA,gCAAAE,OAAA,CAAAY,CAAA,IAAAA,CAAA,GAAAA,CAAA;AAAA,SAAAG,aAAAjB,CAAA,EAAAD,CAAA,oBAAAG,OAAA,CAAAF,CAAA,MAAAA,CAAA,SAAAA,CAAA,MAAAH,CAAA,GAAAG,CAAA,CAAAkB,MAAA,CAAAC,WAAA,kBAAAtB,CAAA,QAAAiB,CAAA,GAAAjB,CAAA,CAAAgB,IAAA,CAAAb,CAAA,EAAAD,CAAA,gCAAAG,OAAA,CAAAY,CAAA,UAAAA,CAAA,YAAAM,SAAA,yEAAArB,CAAA,GAAAsB,MAAA,GAAAC,MAAA,EAAAtB,CAAA;AAAA,SAAAuB,QAAA1B,CAAA,EAAAE,CAAA,QAAAC,CAAA,GAAAQ,MAAA,CAAAgB,IAAA,CAAA3B,CAAA,OAAAW,MAAA,CAAAiB,qBAAA,QAAAC,CAAA,GAAAlB,MAAA,CAAAiB,qBAAA,CAAA5B,CAAA,GAAAE,CAAA,KAAA2B,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAA5B,CAAA,WAAAS,MAAA,CAAAE,wBAAA,CAAAb,CAAA,EAAAE,CAAA,EAAA6B,UAAA,OAAA5B,CAAA,CAAA6B,IAAA,CAAAC,KAAA,CAAA9B,CAAA,EAAA0B,CAAA,YAAA1B,CAAA;AAAA,SAAA+B,cAAAlC,CAAA,aAAAE,CAAA,MAAAA,CAAA,GAAAiC,SAAA,CAAAC,MAAA,EAAAlC,CAAA,UAAAC,CAAA,WAAAgC,SAAA,CAAAjC,CAAA,IAAAiC,SAAA,CAAAjC,CAAA,QAAAA,CAAA,OAAAwB,OAAA,CAAAf,MAAA,CAAAR,CAAA,OAAAkC,OAAA,WAAAnC,CAAA,QAAAoC,gBAAA,aAAAtC,CAAA,EAAAE,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAS,MAAA,CAAA4B,yBAAA,GAAA5B,MAAA,CAAA6B,gBAAA,CAAAxC,CAAA,EAAAW,MAAA,CAAA4B,yBAAA,CAAApC,CAAA,KAAAuB,OAAA,CAAAf,MAAA,CAAAR,CAAA,GAAAkC,OAAA,WAAAnC,CAAA,IAAAS,MAAA,CAAAC,cAAA,CAAAZ,CAAA,EAAAE,CAAA,EAAAS,MAAA,CAAAE,wBAAA,CAAAV,CAAA,EAAAD,CAAA,iBAAAF,CAAA;AAmBA,IAAMyC,KAAK,GAAG,EAAE;AAChB,IAAMC,GAAG,GAAG,CAAC;AACb,IAAMC,MAAM,GAAG,EAAE;AAEjB,IAAMC,oBAAoB,GAAG,SAAvBA,oBAAoBA,CAAG5C,CAAC;EAAA,OAAIA,CAAC,CAAC6C,eAAe,CAAC,CAAC;AAAA;AAErD,IAAMC,QAAQ,OAAGC,qBAAG,EAAAtD,eAAA,KAAAA,eAAA,OAAAuD,uBAAA,iEAInB;AACD,IAAMC,YAAY,GAAGC,4BAAM,CAACC,GAAG,CAAAzD,gBAAA,KAAAA,gBAAA,OAAAsD,uBAAA,uLAC3B,UAAAI,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACC,kBAAkB;AAAA,GACvC,UAAAF,KAAK;EAAA,OAAKA,KAAK,CAACG,UAAU,GAAG,EAAE,uBAAuB;AAAA,CAAC,EAGxCb,GAAG,EAEJA,GAAG,EAGjB,UAAAU,KAAK;EAAA,OAAKA,KAAK,CAACI,WAAW,GAAGV,QAAQ,GAAG,EAAE;AAAA,CAAC,CAC/C;AAED,IAAMW,eAAe,GAAGP,4BAAM,CAACC,GAAG,CAAAxD,gBAAA,KAAAA,gBAAA,OAAAqD,uBAAA,kGAKjC;AAEM,SAASU,sBAAsBA,CAAA,EAAG;EACvC,OAAO,IAAAR,4BAAM,EAACS,YAAK,CAAC,CAAA/D,gBAAA,KAAAA,gBAAA,OAAAoD,uBAAA,4JACT,UAAAI,KAAK;IAAA,OAAIA,KAAK,CAACC,KAAK,CAACO,YAAY;EAAA,GAG3BlB,GAAG,EAGP,UAAAU,KAAK;IAAA,OAAIA,KAAK,CAACC,KAAK,CAACQ,oBAAoB;EAAA;AAGxD;AAEA,IAAMC,gBAAgB,GAAG,IAAAZ,4BAAM,EAACa,8BAAW,CAAC,CAAAlE,gBAAA,KAAAA,gBAAA,OAAAmD,uBAAA,0SAE3BP,KAAK,EACVA,KAAK,EACN,UAAAW,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACW,SAAS;AAAA,GAQ3BtB,GAAG,EAEHD,KAAK,CAElB;AASM,SAASwB,sBAAsBA,CAAA,EAAG;EACvC,IAAMC,eAA+C,GAAG,SAAlDA,eAA+CA,CAAAC,IAAA,EAK/C;IAAA,IAJJC,KAAK,GAAAD,IAAA,CAALC,KAAK;MACLC,KAAK,GAAAF,IAAA,CAALE,KAAK;MACLC,MAAM,GAAAH,IAAA,CAANG,MAAM;MAAAC,aAAA,GAAAJ,IAAA,CACNK,QAAQ;MAARA,QAAQ,GAAAD,aAAA,cAAG,KAAK,GAAAA,aAAA;IAEhB,IAAME,QAAQ,GAAG,IAAAC,kBAAW,EAAC,UAAAC,KAAK;MAAA,OAAIL,MAAM,CAACK,KAAK,CAACC,MAAM,CAACC,KAAK,CAAC;IAAA,GAAE,CAACP,MAAM,CAAC,CAAC;IAC3E,oBACErF,MAAA,YAAA6F,aAAA,CAAChB,gBAAgB;MACfiB,IAAI,EAAC,MAAM;MACXC,SAAS,EAAC,8BAA8B;MACxCH,KAAK,EAAER,KAAM;MACbY,OAAO,EAAErC,oBAAqB;MAC9B6B,QAAQ,EAAEA,QAAS;MACnBD,QAAQ,EAAEA,QAAS;MACnBU,EAAE,KAAAC,MAAA,CAAKf,KAAK;IAAsB,CACnC,CAAC;EAEN,CAAC;EAEDF,eAAe,CAACkB,WAAW,GAAG,iBAAiB;EAC/C,OAAOlB,eAAe;AACxB;AAEA,IAAMmB,cAAc,GAAG;EACrBC,KAAK,KAAAH,MAAA,CAAKxC,MAAM,OAAI;EACpB4C,MAAM,KAAAJ,MAAA,CAAK1C,KAAK;AAClB,CAAC;AAEM,SAAS+C,yBAAyBA,CAAA,EAAG;EAC1C,IAAMC,kBAAkB,GAAG,SAArBA,kBAAkBA,CAAAC,KAAA,EAAgB;IAAA,IAAXtB,KAAK,GAAAsB,KAAA,CAALtB,KAAK;IAChC,IAAMuB,KAAK,GAAG,IAAAC,cAAO,EACnB;MAAA,OAAA1D,aAAA,CAAAA,aAAA,KAAWmD,cAAc;QAAEQ,eAAe,EAAEzB,KAAK;QAAE0B,WAAW,KAAAX,MAAA,CAAKzC,GAAG;MAAI;IAAA,CAAE,EAC5E,CAAC0B,KAAK,CACR,CAAC;IACD,oBAAOnF,MAAA,YAAA6F,aAAA;MAAKa,KAAK,EAAEA,KAAM;MAACX,SAAS,EAAC;IAAkB,CAAE,CAAC;EAC3D,CAAC;EAED,OAAOS,kBAAkB;AAC3B;AAEA,IAAMM,WAAW,GAAG7C,4BAAM,CAACC,GAAG,CAAArD,gBAAA,KAAAA,gBAAA,OAAAkD,uBAAA,uLAEnB,UAAAI,KAAK;EAAA,OAAIA,KAAK,CAACC,KAAK,CAACW,SAAS;AAAA,EAOxC;AAYDgC,gBAAgB,CAACC,IAAI,GAAG,CAACT,yBAAyB,EAAEvB,sBAAsB,EAAEP,sBAAsB,CAAC;AAC5F,SAASsC,gBAAgBA,CAC9BP,kBAAgE,EAChEvB,eAA0D,EAC1DgC,eAA0D,EAC1D;EACA,IAAMC,SAAmC,GAAG,SAAtCA,SAAmCA,CAAAC,KAAA,EAMnC;IAAA,IAAAC,WAAA,GAAAD,KAAA,CALJ/B,KAAK;MAALA,KAAK,GAAAgC,WAAA,cAAG,EAAE,GAAAA,WAAA;MACVC,YAAY,GAAAF,KAAA,CAAZE,YAAY;MACZlC,KAAK,GAAAgC,KAAA,CAALhC,KAAK;MACLmC,aAAa,GAAAH,KAAA,CAAbG,aAAa;MACbC,YAAY,GAAAJ,KAAA,CAAZI,YAAY;IAEZ,IAAMlC,MAAM,GAAG,IAAAI,kBAAW,EACxB,UAAA+B,QAAQ;MAAA,OAAIF,aAAa,IAAIA,aAAa,CAACnC,KAAK,EAAEqC,QAAQ,CAAC;IAAA,GAC3D,CAACrC,KAAK,EAAEmC,aAAa,CACvB,CAAC;IACD,IAAMG,OAAO,GAAG,IAAAhC,kBAAW,EAAC;MAAA,OAAM8B,YAAY,IAAIA,YAAY,CAACpC,KAAK,CAAC;IAAA,GAAE,CAACA,KAAK,EAAEoC,YAAY,CAAC,CAAC;IAC7F,IAAM3B,KAAK,GAAGyB,YAAY,GAAG9E,MAAM,CAAC6C,KAAK,aAALA,KAAK,cAALA,KAAK,GAAI,EAAE,CAAC,GAAG,EAAE;IACrD,oBACEpF,MAAA,YAAA6F,aAAA,CAACrB,eAAe,qBACdxE,MAAA,YAAA6F,aAAA,CAACW,kBAAkB;MAACrB,KAAK,EAAEA;IAAM,CAAE,CAAC,EACnCmC,aAAa,gBACZtH,MAAA,YAAA6F,aAAA,CAACZ,eAAe;MAACM,QAAQ,EAAE,CAAC+B,aAAc;MAAClC,KAAK,EAAEQ,KAAM;MAACT,KAAK,EAAEA,KAAM;MAACE,MAAM,EAAEA;IAAO,CAAE,CAAC,gBAEzFrF,MAAA,YAAA6F,aAAA,CAACiB,WAAW,QAAElB,KAAmB,CAClC,EACA2B,YAAY,gBAAGvH,MAAA,YAAA6F,aAAA,CAACoB,eAAe;MAACjB,OAAO,EAAEyB,OAAQ;MAACnB,MAAM,EAAC;IAAM,CAAE,CAAC,GAAG,IACvD,CAAC;EAEtB,CAAC;EACDY,SAAS,CAACf,WAAW,GAAG,WAAW;EACnC,OAAOe,SAAS;AAClB;AAEA,IAAMQ,oBAAoB,GAAG,SAAvBA,oBAAoBA,CAAIC,YAAY,EAAEC,SAAS,EAAK;EACxD,IAAOC,IAAI,GAAYD,SAAS,CAAzBC,IAAI;IAAEC,MAAM,GAAIF,SAAS,CAAnBE,MAAM;EAEnB,IAAMC,eAAe,OAAAC,mBAAA,aAAOL,YAAY,CAAC;EAEzCE,IAAI,CAACzE,OAAO,CAAC,UAAC6E,KAAK,EAAEC,KAAK,EAAK;IAC7B,IAAMC,YAAY,GAAGR,YAAY,CAACS,SAAS,CAAC,UAAAC,CAAC;MAAA,OAAIA,CAAC,CAACR,IAAI,KAAKI,KAAK;IAAA,EAAC;IAClE,IAAIE,YAAY,KAAK,CAAC,CAAC,EAAE;MACvBJ,eAAe,CAACI,YAAY,CAAC,GAAG;QAC9B/C,KAAK,EAAE0C,MAAM,CAACI,KAAK,CAAC;QACpBL,IAAI,EAAEI,KAAK;QACXK,QAAQ,EAAE;MACZ,CAAC;MACDP,eAAe,CAACI,YAAY,CAAC,CAAC/C,KAAK,GAAG0C,MAAM,CAACI,KAAK,CAAC;IACrD,CAAC,MAAM;MACLH,eAAe,CAAChF,IAAI,CAAC;QACnB8E,IAAI,EAAEI,KAAK;QACX7C,KAAK,EAAE0C,MAAM,CAACI,KAAK,CAAC;QACpBI,QAAQ,EAAE;MACZ,CAAC,CAAC;IACJ;EACF,CAAC,CAAC;EAEF,OAAOP,eAAe;AACxB,CAAC;AAaD;AACA;AACA;AACA;AACA;AACA,SAASQ,sBAAsBA,CAAAC,KAAA,EAAgE;EAAA,IAA9Db,YAAY,GAAAa,KAAA,CAAZb,YAAY;IAAEc,cAAc,GAAAD,KAAA,CAAdC,cAAc;EAC3D,IAAId,YAAY,IAAI,IAAAe,eAAQ,EAACf,YAAY,CAAC,EAAE;IAC1C;IACA,IAAME,IAAI,GAAGnG,MAAM,CAACgB,IAAI,CAACiF,YAAY,CAAC;IACtC,IAAMG,MAAM,GAAGpG,MAAM,CAACiH,MAAM,CAAChB,YAAY,CAAC;IAE1C,OAAOD,oBAAoB,CAACe,cAAc,EAAE;MAACZ,IAAI,EAAJA,IAAI;MAAEC,MAAM,EAANA;IAAM,CAAC,CAAC;EAC7D;EAEA,OAAOW,cAAc;AACvB;AAEO,SAASG,oBAAoBA,CAClCC,KAAgC,EAChCC,SAAwC,EACxCC,MAAkC,EAClCC,KAAgC,EAChCC,OAAoC,EACpCC,SAAwC,EACxCC,WAA4C,EAC5CC,QAAsC,EAC5B;EACV,IAAMC,KAAK,GAAG,IAAA1C,cAAO,EACnB;IAAA,OAAM,IAAA2C,yBAAkB,EAAC;MAACN,KAAK,EAALA,KAAK;MAAED,MAAM,EAANA,MAAM;MAAED,SAAS,EAATA,SAAS;MAAEG,OAAO,EAAPA,OAAO;MAAEJ,KAAK,EAALA;IAAK,CAAC,CAAC;EAAA,GACpE,CAACG,KAAK,EAAED,MAAM,EAAED,SAAS,EAAEG,OAAO,EAAEJ,KAAK,CAC3C,CAAC;EAED,IAAMU,WAAW,GAAG,IAAA5C,cAAO,EACzB;IAAA,OAAM,IAAA6C,kCAA2B,EAAC;MAACH,KAAK,EAALA,KAAK;MAAER,KAAK,EAALA,KAAK;MAAEO,QAAQ,EAARA;IAAQ,CAAC,CAAC;EAAA,GAC3D,CAACC,KAAK,EAAER,KAAK,EAAEO,QAAQ,CACzB,CAAC;EAED,IAAMX,cAAc,GAAG,IAAA9B,cAAO,EAAC,YAAM;IACnC,IAAImC,SAAS,KAAKW,sBAAW,CAACC,aAAa,IAAIV,KAAK,aAALA,KAAK,eAALA,KAAK,CAAEW,QAAQ,EAAE;MAC9D,IAAMC,WAAW,GAAG,IAAAC,uCAAgC,EAACb,KAAK,CAACW,QAAQ,CAAC;MACpE,OAAOC,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEE,GAAG,CAAC,UAAAC,EAAE,EAAI;QAC5B,OAAO;UACLlC,IAAI,EAAEkC,EAAE,CAAClC,IAAI;UACbzC,KAAK,EAAE4E,KAAK,CAACC,OAAO,CAACF,EAAE,CAAC3E,KAAK,CAAC,GAC1B2E,EAAE,CAAC3E,KAAK,CAACjC,MAAM,GAAG,CAAC,MAAA+C,MAAA,CACd6D,EAAE,CAAC3E,KAAK,CAACjC,MAAM,iBAClB4G,EAAE,CAAC3E,KAAK,GACV2E,EAAE,CAAC3E,KAAK,IAAI;QAClB,CAAC;MACH,CAAC,CAAC;IACJ;IACA,OAAO,IAAA8E,uBAAgB,EAAC;MAACb,KAAK,EAAEE,WAAW;MAAET,SAAS,EAATA,SAAS;MAAEK,WAAW,EAAXA,WAAW;MAAED,SAAS,EAATA;IAAS,CAAC,CAAC;EAClF,CAAC,EAAE,CAACF,KAAK,EAAEO,WAAW,EAAET,SAAS,EAAEK,WAAW,EAAED,SAAS,CAAC,CAAC;EAE3D,IAAMiB,wBAAwB,GAAG,IAAAxD,cAAO,EACtC;IAAA,OACE4B,sBAAsB,CAAC;MACrBZ,YAAY,EAAEqB,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAErB,YAAY;MACjCc,cAAc,EAAdA;IACF,CAAC,CAAC;EAAA,GACJ,CAACO,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAErB,YAAY,EAAEc,cAAc,CACtC,CAAC;EAED,OAAO0B,wBAAwB,IAAI,EAAE;AACvC;AAuBAC,kBAAkB,CAACpD,IAAI,GAAG,CAACD,gBAAgB,CAAC;AAC5C,SAASqD,kBAAkBA,CAAClD,SAA8C,EAAE;EAC1E,IAAMmD,WAAuC,GAAG,SAA1CA,WAAuCA,CAAAC,KAAA,EAavC;IAAA,IAZJzB,KAAK,GAAAyB,KAAA,CAALzB,KAAK;MACLI,OAAO,GAAAqB,KAAA,CAAPrB,OAAO;MACP3E,UAAU,GAAAgG,KAAA,CAAVhG,UAAU;MACVyE,MAAM,GAAAuB,KAAA,CAANvB,MAAM;MACNC,KAAK,GAAAsB,KAAA,CAALtB,KAAK;MACLG,WAAW,GAAAmB,KAAA,CAAXnB,WAAW;MACXL,SAAS,GAAAwB,KAAA,CAATxB,SAAS;MACTI,SAAS,GAAAoB,KAAA,CAATpB,SAAS;MACTE,QAAQ,GAAAkB,KAAA,CAARlB,QAAQ;MACRmB,mBAAmB,GAAAD,KAAA,CAAnBC,mBAAmB;MAAAC,kBAAA,GAAAF,KAAA,CACnBjD,YAAY;MAAZA,YAAY,GAAAmD,kBAAA,cAAG,IAAI,GAAAA,kBAAA;MAAAC,iBAAA,GAAAH,KAAA,CACnB/F,WAAW;MAAXA,WAAW,GAAAkG,iBAAA,cAAG,KAAK,GAAAA,iBAAA;IAEnB,IAAAC,KAAA,GAAuB1B,KAAK,IAAI,CAAC,CAAC;MAA3BrB,YAAY,GAAA+C,KAAA,CAAZ/C,YAAY;IAEnB,IAAMgD,OAAO,GAAG/B,oBAAoB,CAClCC,KAAK,EACLC,SAAS,EACTC,MAAM,EACNC,KAAK,EACLC,OAAO,EACPC,SAAS,EACTC,WAAW,EACXC,QACF,CAAC;IAED,IAAM9B,aAAa,GAAG,IAAA7B,kBAAW,EAC/B,UAACN,KAAK,EAAEyF,QAAQ,EAAK;MACnB,IAAIL,mBAAmB,EAAE;QACvBA,mBAAmB,CAAAtH,aAAA,CAAAA,aAAA,KACd0E,YAAY,WAAAtE,gBAAA,iBACd8B,KAAK,EAAGyF,QAAQ,EAClB,CAAC;MACJ;IACF,CAAC,EACD,CAACL,mBAAmB,EAAE5C,YAAY,CACpC,CAAC;IAED,IAAMJ,YAAY,GAAG,IAAA9B,kBAAW,EAC9B,UAAAN,KAAK,EAAI;MACP;MACA;MACA,IAAgB0F,CAAC,GAAalD,YAAY,CAAlCxC,KAAK;QAAS2F,IAAI,OAAAC,yBAAA,aAAIpD,YAAY,GAAlCxC,KAAK,EAAA2E,GAAA,CAAA5H,cAAA;MACb,IAAIqI,mBAAmB,IAAIO,IAAI,EAAE;QAC/BP,mBAAmB,CAACO,IAAI,CAAC;MAC3B;MACA;IACF,CAAC,EACD,CAACP,mBAAmB,EAAE5C,YAAY,CACpC,CAAC;IAED,oBACE3H,MAAA,YAAA6F,aAAA,CAAC7B,YAAY;MACX+B,SAAS,EAAC,qBAAqB;MAC/BxB,WAAW,EAAEA,WAAY;MACzBD,UAAU,EAAEA;IAAW,GAEtBqG,OAAO,CAACb,GAAG,CAAC,UAACkB,MAAM,EAAEhJ,CAAC;MAAA,oBACrBhC,MAAA,YAAA6F,aAAA,CAACqB,SAAS;QACR+D,GAAG,KAAA/E,MAAA,CAAK8E,MAAM,CAACnD,IAAI,OAAA3B,MAAA,CAAIlE,CAAC,CAAG;QAC3BoD,KAAK,EAAE4F,MAAM,CAAC5F,KAAM;QACpBiC,YAAY,EAAEA,YAAa;QAC3BlC,KAAK,EAAE6F,MAAM,CAACnD,IAAK;QACnBP,aAAa,EAAE,CAAC/C,WAAW,GAAG+C,aAAa,GAAG4D,SAAU;QACxD3D,YAAY,EAAEyD,MAAM,CAAC1C,QAAQ,IAAI,CAAC/D,WAAW,GAAGgD,YAAY,GAAG2D;MAAU,CAC1E,CAAC;IAAA,CACH,CACW,CAAC;EAEnB,CAAC;EAED,oBAAOC,iBAAK,CAACC,IAAI,CAACf,WAAW,CAAC;AAChC;AAAC,IAAAgB,QAAA,GAAAC,OAAA,cAEclB,kBAAkB","ignoreList":[]}