UNPKG

kepler.gl.geoiq

Version:

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

338 lines (281 loc) 38.6 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _propTypes = _interopRequireDefault(require("prop-types")); var _reactAnythingSortable = require("react-anything-sortable"); var _lodash = _interopRequireDefault(require("lodash")); var _widgetConfigurator = _interopRequireDefault(require("./widget-configurator")); var _widgetPanelHeader = _interopRequireDefault(require("./widget-panel-header")); var _loadingSpinner = _interopRequireDefault(require("../../common/loading-spinner")); var _sliderBarHandle = _interopRequireDefault(require("../../common/slider/slider-bar-handle")); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _templateObject4() { var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n text-align: center;\n font-size: 30px;\n"]); _templateObject4 = function _templateObject4() { return data; }; return data; } function _templateObject3() { var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n color: #6a7485;\n text-align: center;\n font-size: 14px;\n"]); _templateObject3 = function _templateObject3() { return data; }; return data; } function _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n padding: 12px;\n"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 12px;\n border-radius: 1px;\n margin-bottom: 8px;\n\n &.dragging {\n cursor: move;\n }\n"]); _templateObject = function _templateObject() { return data; }; return data; } // import layers from '../../../../dist/components/common/icons/layers'; var PanelWrapper = _styledComponents["default"].div(_templateObject()); var StyledWidgetContent = _styledComponents["default"].div(_templateObject2(), function (props) { return props.theme.panelBackground; }); var StyledWidgetContentHeader = _styledComponents["default"].div(_templateObject3(), function (props) { return props.theme.panelBackground; }); var StyledWidgetContentValue = _styledComponents["default"].div(_templateObject4(), function (props) { return props.theme.panelBackground; }); function capitalizeFirstLetter(string) { return string.charAt(0).toUpperCase() + string.slice(1).toLowerCase(); } function WidgetPanelFactory() { var _class, _class2, _temp; var WidgetPanel = (0, _reactAnythingSortable.sortable)(_class = (_temp = _class2 = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(WidgetPanel, _Component); function WidgetPanel() { var _getPrototypeOf2; var _this; (0, _classCallCheck2["default"])(this, WidgetPanel); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(WidgetPanel)).call.apply(_getPrototypeOf2, [this].concat(args))); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", { aggregatedData: null }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "inDebounce", 0); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "updateState", function (func) { _this.setState({ aggregatedData: func }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "updateWidgetConfig", function (newProp) { newProp = _objectSpread({}, newProp, { mapState: _this.props.mapState }); _this.props.widgetConfigChange(_this.props.widget, newProp); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "updateWidgetType", function (newType) { _this.props.widgetTypeChange(_this.props.widget, newType); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "updateWidgetVisConfig", function (newVisConfig) { _this.props.widgetVisConfigChange(_this.props.widget, newVisConfig); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "updateWidgetVisualChannelConfig", function (newConfig, channel, scaleKey) { _this.props.widgetVisualChannelConfigChange(_this.props.widget, newConfig, channel, scaleKey); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_updateWidgetLabel", function (_ref) { var value = _ref.target.value; _this.updateWidgetConfig({ label: value }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_toggleVisibility", function (e) { e.stopPropagation(); var isVisible = !_this.props.widget.config.isVisible; _this.updateWidgetConfig({ isVisible: isVisible }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_toggleEnableConfig", function (e) { e.stopPropagation(); var isConfigActive = _this.props.widget.config.isConfigActive; _this.updateWidgetConfig({ isConfigActive: !isConfigActive }); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_removeWidget", function (e) { e.stopPropagation(); _this.props.removeWidget(_this.props.idx); }); return _this; } (0, _createClass2["default"])(WidgetPanel, [{ key: "componentDidMount", value: function componentDidMount() { this.props.widgetConfigChange(this.props.widget, { mapState: this.props.mapState }); } }, { key: "componentWillReceiveProps", value: function componentWillReceiveProps(nextProps) { var _this2 = this; if (!_lodash["default"].isEqual(this.props.mapState, nextProps.mapState) && nextProps.layers && nextProps.widget.config.bounds) { this.props.widgetConfigChange(this.props.widget, { isCalculating: true }); clearTimeout(this.inDebounce); this.inDebounce = setTimeout(function () { _this2.props.widgetConfigChange(_this2.props.widget, { mapState: nextProps.mapState }); clearTimeout(_this2.inDebounce); _this2.inDebounce = 0; }, 300); } } }, { key: "_renderLayerName", value: function _renderLayerName(id) { var placeholder = this.props.layers.map(function (l) { if (l.id === id) { return l.config.label; } }); return placeholder; } }, { key: "render", value: function render() { var _this$props = this.props, widget = _this$props.widget, layers = _this$props.layers, idx = _this$props.idx, datasets = _this$props.datasets, widgetTypeOptions = _this$props.widgetTypeOptions; var config = widget.config; var isConfigActive = config.isConfigActive; return _react["default"].createElement(PanelWrapper, { active: isConfigActive, className: "layer-panel ".concat(this.props.className), style: this.props.style, onMouseDown: this.props.onMouseDown, onTouchStart: this.props.onTouchStart }, _react["default"].createElement(_widgetPanelHeader["default"], { isConfigActive: isConfigActive, id: widget.id, idx: idx, isVisible: config.isVisible, label: config.label, labelRCGColorValues: datasets[config.dataId].color, widgetType: widget.name, onToggleEnableConfig: this._toggleEnableConfig, onToggleVisibility: this._toggleVisibility, onUpdateWidgetLabel: this._updateWidgetLabel, onRemoveWidget: this._removeWidget }), isConfigActive && _react["default"].createElement(_widgetConfigurator["default"], { widget: widget, layers: layers, datasets: datasets, widgetTypeOptions: widgetTypeOptions, openModal: this.props.openModal, updateLayerConfig: this.updateWidgetConfig, updateLayerVisualChannelConfig: this.updateWidgetVisualChannelConfig, updateLayerType: this.updateWidgetType, updateLayerVisConfig: this.updateWidgetVisConfig }), widget.type === 'Function' && config.isVisible && config.aggregatedData && config.aggregationType && (0, _typeof2["default"])(config.aggregatedData) !== 'object' || config.aggregatedData === 0 ? _react["default"].createElement(StyledWidgetContent, null, _react["default"].createElement(StyledWidgetContentHeader, null, capitalizeFirstLetter(config.aggregationType), " :", ' ', this._renderLayerName(config.selectedLayer.id), " :", ' ', config.fieldName), _react["default"].createElement(StyledWidgetContentValue, null, config.isCalculating ? _react["default"].createElement("div", { style: { display: 'inline-block', marginTop: '5px' } }, _react["default"].createElement(_loadingSpinner["default"], null)) : _react["default"].createElement("div", { style: { color: '#6a7485' } }, config.aggregatedData))) : null, widget.type === 'Category' && config.isVisible && config.aggregatedData && config.aggregatedData.length && config.aggregationType ? _react["default"].createElement(StyledWidgetContent, null, config.aggregatedData.map(function (ad) { return _react["default"].createElement(_react["default"].Fragment, null, _react["default"].createElement(StyledWidgetContentHeader, { style: { textAlign: 'inherit' } }, _react["default"].createElement("div", { style: { display: 'flex', color: '#6a7485' } }, ad['y'], ' ', _react["default"].createElement("div", { style: { marginLeft: 'auto' } }, ad['x']))), _react["default"].createElement(_sliderBarHandle["default"], { type: 'category', width: ad['x'] / config.aggregatedData[0]['x'] * 100, sliderBarListener: null }), _react["default"].createElement(StyledWidgetContentValue, null)); })) : null); } }]); return WidgetPanel; }(_react.Component), (0, _defineProperty2["default"])(_class2, "propTypes", { widget: _propTypes["default"].object.isRequired, datasets: _propTypes["default"].object.isRequired, idx: _propTypes["default"].number.isRequired, widgetConfigChange: _propTypes["default"].func.isRequired, widgetTypeChange: _propTypes["default"].func.isRequired, // layers: propTypes.arrayOf(propTypes.any), openModal: _propTypes["default"].func.isRequired, removeWidget: _propTypes["default"].func.isRequired, onCloseConfig: _propTypes["default"].func, widgetTypeOptions: _propTypes["default"].arrayOf(_propTypes["default"].any), widgetVisConfigChange: _propTypes["default"].func, widgetVisualChannelConfigChange: _propTypes["default"].func, mapState: _propTypes["default"].object.isRequired }), _temp)) || _class; return WidgetPanel; } var _default = WidgetPanelFactory; exports["default"] = _default; { /* <StyledWidgetContent> {config.aggregatedData.map(ad => { return ( <React.Fragment> <StyledWidgetContentHeader style={{textAlign: 'inherit'}}> {ad[0]}-{ad[1]} </StyledWidgetContentHeader> <StyledWidgetContentValue /> </React.Fragment> ); })} </StyledWidgetContent> */ } { /* <WidgetBarChart data={config.aggregatedData} height={96.9} width={191.6} margin={0} /> */ } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/widget-panel/widget-panel.js"],"names":["PanelWrapper","styled","div","StyledWidgetContent","props","theme","panelBackground","StyledWidgetContentHeader","StyledWidgetContentValue","capitalizeFirstLetter","string","charAt","toUpperCase","slice","toLowerCase","WidgetPanelFactory","WidgetPanel","sortable","aggregatedData","func","setState","newProp","mapState","widgetConfigChange","widget","newType","widgetTypeChange","newVisConfig","widgetVisConfigChange","newConfig","channel","scaleKey","widgetVisualChannelConfigChange","value","target","updateWidgetConfig","label","e","stopPropagation","isVisible","config","isConfigActive","removeWidget","idx","nextProps","_","isEqual","layers","bounds","isCalculating","clearTimeout","inDebounce","setTimeout","id","placeholder","map","l","datasets","widgetTypeOptions","className","style","onMouseDown","onTouchStart","dataId","color","name","_toggleEnableConfig","_toggleVisibility","_updateWidgetLabel","_removeWidget","openModal","updateWidgetVisualChannelConfig","updateWidgetType","updateWidgetVisConfig","type","aggregationType","_renderLayerName","selectedLayer","fieldName","display","marginTop","length","ad","textAlign","marginLeft","Component","PropTypes","object","isRequired","number","onCloseConfig","arrayOf","any"],"mappings":"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","sourcesContent":["// Copyright (c) 2019 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';\nimport _ from 'lodash';\nimport WidgetConfigurator from './widget-configurator';\nimport WidgetPanelHeader from './widget-panel-header';\nimport LoadingSpinner from 'components/common/loading-spinner';\nimport SliderHandle from 'components/common/slider/slider-bar-handle';\n// import layers from '../../../../dist/components/common/icons/layers';\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`;\nconst StyledWidgetContent = styled.div`\n  background-color: ${props => props.theme.panelBackground};\n  padding: 12px;\n`;\nconst StyledWidgetContentHeader = styled.div`\n  background-color: ${props => props.theme.panelBackground};\n  color: #6a7485;\n  text-align: center;\n  font-size: 14px;\n`;\n\nconst StyledWidgetContentValue = styled.div`\n  background-color: ${props => props.theme.panelBackground};\n  text-align: center;\n  font-size: 30px;\n`;\n\nfunction capitalizeFirstLetter(string) {\n  return string.charAt(0).toUpperCase() + string.slice(1).toLowerCase();\n}\n\nfunction WidgetPanelFactory() {\n  @sortable\n  class WidgetPanel extends Component {\n    static propTypes = {\n      widget: PropTypes.object.isRequired,\n      datasets: PropTypes.object.isRequired,\n      idx: PropTypes.number.isRequired,\n      widgetConfigChange: PropTypes.func.isRequired,\n      widgetTypeChange: PropTypes.func.isRequired,\n      // layers: propTypes.arrayOf(propTypes.any),\n      openModal: PropTypes.func.isRequired,\n      removeWidget: PropTypes.func.isRequired,\n      onCloseConfig: PropTypes.func,\n\n      widgetTypeOptions: PropTypes.arrayOf(PropTypes.any),\n      widgetVisConfigChange: PropTypes.func,\n      widgetVisualChannelConfigChange: PropTypes.func,\n\n      mapState: PropTypes.object.isRequired\n    };\n\n    state = {\n      aggregatedData: null\n    };\n\n    inDebounce = 0;\n\n    componentDidMount() {\n      this.props.widgetConfigChange(this.props.widget, {\n        mapState: this.props.mapState\n      });\n    }\n\n    componentWillReceiveProps(nextProps) {\n      if (\n        !_.isEqual(this.props.mapState, nextProps.mapState) &&\n        nextProps.layers &&\n        nextProps.widget.config.bounds\n      ) {\n        this.props.widgetConfigChange(this.props.widget, {\n          isCalculating: true\n        });\n        clearTimeout(this.inDebounce);\n        this.inDebounce = setTimeout(() => {\n          this.props.widgetConfigChange(this.props.widget, {\n            mapState: nextProps.mapState\n          });\n          clearTimeout(this.inDebounce);\n          this.inDebounce = 0;\n        }, 300);\n      }\n    }\n\n    updateState = func => {\n      this.setState({aggregatedData: func});\n    };\n\n    updateWidgetConfig = newProp => {\n      newProp = {\n        ...newProp,\n        mapState: this.props.mapState\n      };\n      this.props.widgetConfigChange(this.props.widget, newProp);\n    };\n\n    updateWidgetType = newType => {\n      this.props.widgetTypeChange(this.props.widget, newType);\n    };\n\n    updateWidgetVisConfig = newVisConfig => {\n      this.props.widgetVisConfigChange(this.props.widget, newVisConfig);\n    };\n\n    updateWidgetVisualChannelConfig = (newConfig, channel, scaleKey) => {\n      this.props.widgetVisualChannelConfigChange(\n        this.props.widget,\n        newConfig,\n        channel,\n        scaleKey\n      );\n    };\n\n    _updateWidgetLabel = ({target: {value}}) => {\n      this.updateWidgetConfig({label: value});\n    };\n\n    _toggleVisibility = e => {\n      e.stopPropagation();\n      const isVisible = !this.props.widget.config.isVisible;\n      this.updateWidgetConfig({isVisible});\n    };\n\n    _toggleEnableConfig = e => {\n      e.stopPropagation();\n      const {\n        widget: {\n          config: {isConfigActive}\n        }\n      } = this.props;\n      this.updateWidgetConfig({isConfigActive: !isConfigActive});\n    };\n\n    _removeWidget = e => {\n      e.stopPropagation();\n      this.props.removeWidget(this.props.idx);\n    };\n\n    _renderLayerName(id) {\n      var placeholder = this.props.layers.map(l => {\n        if (l.id === id) {\n          return l.config.label;\n        }\n      });\n      return placeholder;\n    }\n\n    render() {\n      const {widget, layers, idx, datasets, widgetTypeOptions} = this.props;\n      const {config} = widget;\n      const {isConfigActive} = config;\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          <WidgetPanelHeader\n            isConfigActive={isConfigActive}\n            id={widget.id}\n            idx={idx}\n            isVisible={config.isVisible}\n            label={config.label}\n            labelRCGColorValues={datasets[config.dataId].color}\n            widgetType={widget.name}\n            onToggleEnableConfig={this._toggleEnableConfig}\n            onToggleVisibility={this._toggleVisibility}\n            onUpdateWidgetLabel={this._updateWidgetLabel}\n            onRemoveWidget={this._removeWidget}\n          />\n          {isConfigActive && (\n            <WidgetConfigurator\n              widget={widget}\n              layers={layers}\n              datasets={datasets}\n              widgetTypeOptions={widgetTypeOptions}\n              openModal={this.props.openModal}\n              updateLayerConfig={this.updateWidgetConfig}\n              updateLayerVisualChannelConfig={\n                this.updateWidgetVisualChannelConfig\n              }\n              updateLayerType={this.updateWidgetType}\n              updateLayerVisConfig={this.updateWidgetVisConfig}\n            />\n          )}\n          {(widget.type === 'Function' &&\n            config.isVisible &&\n            config.aggregatedData &&\n            config.aggregationType &&\n            typeof config.aggregatedData !== 'object') ||\n          config.aggregatedData === 0 ? (\n            <StyledWidgetContent>\n              <StyledWidgetContentHeader>\n                {capitalizeFirstLetter(config.aggregationType)} :{' '}\n                {this._renderLayerName(config.selectedLayer.id)} :{' '}\n                {config.fieldName}\n              </StyledWidgetContentHeader>\n              <StyledWidgetContentValue>\n                {config.isCalculating ? (\n                  <div style={{display: 'inline-block', marginTop: '5px'}}>\n                    <LoadingSpinner />\n                  </div>\n                ) : (\n                  <div style={{color: '#6a7485'}}>{config.aggregatedData}</div>\n                )}\n              </StyledWidgetContentValue>\n            </StyledWidgetContent>\n          ) : null}\n          {widget.type === 'Category' &&\n          config.isVisible &&\n          config.aggregatedData &&\n          config.aggregatedData.length &&\n          config.aggregationType ? (\n            <StyledWidgetContent>\n              {config.aggregatedData.map(ad => {\n                return (\n                  <React.Fragment>\n                    <StyledWidgetContentHeader style={{textAlign: 'inherit'}}>\n                      <div style={{display: 'flex', color: '#6a7485'}}>\n                        {ad['y']}{' '}\n                        <div style={{marginLeft: 'auto'}}>{ad['x']}</div>\n                      </div>\n                    </StyledWidgetContentHeader>\n                    <SliderHandle\n                      type={'category'}\n                      width={(ad['x'] / config.aggregatedData[0]['x']) * 100}\n                      sliderBarListener={null}\n                    />\n                    <StyledWidgetContentValue />\n                  </React.Fragment>\n                );\n              })}\n            </StyledWidgetContent>\n          ) : null}\n        </PanelWrapper>\n      );\n    }\n  }\n\n  return WidgetPanel;\n}\n\nexport default WidgetPanelFactory;\n\n{\n  /* <StyledWidgetContent>\n              {config.aggregatedData.map(ad => {\n                return (\n                  <React.Fragment>\n                    <StyledWidgetContentHeader style={{textAlign: 'inherit'}}>\n                      {ad[0]}-{ad[1]}\n                    </StyledWidgetContentHeader>\n                    <StyledWidgetContentValue />\n                  </React.Fragment>\n                );\n              })}\n            </StyledWidgetContent> */\n}\n\n{\n  /* <WidgetBarChart\n              data={config.aggregatedData}\n              height={96.9}\n              width={191.6}\n              margin={0}\n            /> */\n}\n"]}