UNPKG

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