UNPKG

kepler.gl

Version:

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

286 lines (241 loc) 27.5 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = undefined; var _defineProperty2 = require('babel-runtime/helpers/defineProperty'); var _defineProperty3 = _interopRequireDefault(_defineProperty2); var _extends4 = require('babel-runtime/helpers/extends'); var _extends5 = _interopRequireDefault(_extends4); 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 _class, _temp2; var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n padding-bottom: 12px;\n'], ['\n padding-bottom: 12px;\n']), _templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n height: 48px;\n margin-bottom: 5px;\n opacity: 1;\n position: relative;\n transition: opacity 0.05s ease-in, height 0.25s ease-out;\n \n &.collapsed {\n height: 0;\n margin-bottom: 0;\n opacity: 0;\n }\n\n :hover {\n cursor: pointer;\n background-color: ', ';\n }\n\n .map-title-block img {\n margin-right: 12px;\n }\n\n .map-preview {\n border-radius: 3px;\n height: 30px;\n width: 40px;\n }\n'], ['\n height: 48px;\n margin-bottom: 5px;\n opacity: 1;\n position: relative;\n transition: opacity 0.05s ease-in, height 0.25s ease-out;\n \n &.collapsed {\n height: 0;\n margin-bottom: 0;\n opacity: 0;\n }\n\n :hover {\n cursor: pointer;\n background-color: ', ';\n }\n\n .map-title-block img {\n margin-right: 12px;\n }\n\n .map-preview {\n border-radius: 3px;\n height: 30px;\n width: 40px;\n }\n']), _templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n margin-bottom: 10px;\n display: flex;\n justify-content: space-between;\n\n &:last-child {\n margin-bottom: 0;\n }\n\n .layer-group__visibility-toggle {\n margin-right: 12px;\n }\n'], ['\n margin-bottom: 10px;\n display: flex;\n justify-content: space-between;\n\n &:last-child {\n margin-bottom: 0;\n }\n\n .layer-group__visibility-toggle {\n margin-right: 12px;\n }\n']), _templateObject4 = (0, _taggedTemplateLiteral3.default)(['\n color: ', ';\n'], ['\n color: ', ';\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 _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _styledComponents3 = require('../common/styled-components'); var _panelHeaderAction = require('./panel-header-action'); var _panelHeaderAction2 = _interopRequireDefault(_panelHeaderAction); var _icons = require('../common/icons'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var StyledInteractionPanel = _styledComponents2.default.div(_templateObject); var MapManager = (_temp2 = _class = function (_Component) { (0, _inherits3.default)(MapManager, _Component); function MapManager() { var _ref; var _temp, _this, _ret; (0, _classCallCheck3.default)(this, MapManager); 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 = MapManager.__proto__ || Object.getPrototypeOf(MapManager)).call.apply(_ref, [this].concat(args))), _this), _this.state = { isSelecting: false }, _this._updateConfig = function (newProp) { var newConfig = (0, _extends5.default)({}, _this.props.mapStyle, newProp); _this.props.onConfigChange(newConfig); }, _this._toggleSelecting = function () { _this.setState({ isSelecting: !_this.state.isSelecting }); }, _this._selectStyle = function (val) { _this.props.onStyleChange(val); _this._toggleSelecting(); }, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); } (0, _createClass3.default)(MapManager, [{ key: 'render', value: function render() { var mapStyle = this.props.mapStyle; var editableLayers = mapStyle.visibleLayerGroups; return _react2.default.createElement( 'div', { className: 'map-style-panel' }, _react2.default.createElement( 'div', null, _react2.default.createElement(MapStyleSelector, { mapStyle: mapStyle, isSelecting: this.state.isSelecting, onChange: this._selectStyle, toggleActive: this._toggleSelecting }), Object.keys(editableLayers).length ? _react2.default.createElement(LayerGroupSelector, { layers: mapStyle.visibleLayerGroups, editableLayers: editableLayers, topLayers: mapStyle.topLayerGroups, onChange: this._updateConfig }) : null, _react2.default.createElement( _styledComponents3.Button, { onClick: this.props.showAddMapStyleModal, secondary: true }, _react2.default.createElement(_icons.Add, { height: '12px' }), 'Add Map Style' ) ) ); } }]); return MapManager; }(_react.Component), _class.propTypes = { mapStyle: _propTypes2.default.object.isRequired, onConfigChange: _propTypes2.default.func.isRequired, onStyleChange: _propTypes2.default.func.isRequired, showAddMapStyleModal: _propTypes2.default.func.isRequired }, _temp2); exports.default = MapManager; var StyledMapDropdown = _styledComponents3.StyledPanelHeader.extend(_templateObject2, function (props) { return props.theme.panelBackgroundHover; }); var MapStyleSelector = function MapStyleSelector(_ref2) { var mapStyle = _ref2.mapStyle, onChange = _ref2.onChange, toggleActive = _ref2.toggleActive, isSelecting = _ref2.isSelecting; return _react2.default.createElement( 'div', null, _react2.default.createElement( _styledComponents3.PanelLabel, null, 'Map style' ), Object.keys(mapStyle.mapStyles).map(function (op) { return _react2.default.createElement( StyledMapDropdown, { className: (0, _classnames2.default)('map-dropdown-option', { collapsed: !isSelecting && mapStyle.styleType !== op }), key: op, onClick: isSelecting ? function () { return onChange(op); } : toggleActive }, _react2.default.createElement( _styledComponents3.PanelHeaderContent, { className: 'map-title-block' }, _react2.default.createElement('img', { className: 'map-preview', src: mapStyle.mapStyles[op].icon }), _react2.default.createElement( _styledComponents3.PanelHeaderTitle, { className: 'map-preview-name' }, mapStyle.mapStyles[op].label ) ), !isSelecting ? _react2.default.createElement(_panelHeaderAction2.default, { className: 'map-dropdown-option__enable-config', id: 'map-enable-config', IconComponent: _icons.ArrowDown, tooltip: 'Select Base Map Style', onClick: toggleActive }) : null ); }) ); }; var StyledLayerGroupItem = _styledComponents2.default.div(_templateObject3); var LayerLabel = _styledComponents3.PanelLabelBold.extend(_templateObject4, function (props) { return props.active ? props.theme.textColor : props.theme.labelColor; }); var LayerGroupSelector = function LayerGroupSelector(_ref3) { var layers = _ref3.layers, editableLayers = _ref3.editableLayers, onChange = _ref3.onChange, topLayers = _ref3.topLayers; return _react2.default.createElement( StyledInteractionPanel, { className: 'map-style__layer-group__selector' }, _react2.default.createElement( 'div', { className: 'layer-group__header' }, _react2.default.createElement( _styledComponents3.PanelLabel, null, 'Map Layers' ) ), _react2.default.createElement( _styledComponents3.PanelContent, { className: 'map-style__layer-group' }, Object.keys(editableLayers).map(function (slug) { return _react2.default.createElement( StyledLayerGroupItem, { className: 'layer-group__select', key: slug }, _react2.default.createElement( _styledComponents3.PanelLabelWrapper, null, _react2.default.createElement(_panelHeaderAction2.default, { className: 'layer-group__visibility-toggle', id: slug + '-toggle', tooltip: layers[slug] ? 'hide' : 'show', onClick: function onClick() { return onChange({ visibleLayerGroups: (0, _extends5.default)({}, layers, (0, _defineProperty3.default)({}, slug, !layers[slug])) }); }, IconComponent: layers[slug] ? _icons.EyeSeen : _icons.EyeUnseen, active: layers[slug], flush: true }), _react2.default.createElement( LayerLabel, { active: layers[slug] }, slug ) ), _react2.default.createElement( _styledComponents3.CenterFlexbox, { className: 'layer-group__bring-top' }, _react2.default.createElement(_panelHeaderAction2.default, { id: slug + '-top', tooltip: 'Move to top of data layers', disabled: !layers[slug], IconComponent: _icons.Upload, active: topLayers[slug], onClick: function onClick() { return onChange({ topLayerGroups: (0, _extends5.default)({}, topLayers, (0, _defineProperty3.default)({}, slug, !topLayers[slug])) }); } }) ) ); }) ) ); }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/map-manager.js"],"names":["StyledInteractionPanel","styled","div","MapManager","state","isSelecting","_updateConfig","newConfig","props","mapStyle","newProp","onConfigChange","_toggleSelecting","setState","_selectStyle","onStyleChange","val","editableLayers","visibleLayerGroups","Object","keys","length","topLayerGroups","showAddMapStyleModal","Component","propTypes","PropTypes","object","isRequired","func","StyledMapDropdown","StyledPanelHeader","extend","theme","panelBackgroundHover","MapStyleSelector","onChange","toggleActive","mapStyles","map","collapsed","styleType","op","icon","label","ArrowDown","StyledLayerGroupItem","LayerLabel","PanelLabelBold","active","textColor","labelColor","LayerGroupSelector","layers","topLayers","slug","EyeSeen","EyeUnseen","Upload"],"mappings":"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","file":"map-manager.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 classnames from 'classnames';\nimport styled from 'styled-components';\n\nimport {\n  Button,\n  PanelLabel,\n  StyledPanelHeader,\n  PanelHeaderTitle,\n  PanelHeaderContent,\n  PanelContent,\n  PanelLabelBold,\n  PanelLabelWrapper,\n  CenterFlexbox\n} from 'components/common/styled-components';\n\nimport PanelHeaderAction from 'components/side-panel/panel-header-action';\nimport {Add, ArrowDown, EyeSeen, EyeUnseen, Upload} from 'components/common/icons';\n\nconst StyledInteractionPanel = styled.div`\n  padding-bottom: 12px;\n`;\n\nexport default class MapManager extends Component {\n  static propTypes = {\n    mapStyle: PropTypes.object.isRequired,\n    onConfigChange: PropTypes.func.isRequired,\n    onStyleChange: PropTypes.func.isRequired,\n    showAddMapStyleModal: PropTypes.func.isRequired\n  };\n\n  state = {\n    isSelecting: false\n  };\n\n  _updateConfig = newProp => {\n    const newConfig = {...this.props.mapStyle, ...newProp};\n    this.props.onConfigChange(newConfig);\n  };\n\n  _toggleSelecting = () => {\n    this.setState({isSelecting: !this.state.isSelecting});\n  };\n\n  _selectStyle = val => {\n    this.props.onStyleChange(val);\n    this._toggleSelecting();\n  };\n\n  render() {\n    const {mapStyle} = this.props;\n    const editableLayers = mapStyle.visibleLayerGroups;\n\n    return (\n      <div className=\"map-style-panel\">\n        <div>\n          <MapStyleSelector\n            mapStyle={mapStyle}\n            isSelecting={this.state.isSelecting}\n            onChange={this._selectStyle}\n            toggleActive={this._toggleSelecting}\n          />\n          {Object.keys(editableLayers).length ? (\n            <LayerGroupSelector\n              layers={mapStyle.visibleLayerGroups}\n              editableLayers={editableLayers}\n              topLayers={mapStyle.topLayerGroups}\n              onChange={this._updateConfig}\n            />\n          ) : null}\n          <Button\n            onClick={this.props.showAddMapStyleModal}\n            secondary>\n            <Add height=\"12px\" />Add Map Style\n          </Button>\n        </div>\n      </div>\n    );\n  }\n}\n\nconst StyledMapDropdown = StyledPanelHeader.extend`\n  height: 48px;\n  margin-bottom: 5px;\n  opacity: 1;\n  position: relative;\n  transition: opacity 0.05s ease-in, height 0.25s ease-out;\n  \n  &.collapsed {\n    height: 0;\n    margin-bottom: 0;\n    opacity: 0;\n  }\n\n  :hover {\n    cursor: pointer;\n    background-color: ${props => props.theme.panelBackgroundHover};\n  }\n\n  .map-title-block img {\n    margin-right: 12px;\n  }\n\n  .map-preview {\n    border-radius: 3px;\n    height: 30px;\n    width: 40px;\n  }\n`;\n\nconst MapStyleSelector = ({mapStyle, onChange, toggleActive, isSelecting}) => (\n  <div>\n    <PanelLabel>Map style</PanelLabel>\n    {Object.keys(mapStyle.mapStyles).map(op => (\n      <StyledMapDropdown\n        className={classnames('map-dropdown-option', {\n          collapsed: !isSelecting && mapStyle.styleType !== op\n        })}\n        key={op}\n        onClick={isSelecting ? () => onChange(op) : toggleActive}\n      >\n        <PanelHeaderContent className=\"map-title-block\">\n          <img className=\"map-preview\" src={mapStyle.mapStyles[op].icon} />\n          <PanelHeaderTitle className=\"map-preview-name\">\n            {mapStyle.mapStyles[op].label}\n          </PanelHeaderTitle>\n        </PanelHeaderContent>\n        {!isSelecting ? (\n          <PanelHeaderAction\n            className=\"map-dropdown-option__enable-config\"\n            id=\"map-enable-config\"\n            IconComponent={ArrowDown}\n            tooltip={'Select Base Map Style'}\n            onClick={toggleActive}\n          />\n        ) : null}\n      </StyledMapDropdown>\n    ))}\n  </div>\n);\n\nconst StyledLayerGroupItem = styled.div`\n  margin-bottom: 10px;\n  display: flex;\n  justify-content: space-between;\n\n  &:last-child {\n    margin-bottom: 0;\n  }\n\n  .layer-group__visibility-toggle {\n    margin-right: 12px;\n  }\n`;\n\nconst LayerLabel = PanelLabelBold.extend`\n  color: ${props =>\n    props.active ? props.theme.textColor : props.theme.labelColor};\n`;\nconst LayerGroupSelector = ({layers, editableLayers, onChange, topLayers}) => (\n  <StyledInteractionPanel className=\"map-style__layer-group__selector\">\n    <div className=\"layer-group__header\">\n      <PanelLabel>Map Layers</PanelLabel>\n    </div>\n    <PanelContent className=\"map-style__layer-group\">\n      {Object.keys(editableLayers).map(slug => (\n        <StyledLayerGroupItem className=\"layer-group__select\" key={slug}>\n          <PanelLabelWrapper>\n            <PanelHeaderAction\n              className=\"layer-group__visibility-toggle\"\n              id={`${slug}-toggle`}\n              tooltip={layers[slug] ? 'hide' : 'show'}\n              onClick={() =>\n                onChange({\n                  visibleLayerGroups: {\n                    ...layers,\n                    [slug]: !layers[slug]\n                  }\n                })\n              }\n              IconComponent={layers[slug] ? EyeSeen : EyeUnseen}\n              active={layers[slug]}\n              flush\n            />\n            <LayerLabel active={layers[slug]}>{slug}</LayerLabel>\n          </PanelLabelWrapper>\n          <CenterFlexbox className=\"layer-group__bring-top\">\n            <PanelHeaderAction\n              id={`${slug}-top`}\n              tooltip=\"Move to top of data layers\"\n              disabled={!layers[slug]}\n              IconComponent={Upload}\n              active={topLayers[slug]}\n              onClick={() =>\n                onChange({\n                  topLayerGroups: {\n                    ...topLayers,\n                    [slug]: !topLayers[slug]\n                  }\n                })\n              }\n            />\n          </CenterFlexbox>\n        </StyledLayerGroupItem>\n      ))}\n    </PanelContent>\n  </StyledInteractionPanel>\n);\n"]}