UNPKG

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
"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"]}