kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
291 lines (235 loc) • 31.7 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
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 _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral');
var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2);
var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n ', ';\n flex-grow: 1;\n padding: 16px;\n overflow-y: scroll;\n overflow-x: hidden;\n'], ['\n ', ';\n flex-grow: 1;\n padding: 16px;\n overflow-y: scroll;\n overflow-x: hidden;\n']),
_templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n color: ', ';\n font-size: 20px;\n font-weight: 400;\n letter-spacing: 1.25px;\n margin-bottom: 14px;\n'], ['\n color: ', ';\n font-size: 20px;\n font-weight: 400;\n letter-spacing: 1.25px;\n margin-bottom: 14px;\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.
exports.default = SidePanelFactory;
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _styledComponents = require('styled-components');
var _styledComponents2 = _interopRequireDefault(_styledComponents);
var _sideBar = require('./side-panel/side-bar');
var _sideBar2 = _interopRequireDefault(_sideBar);
var _panelHeader = require('./side-panel/panel-header');
var _panelHeader2 = _interopRequireDefault(_panelHeader);
var _layerManager = require('./side-panel/layer-manager');
var _layerManager2 = _interopRequireDefault(_layerManager);
var _filterManager = require('./side-panel/filter-manager');
var _filterManager2 = _interopRequireDefault(_filterManager);
var _interactionManager = require('./side-panel/interaction-manager');
var _interactionManager2 = _interopRequireDefault(_interactionManager);
var _mapManager = require('./side-panel/map-manager');
var _mapManager2 = _interopRequireDefault(_mapManager);
var _panelToggle = require('./side-panel/panel-toggle');
var _panelToggle2 = _interopRequireDefault(_panelToggle);
var _defaultSettings = require('../constants/default-settings');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var SidePanelContent = _styledComponents2.default.div(_templateObject, function (props) {
return props.theme.sidePanelScrollBar;
});
var PanelTitle = _styledComponents2.default.div(_templateObject2, function (props) {
return props.theme.titleTextColor;
});
SidePanelFactory.deps = [_panelHeader2.default];
/**
*
* Vertical sidebar containing input components for the rendering layers
*/
function SidePanelFactory(PanelHeader) {
var _class, _temp2;
return _temp2 = _class = function (_Component) {
(0, _inherits3.default)(SidePanel, _Component);
function SidePanel() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, SidePanel);
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 = SidePanel.__proto__ || Object.getPrototypeOf(SidePanel)).call.apply(_ref, [this].concat(args))), _this), _this._onOpenOrClose = function () {
_this.props.uiStateActions.toggleSidePanel(_this.props.uiState.activeSidePanel ? null : 'layer');
}, _this._showDatasetTable = function (dataId) {
// this will open data table modal
_this.props.visStateActions.showDatasetTable(dataId);
_this.props.uiStateActions.toggleModal(_defaultSettings.DATA_TABLE_ID);
}, _this._showAddDataModal = function () {
_this.props.uiStateActions.toggleModal(_defaultSettings.ADD_DATA_ID);
}, _this._showAddMapStyleModal = function () {
_this.props.uiStateActions.toggleModal(_defaultSettings.ADD_MAP_STYLE_ID);
}, _this._removeDataset = function (key) {
// this will show the modal dialog to confirm deletion
_this.props.uiStateActions.openDeleteModal(key);
}, _this._onExportImage = function () {
return _this.props.uiStateActions.toggleModal(_defaultSettings.EXPORT_IMAGE_ID);
}, _this._onExportData = function () {
return _this.props.uiStateActions.toggleModal(_defaultSettings.EXPORT_DATA_ID);
}, _this._onExportConfig = function () {
return _this.props.uiStateActions.toggleModal(_defaultSettings.EXPORT_CONFIG_ID);
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
/* component private functions */
(0, _createClass3.default)(SidePanel, [{
key: 'render',
value: function render() {
var _props = this.props,
appName = _props.appName,
version = _props.version,
datasets = _props.datasets,
filters = _props.filters,
layers = _props.layers,
layerBlending = _props.layerBlending,
layerClasses = _props.layerClasses,
uiState = _props.uiState,
layerOrder = _props.layerOrder,
interactionConfig = _props.interactionConfig,
visStateActions = _props.visStateActions,
mapStyleActions = _props.mapStyleActions,
uiStateActions = _props.uiStateActions;
var activeSidePanel = uiState.activeSidePanel;
var isOpen = Boolean(activeSidePanel);
var layerManagerActions = {
addLayer: visStateActions.addLayer,
layerConfigChange: visStateActions.layerConfigChange,
layerVisualChannelConfigChange: visStateActions.layerVisualChannelConfigChange,
layerTypeChange: visStateActions.layerTypeChange,
layerVisConfigChange: visStateActions.layerVisConfigChange,
updateLayerBlending: visStateActions.updateLayerBlending,
updateLayerOrder: visStateActions.reorderLayer,
showDatasetTable: this._showDatasetTable,
showAddDataModal: this._showAddDataModal,
removeLayer: visStateActions.removeLayer,
removeDataset: this._removeDataset
};
var filterManagerActions = {
addFilter: visStateActions.addFilter,
removeFilter: visStateActions.removeFilter,
setFilter: visStateActions.setFilter,
showDatasetTable: this._showDatasetTable,
showAddDataModal: this._showAddDataModal,
toggleAnimation: visStateActions.toggleAnimation,
enlargeFilter: visStateActions.enlargeFilter
};
var interactionManagerActions = {
onConfigChange: visStateActions.interactionConfigChange
};
var mapManagerActions = {
addMapStyleUrl: mapStyleActions.addMapStyleUrl,
onConfigChange: mapStyleActions.mapConfigChange,
onStyleChange: mapStyleActions.mapStyleChange,
onBuildingChange: mapStyleActions.mapBuildingChange,
showAddMapStyleModal: this._showAddMapStyleModal
};
return _react2.default.createElement(
'div',
null,
_react2.default.createElement(
_sideBar2.default,
{
width: this.props.width,
isOpen: isOpen,
minifiedWidth: 0,
onOpenOrClose: this._onOpenOrClose
},
_react2.default.createElement(PanelHeader, {
appName: appName,
version: version,
onExportImage: this._onExportImage,
onExportData: this._onExportData,
visibleDropdown: uiState.visibleDropdown,
showExportDropdown: uiStateActions.showExportDropdown,
hideExportDropdown: uiStateActions.hideExportDropdown,
onExportConfig: this._onExportConfig,
onSaveMap: this.props.onSaveMap
}),
_react2.default.createElement(_panelToggle2.default, {
panels: _defaultSettings.PANELS,
activePanel: activeSidePanel,
togglePanel: uiStateActions.toggleSidePanel
}),
_react2.default.createElement(
SidePanelContent,
{ className: 'side-panel__content' },
_react2.default.createElement(
'div',
null,
_react2.default.createElement(
PanelTitle,
{ className: 'side-panel__content__title' },
(_defaultSettings.PANELS.find(function (_ref2) {
var id = _ref2.id;
return id === activeSidePanel;
}) || {}).label
),
activeSidePanel === 'layer' && _react2.default.createElement(_layerManager2.default, (0, _extends3.default)({}, layerManagerActions, {
datasets: datasets,
layers: layers,
layerClasses: layerClasses,
layerOrder: layerOrder,
layerBlending: layerBlending,
openModal: uiStateActions.toggleModal
})),
activeSidePanel === 'filter' && _react2.default.createElement(_filterManager2.default, (0, _extends3.default)({}, filterManagerActions, {
datasets: datasets,
filters: filters
})),
activeSidePanel === 'interaction' && _react2.default.createElement(_interactionManager2.default, (0, _extends3.default)({}, interactionManagerActions, {
datasets: datasets,
interactionConfig: interactionConfig
})),
activeSidePanel === 'map' && _react2.default.createElement(_mapManager2.default, (0, _extends3.default)({}, mapManagerActions, {
mapStyle: this.props.mapStyle
}))
)
)
)
);
}
}]);
return SidePanel;
}(_react.Component), _class.propTypes = {
filters: _propTypes2.default.arrayOf(_propTypes2.default.any).isRequired,
interactionConfig: _propTypes2.default.object.isRequired,
layerBlending: _propTypes2.default.string.isRequired,
layers: _propTypes2.default.arrayOf(_propTypes2.default.any).isRequired,
layerClasses: _propTypes2.default.object.isRequired,
mapStyle: _propTypes2.default.object.isRequired,
width: _propTypes2.default.number.isRequired,
datasets: _propTypes2.default.object.isRequired,
visStateActions: _propTypes2.default.object.isRequired,
mapStyleActions: _propTypes2.default.object.isRequired
}, _temp2;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/side-panel.js"],"names":["SidePanelFactory","SidePanelContent","styled","div","props","theme","sidePanelScrollBar","PanelTitle","titleTextColor","deps","PanelHeaderFactory","PanelHeader","_onOpenOrClose","uiStateActions","toggleSidePanel","uiState","activeSidePanel","_showDatasetTable","visStateActions","showDatasetTable","dataId","toggleModal","DATA_TABLE_ID","_showAddDataModal","ADD_DATA_ID","_showAddMapStyleModal","ADD_MAP_STYLE_ID","_removeDataset","openDeleteModal","key","_onExportImage","EXPORT_IMAGE_ID","_onExportData","EXPORT_DATA_ID","_onExportConfig","EXPORT_CONFIG_ID","appName","version","datasets","filters","layers","layerBlending","layerClasses","layerOrder","interactionConfig","mapStyleActions","isOpen","Boolean","layerManagerActions","addLayer","layerConfigChange","layerVisualChannelConfigChange","layerTypeChange","layerVisConfigChange","updateLayerBlending","updateLayerOrder","reorderLayer","showAddDataModal","removeLayer","removeDataset","filterManagerActions","addFilter","removeFilter","setFilter","toggleAnimation","enlargeFilter","interactionManagerActions","onConfigChange","interactionConfigChange","mapManagerActions","addMapStyleUrl","mapConfigChange","onStyleChange","mapStyleChange","onBuildingChange","mapBuildingChange","showAddMapStyleModal","width","visibleDropdown","showExportDropdown","hideExportDropdown","onSaveMap","PANELS","find","id","label","mapStyle","Component","propTypes","PropTypes","arrayOf","any","isRequired","object","string","number"],"mappings":"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","file":"side-panel.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 PropTypes from 'prop-types';\nimport styled from 'styled-components';\n\nimport Sidebar from './side-panel/side-bar';\nimport PanelHeaderFactory from './side-panel/panel-header';\nimport LayerManager from './side-panel/layer-manager';\nimport FilterManager from './side-panel/filter-manager';\nimport InteractionManager from './side-panel/interaction-manager';\nimport MapManager from './side-panel/map-manager';\nimport PanelToggle from './side-panel/panel-toggle';\n\nimport {\n  ADD_DATA_ID,\n  ADD_MAP_STYLE_ID,\n  DATA_TABLE_ID,\n  EXPORT_IMAGE_ID,\n  EXPORT_DATA_ID,\n  EXPORT_CONFIG_ID,\n  PANELS\n} from 'constants/default-settings';\n\nconst SidePanelContent = styled.div`\n  ${props => props.theme.sidePanelScrollBar};\n  flex-grow: 1;\n  padding: 16px;\n  overflow-y: scroll;\n  overflow-x: hidden;\n`;\n\nconst PanelTitle = styled.div`\n  color: ${props => props.theme.titleTextColor};\n  font-size: 20px;\n  font-weight: 400;\n  letter-spacing: 1.25px;\n  margin-bottom: 14px;\n`;\n\nSidePanelFactory.deps = [PanelHeaderFactory];\n\n/**\n *\n * Vertical sidebar containing input components for the rendering layers\n */\nexport default function SidePanelFactory(PanelHeader) {\n\n  return class SidePanel extends Component {\n    static propTypes = {\n      filters: PropTypes.arrayOf(PropTypes.any).isRequired,\n      interactionConfig: PropTypes.object.isRequired,\n      layerBlending: PropTypes.string.isRequired,\n      layers: PropTypes.arrayOf(PropTypes.any).isRequired,\n      layerClasses: PropTypes.object.isRequired,\n      mapStyle: PropTypes.object.isRequired,\n      width: PropTypes.number.isRequired,\n      datasets: PropTypes.object.isRequired,\n      visStateActions: PropTypes.object.isRequired,\n      mapStyleActions: PropTypes.object.isRequired\n    };\n\n    /* component private functions */\n    _onOpenOrClose = () => {\n      this.props.uiStateActions.toggleSidePanel(\n        this.props.uiState.activeSidePanel ? null : 'layer'\n      );\n    };\n\n    _showDatasetTable = dataId => {\n      // this will open data table modal\n      this.props.visStateActions.showDatasetTable(dataId);\n      this.props.uiStateActions.toggleModal(DATA_TABLE_ID);\n    };\n\n    _showAddDataModal = () => {\n      this.props.uiStateActions.toggleModal(ADD_DATA_ID);\n    };\n\n    _showAddMapStyleModal = () => {\n      this.props.uiStateActions.toggleModal(ADD_MAP_STYLE_ID);\n    };\n\n    _removeDataset = key => {\n      // this will show the modal dialog to confirm deletion\n      this.props.uiStateActions.openDeleteModal(key);\n    };\n\n    _onExportImage = () => this.props.uiStateActions.toggleModal(EXPORT_IMAGE_ID);\n\n    _onExportData = () => this.props.uiStateActions.toggleModal(EXPORT_DATA_ID);\n\n    _onExportConfig = () => this.props.uiStateActions.toggleModal(EXPORT_CONFIG_ID);\n\n    render() {\n      const {\n        appName,\n        version,\n        datasets,\n        filters,\n        layers,\n        layerBlending,\n        layerClasses,\n        uiState,\n        layerOrder,\n        interactionConfig,\n        visStateActions,\n        mapStyleActions,\n        uiStateActions\n      } = this.props;\n      const {activeSidePanel} = uiState;\n      const isOpen = Boolean(activeSidePanel);\n\n      const layerManagerActions = {\n        addLayer: visStateActions.addLayer,\n        layerConfigChange: visStateActions.layerConfigChange,\n        layerVisualChannelConfigChange:\n        visStateActions.layerVisualChannelConfigChange,\n        layerTypeChange: visStateActions.layerTypeChange,\n        layerVisConfigChange: visStateActions.layerVisConfigChange,\n        updateLayerBlending: visStateActions.updateLayerBlending,\n        updateLayerOrder: visStateActions.reorderLayer,\n        showDatasetTable: this._showDatasetTable,\n        showAddDataModal: this._showAddDataModal,\n        removeLayer: visStateActions.removeLayer,\n        removeDataset: this._removeDataset\n      };\n\n      const filterManagerActions = {\n        addFilter: visStateActions.addFilter,\n        removeFilter: visStateActions.removeFilter,\n        setFilter: visStateActions.setFilter,\n        showDatasetTable: this._showDatasetTable,\n        showAddDataModal: this._showAddDataModal,\n        toggleAnimation: visStateActions.toggleAnimation,\n        enlargeFilter: visStateActions.enlargeFilter\n      };\n\n      const interactionManagerActions = {\n        onConfigChange: visStateActions.interactionConfigChange\n      };\n\n      const mapManagerActions = {\n        addMapStyleUrl: mapStyleActions.addMapStyleUrl,\n        onConfigChange: mapStyleActions.mapConfigChange,\n        onStyleChange: mapStyleActions.mapStyleChange,\n        onBuildingChange: mapStyleActions.mapBuildingChange,\n        showAddMapStyleModal: this._showAddMapStyleModal\n      };\n\n      return (\n        <div>\n          <Sidebar\n            width={this.props.width}\n            isOpen={isOpen}\n            minifiedWidth={0}\n            onOpenOrClose={this._onOpenOrClose}\n          >\n            <PanelHeader\n              appName={appName}\n              version={version}\n              onExportImage={this._onExportImage}\n              onExportData={this._onExportData}\n              visibleDropdown={uiState.visibleDropdown}\n              showExportDropdown={uiStateActions.showExportDropdown}\n              hideExportDropdown={uiStateActions.hideExportDropdown}\n              onExportConfig={this._onExportConfig}\n              onSaveMap={this.props.onSaveMap}\n            />\n            <PanelToggle\n              panels={PANELS}\n              activePanel={activeSidePanel}\n              togglePanel={uiStateActions.toggleSidePanel}\n            />\n            <SidePanelContent className=\"side-panel__content\">\n              <div>\n                <PanelTitle className=\"side-panel__content__title\">\n                  {(PANELS.find(({id}) => id === activeSidePanel) || {}).label}\n                </PanelTitle>\n                {activeSidePanel === 'layer' && (\n                  <LayerManager\n                    {...layerManagerActions}\n                    datasets={datasets}\n                    layers={layers}\n                    layerClasses={layerClasses}\n                    layerOrder={layerOrder}\n                    layerBlending={layerBlending}\n                    openModal={uiStateActions.toggleModal}\n                  />\n                )}\n                {activeSidePanel === 'filter' && (\n                  <FilterManager\n                    {...filterManagerActions}\n                    datasets={datasets}\n                    filters={filters}\n                  />\n                )}\n                {activeSidePanel === 'interaction' && (\n                  <InteractionManager\n                    {...interactionManagerActions}\n                    datasets={datasets}\n                    interactionConfig={interactionConfig}\n                  />\n                )}\n                {activeSidePanel === 'map' && (\n                  <MapManager\n                    {...mapManagerActions}\n                    mapStyle={this.props.mapStyle}\n                  />\n                )}\n              </div>\n            </SidePanelContent>\n          </Sidebar>\n        </div>\n      );\n    }\n  };\n}\n"]}