kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
258 lines (257 loc) • 50.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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _classnames = _interopRequireDefault(require("classnames"));
var _reactDom = require("react-dom");
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireWildcard(require("styled-components"));
var _core = require("@dnd-kit/core");
var _utilities = require("@dnd-kit/utilities");
var _react2 = require("@floating-ui/react");
var _styles = require("@kepler.gl/styles");
var _utils = require("@kepler.gl/utils");
var _icons = require("../common/icons");
var _styledComponents2 = require("../common/styled-components");
var _context = require("../context");
var _useLegendPosition3 = _interopRequireDefault(require("../hooks/use-legend-position"));
var _mapControlPanel = _interopRequireDefault(require("./map-control-panel"));
var _mapControlTooltip = _interopRequireDefault(require("./map-control-tooltip"));
var _mapLegend = _interopRequireDefault(require("./map-legend"));
var _modifiers = require("@dnd-kit/modifiers");
var _templateObject, _templateObject2, _templateObject3; // 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 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 DRAG_RESIZE_ID = 'map-legend-resize';
var DRAG_MOVE_ID = 'map-legend-move';
var StyledDraggableLegendContent = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n outline: none;\n transition: border-color 0.2s ease-in-out;\n border: 1px solid transparent;\n .legend-input-block {\n display: none;\n }\n &.is-dragging .legend-input-block {\n display: block;\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background-color: transparent;\n }\n &:hover,\n &.is-dragging {\n .legend-move-handle {\n opacity: 1;\n pointer-events: auto;\n }\n .legend-resize-handle {\n opacity: 1;\n pointer-events: auto;\n }\n border-color: ", ";\n }\n .map-control__panel-content {\n max-height: calc(100vh - 100px);\n ", ";\n }\n border-radius: 4px;\n z-index: 2;\n .map-control-panel {\n margin-bottom: 0 !important;\n }\n"])), function (props) {
return props.theme.activeColor;
}, function (props) {
return props.contentHeight ? "height: ".concat(props.contentHeight, "px;") : '';
});
var StyledMoveHandle = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n pointer-events: none;\n opacity: 0;\n transition: opacity 0.2s ease-in-out;\n position: absolute;\n display: flex;\n flex-direction: column;\n align-items: center;\n color: white;\n z-index: 2;\n top: 0;\n left: 50%;\n transform: translate(-50%, -50%);\n width: 48px;\n height: 16px;\n border-radius: 4px;\n cursor: move;\n background-color: ", ";\n"])), function (props) {
return props.theme.activeColor;
});
var StyledResizeHandle = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n pointer-events: none;\n opacity: 0;\n transition: opacity 0.2s ease-in-out;\n position: absolute;\n display: flex;\n flex-direction: column;\n align-items: center;\n color: #f7f8fa;\n z-index: 2;\n bottom: 0;\n left: 50%;\n transform: translate(-50%, -50%);\n width: 48px;\n height: 16px;\n border-radius: 4px;\n cursor: ns-resize;\n"])));
var DraggableLegendContent = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
var positionStyles = props.positionStyles,
children = props.children;
var draggableMove = (0, _core.useDraggable)({
id: DRAG_MOVE_ID
});
var draggableResize = (0, _core.useDraggable)({
id: DRAG_RESIZE_ID
});
var refs = (0, _react2.useMergeRefs)([draggableMove.setNodeRef, ref]);
var isDragging = draggableMove.isDragging || draggableResize.isDragging;
return /*#__PURE__*/_react["default"].createElement(StyledDraggableLegendContent, (0, _extends2["default"])({
ref: refs,
className: (0, _classnames["default"])('draggable-legend', {
'is-dragging': isDragging
}),
style: _objectSpread(_objectSpread({}, positionStyles), {}, {
transform: _utilities.CSS.Translate.toString(draggableMove.transform)
}),
contentHeight: props.contentHeight
}, draggableMove.attributes), children, isDragging ? /*#__PURE__*/_react["default"].createElement("div", {
className: "legend-input-block"
}) : null, /*#__PURE__*/_react["default"].createElement(StyledMoveHandle, (0, _extends2["default"])({
className: "legend-move-handle"
}, draggableMove.listeners), /*#__PURE__*/_react["default"].createElement(_icons.DraggableDots, {
height: "16px"
})), /*#__PURE__*/_react["default"].createElement(StyledResizeHandle, (0, _extends2["default"])({
className: "legend-resize-handle",
ref: draggableResize.setNodeRef
}, draggableResize.listeners), /*#__PURE__*/_react["default"].createElement(_icons.HorizontalResizeHandle, {
height: "16px"
})));
});
var DraggableLegend = (0, _styledComponents.withTheme)(function (_ref) {
var _mapControls$mapLegen;
var isSidePanelShown = _ref.isSidePanelShown,
children = _ref.children,
mapControls = _ref.mapControls,
setMapControlSettings = _ref.setMapControlSettings,
theme = _ref.theme;
var settings = mapControls === null || mapControls === void 0 || (_mapControls$mapLegen = mapControls.mapLegend) === null || _mapControls$mapLegen === void 0 ? void 0 : _mapControls$mapLegen.settings;
var legendContentRef = (0, _react.useRef)(null);
var onChangeSettings = (0, _react.useCallback)(function (newSettings) {
return setMapControlSettings('mapLegend', newSettings);
}, [setMapControlSettings]);
var _useLegendPosition = (0, _useLegendPosition3["default"])({
legendContentRef: legendContentRef,
isSidePanelShown: isSidePanelShown,
theme: theme,
settings: settings,
onChangeSettings: onChangeSettings
}),
positionStyles = _useLegendPosition.positionStyles,
updatePosition = _useLegendPosition.updatePosition,
startResize = _useLegendPosition.startResize,
resize = _useLegendPosition.resize,
contentHeight = _useLegendPosition.contentHeight;
var handleDragStart = (0, _react.useCallback)(function (event) {
switch (event.active.id) {
case DRAG_RESIZE_ID:
startResize();
break;
default:
updatePosition();
}
}, [updatePosition, startResize]);
var handleDragEnd = (0, _react.useCallback)(updatePosition, [updatePosition]);
var handleDragMove = (0, _react.useCallback)(function (event) {
switch (event.active.id) {
case DRAG_RESIZE_ID:
resize(event.delta.y);
break;
}
}, [resize]);
return /*#__PURE__*/_react["default"].createElement(_core.DndContext, {
onDragStart: handleDragStart,
onDragMove: handleDragMove,
onDragEnd: handleDragEnd,
modifiers: [_modifiers.restrictToWindowEdges]
}, /*#__PURE__*/_react["default"].createElement(DraggableLegendContent, {
ref: legendContentRef,
positionStyles: positionStyles,
contentHeight: contentHeight
}, children));
});
var ImageExportLegend = (0, _styledComponents.withTheme)(function (_ref2) {
var _containerRef$current;
var settings = _ref2.settings,
isSidePanelShown = _ref2.isSidePanelShown,
theme = _ref2.theme,
children = _ref2.children;
var containerRef = (0, _react.useRef)(null);
var legendContentRef = (0, _react.useRef)(null);
var _useLegendPosition2 = (0, _useLegendPosition3["default"])({
legendContentRef: legendContentRef,
isSidePanelShown: isSidePanelShown,
theme: theme,
settings: settings,
onChangeSettings: function onChangeSettings() {
// do nothing by default
}
}),
positionStyles = _useLegendPosition2.positionStyles;
var portalRoot = (_containerRef$current = containerRef.current) === null || _containerRef$current === void 0 || (_containerRef$current = _containerRef$current.closest('.export-map-instance')) === null || _containerRef$current === void 0 ? void 0 : _containerRef$current.querySelector('#default-deckgl-overlay-wrapper');
return /*#__PURE__*/_react["default"].createElement("div", {
ref: containerRef
}, portalRoot ? /*#__PURE__*/(0, _reactDom.createPortal)( /*#__PURE__*/_react["default"].createElement("div", {
className: "fixed-legend",
ref: legendContentRef,
style: _objectSpread(_objectSpread({}, positionStyles), {}, {
position: 'absolute'
})
}, children), portalRoot) : null);
});
MapLegendPanelFactory.deps = [_mapControlTooltip["default"], _mapControlPanel["default"], _mapLegend["default"]];
var defaultActionIcons = {
legend: function legend(props) {
return /*#__PURE__*/_react["default"].createElement(_icons.Legend, (0, _extends2["default"])({}, props, {
height: "18px"
}));
}
};
var MapLegendPanelComponent = function MapLegendPanelComponent(_ref3) {
var _mapControls$mapLegen2, _rootContext$current;
var layers = _ref3.layers,
mapControls = _ref3.mapControls,
scale = _ref3.scale,
onToggleMapControl = _ref3.onToggleMapControl,
isExport = _ref3.isExport,
logoComponent = _ref3.logoComponent,
_ref3$actionIcons = _ref3.actionIcons,
actionIcons = _ref3$actionIcons === void 0 ? defaultActionIcons : _ref3$actionIcons,
mapState = _ref3.mapState,
onLayerVisConfigChange = _ref3.onLayerVisConfigChange,
onToggleSplitMapViewport = _ref3.onToggleSplitMapViewport,
onClickControlBtn = _ref3.onClickControlBtn,
activeSidePanel = _ref3.activeSidePanel,
setMapControlSettings = _ref3.setMapControlSettings,
_ref3$isViewportUnsyn = _ref3.isViewportUnsyncAllowed,
isViewportUnsyncAllowed = _ref3$isViewportUnsyn === void 0 ? true : _ref3$isViewportUnsyn,
className = _ref3.className,
MapControlTooltip = _ref3.MapControlTooltip,
MapControlPanel = _ref3.MapControlPanel,
MapLegend = _ref3.MapLegend;
var isSidePanelShown = Boolean(activeSidePanel);
var settings = mapControls === null || mapControls === void 0 || (_mapControls$mapLegen2 = mapControls.mapLegend) === null || _mapControls$mapLegen2 === void 0 ? void 0 : _mapControls$mapLegen2.settings;
var mapLegend = (mapControls === null || mapControls === void 0 ? void 0 : mapControls.mapLegend) || {};
var _ref4 = mapLegend || {},
active = _ref4.active,
disableEdit = _ref4.disableEdit;
var rootContext = (0, _react.useContext)(_context.RootContext);
var onClick = (0, _react.useCallback)(function () {
var _mapControls$mapDraw;
onClickControlBtn === null || onClickControlBtn === void 0 || onClickControlBtn();
if (mapControls !== null && mapControls !== void 0 && (_mapControls$mapDraw = mapControls.mapDraw) !== null && _mapControls$mapDraw !== void 0 && _mapControls$mapDraw.active) {
onToggleMapControl('mapDraw');
}
onToggleMapControl('mapLegend');
}, [onClickControlBtn, onToggleMapControl, mapControls]);
var onCloseClick = (0, _react.useCallback)(function (e) {
e.preventDefault();
onToggleMapControl('mapLegend');
}, [onToggleMapControl]);
if (!mapLegend.show) {
return null;
}
var legendPanel = active ? /*#__PURE__*/_react["default"].createElement(MapControlPanel, {
scale: scale,
header: "header.layerLegend",
onClick: onCloseClick,
pinnable: false,
disableClose: false,
isExport: isExport,
logoComponent: logoComponent,
mapState: mapState,
onToggleSplitMapViewport: onToggleSplitMapViewport,
isViewportUnsyncAllowed: isViewportUnsyncAllowed,
className: className
}, /*#__PURE__*/_react["default"].createElement(MapLegend, {
layers: layers,
mapState: mapState,
disableEdit: disableEdit,
isExport: isExport,
onLayerVisConfigChange: onLayerVisConfigChange
})) : null;
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, active ? (0, _utils.hasPortableWidth)(_styles.breakPointValues) ? legendPanel : isExport ? /*#__PURE__*/_react["default"].createElement(ImageExportLegend, {
isSidePanelShown: isSidePanelShown,
settings: settings
}, legendPanel) : ( /*#__PURE__*/(0, _reactDom.createPortal)( /*#__PURE__*/_react["default"].createElement(DraggableLegend, {
isSidePanelShown: isSidePanelShown,
mapControls: mapControls,
setMapControlSettings: setMapControlSettings
}, legendPanel), (_rootContext$current = rootContext === null || rootContext === void 0 ? void 0 : rootContext.current) !== null && _rootContext$current !== void 0 ? _rootContext$current : document.body)) : null, !isExport ? /*#__PURE__*/_react["default"].createElement(MapControlTooltip, {
id: "show-legend",
message: "tooltip.showLegend"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.MapControlButton, {
className: "map-control-button show-legend",
onClick: onClick
}, /*#__PURE__*/_react["default"].createElement(actionIcons.legend, {
height: "22px"
}))) : null);
};
function MapLegendPanelFactory(MapControlTooltip, MapControlPanel, MapLegend) {
return function (props) {
return /*#__PURE__*/_react["default"].createElement(MapLegendPanelComponent, (0, _extends2["default"])({}, props, {
MapControlTooltip: MapControlTooltip,
MapControlPanel: MapControlPanel,
MapLegend: MapLegend
}));
};
}
var _default = exports["default"] = MapLegendPanelFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_classnames","_interopRequireDefault","require","_reactDom","_react","_interopRequireWildcard","_styledComponents","_core","_utilities","_react2","_styles","_utils","_icons","_styledComponents2","_context","_useLegendPosition3","_mapControlPanel","_mapControlTooltip","_mapLegend","_modifiers","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","DRAG_RESIZE_ID","DRAG_MOVE_ID","StyledDraggableLegendContent","styled","div","_taggedTemplateLiteral2","props","theme","activeColor","contentHeight","concat","StyledMoveHandle","StyledResizeHandle","DraggableLegendContent","forwardRef","ref","positionStyles","children","draggableMove","useDraggable","id","draggableResize","refs","useMergeRefs","setNodeRef","isDragging","createElement","_extends2","className","classnames","style","transform","CSS","Translate","toString","attributes","listeners","DraggableDots","height","HorizontalResizeHandle","DraggableLegend","withTheme","_ref","_mapControls$mapLegen","isSidePanelShown","mapControls","setMapControlSettings","settings","mapLegend","legendContentRef","useRef","onChangeSettings","useCallback","newSettings","_useLegendPosition","useLegendPosition","updatePosition","startResize","resize","handleDragStart","event","active","handleDragEnd","handleDragMove","delta","y","DndContext","onDragStart","onDragMove","onDragEnd","modifiers","restrictToWindowEdges","ImageExportLegend","_ref2","_containerRef$current","containerRef","_useLegendPosition2","portalRoot","current","closest","querySelector","createPortal","position","MapLegendPanelFactory","deps","MapControlTooltipFactory","MapControlPanelFactory","MapLegendFactory","defaultActionIcons","legend","Legend","MapLegendPanelComponent","_ref3","_mapControls$mapLegen2","_rootContext$current","layers","scale","onToggleMapControl","isExport","logoComponent","_ref3$actionIcons","actionIcons","mapState","onLayerVisConfigChange","onToggleSplitMapViewport","onClickControlBtn","activeSidePanel","_ref3$isViewportUnsyn","isViewportUnsyncAllowed","MapControlTooltip","MapControlPanel","MapLegend","Boolean","_ref4","disableEdit","rootContext","useContext","RootContext","onClick","_mapControls$mapDraw","mapDraw","onCloseClick","preventDefault","show","legendPanel","header","pinnable","disableClose","Fragment","hasPortableWidth","breakPointValues","document","body","message","MapControlButton","_default","exports"],"sources":["../../src/map/map-legend-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport classnames from 'classnames';\nimport {createPortal} from 'react-dom';\nimport React, {\n  ComponentType,\n  FC,\n  forwardRef,\n  useCallback,\n  useContext,\n  useRef,\n  PropsWithChildren\n} from 'react';\nimport styled, {withTheme} from 'styled-components';\n\nimport {DndContext, useDraggable} from '@dnd-kit/core';\nimport {CSS} from '@dnd-kit/utilities';\nimport {useMergeRefs} from '@floating-ui/react';\n\nimport {ActionHandler, setMapControlSettings, toggleSplitMapViewport} from '@kepler.gl/actions';\nimport {Layer} from '@kepler.gl/layers';\nimport {breakPointValues} from '@kepler.gl/styles';\nimport {LayerVisConfig, MapControlMapLegend, MapControls, MapState} from '@kepler.gl/types';\nimport {hasPortableWidth} from '@kepler.gl/utils';\nimport {MapLegendControlSettings} from '@kepler.gl/types';\n\nimport {Legend, DraggableDots, HorizontalResizeHandle} from '../common/icons';\nimport {MapControlButton} from '../common/styled-components';\nimport {RootContext} from '../context';\nimport useLegendPosition from '../hooks/use-legend-position';\nimport MapControlPanelFactory from './map-control-panel';\nimport MapControlTooltipFactory from './map-control-tooltip';\nimport MapLegendFactory from './map-legend';\nimport {restrictToWindowEdges} from '@dnd-kit/modifiers';\n\nconst DRAG_RESIZE_ID = 'map-legend-resize';\nconst DRAG_MOVE_ID = 'map-legend-move';\n\nconst StyledDraggableLegendContent = styled.div<{contentHeight?: number}>`\n  position: absolute;\n  outline: none;\n  transition: border-color 0.2s ease-in-out;\n  border: 1px solid transparent;\n  .legend-input-block {\n    display: none;\n  }\n  &.is-dragging .legend-input-block {\n    display: block;\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    background-color: transparent;\n  }\n  &:hover,\n  &.is-dragging {\n    .legend-move-handle {\n      opacity: 1;\n      pointer-events: auto;\n    }\n    .legend-resize-handle {\n      opacity: 1;\n      pointer-events: auto;\n    }\n    border-color: ${props => props.theme.activeColor};\n  }\n  .map-control__panel-content {\n    max-height: calc(100vh - 100px);\n    ${props => (props.contentHeight ? `height: ${props.contentHeight}px;` : '')};\n  }\n  border-radius: 4px;\n  z-index: 2;\n  .map-control-panel {\n    margin-bottom: 0 !important;\n  }\n`;\n\nconst StyledMoveHandle = styled.div`\n  pointer-events: none;\n  opacity: 0;\n  transition: opacity 0.2s ease-in-out;\n  position: absolute;\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  color: white;\n  z-index: 2;\n  top: 0;\n  left: 50%;\n  transform: translate(-50%, -50%);\n  width: 48px;\n  height: 16px;\n  border-radius: 4px;\n  cursor: move;\n  background-color: ${props => props.theme.activeColor};\n`;\n\nconst StyledResizeHandle = styled.div`\n  pointer-events: none;\n  opacity: 0;\n  transition: opacity 0.2s ease-in-out;\n  position: absolute;\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  color: #f7f8fa;\n  z-index: 2;\n  bottom: 0;\n  left: 50%;\n  transform: translate(-50%, -50%);\n  width: 48px;\n  height: 16px;\n  border-radius: 4px;\n  cursor: ns-resize;\n`;\n\nexport type MapLegendPanelFactoryDeps = [\n  typeof MapControlTooltipFactory,\n  typeof MapControlPanelFactory,\n  typeof MapLegendFactory\n];\n\ntype DraggableLegendContentProps = {\n  contentHeight?: number;\n  positionStyles: Record<string, unknown>;\n  children: React.ReactNode;\n};\n\nconst DraggableLegendContent = forwardRef((props: DraggableLegendContentProps, ref) => {\n  const {positionStyles, children} = props;\n  const draggableMove = useDraggable({id: DRAG_MOVE_ID});\n  const draggableResize = useDraggable({id: DRAG_RESIZE_ID});\n  const refs = useMergeRefs([draggableMove.setNodeRef, ref]);\n  const isDragging = draggableMove.isDragging || draggableResize.isDragging;\n  return (\n    <StyledDraggableLegendContent\n      ref={refs}\n      className={classnames('draggable-legend', {'is-dragging': isDragging})}\n      style={{...positionStyles, transform: CSS.Translate.toString(draggableMove.transform)}}\n      contentHeight={props.contentHeight}\n      {...draggableMove.attributes}\n    >\n      {children}\n      {isDragging ? <div className=\"legend-input-block\" /> : null}\n      <StyledMoveHandle className=\"legend-move-handle\" {...draggableMove.listeners}>\n        <DraggableDots height=\"16px\" />\n      </StyledMoveHandle>\n      <StyledResizeHandle\n        className=\"legend-resize-handle\"\n        ref={draggableResize.setNodeRef}\n        {...draggableResize.listeners}\n      >\n        <HorizontalResizeHandle height=\"16px\" />\n      </StyledResizeHandle>\n    </StyledDraggableLegendContent>\n  );\n});\n\ntype DraggableLegendProps = PropsWithChildren<{\n  isSidePanelShown: boolean;\n  mapControls: MapControls;\n  setMapControlSettings: typeof setMapControlSettings;\n}>;\n\nconst DraggableLegend = withTheme(\n  ({\n    isSidePanelShown,\n    children,\n    mapControls,\n    setMapControlSettings,\n    theme\n  }: DraggableLegendProps & {theme: any}) => {\n    const settings = mapControls?.mapLegend?.settings;\n\n    const legendContentRef = useRef<HTMLElement>(null);\n    const onChangeSettings = useCallback(\n      newSettings => setMapControlSettings('mapLegend', newSettings),\n      [setMapControlSettings]\n    );\n    const {positionStyles, updatePosition, startResize, resize, contentHeight} = useLegendPosition({\n      legendContentRef,\n      isSidePanelShown,\n      theme,\n      settings,\n      onChangeSettings\n    });\n\n    const handleDragStart = useCallback(\n      event => {\n        switch (event.active.id) {\n          case DRAG_RESIZE_ID:\n            startResize();\n            break;\n          default:\n            updatePosition();\n        }\n      },\n      [updatePosition, startResize]\n    );\n    const handleDragEnd = useCallback(updatePosition, [updatePosition]);\n    const handleDragMove = useCallback(\n      event => {\n        switch (event.active.id) {\n          case DRAG_RESIZE_ID:\n            resize(event.delta.y);\n            break;\n        }\n      },\n      [resize]\n    );\n\n    return (\n      <DndContext\n        onDragStart={handleDragStart}\n        onDragMove={handleDragMove}\n        onDragEnd={handleDragEnd}\n        modifiers={[restrictToWindowEdges]}\n      >\n        <DraggableLegendContent\n          ref={legendContentRef}\n          positionStyles={positionStyles}\n          contentHeight={contentHeight}\n        >\n          {children}\n        </DraggableLegendContent>\n      </DndContext>\n    );\n  }\n) as FC<DraggableLegendProps>;\n\ntype ImageExportLegendProps = {\n  settings?: MapLegendControlSettings;\n  isSidePanelShown: boolean;\n  children: React.ReactNode;\n};\n\nconst ImageExportLegend = withTheme(({settings, isSidePanelShown, theme, children}) => {\n  const containerRef: React.MutableRefObject<HTMLDivElement | null> = useRef(null);\n  const legendContentRef: React.MutableRefObject<HTMLDivElement | null> = useRef(null);\n\n  const {positionStyles} = useLegendPosition({\n    legendContentRef,\n    isSidePanelShown,\n    theme,\n    settings,\n    onChangeSettings: () => {\n      // do nothing by default\n    }\n  });\n\n  const portalRoot = containerRef.current\n    ?.closest('.export-map-instance')\n    ?.querySelector('#default-deckgl-overlay-wrapper');\n\n  return (\n    <div ref={containerRef}>\n      {portalRoot\n        ? createPortal(\n            <div\n              className=\"fixed-legend\"\n              ref={legendContentRef}\n              style={{...positionStyles, position: 'absolute'}}\n            >\n              {children}\n            </div>,\n            portalRoot\n          )\n        : null}\n    </div>\n  );\n}) as React.FC<ImageExportLegendProps>;\n\nMapLegendPanelFactory.deps = [MapControlTooltipFactory, MapControlPanelFactory, MapLegendFactory];\n\ninterface MapLegendPanelIcons {\n  legend: ComponentType<any>;\n}\n\nexport type MapLegendPanelProps = {\n  theme: any;\n  layers: ReadonlyArray<Layer>;\n  scale: number;\n  onToggleMapControl: (control: string) => void;\n  isExport: boolean;\n  logoComponent: Element;\n  actionIcons: MapLegendPanelIcons;\n  mapControls: MapControls;\n  mapState?: MapState;\n  onLayerVisConfigChange?: (oldLayer: Layer, newVisConfig: Partial<LayerVisConfig>) => void;\n  onToggleSplitMapViewport?: ActionHandler<typeof toggleSplitMapViewport>;\n  isViewportUnsyncAllowed?: boolean;\n  onClickControlBtn?: (e?: MouseEvent) => void;\n  className: string;\n  settings: MapLegendControlSettings;\n  isSidePanelShown: boolean;\n  activeSidePanel: string | null;\n  setMapControlSettings: any;\n};\n\ntype MapLegendPanelComponents = {\n  MapControlTooltip: ReturnType<typeof MapControlTooltipFactory>;\n  MapControlPanel: ReturnType<typeof MapControlPanelFactory>;\n  MapLegend: ReturnType<typeof MapLegendFactory>;\n};\n\ntype MapLegendPanelComponentType = React.FC<MapLegendPanelProps>;\n\nconst defaultActionIcons = {\n  legend: props => <Legend {...props} height=\"18px\" />\n};\n\nconst MapLegendPanelComponent = ({\n  layers,\n  mapControls,\n  scale,\n  onToggleMapControl,\n  isExport,\n  logoComponent,\n  actionIcons = defaultActionIcons,\n  mapState,\n  onLayerVisConfigChange,\n  onToggleSplitMapViewport,\n  onClickControlBtn,\n  activeSidePanel,\n  setMapControlSettings,\n  isViewportUnsyncAllowed = true,\n  className,\n  MapControlTooltip,\n  MapControlPanel,\n  MapLegend\n}: MapLegendPanelProps & MapLegendPanelComponents) => {\n  const isSidePanelShown = Boolean(activeSidePanel);\n  const settings = mapControls?.mapLegend?.settings;\n\n  const mapLegend = mapControls?.mapLegend || ({} as MapControlMapLegend);\n  const {active, disableEdit} = mapLegend || {};\n  const rootContext = useContext(RootContext);\n\n  const onClick = useCallback(() => {\n    onClickControlBtn?.();\n    if (mapControls?.mapDraw?.active) {\n      onToggleMapControl('mapDraw');\n    }\n    onToggleMapControl('mapLegend');\n  }, [onClickControlBtn, onToggleMapControl, mapControls]);\n  const onCloseClick = useCallback(\n    e => {\n      e.preventDefault();\n      onToggleMapControl('mapLegend');\n    },\n    [onToggleMapControl]\n  );\n\n  if (!mapLegend.show) {\n    return null;\n  }\n\n  const legendPanel = active ? (\n    <MapControlPanel\n      scale={scale}\n      header=\"header.layerLegend\"\n      {...{onClick: onCloseClick, pinnable: false, disableClose: false}}\n      isExport={isExport}\n      logoComponent={logoComponent}\n      mapState={mapState}\n      onToggleSplitMapViewport={onToggleSplitMapViewport}\n      isViewportUnsyncAllowed={isViewportUnsyncAllowed}\n      className={className}\n    >\n      <MapLegend\n        layers={layers}\n        mapState={mapState}\n        disableEdit={disableEdit}\n        isExport={isExport}\n        onLayerVisConfigChange={onLayerVisConfigChange}\n      />\n    </MapControlPanel>\n  ) : null;\n\n  return (\n    <>\n      {active ? (\n        hasPortableWidth(breakPointValues) ? (\n          legendPanel\n        ) : isExport ? (\n          <ImageExportLegend isSidePanelShown={isSidePanelShown} settings={settings}>\n            {legendPanel}\n          </ImageExportLegend>\n        ) : (\n          createPortal(\n            <DraggableLegend\n              isSidePanelShown={isSidePanelShown}\n              mapControls={mapControls}\n              setMapControlSettings={setMapControlSettings}\n            >\n              {legendPanel}\n            </DraggableLegend>,\n            rootContext?.current ?? document.body\n          )\n        )\n      ) : null}\n      {!isExport ? (\n        <MapControlTooltip id=\"show-legend\" message=\"tooltip.showLegend\">\n          <MapControlButton className=\"map-control-button show-legend\" onClick={onClick}>\n            <actionIcons.legend height=\"22px\" />\n          </MapControlButton>\n        </MapControlTooltip>\n      ) : null}\n    </>\n  );\n};\n\nfunction MapLegendPanelFactory(\n  MapControlTooltip: ReturnType<typeof MapControlTooltipFactory>,\n  MapControlPanel: ReturnType<typeof MapControlPanelFactory>,\n  MapLegend: ReturnType<typeof MapLegendFactory>\n): MapLegendPanelComponentType {\n  return (props: MapLegendPanelProps) => (\n    <MapLegendPanelComponent\n      {...props}\n      MapControlTooltip={MapControlTooltip}\n      MapControlPanel={MapControlPanel}\n      MapLegend={MapLegend}\n    />\n  );\n}\n\nexport default MapLegendPanelFactory;\n"],"mappings":"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