kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
190 lines (189 loc) • 39 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"] = MapPopoverFactory;
exports.getSelectedFeature = getSelectedFeature;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _mapPopoverContent = _interopRequireDefault(require("./map-popover-content"));
var _icons = require("../common/icons");
var _reactIntl = require("react-intl");
var _localization = require("@kepler.gl/localization");
var _context = require("../context");
var _layers = require("@kepler.gl/layers");
var _commonUtils = require("@kepler.gl/common-utils");
var _constants = require("@kepler.gl/constants");
var _reducers = require("@kepler.gl/reducers");
var _react2 = require("@floating-ui/react");
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
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 SELECTABLE_LAYERS = [_constants.LAYER_TYPES.hexagonId, _constants.LAYER_TYPES.geojson];
var MAX_WIDTH = 500;
var MAX_HEIGHT = 600;
var StyledMapPopover = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n\n max-width: ", "px;\n max-height: ", "px;\n padding: 14px;\n & > * + * {\n margin-top: 6px;\n }\n ", ";\n font-family: ", ";\n font-size: 11px;\n font-weight: 500;\n background-color: ", ";\n color: ", ";\n z-index: 98; /* should be below 99 which is side pane */\n overflow-x: auto;\n box-shadow: ", ";\n\n &:hover {\n background-color: ", ";\n }\n\n .primary-label {\n color: ", ";\n font-size: 10px;\n }\n\n .map-popover__layer-info,\n .coordingate-hover-info {\n & > * + * {\n margin-top: 7px;\n }\n }\n\n table {\n width: auto;\n display: grid;\n border-collapse: collapse;\n row-gap: 5px;\n column-gap: 5px;\n }\n\n .coordingate-hover-info > table {\n grid-template-columns: auto auto auto;\n }\n .map-popover__layer-info > table {\n grid-template-columns: auto auto;\n }\n\n tbody,\n tr {\n display: contents;\n }\n\n td {\n border-color: transparent;\n color: ", ";\n }\n\n td.row__value {\n text-align: right;\n font-weight: 500;\n color: ", ";\n }\n"])), MAX_WIDTH, MAX_HEIGHT, function (props) {
return props.theme.scrollBar;
}, function (props) {
return props.theme.fontFamily;
}, function (props) {
return props.theme.panelBackground;
}, function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.panelBoxShadow;
}, function (props) {
return "".concat(props.theme.panelBackground);
}, function (props) {
return props.theme.notificationColors.success;
}, function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.textColorHl;
});
var PinnedButtons = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-self: center;\n align-items: center;\n justify-items: center;\n & > * + * {\n margin-left: 10px;\n }\n"])));
var PopoverContent = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n & > * + * {\n margin-top: 12px;\n }\n"])));
var StyledIcon = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n\n &:hover {\n cursor: pointer;\n color: ", ";\n }\n"])), function (props) {
return props.theme.activeColor;
}, function (props) {
return props.theme.linkBtnColor;
});
var StyledSelectGeometry = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n color: ", ";\n svg {\n margin-right: 6px;\n }\n\n &:hover {\n cursor: pointer;\n color: ", ";\n }\n"])), function (props) {
return props.theme.textColorHl;
}, function (props) {
return props.theme.linkBtnColor;
});
MapPopoverFactory.deps = [_mapPopoverContent["default"]];
function getSelectedFeature(layerHoverProp) {
var _layer$config, _layer$config2;
var layer = layerHoverProp === null || layerHoverProp === void 0 ? void 0 : layerHoverProp.layer;
var fieldIdx;
var selectedFeature;
switch (layer === null || layer === void 0 ? void 0 : layer.type) {
case _constants.LAYER_TYPES.hexagonId:
fieldIdx = (_layer$config = layer.config) === null || _layer$config === void 0 || (_layer$config = _layer$config.columns) === null || _layer$config === void 0 || (_layer$config = _layer$config.hex_id) === null || _layer$config === void 0 ? void 0 : _layer$config.fieldIdx;
selectedFeature = (0, _commonUtils.idToPolygonGeo)({
id: (0, _reducers.getLayerHoverPropValue)(layerHoverProp === null || layerHoverProp === void 0 ? void 0 : layerHoverProp.data, fieldIdx)
}, {
isClosed: true
});
break;
case _constants.LAYER_TYPES.geojson:
fieldIdx = (_layer$config2 = layer.config) === null || _layer$config2 === void 0 || (_layer$config2 = _layer$config2.columns) === null || _layer$config2 === void 0 || (_layer$config2 = _layer$config2.geojson) === null || _layer$config2 === void 0 ? void 0 : _layer$config2.fieldIdx;
selectedFeature = (0, _layers.parseGeoJsonRawFeature)((0, _reducers.getLayerHoverPropValue)(layerHoverProp === null || layerHoverProp === void 0 ? void 0 : layerHoverProp.data, fieldIdx));
break;
default:
break;
}
if (selectedFeature) {
return _objectSpread(_objectSpread({}, selectedFeature), {}, {
// unique id should be assigned to features in the editor
id: (0, _commonUtils.generateHashId)(8)
});
} else {
return null;
}
}
function MapPopoverFactory(MapPopoverContent) {
var MapPopover = function MapPopover(_ref) {
var _layerHoverProp$layer, _layerHoverProp$layer2;
var x = _ref.x,
y = _ref.y,
frozen = _ref.frozen,
coordinate = _ref.coordinate,
layerHoverProp = _ref.layerHoverProp,
isBase = _ref.isBase,
zoom = _ref.zoom,
container = _ref.container,
onClose = _ref.onClose,
onSetFeatures = _ref.onSetFeatures,
setSelectedFeature = _ref.setSelectedFeature,
featureCollection = _ref.featureCollection;
var _useState = (0, _react.useState)('start'),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
horizontalPlacement = _useState2[0],
setHorizontalPlacement = _useState2[1];
var moveLeft = function moveLeft() {
return setHorizontalPlacement('end');
};
var moveRight = function moveRight() {
return setHorizontalPlacement('start');
};
var rootContext = (0, _react.useContext)(_context.RootContext);
var _useFloating = (0, _react2.useFloating)({
placement: "".concat(horizontalPlacement == 'end' ? 'left' : 'right', "-start"),
middleware: [(0, _react2.offset)({
mainAxis: 20,
alignmentAxis: 20
}), (0, _react2.flip)()]
}),
refs = _useFloating.refs,
context = _useFloating.context,
floatingStyles = _useFloating.floatingStyles;
var onSetSelectedFeature = (0, _react.useCallback)(function () {
var clickContext = {
mapIndex: 0,
rightClick: true,
position: {
x: x,
y: y
}
};
var selectedFeature = getSelectedFeature(layerHoverProp);
if (selectedFeature) {
setSelectedFeature(selectedFeature, clickContext);
var updatedFeatures = featureCollection ? [].concat((0, _toConsumableArray2["default"])(featureCollection.features), [selectedFeature]) : [selectedFeature];
onSetFeatures(updatedFeatures);
}
onClose();
}, [onClose, onSetFeatures, x, y, setSelectedFeature, layerHoverProp, featureCollection]);
var containerBounds = container === null || container === void 0 ? void 0 : container.getBoundingClientRect();
var clientPoint = (0, _react2.useClientPoint)(context, {
x: ((containerBounds === null || containerBounds === void 0 ? void 0 : containerBounds.left) || 0) + x,
y: ((containerBounds === null || containerBounds === void 0 ? void 0 : containerBounds.top) || 0) + y
});
var _useInteractions = (0, _react2.useInteractions)([clientPoint]),
getFloatingProps = _useInteractions.getFloatingProps;
return /*#__PURE__*/_react["default"].createElement(_react2.FloatingPortal, {
root: rootContext === null || rootContext === void 0 ? void 0 : rootContext.current
}, /*#__PURE__*/_react["default"].createElement(StyledMapPopover, (0, _extends2["default"])({
className: "map-popover",
ref: refs.setFloating,
style: floatingStyles
}, getFloatingProps()), frozen ? /*#__PURE__*/_react["default"].createElement(PinnedButtons, null, horizontalPlacement === 'start' && /*#__PURE__*/_react["default"].createElement(StyledIcon, {
className: "popover-arrow-left",
onClick: moveLeft
}, /*#__PURE__*/_react["default"].createElement(_icons.ArrowLeft, null)), /*#__PURE__*/_react["default"].createElement(StyledIcon, {
className: "popover-pin",
onClick: onClose
}, /*#__PURE__*/_react["default"].createElement(_icons.Pin, {
height: "16px"
})), horizontalPlacement === 'end' && /*#__PURE__*/_react["default"].createElement(StyledIcon, {
className: "popover-arrow-right",
onClick: moveRight
}, /*#__PURE__*/_react["default"].createElement(_icons.ArrowRight, null)), isBase && /*#__PURE__*/_react["default"].createElement("div", {
className: "primary-label"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "mapPopover.primary"
}))) : null, /*#__PURE__*/_react["default"].createElement(PopoverContent, null, /*#__PURE__*/_react["default"].createElement(MapPopoverContent, {
coordinate: coordinate,
zoom: zoom,
layerHoverProp: layerHoverProp
})), layerHoverProp !== null && layerHoverProp !== void 0 && (_layerHoverProp$layer = layerHoverProp.layer) !== null && _layerHoverProp$layer !== void 0 && _layerHoverProp$layer.type && SELECTABLE_LAYERS.includes(layerHoverProp === null || layerHoverProp === void 0 || (_layerHoverProp$layer2 = layerHoverProp.layer) === null || _layerHoverProp$layer2 === void 0 ? void 0 : _layerHoverProp$layer2.type) && frozen ? /*#__PURE__*/_react["default"].createElement(StyledSelectGeometry, {
className: "select-geometry",
onClick: onSetSelectedFeature
}, /*#__PURE__*/_react["default"].createElement(_icons.CursorPoint, null), "Select Geometry") : null));
};
return (0, _reactIntl.injectIntl)(MapPopover);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_mapPopoverContent","_icons","_reactIntl","_localization","_context","_layers","_commonUtils","_constants","_reducers","_react2","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","SELECTABLE_LAYERS","LAYER_TYPES","hexagonId","geojson","MAX_WIDTH","MAX_HEIGHT","StyledMapPopover","styled","div","_taggedTemplateLiteral2","props","theme","scrollBar","fontFamily","panelBackground","textColor","panelBoxShadow","concat","notificationColors","success","textColorHl","PinnedButtons","PopoverContent","StyledIcon","activeColor","linkBtnColor","StyledSelectGeometry","MapPopoverFactory","deps","MapPopoverContentFactory","getSelectedFeature","layerHoverProp","_layer$config","_layer$config2","layer","fieldIdx","selectedFeature","type","config","columns","hex_id","idToPolygonGeo","id","getLayerHoverPropValue","data","isClosed","parseGeoJsonRawFeature","generateHashId","MapPopoverContent","MapPopover","_ref","_layerHoverProp$layer","_layerHoverProp$layer2","x","y","frozen","coordinate","isBase","zoom","container","onClose","onSetFeatures","setSelectedFeature","featureCollection","_useState","useState","_useState2","_slicedToArray2","horizontalPlacement","setHorizontalPlacement","moveLeft","moveRight","rootContext","useContext","RootContext","_useFloating","useFloating","placement","middleware","offset","mainAxis","alignmentAxis","flip","refs","context","floatingStyles","onSetSelectedFeature","useCallback","clickContext","mapIndex","rightClick","position","updatedFeatures","_toConsumableArray2","features","containerBounds","getBoundingClientRect","clientPoint","useClientPoint","left","top","_useInteractions","useInteractions","getFloatingProps","createElement","FloatingPortal","root","current","_extends2","className","ref","setFloating","style","onClick","ArrowLeft","Pin","height","ArrowRight","FormattedMessage","includes","CursorPoint","injectIntl"],"sources":["../../src/map/map-popover.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useState, useCallback, useContext} from 'react';\nimport styled from 'styled-components';\nimport MapPopoverContentFactory from './map-popover-content';\nimport {Pin, ArrowLeft, ArrowRight, CursorPoint} from '../common/icons';\nimport {injectIntl, IntlShape} from 'react-intl';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {RootContext} from '../context';\nimport {parseGeoJsonRawFeature} from '@kepler.gl/layers';\nimport {generateHashId, idToPolygonGeo} from '@kepler.gl/common-utils';\nimport {LAYER_TYPES} from '@kepler.gl/constants';\nimport {LayerHoverProp, getLayerHoverPropValue} from '@kepler.gl/reducers';\nimport {Feature, FeatureSelectionContext} from '@kepler.gl/types';\nimport {\n  FloatingPortal,\n  flip,\n  offset,\n  useClientPoint,\n  useFloating,\n  useInteractions\n} from '@floating-ui/react';\n\nconst SELECTABLE_LAYERS: string[] = [LAYER_TYPES.hexagonId, LAYER_TYPES.geojson];\nconst MAX_WIDTH = 500;\nconst MAX_HEIGHT = 600;\n\nconst StyledMapPopover = styled.div`\n  display: flex;\n  flex-direction: column;\n\n  max-width: ${MAX_WIDTH}px;\n  max-height: ${MAX_HEIGHT}px;\n  padding: 14px;\n  & > * + * {\n    margin-top: 6px;\n  }\n  ${props => props.theme.scrollBar};\n  font-family: ${props => props.theme.fontFamily};\n  font-size: 11px;\n  font-weight: 500;\n  background-color: ${props => props.theme.panelBackground};\n  color: ${props => props.theme.textColor};\n  z-index: 98; /* should be below 99 which is side pane */\n  overflow-x: auto;\n  box-shadow: ${props => props.theme.panelBoxShadow};\n\n  &:hover {\n    background-color: ${props => `${props.theme.panelBackground}`};\n  }\n\n  .primary-label {\n    color: ${props => props.theme.notificationColors.success};\n    font-size: 10px;\n  }\n\n  .map-popover__layer-info,\n  .coordingate-hover-info {\n    & > * + * {\n      margin-top: 7px;\n    }\n  }\n\n  table {\n    width: auto;\n    display: grid;\n    border-collapse: collapse;\n    row-gap: 5px;\n    column-gap: 5px;\n  }\n\n  .coordingate-hover-info > table {\n    grid-template-columns: auto auto auto;\n  }\n  .map-popover__layer-info > table {\n    grid-template-columns: auto auto;\n  }\n\n  tbody,\n  tr {\n    display: contents;\n  }\n\n  td {\n    border-color: transparent;\n    color: ${props => props.theme.textColor};\n  }\n\n  td.row__value {\n    text-align: right;\n    font-weight: 500;\n    color: ${props => props.theme.textColorHl};\n  }\n`;\n\nconst PinnedButtons = styled.div`\n  display: flex;\n  align-self: center;\n  align-items: center;\n  justify-items: center;\n  & > * + * {\n    margin-left: 10px;\n  }\n`;\n\nconst PopoverContent = styled.div`\n  display: flex;\n  flex-direction: column;\n  & > * + * {\n    margin-top: 12px;\n  }\n`;\n\nconst StyledIcon = styled.div`\n  color: ${props => props.theme.activeColor};\n\n  &:hover {\n    cursor: pointer;\n    color: ${props => props.theme.linkBtnColor};\n  }\n`;\n\nconst StyledSelectGeometry = styled.div`\n  display: flex;\n  align-items: center;\n  color: ${props => props.theme.textColorHl};\n  svg {\n    margin-right: 6px;\n  }\n\n  &:hover {\n    cursor: pointer;\n    color: ${props => props.theme.linkBtnColor};\n  }\n`;\n\nMapPopoverFactory.deps = [MapPopoverContentFactory];\n\nexport function getSelectedFeature(layerHoverProp: LayerHoverProp | null): Feature | null {\n  const layer = layerHoverProp?.layer;\n  let fieldIdx;\n  let selectedFeature;\n  switch (layer?.type) {\n    case LAYER_TYPES.hexagonId:\n      fieldIdx = layer.config?.columns?.hex_id?.fieldIdx;\n      selectedFeature = idToPolygonGeo(\n        {id: getLayerHoverPropValue(layerHoverProp?.data, fieldIdx)},\n        {isClosed: true}\n      );\n      break;\n    case LAYER_TYPES.geojson:\n      fieldIdx = layer.config?.columns?.geojson?.fieldIdx;\n      selectedFeature = parseGeoJsonRawFeature(\n        getLayerHoverPropValue(layerHoverProp?.data, fieldIdx)\n      );\n      break;\n    default:\n      break;\n  }\n\n  if (selectedFeature) {\n    return {\n      ...selectedFeature,\n      // unique id should be assigned to features in the editor\n      id: generateHashId(8)\n    };\n  } else {\n    return null;\n  }\n}\n\nexport type MapPopoverProps = {\n  x: number;\n  y: number;\n  frozen?: boolean;\n  coordinate: [number, number] | boolean;\n  layerHoverProp: LayerHoverProp | null;\n  isBase?: boolean;\n  zoom: number;\n  container?: HTMLElement | null;\n  onClose: () => void;\n  onSetFeatures: (features: Feature[]) => any;\n  setSelectedFeature: (feature: Feature | null, clickContext?: FeatureSelectionContext) => any;\n  featureCollection?: {\n    type: string;\n    features: Feature[];\n  };\n};\n\ntype IntlProps = {\n  intl: IntlShape;\n};\n\nexport default function MapPopoverFactory(\n  MapPopoverContent: ReturnType<typeof MapPopoverContentFactory>\n) {\n  const MapPopover: React.FC<MapPopoverProps & IntlProps> = ({\n    x,\n    y,\n    frozen,\n    coordinate,\n    layerHoverProp,\n    isBase,\n    zoom,\n    container,\n    onClose,\n    onSetFeatures,\n    setSelectedFeature,\n    featureCollection\n  }) => {\n    const [horizontalPlacement, setHorizontalPlacement] = useState('start');\n    const moveLeft = () => setHorizontalPlacement('end');\n    const moveRight = () => setHorizontalPlacement('start');\n    const rootContext = useContext(RootContext);\n    const {refs, context, floatingStyles} = useFloating({\n      placement: `${horizontalPlacement == 'end' ? 'left' : 'right'}-start`,\n      middleware: [offset({mainAxis: 20, alignmentAxis: 20}), flip()]\n    });\n    const onSetSelectedFeature = useCallback(() => {\n      const clickContext = {\n        mapIndex: 0,\n        rightClick: true,\n        position: {x, y}\n      };\n      const selectedFeature = getSelectedFeature(layerHoverProp);\n      if (selectedFeature) {\n        setSelectedFeature(selectedFeature, clickContext);\n        const updatedFeatures = featureCollection\n          ? [...featureCollection.features, selectedFeature]\n          : [selectedFeature];\n        onSetFeatures(updatedFeatures);\n      }\n      onClose();\n    }, [onClose, onSetFeatures, x, y, setSelectedFeature, layerHoverProp, featureCollection]);\n\n    const containerBounds = container?.getBoundingClientRect();\n    const clientPoint = useClientPoint(context, {\n      x: (containerBounds?.left || 0) + x,\n      y: (containerBounds?.top || 0) + y\n    });\n    const {getFloatingProps} = useInteractions([clientPoint]);\n\n    return (\n      <FloatingPortal root={rootContext?.current}>\n        <StyledMapPopover\n          className=\"map-popover\"\n          ref={refs.setFloating}\n          style={floatingStyles}\n          {...getFloatingProps()}\n        >\n          {frozen ? (\n            <PinnedButtons>\n              {horizontalPlacement === 'start' && (\n                <StyledIcon className=\"popover-arrow-left\" onClick={moveLeft}>\n                  <ArrowLeft />\n                </StyledIcon>\n              )}\n              <StyledIcon className=\"popover-pin\" onClick={onClose}>\n                <Pin height=\"16px\" />\n              </StyledIcon>\n              {horizontalPlacement === 'end' && (\n                <StyledIcon className=\"popover-arrow-right\" onClick={moveRight}>\n                  <ArrowRight />\n                </StyledIcon>\n              )}\n              {isBase && (\n                <div className=\"primary-label\">\n                  <FormattedMessage id=\"mapPopover.primary\" />\n                </div>\n              )}\n            </PinnedButtons>\n          ) : null}\n          <PopoverContent>\n            <MapPopoverContent\n              coordinate={coordinate}\n              zoom={zoom}\n              layerHoverProp={layerHoverProp}\n            />\n          </PopoverContent>\n          {layerHoverProp?.layer?.type &&\n          SELECTABLE_LAYERS.includes(layerHoverProp?.layer?.type) &&\n          frozen ? (\n            <StyledSelectGeometry className=\"select-geometry\" onClick={onSetSelectedFeature}>\n              <CursorPoint />\n              Select Geometry\n            </StyledSelectGeometry>\n          ) : null}\n        </StyledMapPopover>\n      </FloatingPortal>\n    );\n  };\n  return injectIntl(MapPopover);\n}\n"],"mappings":"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","ignoreList":[]}