kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
237 lines (234 loc) • 41.5 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = PlotContainerFactory;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _reselect = require("reselect");
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reactMapGl = require("react-map-gl");
var _debounce = _interopRequireDefault(require("lodash/debounce"));
var _utils = require("@kepler.gl/utils");
var _reducers = require("@kepler.gl/reducers");
var _mapContainer = _interopRequireDefault(require("./map-container"));
var _mapsLayout = _interopRequireDefault(require("./maps-layout"));
var _mapViewStateContext = require("./map-view-state-context");
var _constants = require("@kepler.gl/constants");
var _templateObject, _templateObject2; // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
// libraries
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; }
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
var CLASS_FILTER = ['maplibregl-control-container', 'mapboxgl-control-container', 'attrition-link', 'attrition-logo', 'map-control__panel-split-viewport-tools'];
var DOM_FILTER_FUNC = function DOM_FILTER_FUNC(node) {
return !CLASS_FILTER.includes(node.className);
};
var OUT_OF_SCREEN_POSITION = -9999;
PlotContainerFactory.deps = [_mapContainer["default"], _mapsLayout["default"]];
// Remove mapbox logo in exported map, because it contains non-ascii characters
// Remove split viewport UI controls from exported images when the legend is shown
var StyledPlotContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n .maplibregl-ctrl-bottom-left,\n .maplibregl-ctrl-bottom-right,\n .maplibre-attribution-container,\n .mapboxgl-ctrl-bottom-left,\n .mapboxgl-ctrl-bottom-right,\n .mapbox-attribution-container,\n .map-control__panel-split-viewport-tools {\n display: none;\n }\n\n position: absolute;\n top: ", "px;\n left: ", "px;\n"])), OUT_OF_SCREEN_POSITION, OUT_OF_SCREEN_POSITION);
var StyledMapContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", "px;\n height: ", "px;\n display: flex;\n"])), function (props) {
return props.width;
}, function (props) {
return props.height;
});
function PlotContainerFactory(MapContainer, MapsLayout) {
var PlotContainer = /*#__PURE__*/function (_Component) {
function PlotContainer(_props) {
var _this;
(0, _classCallCheck2["default"])(this, PlotContainer);
_this = _callSuper(this, PlotContainer, [_props]);
(0, _defineProperty2["default"])(_this, "plottingAreaRef", /*#__PURE__*/(0, _react.createRef)());
(0, _defineProperty2["default"])(_this, "mapStyleSelector", function (props) {
return props.mapFields.mapStyle;
});
(0, _defineProperty2["default"])(_this, "mapScaleSelector", function (props) {
var imageSize = props.exportImageSetting.imageSize;
var mapState = props.mapFields.mapState;
if (imageSize.scale) {
return imageSize.scale;
}
var scale = (0, _utils.getScaleFromImageSize)(imageSize.imageW, imageSize.imageH, mapState.width * (mapState.isSplit ? 2 : 1), mapState.height);
return scale > 0 ? scale : 1;
});
(0, _defineProperty2["default"])(_this, "scaledMapStyleSelector", (0, _reselect.createSelector)(_this.mapStyleSelector, _this.mapScaleSelector, function (mapStyle, scale) {
return _objectSpread(_objectSpread({}, mapStyle), {}, {
bottomMapStyle: (0, _utils.scaleMapStyleByResolution)(mapStyle.bottomMapStyle, scale),
topMapStyle: (0, _utils.scaleMapStyleByResolution)(mapStyle.topMapStyle, scale)
});
}));
(0, _defineProperty2["default"])(_this, "_onMapRender", function (map) {
if (map.isStyleLoaded()) {
_this._retrieveNewScreenshot();
}
});
(0, _defineProperty2["default"])(_this, "_retrieveNewScreenshot", function () {
if (_this.plottingAreaRef.current) {
var _this$props$exportIma = _this.props.exportImageSetting,
imageSize = _this$props$exportIma.imageSize,
escapeXhtmlForWebpack = _this$props$exportIma.escapeXhtmlForWebpack;
(0, _utils.convertToPng)(_this.plottingAreaRef.current, {
filter: DOM_FILTER_FUNC,
width: imageSize.imageW,
height: imageSize.imageH,
escapeXhtmlForWebpack: escapeXhtmlForWebpack
}).then(_this.props.setExportImageDataUri)["catch"](function (err) {
_this.props.setExportImageError(err);
if (_this.props.enableErrorNotification) {
_this.props.addNotification((0, _utils.exportImageError)({
err: err
}));
}
});
}
});
_this._onMapRender = (0, _debounce["default"])(_this._onMapRender, 500);
_this._retrieveNewScreenshot = (0, _debounce["default"])(_this._retrieveNewScreenshot, 500);
_this.state = {
plotEffects: _this.getEffectsForPlot()
};
return _this;
}
(0, _inherits2["default"])(PlotContainer, _Component);
return (0, _createClass2["default"])(PlotContainer, [{
key: "getEffectsForPlot",
value: function getEffectsForPlot() {
return this.props.mapFields.visState.effects.map(function (effect) {
return effect.clone();
});
}
}, {
key: "componentDidMount",
value: function componentDidMount() {
this.props.setExportImageSetting({
processing: true
});
}
}, {
key: "componentDidUpdate",
value: function componentDidUpdate(prevProps) {
var _this2 = this;
// re-fetch the new screenshot only when ratio legend or resolution changes
var checks = ['ratio', 'resolution', 'legend'];
var shouldRetrieveScreenshot = checks.some(function (item) {
return _this2.props.exportImageSetting[item] !== prevProps.exportImageSetting[item];
});
if (shouldRetrieveScreenshot) {
this.props.setExportImageSetting({
processing: true
});
this._retrieveNewScreenshot();
}
}
}, {
key: "render",
value: function render() {
var _this$props = this.props,
exportImageSetting = _this$props.exportImageSetting,
mapFields = _this$props.mapFields,
_this$props$splitMaps = _this$props.splitMaps,
splitMaps = _this$props$splitMaps === void 0 ? [] : _this$props$splitMaps;
var mapState = mapFields.mapState,
visState = mapFields.visState;
var layers = visState.layers,
layerData = visState.layerData;
var imageSize = exportImageSetting.imageSize,
legend = exportImageSetting.legend;
var isSplit = splitMaps && splitMaps.length > 1;
var size = {
width: (imageSize === null || imageSize === void 0 ? void 0 : imageSize.imageW) || 1,
height: (imageSize === null || imageSize === void 0 ? void 0 : imageSize.imageH) || 1
};
var width = size.width / (isSplit ? 2 : 1);
var height = size.height;
var scale = this.mapScaleSelector(this.props);
var newMapState = _objectSpread(_objectSpread({}, mapState), {}, {
width: width,
height: height,
zoom: mapState.zoom + (Math.log2(scale) || 0)
});
// center and all layer bounds
if (exportImageSetting.center) {
var renderedLayers = layers.filter(function (layer, idx) {
return layer.id !== _constants.GEOCODER_LAYER_ID && layer.shouldRenderLayer(layerData[idx]);
});
var bounds = (0, _reducers.findMapBounds)(renderedLayers);
var centerAndZoom = (0, _utils.getCenterAndZoomFromBounds)(bounds, {
width: width,
height: height
});
if (centerAndZoom) {
var zoom = Number.isFinite(centerAndZoom.zoom) ? centerAndZoom.zoom : mapState.zoom;
newMapState.longitude = centerAndZoom.center[0];
newMapState.latitude = centerAndZoom.center[1];
newMapState.zoom = zoom + Number(Math.log2(scale) || 0);
}
}
var mapProps = _objectSpread(_objectSpread({}, mapFields), {}, {
mapStyle: this.scaledMapStyleSelector(this.props),
// override viewport based on export settings
mapState: newMapState,
mapControls: {
// override map legend visibility
mapLegend: {
show: legend,
active: true
}
},
MapComponent: _reactMapGl.Map,
onMapRender: this._onMapRender,
isExport: true,
deckGlProps: _objectSpread(_objectSpread({}, mapFields.deckGlProps), {}, {
glOptions: {
preserveDrawingBuffer: true,
useDevicePixels: false
}
}),
visState: _objectSpread(_objectSpread({}, mapFields.visState), {}, {
// Make sure to use effects not associated with a different WebGL context
effects: this.state.plotEffects
})
});
var mapContainers = !isSplit ? /*#__PURE__*/_react["default"].createElement(MapContainer, (0, _extends2["default"])({
index: 0,
primary: true
}, mapProps)) : /*#__PURE__*/_react["default"].createElement(MapsLayout, {
className: "plot-container-maps",
mapState: newMapState
}, splitMaps.map(function (settings, index) {
return /*#__PURE__*/_react["default"].createElement(MapContainer, (0, _extends2["default"])({
key: index,
index: index,
primary: index === 1
}, mapProps));
}));
return /*#__PURE__*/_react["default"].createElement(StyledPlotContainer, {
className: "export-map-instance"
}, /*#__PURE__*/_react["default"].createElement(StyledMapContainer, {
ref: this.plottingAreaRef,
width: size.width,
height: size.height
}, /*#__PURE__*/_react["default"].createElement(_mapViewStateContext.MapViewStateContextProvider, {
mapState: newMapState
}, mapContainers)));
}
}]);
}(_react.Component);
return PlotContainer;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reselect","_styledComponents","_interopRequireDefault","_reactMapGl","_debounce","_utils","_reducers","_mapContainer","_mapsLayout","_mapViewStateContext","_constants","_templateObject","_templateObject2","_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","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","Boolean","prototype","valueOf","CLASS_FILTER","DOM_FILTER_FUNC","node","includes","className","OUT_OF_SCREEN_POSITION","PlotContainerFactory","deps","MapContainerFactory","MapsLayoutFactory","StyledPlotContainer","styled","div","_taggedTemplateLiteral2","StyledMapContainer","props","width","height","MapContainer","MapsLayout","PlotContainer","_Component","_this","_classCallCheck2","createRef","mapFields","mapStyle","imageSize","exportImageSetting","mapState","scale","getScaleFromImageSize","imageW","imageH","isSplit","createSelector","mapStyleSelector","mapScaleSelector","bottomMapStyle","scaleMapStyleByResolution","topMapStyle","map","isStyleLoaded","_retrieveNewScreenshot","plottingAreaRef","current","_this$props$exportIma","escapeXhtmlForWebpack","convertToPng","then","setExportImageDataUri","err","setExportImageError","enableErrorNotification","addNotification","exportImageError","_onMapRender","debounce","state","plotEffects","getEffectsForPlot","_inherits2","_createClass2","key","value","visState","effects","effect","clone","componentDidMount","setExportImageSetting","processing","componentDidUpdate","prevProps","_this2","checks","shouldRetrieveScreenshot","some","item","render","_this$props","_this$props$splitMaps","splitMaps","layers","layerData","legend","size","newMapState","zoom","Math","log2","center","renderedLayers","layer","idx","id","GEOCODER_LAYER_ID","shouldRenderLayer","bounds","findMapBounds","centerAndZoom","getCenterAndZoomFromBounds","Number","isFinite","longitude","latitude","mapProps","scaledMapStyleSelector","mapControls","mapLegend","show","active","MapComponent","Map","onMapRender","isExport","deckGlProps","glOptions","preserveDrawingBuffer","useDevicePixels","mapContainers","createElement","_extends2","index","primary","settings","ref","MapViewStateContextProvider","Component"],"sources":["../src/plot-container.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\n// libraries\nimport React, {Component, createRef} from 'react';\nimport {createSelector} from 'reselect';\nimport styled from 'styled-components';\nimport {Map} from 'react-map-gl';\nimport debounce from 'lodash/debounce';\nimport {\n  exportImageError,\n  scaleMapStyleByResolution,\n  getCenterAndZoomFromBounds,\n  convertToPng,\n  getScaleFromImageSize\n} from '@kepler.gl/utils';\nimport {findMapBounds} from '@kepler.gl/reducers';\nimport MapContainerFactory from './map-container';\nimport MapsLayoutFactory from './maps-layout';\nimport {MapViewStateContextProvider} from './map-view-state-context';\n\nimport {GEOCODER_LAYER_ID, ExportImage} from '@kepler.gl/constants';\nimport {Effect, SplitMap} from '@kepler.gl/types';\nimport {\n  ActionHandler,\n  addNotification,\n  setExportImageDataUri,\n  setExportImageError,\n  setExportImageSetting\n} from '@kepler.gl/actions';\nimport {mapFieldsSelector} from './kepler-gl';\n\nconst CLASS_FILTER = [\n  'maplibregl-control-container',\n  'mapboxgl-control-container',\n  'attrition-link',\n  'attrition-logo',\n  'map-control__panel-split-viewport-tools'\n];\nconst DOM_FILTER_FUNC = node => !CLASS_FILTER.includes(node.className);\nconst OUT_OF_SCREEN_POSITION = -9999;\n\nPlotContainerFactory.deps = [MapContainerFactory, MapsLayoutFactory];\n\n// Remove mapbox logo in exported map, because it contains non-ascii characters\n// Remove split viewport UI controls from exported images when the legend is shown\nconst StyledPlotContainer = styled.div`\n  .maplibregl-ctrl-bottom-left,\n  .maplibregl-ctrl-bottom-right,\n  .maplibre-attribution-container,\n  .mapboxgl-ctrl-bottom-left,\n  .mapboxgl-ctrl-bottom-right,\n  .mapbox-attribution-container,\n  .map-control__panel-split-viewport-tools {\n    display: none;\n  }\n\n  position: absolute;\n  top: ${OUT_OF_SCREEN_POSITION}px;\n  left: ${OUT_OF_SCREEN_POSITION}px;\n`;\n\ninterface StyledMapContainerProps {\n  width?: number;\n  height?: number;\n}\n\nconst StyledMapContainer = styled.div<StyledMapContainerProps>`\n  width: ${props => props.width}px;\n  height: ${props => props.height}px;\n  display: flex;\n`;\n\ninterface PlotContainerProps {\n  width?: number;\n  height?: number;\n  exportImageSetting: ExportImage;\n  addNotification: ActionHandler<typeof addNotification>;\n  mapFields: ReturnType<typeof mapFieldsSelector>;\n  setExportImageSetting: typeof setExportImageSetting;\n  setExportImageDataUri: typeof setExportImageDataUri;\n  setExportImageError: typeof setExportImageError;\n  splitMaps?: SplitMap[];\n  enableErrorNotification?: boolean;\n}\n\ninterface PlotContainerState {\n  plotEffects: Effect[];\n}\n\nexport default function PlotContainerFactory(\n  MapContainer: ReturnType<typeof MapContainerFactory>,\n  MapsLayout: ReturnType<typeof MapsLayoutFactory>\n): React.ComponentType<PlotContainerProps> {\n  class PlotContainer extends Component<PlotContainerProps, PlotContainerState> {\n    constructor(props) {\n      super(props);\n      this._onMapRender = debounce(this._onMapRender, 500);\n      this._retrieveNewScreenshot = debounce(this._retrieveNewScreenshot, 500);\n\n      this.state = {\n        plotEffects: this.getEffectsForPlot()\n      };\n    }\n\n    private getEffectsForPlot() {\n      return this.props.mapFields.visState.effects.map(effect => effect.clone());\n    }\n\n    componentDidMount() {\n      this.props.setExportImageSetting({processing: true});\n    }\n\n    componentDidUpdate(prevProps) {\n      // re-fetch the new screenshot only when ratio legend or resolution changes\n      const checks = ['ratio', 'resolution', 'legend'];\n      const shouldRetrieveScreenshot = checks.some(\n        item => this.props.exportImageSetting[item] !== prevProps.exportImageSetting[item]\n      );\n      if (shouldRetrieveScreenshot) {\n        this.props.setExportImageSetting({processing: true});\n        this._retrieveNewScreenshot();\n      }\n    }\n\n    plottingAreaRef = createRef<HTMLDivElement>();\n\n    mapStyleSelector = props => props.mapFields.mapStyle;\n    mapScaleSelector = props => {\n      const {imageSize} = props.exportImageSetting;\n      const {mapState} = props.mapFields;\n      if (imageSize.scale) {\n        return imageSize.scale;\n      }\n\n      const scale = getScaleFromImageSize(\n        imageSize.imageW,\n        imageSize.imageH,\n        mapState.width * (mapState.isSplit ? 2 : 1),\n        mapState.height\n      );\n\n      return scale > 0 ? scale : 1;\n    };\n\n    scaledMapStyleSelector = createSelector(\n      this.mapStyleSelector,\n      this.mapScaleSelector,\n      (mapStyle, scale) => ({\n        ...mapStyle,\n        bottomMapStyle: scaleMapStyleByResolution(mapStyle.bottomMapStyle, scale),\n        topMapStyle: scaleMapStyleByResolution(mapStyle.topMapStyle, scale)\n      })\n    );\n\n    _onMapRender = map => {\n      if (map.isStyleLoaded()) {\n        this._retrieveNewScreenshot();\n      }\n    };\n\n    _retrieveNewScreenshot = () => {\n      if (this.plottingAreaRef.current) {\n        const {imageSize, escapeXhtmlForWebpack} = this.props.exportImageSetting;\n        convertToPng(this.plottingAreaRef.current, {\n          filter: DOM_FILTER_FUNC,\n          width: imageSize.imageW,\n          height: imageSize.imageH,\n          escapeXhtmlForWebpack\n        })\n          .then(this.props.setExportImageDataUri)\n          .catch(err => {\n            this.props.setExportImageError(err);\n            if (this.props.enableErrorNotification) {\n              this.props.addNotification(exportImageError({err}));\n            }\n          });\n      }\n    };\n\n    render() {\n      const {exportImageSetting, mapFields, splitMaps = []} = this.props;\n      const {mapState, visState} = mapFields;\n      const {layers, layerData} = visState;\n      const {imageSize, legend} = exportImageSetting;\n\n      const isSplit = splitMaps && splitMaps.length > 1;\n\n      const size = {\n        width: imageSize?.imageW || 1,\n        height: imageSize?.imageH || 1\n      };\n      const width = size.width / (isSplit ? 2 : 1);\n      const height = size.height;\n      const scale = this.mapScaleSelector(this.props);\n      const newMapState = {\n        ...mapState,\n        width,\n        height,\n        zoom: mapState.zoom + (Math.log2(scale) || 0)\n      };\n\n      // center and all layer bounds\n      if (exportImageSetting.center) {\n        const renderedLayers = layers.filter(\n          (layer, idx) => layer.id !== GEOCODER_LAYER_ID && layer.shouldRenderLayer(layerData[idx])\n        );\n        const bounds = findMapBounds(renderedLayers);\n        const centerAndZoom = getCenterAndZoomFromBounds(bounds, {width, height});\n        if (centerAndZoom) {\n          const zoom = Number.isFinite(centerAndZoom.zoom) ? centerAndZoom.zoom : mapState.zoom;\n\n          newMapState.longitude = centerAndZoom.center[0];\n          newMapState.latitude = centerAndZoom.center[1];\n          newMapState.zoom = zoom + Number(Math.log2(scale) || 0);\n        }\n      }\n\n      const mapProps = {\n        ...mapFields,\n        mapStyle: this.scaledMapStyleSelector(this.props),\n\n        // override viewport based on export settings\n        mapState: newMapState,\n        mapControls: {\n          // override map legend visibility\n          mapLegend: {\n            show: legend,\n            active: true\n          }\n        },\n        MapComponent: Map,\n        onMapRender: this._onMapRender,\n        isExport: true,\n        deckGlProps: {\n          ...mapFields.deckGlProps,\n          glOptions: {\n            preserveDrawingBuffer: true,\n            useDevicePixels: false\n          }\n        },\n        visState: {\n          ...mapFields.visState,\n          // Make sure to use effects not associated with a different WebGL context\n          effects: this.state.plotEffects\n        }\n      };\n\n      const mapContainers = !isSplit ? (\n        <MapContainer index={0} primary={true} {...mapProps} />\n      ) : (\n        <MapsLayout className=\"plot-container-maps\" mapState={newMapState}>\n          {splitMaps.map((settings, index) => (\n            <MapContainer key={index} index={index} primary={index === 1} {...mapProps} />\n          ))}\n        </MapsLayout>\n      );\n      return (\n        <StyledPlotContainer className=\"export-map-instance\">\n          <StyledMapContainer ref={this.plottingAreaRef} width={size.width} height={size.height}>\n            <MapViewStateContextProvider mapState={newMapState}>\n              {mapContainers}\n            </MapViewStateContextProvider>\n          </StyledMapContainer>\n        </StyledPlotContainer>\n      );\n    }\n  }\n  return PlotContainer;\n}\n"],"mappings":"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","ignoreList":[]}
;