kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
384 lines (320 loc) • 43.8 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"] = void 0;
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
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 _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
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 _window = require("global/window");
var _redux = require("redux");
var _d3Request = require("d3-request");
var _styledComponents = _interopRequireWildcard(require("styled-components"));
var _keplerglConnect = require("../connect/keplergl-connect");
var _mapboxGlStyleEditor = require("../utils/map-style-utils/mapbox-gl-style-editor");
var VisStateActions = _interopRequireWildcard(require("../actions/vis-state-actions"));
var MapStateActions = _interopRequireWildcard(require("../actions/map-state-actions"));
var MapStyleActions = _interopRequireWildcard(require("../actions/map-style-actions"));
var UIStateActions = _interopRequireWildcard(require("../actions/ui-state-actions"));
var _defaultSettings = require("../constants/default-settings");
var _sidePanel = _interopRequireDefault(require("./side-panel"));
var _mapContainer = _interopRequireDefault(require("./map-container"));
var _bottomWidget = _interopRequireDefault(require("./bottom-widget"));
var _modalContainer = _interopRequireDefault(require("./modal-container"));
var _plotContainer = _interopRequireDefault(require("./plot-container"));
var _notificationPanel = _interopRequireDefault(require("./notification-panel"));
var _utils = require("../utils/utils");
var _base = require("../styles/base");
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 _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ff-clan-web-pro, 'Helvetica Neue', Helvetica, sans-serif;\n font-weight: 400;\n font-size: 0.875em;\n line-height: 1.71429;\n\n *,\n *:before,\n *:after {\n -webkit-box-sizing: border-box;\n -moz-box-sizing: border-box;\n box-sizing: border-box;\n }\n\n ul {\n margin: 0;\n padding: 0;\n }\n\n li {\n margin: 0;\n }\n\n a {\n text-decoration: none;\n color: ", ";\n }\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
// Maybe we should think about exporting this or creating a variable
// as part of the base.js theme
var GlobalStyle = _styledComponents["default"].div(_templateObject(), function (props) {
return props.theme.labelColor;
});
KeplerGlFactory.deps = [_bottomWidget["default"], _mapContainer["default"], _modalContainer["default"], _sidePanel["default"], _plotContainer["default"], _notificationPanel["default"]];
function KeplerGlFactory(BottomWidget, MapContainer, ModalWrapper, SidePanel, PlotContainer, NotificationPanel) {
var KeplerGL =
/*#__PURE__*/
function (_Component) {
(0, _inherits2["default"])(KeplerGL, _Component);
function KeplerGL() {
var _getPrototypeOf2;
var _this;
(0, _classCallCheck2["default"])(this, KeplerGL);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(KeplerGL)).call.apply(_getPrototypeOf2, [this].concat(args)));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_loadMapStyle", function () {
var defaultStyles = Object.values(_this.props.mapStyle.mapStyles); // add id to custom map styles if not given
var customeStyles = (_this.props.mapStyles || []).map(function (ms) {
return _objectSpread({}, ms, {
id: ms.id || (0, _utils.generateHashId)()
});
});
[].concat((0, _toConsumableArray2["default"])(customeStyles), (0, _toConsumableArray2["default"])(defaultStyles)).forEach(function (style) {
if (style.style) {
_this.props.mapStyleActions.loadMapStyles((0, _defineProperty2["default"])({}, style.id, style));
} else {
_this._requestMapStyle(style);
}
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_requestMapStyle", function (mapStyle) {
var url = mapStyle.url,
id = mapStyle.id;
var downloadUrl = (0, _mapboxGlStyleEditor.isValidStyleUrl)(url) ? (0, _mapboxGlStyleEditor.getStyleDownloadUrl)(url, _this.props.mapboxApiAccessToken) : url;
(0, _d3Request.json)(downloadUrl, function (error, result) {
if (error) {
_window.console.warn("Error loading map style ".concat(url));
} else {
_this.props.mapStyleActions.loadMapStyles((0, _defineProperty2["default"])({}, id, _objectSpread({}, mapStyle, {
style: result
})));
}
});
});
return _this;
}
(0, _createClass2["default"])(KeplerGL, [{
key: "componentWillMount",
value: function componentWillMount() {
this._loadMapStyle(this.props.mapStyles);
this._handleResize(this.props);
}
}, {
key: "componentWillReceiveProps",
value: function componentWillReceiveProps(nextProps) {
if ( // if dimension props has changed
this.props.height !== nextProps.height || this.props.width !== nextProps.width || // react-map-gl will dispatch updateViewport after this._handleResize is called
// here we check if this.props.mapState.height is sync with props.height
nextProps.height !== this.props.mapState.height) {
this._handleResize(nextProps);
}
}
}, {
key: "_handleResize",
value: function _handleResize(_ref) {
var width = _ref.width,
height = _ref.height;
if (!Number.isFinite(width) || !Number.isFinite(height)) {
_window.console.warn('width and height is required');
return;
}
this.props.mapStateActions.updateMap({
width: width / (1 + Number(this.props.mapState.isSplit)),
height: height
});
}
}, {
key: "render",
value: function render() {
var _this2 = this;
var _this$props = this.props,
id = _this$props.id,
appName = _this$props.appName,
version = _this$props.version,
onSaveMap = _this$props.onSaveMap,
width = _this$props.width,
height = _this$props.height,
mapboxApiAccessToken = _this$props.mapboxApiAccessToken,
mapStyle = _this$props.mapStyle,
mapState = _this$props.mapState,
uiState = _this$props.uiState,
visState = _this$props.visState,
visStateActions = _this$props.visStateActions,
mapStateActions = _this$props.mapStateActions,
mapStyleActions = _this$props.mapStyleActions,
uiStateActions = _this$props.uiStateActions;
var filters = visState.filters,
layers = visState.layers,
widgets = visState.widgets,
splitMaps = visState.splitMaps,
layerOrder = visState.layerOrder,
layerBlending = visState.layerBlending,
layerClasses = visState.layerClasses,
widgetOrder = visState.widgetOrder,
widgetClasses = visState.widgetClasses,
interactionConfig = visState.interactionConfig,
datasets = visState.datasets,
layerData = visState.layerData,
hoverInfo = visState.hoverInfo,
clicked = visState.clicked;
var notificationPanelFields = {
removeNotification: uiStateActions.removeNotification,
notifications: uiState.notifications
};
var sideFields = {
appName: appName,
version: version,
datasets: datasets,
filters: filters,
layers: layers,
layerOrder: layerOrder,
layerClasses: layerClasses,
widgets: widgets,
widgetOrder: widgetOrder,
widgetClasses: widgetClasses,
interactionConfig: interactionConfig,
mapStyle: mapStyle,
layerBlending: layerBlending,
onSaveMap: onSaveMap,
uiState: uiState,
mapState: mapState,
mapStyleActions: mapStyleActions,
visStateActions: visStateActions,
uiStateActions: uiStateActions,
width: _defaultSettings.DIMENSIONS.sidePanel.width
};
var mapFields = {
datasets: datasets,
mapboxApiAccessToken: mapboxApiAccessToken,
mapState: mapState,
mapStyle: mapStyle,
mapControls: uiState.mapControls,
layers: layers,
layerOrder: layerOrder,
layerData: layerData,
layerBlending: layerBlending,
interactionConfig: interactionConfig,
hoverInfo: hoverInfo,
clicked: clicked,
toggleMapControl: uiStateActions.toggleMapControl,
uiStateActions: uiStateActions,
visStateActions: visStateActions,
mapStateActions: mapStateActions
};
var isSplit = splitMaps && splitMaps.length > 1;
var containerW = mapState.width * (Number(isSplit) + 1);
var mapContainers = !isSplit ? [_react["default"].createElement(MapContainer, (0, _extends2["default"])({
key: 0,
index: 0
}, mapFields, {
mapLayers: isSplit ? splitMaps[0].layers : null
}))] : splitMaps.map(function (settings, index) {
return _react["default"].createElement(MapContainer, (0, _extends2["default"])({
key: index,
index: index
}, mapFields, {
mapLayers: splitMaps[index].layers
}));
});
var isExporting = uiState.currentModal === _defaultSettings.EXPORT_IMAGE_ID;
return _react["default"].createElement(_styledComponents.ThemeProvider, {
theme: _base.theme
}, _react["default"].createElement(GlobalStyle, {
style: {
position: 'relative',
width: "".concat(width, "px"),
height: "".concat(height, "px")
},
className: "kepler-gl",
id: "kepler-gl__".concat(id),
innerRef: function innerRef(node) {
_this2.root = node;
}
}, !uiState.readOnly && _react["default"].createElement(SidePanel, sideFields), _react["default"].createElement("div", {
className: "maps",
style: {
display: 'flex'
}
}, mapContainers), isExporting && _react["default"].createElement(PlotContainer, {
width: width,
height: height,
exportImageSetting: uiState.exportImage,
mapFields: mapFields,
startExportingImage: uiStateActions.startExportingImage,
setExportImageDataUri: uiStateActions.setExportImageDataUri
}), _react["default"].createElement(BottomWidget, {
filters: filters,
datasets: datasets,
uiState: uiState,
visStateActions: visStateActions,
sidePanelWidth: _defaultSettings.DIMENSIONS.sidePanel.width + _defaultSettings.DIMENSIONS.sidePanel.margin.left,
containerW: containerW
}), _react["default"].createElement(ModalWrapper, {
mapStyle: mapStyle,
visState: visState,
mapState: mapState,
uiState: uiState,
mapboxApiAccessToken: mapboxApiAccessToken,
visStateActions: visStateActions,
uiStateActions: uiStateActions,
mapStyleActions: mapStyleActions,
rootNode: this.root,
containerW: containerW,
containerH: mapState.height
})));
}
}]);
return KeplerGL;
}(_react.Component);
(0, _defineProperty2["default"])(KeplerGL, "defaultProps", {
mapStyles: [],
width: 800,
height: 800,
appName: _defaultSettings.KEPLER_GL_NAME,
version: _defaultSettings.KEPLER_GL_VERSION
});
return (0, _keplerglConnect.connect)(mapStateToProps, mapDispatchToProps)(KeplerGL);
}
function mapStateToProps(state, props) {
return _objectSpread({}, props, {
visState: state.visState,
mapStyle: state.mapStyle,
mapState: state.mapState,
uiState: state.uiState
});
}
function mapDispatchToProps(dispatch, ownProps) {
var userActions = ownProps.actions || {};
var _map = [VisStateActions, MapStateActions, MapStyleActions, UIStateActions].map(function (actions) {
return (0, _redux.bindActionCreators)(mergeActions(actions, userActions), dispatch);
}),
_map2 = (0, _slicedToArray2["default"])(_map, 4),
visStateActions = _map2[0],
mapStateActions = _map2[1],
mapStyleActions = _map2[2],
uiStateActions = _map2[3];
return {
visStateActions: visStateActions,
mapStateActions: mapStateActions,
mapStyleActions: mapStyleActions,
uiStateActions: uiStateActions,
dispatch: dispatch
};
}
/**
* Override default maps-gl actions with user defined actions using the same key
*/
function mergeActions(actions, userActions) {
var overrides = {};
for (var key in userActions) {
if (userActions.hasOwnProperty(key) && actions.hasOwnProperty(key)) {
overrides[key] = userActions[key];
}
}
return _objectSpread({}, actions, {}, overrides);
}
var _default = KeplerGlFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/kepler-gl.js"],"names":["GlobalStyle","styled","div","props","theme","labelColor","KeplerGlFactory","deps","BottomWidgetFactory","MapContainerFactory","ModalContainerFactory","SidePanelFactory","PlotContainerFactory","NotificationPanelFactory","BottomWidget","MapContainer","ModalWrapper","SidePanel","PlotContainer","NotificationPanel","KeplerGL","defaultStyles","Object","values","mapStyle","mapStyles","customeStyles","map","ms","id","forEach","style","mapStyleActions","loadMapStyles","_requestMapStyle","url","downloadUrl","mapboxApiAccessToken","error","result","Console","warn","_loadMapStyle","_handleResize","nextProps","height","width","mapState","Number","isFinite","mapStateActions","updateMap","isSplit","appName","version","onSaveMap","uiState","visState","visStateActions","uiStateActions","filters","layers","widgets","splitMaps","layerOrder","layerBlending","layerClasses","widgetOrder","widgetClasses","interactionConfig","datasets","layerData","hoverInfo","clicked","notificationPanelFields","removeNotification","notifications","sideFields","DIMENSIONS","sidePanel","mapFields","mapControls","toggleMapControl","length","containerW","mapContainers","settings","index","isExporting","currentModal","EXPORT_IMAGE_ID","position","node","root","readOnly","display","exportImage","startExportingImage","setExportImageDataUri","margin","left","Component","KEPLER_GL_NAME","KEPLER_GL_VERSION","mapStateToProps","mapDispatchToProps","state","dispatch","ownProps","userActions","actions","VisStateActions","MapStateActions","MapStyleActions","UIStateActions","mergeActions","overrides","key","hasOwnProperty"],"mappings":"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","sourcesContent":["// Copyright (c) 2019 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React, {Component} from 'react';\nimport {console as Console} from 'global/window';\nimport {bindActionCreators} from 'redux';\nimport {json as requestJson} from 'd3-request';\nimport styled, {ThemeProvider} from 'styled-components';\nimport {connect as keplerGlConnect} from 'connect/keplergl-connect';\nimport {\n  isValidStyleUrl,\n  getStyleDownloadUrl\n} from 'utils/map-style-utils/mapbox-gl-style-editor';\n\nimport * as VisStateActions from 'actions/vis-state-actions';\nimport * as MapStateActions from 'actions/map-state-actions';\nimport * as MapStyleActions from 'actions/map-style-actions';\nimport * as UIStateActions from 'actions/ui-state-actions';\n\nimport {\n  EXPORT_IMAGE_ID,\n  DIMENSIONS,\n  KEPLER_GL_NAME,\n  KEPLER_GL_VERSION\n} from 'constants/default-settings';\n\nimport SidePanelFactory from './side-panel';\nimport MapContainerFactory from './map-container';\nimport BottomWidgetFactory from './bottom-widget';\nimport ModalContainerFactory from './modal-container';\nimport PlotContainerFactory from './plot-container';\nimport NotificationPanelFactory from './notification-panel';\n\nimport {generateHashId} from 'utils/utils';\n\nimport {theme} from 'styles/base';\n\n// Maybe we should think about exporting this or creating a variable\n// as part of the base.js theme\nconst GlobalStyle = styled.div`\n  font-family: ff-clan-web-pro, 'Helvetica Neue', Helvetica, sans-serif;\n  font-weight: 400;\n  font-size: 0.875em;\n  line-height: 1.71429;\n\n  *,\n  *:before,\n  *:after {\n    -webkit-box-sizing: border-box;\n    -moz-box-sizing: border-box;\n    box-sizing: border-box;\n  }\n\n  ul {\n    margin: 0;\n    padding: 0;\n  }\n\n  li {\n    margin: 0;\n  }\n\n  a {\n    text-decoration: none;\n    color: ${props => props.theme.labelColor};\n  }\n`;\n\nKeplerGlFactory.deps = [\n  BottomWidgetFactory,\n  MapContainerFactory,\n  ModalContainerFactory,\n  SidePanelFactory,\n  PlotContainerFactory,\n  NotificationPanelFactory\n];\n\nfunction KeplerGlFactory(\n  BottomWidget,\n  MapContainer,\n  ModalWrapper,\n  SidePanel,\n  PlotContainer,\n  NotificationPanel\n) {\n  class KeplerGL extends Component {\n    static defaultProps = {\n      mapStyles: [],\n      width: 800,\n      height: 800,\n      appName: KEPLER_GL_NAME,\n      version: KEPLER_GL_VERSION\n    };\n\n    componentWillMount() {\n      this._loadMapStyle(this.props.mapStyles);\n      this._handleResize(this.props);\n    }\n\n    componentWillReceiveProps(nextProps) {\n      if (\n        // if dimension props has changed\n        this.props.height !== nextProps.height ||\n        this.props.width !== nextProps.width ||\n        // react-map-gl will dispatch updateViewport after this._handleResize is called\n        // here we check if this.props.mapState.height is sync with props.height\n        nextProps.height !== this.props.mapState.height\n      ) {\n        this._handleResize(nextProps);\n      }\n    }\n\n    _handleResize({width, height}) {\n      if (!Number.isFinite(width) || !Number.isFinite(height)) {\n        Console.warn('width and height is required');\n        return;\n      }\n      this.props.mapStateActions.updateMap({\n        width: width / (1 + Number(this.props.mapState.isSplit)),\n        height\n      });\n    }\n\n    _loadMapStyle = () => {\n      const defaultStyles = Object.values(this.props.mapStyle.mapStyles);\n      // add id to custom map styles if not given\n      const customeStyles = (this.props.mapStyles || []).map(ms => ({\n        ...ms,\n        id: ms.id || generateHashId()\n      }));\n\n      [...customeStyles, ...defaultStyles].forEach(style => {\n        if (style.style) {\n          this.props.mapStyleActions.loadMapStyles({\n            [style.id]: style\n          });\n        } else {\n          this._requestMapStyle(style);\n        }\n      });\n    };\n\n    _requestMapStyle = mapStyle => {\n      const {url, id} = mapStyle;\n\n      const downloadUrl = isValidStyleUrl(url)\n        ? getStyleDownloadUrl(url, this.props.mapboxApiAccessToken)\n        : url;\n\n      requestJson(downloadUrl, (error, result) => {\n        if (error) {\n          Console.warn(`Error loading map style ${url}`);\n        } else {\n          this.props.mapStyleActions.loadMapStyles({\n            [id]: {...mapStyle, style: result}\n          });\n        }\n      });\n    };\n\n    render() {\n      const {\n        // props\n        id,\n        appName,\n        version,\n        onSaveMap,\n        width,\n        height,\n        mapboxApiAccessToken,\n\n        // redux state\n        mapStyle,\n        mapState,\n        uiState,\n        visState,\n\n        // actions,\n        visStateActions,\n        mapStateActions,\n        mapStyleActions,\n        uiStateActions\n      } = this.props;\n\n      const {\n        filters,\n        layers,\n        widgets,\n        splitMaps, // this will store support for split map view is necessary\n        layerOrder,\n        layerBlending,\n        layerClasses,\n        widgetOrder,\n        widgetClasses,\n        interactionConfig,\n        datasets,\n        layerData,\n        hoverInfo,\n        clicked\n      } = visState;\n\n      const notificationPanelFields = {\n        removeNotification: uiStateActions.removeNotification,\n        notifications: uiState.notifications\n      };\n\n      const sideFields = {\n        appName,\n        version,\n        datasets,\n        filters,\n        layers,\n        layerOrder,\n        layerClasses,\n        widgets,\n        widgetOrder,\n        widgetClasses,\n        interactionConfig,\n        mapStyle,\n        layerBlending,\n        onSaveMap,\n        uiState,\n        mapState,\n        mapStyleActions,\n        visStateActions,\n        uiStateActions,\n        width: DIMENSIONS.sidePanel.width\n      };\n\n      const mapFields = {\n        datasets,\n        mapboxApiAccessToken,\n        mapState,\n        mapStyle,\n        mapControls: uiState.mapControls,\n        layers,\n        layerOrder,\n        layerData,\n        layerBlending,\n        interactionConfig,\n        hoverInfo,\n        clicked,\n        toggleMapControl: uiStateActions.toggleMapControl,\n        uiStateActions,\n        visStateActions,\n        mapStateActions\n      };\n\n      const isSplit = splitMaps && splitMaps.length > 1;\n      const containerW = mapState.width * (Number(isSplit) + 1);\n\n      const mapContainers = !isSplit\n        ? [\n            <MapContainer\n              key={0}\n              index={0}\n              {...mapFields}\n              mapLayers={isSplit ? splitMaps[0].layers : null}\n            />\n          ]\n        : splitMaps.map((settings, index) => (\n            <MapContainer\n              key={index}\n              index={index}\n              {...mapFields}\n              mapLayers={splitMaps[index].layers}\n            />\n          ));\n\n      const isExporting = uiState.currentModal === EXPORT_IMAGE_ID;\n\n      return (\n        <ThemeProvider theme={theme}>\n          <GlobalStyle\n            style={{\n              position: 'relative',\n              width: `${width}px`,\n              height: `${height}px`\n            }}\n            className=\"kepler-gl\"\n            id={`kepler-gl__${id}`}\n            innerRef={node => {\n              this.root = node;\n            }}\n          >\n            {/* <NotificationPanel {...notificationPanelFields} /> */}\n            {!uiState.readOnly && <SidePanel {...sideFields} />}\n            <div className=\"maps\" style={{display: 'flex'}}>\n              {mapContainers}\n            </div>\n            {isExporting && (\n              <PlotContainer\n                width={width}\n                height={height}\n                exportImageSetting={uiState.exportImage}\n                mapFields={mapFields}\n                startExportingImage={uiStateActions.startExportingImage}\n                setExportImageDataUri={uiStateActions.setExportImageDataUri}\n              />\n            )}\n            <BottomWidget\n              filters={filters}\n              datasets={datasets}\n              uiState={uiState}\n              visStateActions={visStateActions}\n              sidePanelWidth={\n                DIMENSIONS.sidePanel.width + DIMENSIONS.sidePanel.margin.left\n              }\n              containerW={containerW}\n            />\n            <ModalWrapper\n              mapStyle={mapStyle}\n              visState={visState}\n              mapState={mapState}\n              uiState={uiState}\n              mapboxApiAccessToken={mapboxApiAccessToken}\n              visStateActions={visStateActions}\n              uiStateActions={uiStateActions}\n              mapStyleActions={mapStyleActions}\n              rootNode={this.root}\n              containerW={containerW}\n              containerH={mapState.height}\n            />\n          </GlobalStyle>\n        </ThemeProvider>\n      );\n    }\n  }\n\n  return keplerGlConnect(mapStateToProps, mapDispatchToProps)(KeplerGL);\n}\n\nfunction mapStateToProps(state, props) {\n  return {\n    ...props,\n    visState: state.visState,\n    mapStyle: state.mapStyle,\n    mapState: state.mapState,\n    uiState: state.uiState\n  };\n}\n\nfunction mapDispatchToProps(dispatch, ownProps) {\n  const userActions = ownProps.actions || {};\n\n  const [visStateActions, mapStateActions, mapStyleActions, uiStateActions] = [\n    VisStateActions,\n    MapStateActions,\n    MapStyleActions,\n    UIStateActions\n  ].map(actions =>\n    bindActionCreators(mergeActions(actions, userActions), dispatch)\n  );\n\n  return {\n    visStateActions,\n    mapStateActions,\n    mapStyleActions,\n    uiStateActions,\n    dispatch\n  };\n}\n\n/**\n * Override default maps-gl actions with user defined actions using the same key\n */\nfunction mergeActions(actions, userActions) {\n  const overrides = {};\n  for (const key in userActions) {\n    if (userActions.hasOwnProperty(key) && actions.hasOwnProperty(key)) {\n      overrides[key] = userActions[key];\n    }\n  }\n\n  return {...actions, ...overrides};\n}\n\nexport default KeplerGlFactory;\n"]}