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