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