kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
624 lines (546 loc) • 81.9 kB
JavaScript
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = MapContainerFactory;
exports.Attribution = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _reactMapGl = _interopRequireDefault(require("react-map-gl"));
var _react2 = _interopRequireDefault(require("@deck.gl/react"));
var _reselect = require("reselect");
var _viewportMercatorProject = _interopRequireDefault(require("viewport-mercator-project"));
var _notificationsUtils = require("../utils/notifications-utils");
var _mapPopover = _interopRequireDefault(require("./map/map-popover"));
var _mapControl = _interopRequireDefault(require("./map/map-control"));
var _styledComponents = require("./common/styled-components");
var _editor = _interopRequireDefault(require("./editor/editor"));
var _mapboxUtils = require("../layers/mapbox-utils");
var _glUtils = require("../utils/gl-utils");
var _mapboxUtils2 = require("../utils/map-style-utils/mapbox-utils");
var _layerUtils = require("../utils/layer-utils");
var _dBuildingLayer = _interopRequireDefault(require("../deckgl-layers/3d-building-layer/3d-building-layer"));
var _defaultSettings = require("../constants/default-settings");
var _errorBoundary = _interopRequireDefault(require("./common/error-boundary"));
var _observeDimensions = require("../utils/observe-dimensions");
var _locales = require("../localization/locales");
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
/** @type {{[key: string]: React.CSSProperties}} */
var MAP_STYLE = {
container: {
display: 'inline-block',
position: 'relative',
width: '100%',
height: '100%'
},
top: {
position: 'absolute',
top: '0px',
pointerEvents: 'none',
width: '100%',
height: '100%'
}
};
var MAPBOXGL_STYLE_UPDATE = 'style.load';
var MAPBOXGL_RENDER = 'render';
var TRANSITION_DURATION = 0;
var Attribution = function Attribution() {
return /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledAttrbution, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "attrition-logo"
}, "Basemap by:", /*#__PURE__*/_react["default"].createElement("a", {
className: "mapboxgl-ctrl-logo",
target: "_blank",
rel: "noopener noreferrer",
href: "https://www.mapbox.com/",
"aria-label": "Mapbox logo"
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "attrition-link"
}, /*#__PURE__*/_react["default"].createElement("a", {
href: "https://kepler.gl/policy/",
target: "_blank",
rel: "noopener noreferrer"
}, "\xA9 kepler.gl |", ' '), /*#__PURE__*/_react["default"].createElement("a", {
href: "https://www.mapbox.com/about/maps/",
target: "_blank",
rel: "noopener noreferrer"
}, "\xA9 Mapbox |", ' '), /*#__PURE__*/_react["default"].createElement("a", {
href: "http://www.openstreetmap.org/copyright",
target: "_blank",
rel: "noopener noreferrer"
}, "\xA9 OpenStreetMap |", ' '), /*#__PURE__*/_react["default"].createElement("a", {
href: "https://www.mapbox.com/map-feedback/",
target: "_blank",
rel: "noopener noreferrer"
}, /*#__PURE__*/_react["default"].createElement("strong", null, "Improve this map"))));
};
exports.Attribution = Attribution;
MapContainerFactory.deps = [_mapPopover["default"], _mapControl["default"], _editor["default"]];
function MapContainerFactory(MapPopover, MapControl, Editor) {
var MapContainer = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(MapContainer, _Component);
var _super = _createSuper(MapContainer);
function MapContainer(_props) {
var _this;
(0, _classCallCheck2["default"])(this, MapContainer);
_this = _super.call(this, _props);
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_handleResize", function (dimensions) {
var primary = _this.props.primary;
if (primary) {
var mapStateActions = _this.props.mapStateActions;
if (dimensions && dimensions.width > 0 && dimensions.height > 0) {
mapStateActions.updateMap(dimensions);
}
}
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "layersSelector", function (props) {
return props.layers;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "layerDataSelector", function (props) {
return props.layerData;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "mapLayersSelector", function (props) {
return props.mapLayers;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "layerOrderSelector", function (props) {
return props.layerOrder;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "layersToRenderSelector", (0, _reselect.createSelector)(_this.layersSelector, _this.layerDataSelector, _this.mapLayersSelector, _layerUtils.prepareLayersToRender));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "layersForDeckSelector", (0, _reselect.createSelector)(_this.layersSelector, _this.layerDataSelector, _layerUtils.prepareLayersForDeck));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "filtersSelector", function (props) {
return props.filters;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "polygonFilters", (0, _reselect.createSelector)(_this.filtersSelector, function (filters) {
return filters.filter(function (f) {
return f.type === _defaultSettings.FILTER_TYPES.polygon;
});
}));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "mapboxLayersSelector", (0, _reselect.createSelector)(_this.layersSelector, _this.layerDataSelector, _this.layerOrderSelector, _this.layersToRenderSelector, _mapboxUtils.generateMapboxLayers));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onCloseMapPopover", function () {
_this.props.visStateActions.onLayerClick(null);
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onLayerSetDomain", function (idx, colorDomain) {
_this.props.visStateActions.layerConfigChange(_this.props.layers[idx], {
colorDomain: colorDomain
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_handleMapToggleLayer", function (layerId) {
var _this$props = _this.props,
_this$props$index = _this$props.index,
mapIndex = _this$props$index === void 0 ? 0 : _this$props$index,
visStateActions = _this$props.visStateActions;
visStateActions.toggleLayerForMap(mapIndex, layerId);
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onMapboxStyleUpdate", function () {
// force refresh mapboxgl layers
_this.previousLayers = {};
_this._updateMapboxLayers();
if (typeof _this.props.onMapStyleLoaded === 'function') {
_this.props.onMapStyleLoaded(_this._map);
}
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_setMapboxMap", function (mapbox) {
if (!_this._map && mapbox) {
_this._map = mapbox.getMap(); // i noticed in certain context we don't access the actual map element
if (!_this._map) {
return;
} // bind mapboxgl event listener
_this._map.on(MAPBOXGL_STYLE_UPDATE, _this._onMapboxStyleUpdate);
_this._map.on(MAPBOXGL_RENDER, function () {
if (typeof _this.props.onMapRender === 'function') {
_this.props.onMapRender(_this._map);
}
});
}
if (_this.props.getMapboxRef) {
// The parent component can gain access to our MapboxGlMap by
// providing this callback. Note that 'mapbox' will be null when the
// ref is unset (e.g. when a split map is closed).
_this.props.getMapboxRef(mapbox, _this.props.index);
}
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onBeforeRender", function (_ref) {
var gl = _ref.gl;
(0, _glUtils.setLayerBlending)(gl, _this.props.layerBlending);
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onDeckError", function (error, layer) {
var errorMessage = "An error in deck.gl: ".concat(error.message, " in ").concat(layer.id);
var notificationId = "".concat(layer.id, "-").concat(error.message); // Throttle error notifications, as React doesn't like too many state changes from here.
_this._deckGLErrorsElapsed = _this._deckGLErrorsElapsed || {};
var lastShown = _this._deckGLErrorsElapsed[notificationId];
if (!lastShown || lastShown < Date.now() - _defaultSettings.THROTTLE_NOTIFICATION_TIME) {
_this._deckGLErrorsElapsed[notificationId] = Date.now(); // Create new error notification or update existing one with same id.
// Update is required to preserve the order of notifications as they probably are going to "jump" based on order of errors.
var uiStateActions = _this.props.uiStateActions;
uiStateActions.addNotification((0, _notificationsUtils.errorNotification)({
message: errorMessage,
id: notificationId
}));
}
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onViewportChange", function (viewState) {
var width = viewState.width,
height = viewState.height,
restViewState = (0, _objectWithoutProperties2["default"])(viewState, ["width", "height"]);
var primary = _this.props.primary; // react-map-gl sends 0,0 dimensions during initialization
// after we have received proper dimensions from observeDimensions
var next = _objectSpread(_objectSpread({}, width > 0 && height > 0 ? viewState : restViewState), {}, {
// enabling transition in two maps may lead to endless update loops
transitionDuration: primary ? TRANSITION_DURATION : 0
});
if (typeof _this.props.onViewStateChange === 'function') {
_this.props.onViewStateChange(next);
}
_this.props.mapStateActions.updateMap(next);
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_toggleMapControl", function (panelId) {
var _this$props2 = _this.props,
index = _this$props2.index,
uiStateActions = _this$props2.uiStateActions;
uiStateActions.toggleMapControl(panelId, index);
});
_this.previousLayers = {// [layers.id]: mapboxLayerConfig
};
_this._deck = null;
_this._ref = /*#__PURE__*/(0, _react.createRef)();
return _this;
}
(0, _createClass2["default"])(MapContainer, [{
key: "componentDidMount",
value: function componentDidMount() {
(0, _observeDimensions.observeDimensions)(this._ref.current, this._handleResize);
}
}, {
key: "componentWillUnmount",
value: function componentWillUnmount() {
// unbind mapboxgl event listener
if (this._map) {
this._map.off(MAPBOXGL_STYLE_UPDATE);
this._map.off(MAPBOXGL_RENDER);
}
(0, _observeDimensions.unobserveDimensions)(this._ref.current);
}
}, {
key: "_onDeckInitialized",
value: function _onDeckInitialized(gl) {
if (this.props.onDeckInitialized) {
this.props.onDeckInitialized(this._deck, gl);
}
}
}, {
key: "_renderMapPopover",
value:
/* component render functions */
/* eslint-disable complexity */
function _renderMapPopover(layersToRender) {
// TODO: move this into reducer so it can be tested
var _this$props3 = this.props,
mapState = _this$props3.mapState,
hoverInfo = _this$props3.hoverInfo,
clicked = _this$props3.clicked,
datasets = _this$props3.datasets,
interactionConfig = _this$props3.interactionConfig,
layers = _this$props3.layers,
_this$props3$mousePos = _this$props3.mousePos,
mousePosition = _this$props3$mousePos.mousePosition,
coordinate = _this$props3$mousePos.coordinate,
pinned = _this$props3$mousePos.pinned;
if (!mousePosition || !interactionConfig.tooltip) {
return null;
}
var layerHoverProp = (0, _layerUtils.getLayerHoverProp)({
interactionConfig: interactionConfig,
hoverInfo: hoverInfo,
layers: layers,
layersToRender: layersToRender,
datasets: datasets
});
var compareMode = interactionConfig.tooltip.config ? interactionConfig.tooltip.config.compareMode : false;
var pinnedPosition = {};
var layerPinnedProp = null;
if (pinned || clicked) {
// project lnglat to screen so that tooltip follows the object on zoom
var viewport = new _viewportMercatorProject["default"](mapState);
var lngLat = clicked ? clicked.lngLat : pinned.coordinate;
pinnedPosition = this._getHoverXY(viewport, lngLat);
layerPinnedProp = (0, _layerUtils.getLayerHoverProp)({
interactionConfig: interactionConfig,
hoverInfo: clicked,
layers: layers,
layersToRender: layersToRender,
datasets: datasets
});
if (layerHoverProp && layerPinnedProp) {
layerHoverProp.primaryData = layerPinnedProp.data;
layerHoverProp.compareType = interactionConfig.tooltip.config.compareType;
}
}
var commonProp = {
onClose: this._onCloseMapPopover,
zoom: mapState.zoom,
container: this._deck ? this._deck.canvas : undefined
};
return /*#__PURE__*/_react["default"].createElement(_errorBoundary["default"], null, layerPinnedProp && /*#__PURE__*/_react["default"].createElement(MapPopover, (0, _extends2["default"])({}, pinnedPosition, commonProp, {
layerHoverProp: layerPinnedProp,
coordinate: interactionConfig.coordinate.enabled && (pinned || {}).coordinate,
frozen: true,
isBase: compareMode
})), layerHoverProp && (!layerPinnedProp || compareMode) && /*#__PURE__*/_react["default"].createElement(MapPopover, (0, _extends2["default"])({
x: mousePosition[0],
y: mousePosition[1]
}, commonProp, {
layerHoverProp: layerHoverProp,
frozen: false,
coordinate: interactionConfig.coordinate.enabled && coordinate
})));
}
/* eslint-enable complexity */
}, {
key: "_getHoverXY",
value: function _getHoverXY(viewport, lngLat) {
var screenCoord = !viewport || !lngLat ? null : viewport.project(lngLat);
return screenCoord && {
x: screenCoord[0],
y: screenCoord[1]
};
}
}, {
key: "_renderDeckOverlay",
value: function _renderDeckOverlay(layersForDeck) {
var _this$props$deckGlPro,
_this2 = this;
var _this$props4 = this.props,
mapState = _this$props4.mapState,
mapStyle = _this$props4.mapStyle,
layerData = _this$props4.layerData,
layerOrder = _this$props4.layerOrder,
layers = _this$props4.layers,
visStateActions = _this$props4.visStateActions,
mapboxApiAccessToken = _this$props4.mapboxApiAccessToken,
mapboxApiUrl = _this$props4.mapboxApiUrl; // initialise layers from props if exists
var deckGlLayers = ((_this$props$deckGlPro = this.props.deckGlProps) === null || _this$props$deckGlPro === void 0 ? void 0 : _this$props$deckGlPro.layers) || []; // wait until data is ready before render data layers
if (layerData && layerData.length) {
// last layer render first
var dataLayers = layerOrder.slice().reverse().filter(function (idx) {
return layersForDeck[layers[idx].id];
}).reduce(function (overlays, idx) {
var layerCallbacks = {
onSetLayerDomain: function onSetLayerDomain(val) {
return _this2._onLayerSetDomain(idx, val);
}
};
var layerOverlay = (0, _layerUtils.renderDeckGlLayer)(_this2.props, layerCallbacks, idx);
return overlays.concat(layerOverlay || []);
}, []);
deckGlLayers = deckGlLayers.concat(dataLayers);
}
if (mapStyle.visibleLayerGroups['3d building']) {
deckGlLayers.push(new _dBuildingLayer["default"]({
id: '_keplergl_3d-building',
mapboxApiAccessToken: mapboxApiAccessToken,
mapboxApiUrl: mapboxApiUrl,
threeDBuildingColor: mapStyle.threeDBuildingColor,
updateTriggers: {
getFillColor: mapStyle.threeDBuildingColor
}
}));
}
return /*#__PURE__*/_react["default"].createElement(_react2["default"], (0, _extends2["default"])({}, this.props.deckGlProps, {
viewState: mapState,
id: "default-deckgl-overlay",
layers: deckGlLayers,
onBeforeRender: this._onBeforeRender,
onHover: visStateActions.onLayerHover,
onClick: visStateActions.onLayerClick,
onError: this._onDeckError,
ref: function ref(comp) {
if (comp && comp.deck && !_this2._deck) {
_this2._deck = comp.deck;
}
},
onWebGLInitialized: function onWebGLInitialized(gl) {
return _this2._onDeckInitialized(gl);
}
}));
}
}, {
key: "_updateMapboxLayers",
value: function _updateMapboxLayers() {
var mapboxLayers = this.mapboxLayersSelector(this.props);
if (!Object.keys(mapboxLayers).length && !Object.keys(this.previousLayers).length) {
return;
}
(0, _mapboxUtils.updateMapboxLayers)(this._map, mapboxLayers, this.previousLayers);
this.previousLayers = mapboxLayers;
}
}, {
key: "_renderMapboxOverlays",
value: function _renderMapboxOverlays() {
if (this._map && this._map.isStyleLoaded()) {
this._updateMapboxLayers();
}
}
}, {
key: "_renderMap",
value:
/* eslint-disable complexity */
function _renderMap() {
var _this$props5 = this.props,
mapState = _this$props5.mapState,
mapStyle = _this$props5.mapStyle,
mapStateActions = _this$props5.mapStateActions,
layers = _this$props5.layers,
MapComponent = _this$props5.MapComponent,
datasets = _this$props5.datasets,
mapboxApiAccessToken = _this$props5.mapboxApiAccessToken,
mapboxApiUrl = _this$props5.mapboxApiUrl,
mapControls = _this$props5.mapControls,
isExport = _this$props5.isExport,
locale = _this$props5.locale,
uiStateActions = _this$props5.uiStateActions,
visStateActions = _this$props5.visStateActions,
interactionConfig = _this$props5.interactionConfig,
editor = _this$props5.editor,
index = _this$props5.index,
primary = _this$props5.primary;
var layersToRender = this.layersToRenderSelector(this.props);
var layersForDeck = this.layersForDeckSelector(this.props);
var mapProps = _objectSpread(_objectSpread({}, mapState), {}, {
width: '100%',
height: '100%',
preserveDrawingBuffer: true,
mapboxApiAccessToken: mapboxApiAccessToken,
mapboxApiUrl: mapboxApiUrl,
onViewportChange: this._onViewportChange,
transformRequest: _mapboxUtils2.transformRequest
});
var isEdit = (mapControls.mapDraw || {}).active;
var hasGeocoderLayer = layers.find(function (l) {
return l.id === _defaultSettings.GEOCODER_LAYER_ID;
});
var isSplit = Boolean(mapState.isSplit);
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(MapControl, {
datasets: datasets,
availableLocales: Object.keys(_locales.LOCALE_CODES),
dragRotate: mapState.dragRotate,
isSplit: isSplit,
primary: primary,
isExport: isExport,
layers: layers,
layersToRender: layersToRender,
mapIndex: index,
mapControls: mapControls,
readOnly: this.props.readOnly,
scale: mapState.scale || 1,
top: interactionConfig.geocoder && interactionConfig.geocoder.enabled ? 52 : 0,
editor: editor,
locale: locale,
onTogglePerspective: mapStateActions.togglePerspective,
onToggleSplitMap: mapStateActions.toggleSplitMap,
onMapToggleLayer: this._handleMapToggleLayer,
onToggleMapControl: this._toggleMapControl,
onSetEditorMode: visStateActions.setEditorMode,
onSetLocale: uiStateActions.setLocale,
onToggleEditorVisibility: visStateActions.toggleEditorVisibility
}), /*#__PURE__*/_react["default"].createElement(MapComponent, (0, _extends2["default"])({}, mapProps, {
key: "bottom",
ref: this._setMapboxMap,
mapStyle: mapStyle.bottomMapStyle,
getCursor: this.props.hoverInfo ? function () {
return 'pointer';
} : undefined,
onMouseMove: this.props.visStateActions.onMouseMove
}), this._renderDeckOverlay(layersForDeck), this._renderMapboxOverlays(), /*#__PURE__*/_react["default"].createElement(Editor, {
index: index,
datasets: datasets,
editor: editor,
filters: this.polygonFilters(this.props),
isEnabled: isEdit,
layers: layers,
layersToRender: layersToRender,
onDeleteFeature: visStateActions.deleteFeature,
onSelect: visStateActions.setSelectedFeature,
onUpdate: visStateActions.setFeatures,
onTogglePolygonFilter: visStateActions.setPolygonFilterLayer,
style: {
pointerEvents: isEdit ? 'all' : 'none',
position: 'absolute',
display: editor.visible ? 'block' : 'none'
}
})), mapStyle.topMapStyle || hasGeocoderLayer ? /*#__PURE__*/_react["default"].createElement("div", {
style: MAP_STYLE.top
}, /*#__PURE__*/_react["default"].createElement(MapComponent, (0, _extends2["default"])({}, mapProps, {
key: "top",
mapStyle: mapStyle.topMapStyle
}), this._renderDeckOverlay((0, _defineProperty2["default"])({}, _defaultSettings.GEOCODER_LAYER_ID, true)))) : null, this._renderMapPopover(layersToRender), !isSplit || index === 1 ? /*#__PURE__*/_react["default"].createElement(Attribution, null) : null);
}
}, {
key: "render",
value: function render() {
var _this$props6 = this.props,
mapState = _this$props6.mapState,
mapStyle = _this$props6.mapStyle;
return /*#__PURE__*/_react["default"].createElement(_styledComponents.StyledMapContainer, {
ref: this._ref,
style: MAP_STYLE.container,
globe: mapState.globe
}, mapStyle.bottomMapStyle && this._renderMap());
}
}]);
return MapContainer;
}(_react.Component);
(0, _defineProperty2["default"])(MapContainer, "propTypes", {
// required
datasets: _propTypes["default"].object,
interactionConfig: _propTypes["default"].object.isRequired,
layerBlending: _propTypes["default"].string.isRequired,
layerOrder: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired,
layerData: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired,
layers: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired,
filters: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired,
mapState: _propTypes["default"].object.isRequired,
mapControls: _propTypes["default"].object.isRequired,
mapStyle: _propTypes["default"].object.isRequired,
mousePos: _propTypes["default"].object.isRequired,
mapboxApiAccessToken: _propTypes["default"].string.isRequired,
mapboxApiUrl: _propTypes["default"].string,
visStateActions: _propTypes["default"].object.isRequired,
mapStateActions: _propTypes["default"].object.isRequired,
uiStateActions: _propTypes["default"].object.isRequired,
// optional
primary: _propTypes["default"].bool,
// primary one will be reporting its size to appState
readOnly: _propTypes["default"].bool,
isExport: _propTypes["default"].bool,
clicked: _propTypes["default"].object,
hoverInfo: _propTypes["default"].object,
mapLayers: _propTypes["default"].object,
onMapToggleLayer: _propTypes["default"].func,
onMapStyleLoaded: _propTypes["default"].func,
onMapRender: _propTypes["default"].func,
getMapboxRef: _propTypes["default"].func,
index: _propTypes["default"].number
});
(0, _defineProperty2["default"])(MapContainer, "defaultProps", {
MapComponent: _reactMapGl["default"],
deckGlProps: {},
index: 0,
primary: true
});
MapContainer.displayName = 'MapContainer';
return MapContainer;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/map-container.js"],"names":["MAP_STYLE","container","display","position","width","height","top","pointerEvents","MAPBOXGL_STYLE_UPDATE","MAPBOXGL_RENDER","TRANSITION_DURATION","Attribution","MapContainerFactory","deps","MapPopoverFactory","MapControlFactory","EditorFactory","MapPopover","MapControl","Editor","MapContainer","props","dimensions","primary","mapStateActions","updateMap","layers","layerData","mapLayers","layerOrder","layersSelector","layerDataSelector","mapLayersSelector","prepareLayersToRender","prepareLayersForDeck","filters","filtersSelector","filter","f","type","FILTER_TYPES","polygon","layerOrderSelector","layersToRenderSelector","generateMapboxLayers","visStateActions","onLayerClick","idx","colorDomain","layerConfigChange","layerId","index","mapIndex","toggleLayerForMap","previousLayers","_updateMapboxLayers","onMapStyleLoaded","_map","mapbox","getMap","on","_onMapboxStyleUpdate","onMapRender","getMapboxRef","gl","layerBlending","error","layer","errorMessage","message","id","notificationId","_deckGLErrorsElapsed","lastShown","Date","now","THROTTLE_NOTIFICATION_TIME","uiStateActions","addNotification","viewState","restViewState","next","transitionDuration","onViewStateChange","panelId","toggleMapControl","_deck","_ref","current","_handleResize","off","onDeckInitialized","layersToRender","mapState","hoverInfo","clicked","datasets","interactionConfig","mousePos","mousePosition","coordinate","pinned","tooltip","layerHoverProp","compareMode","config","pinnedPosition","layerPinnedProp","viewport","WebMercatorViewport","lngLat","_getHoverXY","primaryData","data","compareType","commonProp","onClose","_onCloseMapPopover","zoom","canvas","undefined","enabled","screenCoord","project","x","y","layersForDeck","mapStyle","mapboxApiAccessToken","mapboxApiUrl","deckGlLayers","deckGlProps","length","dataLayers","slice","reverse","reduce","overlays","layerCallbacks","onSetLayerDomain","val","_onLayerSetDomain","layerOverlay","concat","visibleLayerGroups","push","ThreeDBuildingLayer","threeDBuildingColor","updateTriggers","getFillColor","_onBeforeRender","onLayerHover","_onDeckError","comp","deck","_onDeckInitialized","mapboxLayers","mapboxLayersSelector","Object","keys","isStyleLoaded","MapComponent","mapControls","isExport","locale","editor","layersForDeckSelector","mapProps","preserveDrawingBuffer","onViewportChange","_onViewportChange","transformRequest","isEdit","mapDraw","active","hasGeocoderLayer","find","l","GEOCODER_LAYER_ID","isSplit","Boolean","LOCALE_CODES","dragRotate","readOnly","scale","geocoder","togglePerspective","toggleSplitMap","_handleMapToggleLayer","_toggleMapControl","setEditorMode","setLocale","toggleEditorVisibility","_setMapboxMap","bottomMapStyle","onMouseMove","_renderDeckOverlay","_renderMapboxOverlays","polygonFilters","deleteFeature","setSelectedFeature","setFeatures","setPolygonFilterLayer","visible","topMapStyle","_renderMapPopover","globe","_renderMap","Component","PropTypes","object","isRequired","string","arrayOf","any","bool","onMapToggleLayer","func","number","MapboxGLMap","displayName"],"mappings":"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