UNPKG

kepler.gl.geoiq

Version:

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

393 lines (336 loc) 49.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof3 = require("@babel/runtime/helpers/typeof"); 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 _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); 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")); var _templateObject, _templateObject2, _templateObject3, _templateObject4; function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } // import layers from '../../../../dist/components/common/icons/layers'; var PanelWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n font-size: 12px;\n border-radius: 1px;\n margin-bottom: 8px;\n\n &.dragging {\n cursor: move;\n }\n"]))); var StyledWidgetContent = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n padding: 12px;\n"])), function (props) { return props.theme.panelBackground; }); var StyledWidgetContentHeader = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n color: #6a7485;\n text-align: center;\n font-size: 14px;\n"])), function (props) { return props.theme.panelBackground; }); var StyledWidgetContentValue = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n text-align: center;\n font-size: 30px;\n"])), 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); var _super = _createSuper(WidgetPanel); function WidgetPanel() { 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 = _super.call.apply(_super, [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) { var _this$props = _this.props, auth = _this$props.auth, widget = _this$props.widget, project = _this$props.project, mapState = _this$props.mapState, datasets = _this$props.datasets, filters = _this$props.filters, widgetConfigChange = _this$props.widgetConfigChange; var props = Object.keys(newProp); if (widget.shouldCalculateAggregatedData(props)) { // this.calculateWidgetAggregationData( // widget, // filters, // datasets, // mapState, // auth, // project, // widgetConfigChange // ); widgetConfigChange(widget, { apiCallRequest: true }); } newProp = _objectSpread(_objectSpread({}, newProp), {}, { mapState: mapState }); _this.props.widgetConfigChange(widget, newProp, auth, project); }); (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() { var _this$props2 = this.props, auth = _this$props2.auth, project = _this$props2.project, mapState = _this$props2.mapState, datasets = _this$props2.datasets, filters = _this$props2.filters, widget = _this$props2.widget, widgetConfigChange = _this$props2.widgetConfigChange; var result = widget.calculateAggregationData(widget, filters, datasets, mapState, auth, project); if (result) { result.then(function (result) { // widget.updateWidgetConfig({ // aggregatedData: result // }); widgetConfigChange(widget, { aggregatedData: result }); }); } } }, { key: "componentWillReceiveProps", value: function componentWillReceiveProps(nextProps) { var _this2 = this; var auth = nextProps.auth, project = nextProps.project, widget = nextProps.widget, filters = nextProps.filters, datasets = nextProps.datasets, mapState = nextProps.mapState, widgetConfigChange = nextProps.widgetConfigChange; if (widget.config.apiCallRequest) { widgetConfigChange(widget, { apiCallRequest: false }); this.calculateWidgetAggregationData(widget, filters, datasets, mapState, auth, project, widgetConfigChange); } if (!_lodash["default"].isEqual(this.props.mapState, nextProps.mapState) && // nextProps.layers && nextProps.widget.config.bounds) { nextProps.widgetConfigChange(nextProps.widget, { isCalculating: true }, auth, project); clearTimeout(this.inDebounce); this.inDebounce = setTimeout(function () { var result = widget.calculateAggregationData(widget, filters, datasets, mapState, auth, project); result.then(function (result) { widgetConfigChange(widget, { aggregatedData: result, isCalculating: false }); }); // nextProps.widgetConfigChange( // nextProps.widget, // { // mapState: nextProps.mapState // }, // auth, // project // ); clearTimeout(_this2.inDebounce); _this2.inDebounce = 0; }, 300); } } }, { key: "calculateWidgetAggregationData", value: function calculateWidgetAggregationData(widget, filters, datasets, mapState, auth, project, widgetConfigChange) { var result = widget.calculateAggregationData(widget, filters, datasets, mapState, auth, project); if (result) { result.then(function (result) { widgetConfigChange(widget, { aggregatedData: result, apiCallRequest: false }); }); } } }, { 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$props3 = this.props, widget = _this$props3.widget, layers = _this$props3.layers, idx = _this$props3.idx, datasets = _this$props3.datasets, widgetTypeOptions = _this$props3.widgetTypeOptions; var config = widget.config; var isConfigActive = config.isConfigActive; return (/*#__PURE__*/_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 }, /*#__PURE__*/_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 && /*#__PURE__*/_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 ? /*#__PURE__*/_react["default"].createElement(StyledWidgetContent, null, /*#__PURE__*/_react["default"].createElement(StyledWidgetContentHeader, null, capitalizeFirstLetter(config.aggregationType), " :", ' ', config.fieldName), /*#__PURE__*/_react["default"].createElement(StyledWidgetContentValue, null, config.isCalculating ? /*#__PURE__*/_react["default"].createElement("div", { style: { display: 'inline-block', marginTop: '5px' } }, /*#__PURE__*/_react["default"].createElement(_loadingSpinner["default"], null)) : /*#__PURE__*/_react["default"].createElement("div", { style: { color: '#6a7485' } }, config.aggregatedData))) : null, widget.type === 'Category' && config.isVisible && config.aggregatedData && config.aggregatedData.length && config.aggregationType ? /*#__PURE__*/_react["default"].createElement(StyledWidgetContent, null, config.aggregatedData.map(function (ad) { return (/*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(StyledWidgetContentHeader, { style: { textAlign: 'inherit' } }, /*#__PURE__*/_react["default"].createElement("div", { style: { display: 'flex', color: '#6a7485' } }, ad.y, ' ', /*#__PURE__*/_react["default"].createElement("div", { style: { marginLeft: 'auto' } }, ad.x))), /*#__PURE__*/_react["default"].createElement(_sliderBarHandle["default"], { type: 'category', width: ad.x / config.aggregatedData[0].x * 100, sliderBarListener: null }), /*#__PURE__*/_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, auth: _propTypes["default"].object.isRequired, project: _propTypes["default"].object.isRequired }), _temp)) || _class; return WidgetPanel; } var _default = exports["default"] = WidgetPanelFactory; { /* <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","auth","widget","project","mapState","datasets","filters","widgetConfigChange","Object","keys","shouldCalculateAggregatedData","apiCallRequest","newType","widgetTypeChange","newVisConfig","widgetVisConfigChange","newConfig","channel","scaleKey","widgetVisualChannelConfigChange","value","target","updateWidgetConfig","label","e","stopPropagation","isVisible","config","isConfigActive","removeWidget","idx","result","calculateAggregationData","then","nextProps","calculateWidgetAggregationData","_","isEqual","bounds","isCalculating","clearTimeout","inDebounce","setTimeout","id","placeholder","layers","map","l","widgetTypeOptions","className","style","onMouseDown","onTouchStart","dataId","color","name","_toggleEnableConfig","_toggleVisibility","_updateWidgetLabel","_removeWidget","openModal","updateWidgetVisualChannelConfig","updateWidgetType","updateWidgetVisConfig","type","aggregationType","fieldName","display","marginTop","length","ad","textAlign","y","marginLeft","x","Component","PropTypes","object","isRequired","number","onCloseConfig","arrayOf","any"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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      auth: PropTypes.object.isRequired,\n      project: PropTypes.object.isRequired\n    };\n\n    state = {\n      aggregatedData: null\n    };\n\n    inDebounce = 0;\n\n    componentDidMount() {\n      const {\n        auth,\n        project,\n        mapState,\n        datasets,\n        filters,\n        widget,\n        widgetConfigChange\n      } = this.props;\n      const result = widget.calculateAggregationData(\n        widget,\n        filters,\n        datasets,\n        mapState,\n        auth,\n        project\n      );\n      if (result) {\n        result.then(function(result) {\n          // widget.updateWidgetConfig({\n          //   aggregatedData: result\n          // });\n          widgetConfigChange(widget, {aggregatedData: result});\n        });\n      }\n    }\n\n    componentWillReceiveProps(nextProps) {\n      const {\n        auth,\n        project,\n        widget,\n        filters,\n        datasets,\n        mapState,\n        widgetConfigChange\n      } = nextProps;\n\n      if (widget.config.apiCallRequest) {\n        widgetConfigChange(widget, {apiCallRequest: false});\n        this.calculateWidgetAggregationData(\n          widget,\n          filters,\n          datasets,\n          mapState,\n          auth,\n          project,\n          widgetConfigChange\n        );\n      }\n\n      if (\n        !_.isEqual(this.props.mapState, nextProps.mapState) &&\n        // nextProps.layers &&\n        nextProps.widget.config.bounds\n      ) {\n        nextProps.widgetConfigChange(\n          nextProps.widget,\n          {\n            isCalculating: true\n          },\n          auth,\n          project\n        );\n\n        clearTimeout(this.inDebounce);\n        this.inDebounce = setTimeout(() => {\n          const result = widget.calculateAggregationData(\n            widget,\n            filters,\n            datasets,\n            mapState,\n            auth,\n            project\n          );\n\n          result.then(function(result) {\n            widgetConfigChange(widget, {\n              aggregatedData: result,\n              isCalculating: false\n            });\n          });\n          // nextProps.widgetConfigChange(\n          //   nextProps.widget,\n          //   {\n          //     mapState: nextProps.mapState\n          //   },\n          //   auth,\n          //   project\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    calculateWidgetAggregationData(\n      widget,\n      filters,\n      datasets,\n      mapState,\n      auth,\n      project,\n      widgetConfigChange\n    ) {\n      const result = widget.calculateAggregationData(\n        widget,\n        filters,\n        datasets,\n        mapState,\n        auth,\n        project\n      );\n      if (result) {\n        result.then(function(result) {\n          widgetConfigChange(widget, {\n            aggregatedData: result,\n            apiCallRequest: false\n          });\n        });\n      }\n    }\n\n    updateWidgetConfig = newProp => {\n      const {\n        auth,\n        widget,\n        project,\n        mapState,\n        datasets,\n        filters,\n        widgetConfigChange\n      } = this.props;\n\n      const props = Object.keys(newProp);\n      if (widget.shouldCalculateAggregatedData(props)) {\n        // this.calculateWidgetAggregationData(\n        //   widget,\n        //   filters,\n        //   datasets,\n        //   mapState,\n        //   auth,\n        //   project,\n        //   widgetConfigChange\n        // );\n        widgetConfigChange(widget, {apiCallRequest: true});\n      }\n\n      newProp = {\n        ...newProp,\n        mapState\n      };\n\n      this.props.widgetConfigChange(widget, newProp, auth, project);\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"]}