UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

419 lines (337 loc) 41.3 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.keplerGlChildDeps = undefined; var _slicedToArray2 = require('babel-runtime/helpers/slicedToArray'); var _slicedToArray3 = _interopRequireDefault(_slicedToArray2); var _defineProperty2 = require('babel-runtime/helpers/defineProperty'); var _defineProperty3 = _interopRequireDefault(_defineProperty2); var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray'); var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2); var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral'); var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2); var _templateObject = (0, _taggedTemplateLiteral3.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'], ['\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']); // Copyright (c) 2018 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _window = require('global/window'); var _redux = require('redux'); var _d3Request = require('d3-request'); var _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _keplerglConnect = require('../connect/keplergl-connect'); var _visStateActions = require('../actions/vis-state-actions'); var VisStateActions = _interopRequireWildcard(_visStateActions); var _mapStateActions = require('../actions/map-state-actions'); var MapStateActions = _interopRequireWildcard(_mapStateActions); var _mapStyleActions = require('../actions/map-style-actions'); var MapStyleActions = _interopRequireWildcard(_mapStyleActions); var _uiStateActions = require('../actions/ui-state-actions'); var UIStateActions = _interopRequireWildcard(_uiStateActions); var _defaultSettings = require('../constants/default-settings'); var _sidePanel = require('./side-panel'); var _sidePanel2 = _interopRequireDefault(_sidePanel); var _mapContainer = require('./map-container'); var _mapContainer2 = _interopRequireDefault(_mapContainer); var _bottomWidget = require('./bottom-widget'); var _bottomWidget2 = _interopRequireDefault(_bottomWidget); var _modalContainer = require('./modal-container'); var _modalContainer2 = _interopRequireDefault(_modalContainer); var _plotContainer = require('./plot-container'); var _plotContainer2 = _interopRequireDefault(_plotContainer); var _utils = require('../utils/utils'); var _base = require('../styles/base'); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var GlobalStyle = _styledComponents2.default.div(_templateObject, function (props) { return props.theme.labelColor; }); var keplerGlChildDeps = exports.keplerGlChildDeps = [].concat((0, _toConsumableArray3.default)(_bottomWidget2.default.deps), (0, _toConsumableArray3.default)(_sidePanel2.default.deps), (0, _toConsumableArray3.default)(_modalContainer2.default.deps), (0, _toConsumableArray3.default)(_mapContainer2.default.deps)); KeplerGlFactory.deps = [_bottomWidget2.default, _mapContainer2.default, _modalContainer2.default, _sidePanel2.default, _plotContainer2.default]; function KeplerGlFactory(BottomWidget, MapContainer, ModalWrapper, SidePanel, PlotContainer) { var _class, _temp2; var KeplerGL = (_temp2 = _class = function (_Component) { (0, _inherits3.default)(KeplerGL, _Component); function KeplerGL() { var _ref; var _temp, _this, _ret; (0, _classCallCheck3.default)(this, KeplerGL); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = KeplerGL.__proto__ || Object.getPrototypeOf(KeplerGL)).call.apply(_ref, [this].concat(args))), _this), _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 (0, _extends3.default)({}, ms, { id: ms.id || (0, _utils.generateHashId)() }); }); [].concat((0, _toConsumableArray3.default)(customeStyles), (0, _toConsumableArray3.default)(defaultStyles)).forEach(function (style) { if (style.style) { _this.props.mapStyleActions.loadMapStyles((0, _defineProperty3.default)({}, style.id, style)); } else { _this._requestMapStyle(style); } }); }, _this._requestMapStyle = function (mapStyle) { var url = mapStyle.url, id = mapStyle.id; (0, _d3Request.json)(url, function (error, result) { if (error) { _window.console.warn('Error loading map style ' + mapStyle.url); } else { _this.props.mapStyleActions.loadMapStyles((0, _defineProperty3.default)({}, id, (0, _extends3.default)({}, mapStyle, { style: result }))); } }); }, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); } (0, _createClass3.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(_ref2) { var width = _ref2.width, height = _ref2.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 _props = this.props, id = _props.id, appName = _props.appName, version = _props.version, onSaveMap = _props.onSaveMap, width = _props.width, height = _props.height, mapboxApiAccessToken = _props.mapboxApiAccessToken, mapStyle = _props.mapStyle, mapState = _props.mapState, uiState = _props.uiState, visState = _props.visState, visStateActions = _props.visStateActions, mapStateActions = _props.mapStateActions, mapStyleActions = _props.mapStyleActions, uiStateActions = _props.uiStateActions; var filters = visState.filters, layers = visState.layers, splitMaps = visState.splitMaps, layerOrder = visState.layerOrder, layerBlending = visState.layerBlending, layerClasses = visState.layerClasses, interactionConfig = visState.interactionConfig, datasets = visState.datasets, layerData = visState.layerData, hoverInfo = visState.hoverInfo, clicked = visState.clicked; var sideFields = { appName: appName, version: version, datasets: datasets, filters: filters, layers: layers, layerOrder: layerOrder, layerClasses: layerClasses, interactionConfig: interactionConfig, mapStyle: mapStyle, layerBlending: layerBlending, onSaveMap: onSaveMap, uiState: uiState, 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 ? [_react2.default.createElement(MapContainer, (0, _extends3.default)({ key: 0, index: 0 }, mapFields, { mapLayers: isSplit ? splitMaps[0].layers : null }))] : splitMaps.map(function (settings, index) { return _react2.default.createElement(MapContainer, (0, _extends3.default)({ key: index, index: index }, mapFields, { mapLayers: splitMaps[index].layers })); }); var isExporting = uiState.currentModal === _defaultSettings.EXPORT_IMAGE_ID; return _react2.default.createElement( _styledComponents.ThemeProvider, { theme: _base.theme }, _react2.default.createElement( GlobalStyle, { style: { position: 'relative', width: width + 'px', height: height + 'px' }, className: 'kepler-gl', id: 'kepler-gl__' + id, innerRef: function innerRef(node) { _this2.root = node; } }, !uiState.readOnly && _react2.default.createElement(SidePanel, sideFields), _react2.default.createElement( 'div', { className: 'maps', style: { display: 'flex' } }, mapContainers ), isExporting && _react2.default.createElement(PlotContainer, { width: width, height: height, exportImageSetting: uiState.exportImage, mapFields: mapFields, startExportingImage: uiStateActions.startExportingImage, setExportImageDataUri: uiStateActions.setExportImageDataUri }), _react2.default.createElement(BottomWidget, { filters: filters, datasets: datasets, uiState: uiState, visStateActions: visStateActions, sidePanelWidth: _defaultSettings.DIMENSIONS.sidePanel.width + _defaultSettings.DIMENSIONS.sidePanel.margin.left, containerW: containerW }), _react2.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), _class.defaultProps = { mapStyles: [], width: 800, height: 800, appName: _defaultSettings.KEPLER_GL_NAME, version: _defaultSettings.KEPLER_GL_VERSION }, _temp2); return (0, _keplerglConnect.connect)(mapStateToProps, mapDispatchToProps)(KeplerGL); } function mapStateToProps(state, props) { return (0, _extends3.default)({}, 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, _slicedToArray3.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 (0, _extends3.default)({}, actions, overrides); } exports.default = KeplerGlFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/kepler-gl.js"],"names":["VisStateActions","MapStateActions","MapStyleActions","UIStateActions","GlobalStyle","styled","div","props","theme","labelColor","keplerGlChildDeps","BottomWidgetFactory","deps","SidePanelFactory","ModalContainerFactory","MapContainerFactory","KeplerGlFactory","PlotContainerFactory","BottomWidget","MapContainer","ModalWrapper","SidePanel","PlotContainer","KeplerGL","_loadMapStyle","defaultStyles","Object","values","mapStyle","mapStyles","customeStyles","map","ms","id","forEach","style","mapStyleActions","loadMapStyles","_requestMapStyle","url","error","result","Console","warn","_handleResize","nextProps","height","width","mapState","Number","isFinite","mapStateActions","updateMap","isSplit","appName","version","onSaveMap","mapboxApiAccessToken","uiState","visState","visStateActions","uiStateActions","filters","layers","splitMaps","layerOrder","layerBlending","layerClasses","interactionConfig","datasets","layerData","hoverInfo","clicked","sideFields","DIMENSIONS","sidePanel","mapFields","mapControls","toggleMapControl","length","containerW","mapContainers","settings","index","isExporting","currentModal","EXPORT_IMAGE_ID","position","root","node","readOnly","display","exportImage","startExportingImage","setExportImageDataUri","margin","left","Component","defaultProps","KEPLER_GL_NAME","KEPLER_GL_VERSION","mapStateToProps","mapDispatchToProps","state","dispatch","ownProps","userActions","actions","mergeActions","overrides","key","hasOwnProperty"],"mappings":"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","file":"kepler-gl.js","sourcesContent":["// Copyright (c) 2018 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';\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 {EXPORT_IMAGE_ID, DIMENSIONS,\n  KEPLER_GL_NAME, KEPLER_GL_VERSION} 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';\n\nimport {generateHashId} from 'utils/utils';\n\nimport {theme} from 'styles/base';\n\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\nexport const keplerGlChildDeps = [\n  ...BottomWidgetFactory.deps,\n  ...SidePanelFactory.deps,\n  ...ModalContainerFactory.deps,\n  ...MapContainerFactory.deps\n];\n\nKeplerGlFactory.deps = [\n  BottomWidgetFactory,\n  MapContainerFactory,\n  ModalContainerFactory,\n  SidePanelFactory,\n  PlotContainerFactory\n];\n\nfunction KeplerGlFactory(\n  BottomWidget,\n  MapContainer,\n  ModalWrapper,\n  SidePanel,\n  PlotContainer\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(\n        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\n    _requestMapStyle = (mapStyle) => {\n      const {url, id} = mapStyle;\n      requestJson(url, (error, result) => {\n        if (error) {\n          Console.warn(`Error loading map style ${mapStyle.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        splitMaps, // this will store support for split map view is necessary\n        layerOrder,\n        layerBlending,\n        layerClasses,\n        interactionConfig,\n        datasets,\n        layerData,\n        hoverInfo,\n        clicked\n      } = visState;\n\n      const sideFields = {\n        appName,\n        version,\n        datasets,\n        filters,\n        layers,\n        layerOrder,\n        layerClasses,\n        interactionConfig,\n        mapStyle,\n        layerBlending,\n        onSaveMap,\n        uiState,\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            {!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 [\n    visStateActions,\n    mapStateActions,\n    mapStyleActions,\n    uiStateActions\n  ] = [\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"]}