UNPKG

kepler.gl

Version:

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

181 lines (142 loc) 18.5 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = undefined; 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, _class2, _temp2; var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n font-size: 12px;\n border-radius: 1px;\n margin-bottom: 8px;\n\n &.dragging {\n cursor: move;\n }\n'], ['\n font-size: 12px;\n border-radius: 1px;\n margin-bottom: 8px;\n\n &.dragging {\n cursor: move;\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 _styledComponents = require('styled-components'); var _styledComponents2 = _interopRequireDefault(_styledComponents); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _reactAnythingSortable = require('react-anything-sortable'); var _layerConfigurator = require('./layer-configurator'); var _layerConfigurator2 = _interopRequireDefault(_layerConfigurator); var _layerPanelHeader = require('./layer-panel-header'); var _layerPanelHeader2 = _interopRequireDefault(_layerPanelHeader); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var PanelWrapper = _styledComponents2.default.div(_templateObject); var LayerPanel = (0, _reactAnythingSortable.sortable)(_class = (_temp2 = _class2 = function (_Component) { (0, _inherits3.default)(LayerPanel, _Component); function LayerPanel() { var _ref; var _temp, _this, _ret; (0, _classCallCheck3.default)(this, LayerPanel); 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 = LayerPanel.__proto__ || Object.getPrototypeOf(LayerPanel)).call.apply(_ref, [this].concat(args))), _this), _this.updateLayerConfig = function (newProp) { _this.props.layerConfigChange(_this.props.layer, newProp); }, _this.updateLayerType = function (newType) { _this.props.layerTypeChange(_this.props.layer, newType); }, _this.updateLayerVisConfig = function (newVisConfig) { _this.props.layerVisConfigChange(_this.props.layer, newVisConfig); }, _this.updateLayerVisualChannelConfig = function (newConfig, channel, scaleKey) { _this.props.layerVisualChannelConfigChange(_this.props.layer, newConfig, channel, scaleKey); }, _this._updateLayerLabel = function (_ref2) { var value = _ref2.target.value; _this.updateLayerConfig({ label: value }); }, _this._toggleVisibility = function (e) { e.stopPropagation(); var isVisible = !_this.props.layer.config.isVisible; _this.updateLayerConfig({ isVisible: isVisible }); }, _this._toggleEnableConfig = function (e) { e.stopPropagation(); var isConfigActive = _this.props.layer.config.isConfigActive; _this.updateLayerConfig({ isConfigActive: !isConfigActive }); }, _this._removeLayer = function (e) { e.stopPropagation(); _this.props.removeLayer(_this.props.idx); }, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); } (0, _createClass3.default)(LayerPanel, [{ key: 'render', value: function render() { var _props = this.props, layer = _props.layer, idx = _props.idx, datasets = _props.datasets, layerTypeOptions = _props.layerTypeOptions; var config = layer.config; var isConfigActive = config.isConfigActive; return _react2.default.createElement( PanelWrapper, { active: isConfigActive, className: 'layer-panel ' + this.props.className, style: this.props.style, onMouseDown: this.props.onMouseDown, onTouchStart: this.props.onTouchStart }, _react2.default.createElement(_layerPanelHeader2.default, { isConfigActive: isConfigActive, id: layer.id, idx: idx, isVisible: config.isVisible, label: config.label, labelRCGColorValues: datasets[config.dataId].color, layerType: layer.name, onToggleEnableConfig: this._toggleEnableConfig, onToggleVisibility: this._toggleVisibility, onUpdateLayerLabel: this._updateLayerLabel, onRemoveLayer: this._removeLayer }), isConfigActive && _react2.default.createElement(_layerConfigurator2.default, { layer: layer, datasets: datasets, layerTypeOptions: layerTypeOptions, openModal: this.props.openModal, updateLayerConfig: this.updateLayerConfig, updateLayerVisualChannelConfig: this.updateLayerVisualChannelConfig, updateLayerType: this.updateLayerType, updateLayerVisConfig: this.updateLayerVisConfig }) ); } }]); return LayerPanel; }(_react.Component), _class2.propTypes = { layer: _propTypes2.default.object.isRequired, datasets: _propTypes2.default.object.isRequired, idx: _propTypes2.default.number.isRequired, layerConfigChange: _propTypes2.default.func.isRequired, layerTypeChange: _propTypes2.default.func.isRequired, openModal: _propTypes2.default.func.isRequired, removeLayer: _propTypes2.default.func.isRequired, onCloseConfig: _propTypes2.default.func, layerTypeOptions: _propTypes2.default.arrayOf(_propTypes2.default.any), layerVisConfigChange: _propTypes2.default.func, layerVisualChannelConfigChange: _propTypes2.default.func }, _temp2)) || _class; exports.default = LayerPanel; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/layer-panel.js"],"names":["PanelWrapper","styled","div","LayerPanel","sortable","updateLayerConfig","props","layerConfigChange","layer","newProp","updateLayerType","layerTypeChange","newType","updateLayerVisConfig","layerVisConfigChange","newVisConfig","updateLayerVisualChannelConfig","newConfig","channel","scaleKey","layerVisualChannelConfigChange","_updateLayerLabel","value","target","label","_toggleVisibility","e","stopPropagation","isVisible","config","_toggleEnableConfig","isConfigActive","_removeLayer","removeLayer","idx","datasets","layerTypeOptions","className","style","onMouseDown","onTouchStart","id","dataId","color","name","openModal","Component","propTypes","PropTypes","object","isRequired","number","func","onCloseConfig","arrayOf","any"],"mappings":"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","file":"layer-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 styled from 'styled-components';\nimport PropTypes from 'prop-types';\nimport {sortable} from 'react-anything-sortable';\n\nimport LayerConfigurator from './layer-configurator';\nimport LayerPanelHeader from './layer-panel-header';\n\nconst PanelWrapper = styled.div`\n  font-size: 12px;\n  border-radius: 1px;\n  margin-bottom: 8px;\n\n  &.dragging {\n    cursor: move;\n  }\n`;\n\n@sortable\nexport default class LayerPanel extends Component {\n  static propTypes = {\n    layer: PropTypes.object.isRequired,\n    datasets: PropTypes.object.isRequired,\n    idx: PropTypes.number.isRequired,\n    layerConfigChange: PropTypes.func.isRequired,\n    layerTypeChange: PropTypes.func.isRequired,\n    openModal: PropTypes.func.isRequired,\n    removeLayer: PropTypes.func.isRequired,\n    onCloseConfig: PropTypes.func,\n\n    layerTypeOptions: PropTypes.arrayOf(PropTypes.any),\n    layerVisConfigChange: PropTypes.func,\n    layerVisualChannelConfigChange: PropTypes.func\n  };\n\n  updateLayerConfig = newProp => {\n    this.props.layerConfigChange(this.props.layer, newProp);\n  };\n\n  updateLayerType = newType => {\n    this.props.layerTypeChange(this.props.layer, newType);\n  };\n\n  updateLayerVisConfig = newVisConfig => {\n    this.props.layerVisConfigChange(this.props.layer, newVisConfig);\n  };\n\n  updateLayerVisualChannelConfig = (newConfig, channel, scaleKey) => {\n    this.props.layerVisualChannelConfigChange(\n      this.props.layer,\n      newConfig,\n      channel,\n      scaleKey\n    );\n  };\n\n  _updateLayerLabel = ({target: {value}}) => {\n    this.updateLayerConfig({label: value});\n  };\n\n  _toggleVisibility = e => {\n    e.stopPropagation();\n    const isVisible = !this.props.layer.config.isVisible;\n    this.updateLayerConfig({isVisible});\n  };\n\n  _toggleEnableConfig = e => {\n    e.stopPropagation();\n    const {layer: {config: {isConfigActive}}} = this.props;\n    this.updateLayerConfig({isConfigActive: !isConfigActive});\n  };\n\n  _removeLayer = e => {\n    e.stopPropagation();\n    this.props.removeLayer(this.props.idx);\n  };\n  render() {\n    const {layer, idx, datasets, layerTypeOptions} = this.props;\n    const {config} = layer;\n    const {isConfigActive} = config;\n\n    return (\n      <PanelWrapper\n        active={isConfigActive}\n        className={`layer-panel ${this.props.className}`}\n        style={this.props.style}\n        onMouseDown={this.props.onMouseDown}\n        onTouchStart={this.props.onTouchStart}\n      >\n        <LayerPanelHeader\n          isConfigActive={isConfigActive}\n          id={layer.id}\n          idx={idx}\n          isVisible={config.isVisible}\n          label={config.label}\n          labelRCGColorValues={datasets[config.dataId].color}\n          layerType={layer.name}\n          onToggleEnableConfig={this._toggleEnableConfig}\n          onToggleVisibility={this._toggleVisibility}\n          onUpdateLayerLabel={this._updateLayerLabel}\n          onRemoveLayer={this._removeLayer}\n        />\n        {isConfigActive && (\n          <LayerConfigurator\n            layer={layer}\n            datasets={datasets}\n            layerTypeOptions={layerTypeOptions}\n            openModal={this.props.openModal}\n            updateLayerConfig={this.updateLayerConfig}\n            updateLayerVisualChannelConfig={this.updateLayerVisualChannelConfig}\n            updateLayerType={this.updateLayerType}\n            updateLayerVisConfig={this.updateLayerVisConfig}\n          />\n        )}\n      </PanelWrapper>\n    );\n  }\n}\n"]}