UNPKG

kepler.gl

Version:

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

188 lines (142 loc) 17.1 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 _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 _propTypes = _interopRequireDefault(require("prop-types")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _switch = _interopRequireDefault(require("../../common/switch")); var _brushConfig = _interopRequireDefault(require("./brush-config")); var _tooltipConfig = _interopRequireDefault(require("./tooltip-config")); var _styledComponents2 = require("../../common/styled-components"); var _reactIntl = require("react-intl"); 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 _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n padding-bottom: 6px;\n"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["default"])(["\n border-top: 1px solid ", ";\n"]); _templateObject = function _templateObject() { return data; }; return data; } var StyledPanelContent = (0, _styledComponents["default"])(_styledComponents2.PanelContent)(_templateObject(), function (props) { return props.theme.panelBorderColor; }); var StyledInteractionPanel = _styledComponents["default"].div(_templateObject2()); InteractionPanelFactory.deps = [_tooltipConfig["default"], _brushConfig["default"]]; function InteractionPanelFactory(TooltipConfig, BrushConfig) { var _class, _temp; return _temp = _class = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(InteractionPanel, _Component); function InteractionPanel() { var _getPrototypeOf2; var _this; (0, _classCallCheck2["default"])(this, InteractionPanel); 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"])(InteractionPanel)).call.apply(_getPrototypeOf2, [this].concat(args))); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", { isConfigActive: false }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_updateConfig", function (newProp) { _this.props.onConfigChange(_objectSpread({}, _this.props.config, {}, newProp)); }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_enableConfig", function () { _this.setState({ isConfigActive: !_this.state.isConfigActive }); }); return _this; } (0, _createClass2["default"])(InteractionPanel, [{ key: "render", value: function render() { var _this2 = this; var _this$props = this.props, config = _this$props.config, datasets = _this$props.datasets; var onChange = function onChange(newConfig) { return _this2._updateConfig({ config: newConfig }); }; var template = null; switch (config.id) { case 'tooltip': template = _react["default"].createElement(TooltipConfig, { datasets: datasets, config: config.config, onChange: onChange }); break; case 'brush': template = _react["default"].createElement(BrushConfig, { config: config.config, onChange: onChange }); break; default: break; } return _react["default"].createElement(StyledInteractionPanel, { className: "interaction-panel" }, _react["default"].createElement(_styledComponents2.StyledPanelHeader, { className: "interaction-panel__header", onClick: this._enableConfig }, _react["default"].createElement(_styledComponents2.PanelHeaderContent, { className: "interaction-panel__header__content" }, _react["default"].createElement("div", { className: "interaction-panel__header__icon icon" }, _react["default"].createElement(config.iconComponent, { height: "12px" })), _react["default"].createElement("div", { className: "interaction-panel__header__title" }, _react["default"].createElement(_styledComponents2.PanelHeaderTitle, null, _react["default"].createElement(_reactIntl.FormattedMessage, { id: config.label })))), _react["default"].createElement("div", { className: "interaction-panel__header__actions" }, _react["default"].createElement(_switch["default"], { checked: config.enabled, id: "".concat(config.id, "-toggle"), onChange: function onChange() { return _this2._updateConfig({ enabled: !config.enabled }); }, secondary: true }))), config.enabled && template && _react["default"].createElement(StyledPanelContent, { className: "interaction-panel__content" }, template)); } }]); return InteractionPanel; }(_react.Component), (0, _defineProperty2["default"])(_class, "propTypes", { datasets: _propTypes["default"].object.isRequired, config: _propTypes["default"].object.isRequired, onConfigChange: _propTypes["default"].func.isRequired }), _temp; } var _default = InteractionPanelFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/interaction-panel/interaction-panel.js"],"names":["StyledPanelContent","PanelContent","props","theme","panelBorderColor","StyledInteractionPanel","styled","div","InteractionPanelFactory","deps","TooltipConfigFactory","BrushConfigFactory","TooltipConfig","BrushConfig","isConfigActive","newProp","onConfigChange","config","setState","state","datasets","onChange","newConfig","_updateConfig","template","id","_enableConfig","label","enabled","Component","PropTypes","object","isRequired","func"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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 styled from 'styled-components';\nimport Switch from 'components/common/switch';\n\nimport BrushConfigFactory from './brush-config';\nimport TooltipConfigFactory from './tooltip-config';\n\nimport {\n  StyledPanelHeader,\n  PanelHeaderTitle,\n  PanelHeaderContent,\n  PanelContent\n} from 'components/common/styled-components';\nimport { FormattedMessage } from \"react-intl\";\n\nconst StyledPanelContent = styled(PanelContent)`\n  border-top: 1px solid ${props => props.theme.panelBorderColor};\n`;\n\nconst StyledInteractionPanel = styled.div`\n  padding-bottom: 6px;\n`;\n\nInteractionPanelFactory.deps = [TooltipConfigFactory, BrushConfigFactory];\n\nfunction InteractionPanelFactory(TooltipConfig, BrushConfig) {\n  return class InteractionPanel extends Component {\n    static propTypes = {\n      datasets: PropTypes.object.isRequired,\n      config: PropTypes.object.isRequired,\n      onConfigChange: PropTypes.func.isRequired\n    };\n\n    state = {isConfigActive: false};\n\n    _updateConfig = newProp => {\n      this.props.onConfigChange({\n        ...this.props.config,\n        ...newProp\n      });\n    };\n\n    _enableConfig = () => {\n      this.setState({isConfigActive: !this.state.isConfigActive});\n    };\n\n    render() {\n      const {config, datasets} = this.props;\n      const onChange = newConfig => this._updateConfig({config: newConfig});\n      let template = null;\n\n      switch (config.id) {\n        case 'tooltip':\n          template = (\n            <TooltipConfig datasets={datasets} config={config.config} onChange={onChange} />\n          );\n          break;\n\n        case 'brush':\n          template = <BrushConfig config={config.config} onChange={onChange} />;\n          break;\n\n        default:\n          break;\n      }\n\n      return (\n        <StyledInteractionPanel className=\"interaction-panel\">\n          <StyledPanelHeader className=\"interaction-panel__header\" onClick={this._enableConfig}>\n            <PanelHeaderContent className=\"interaction-panel__header__content\">\n              <div className=\"interaction-panel__header__icon icon\">\n                <config.iconComponent height=\"12px\" />\n              </div>\n              <div className=\"interaction-panel__header__title\">\n\n                <PanelHeaderTitle><FormattedMessage id={config.label} /></PanelHeaderTitle>\n              </div>\n            </PanelHeaderContent>\n            <div className=\"interaction-panel__header__actions\">\n              <Switch\n                checked={config.enabled}\n                id={`${config.id}-toggle`}\n                onChange={() => this._updateConfig({enabled: !config.enabled})}\n                secondary\n              />\n            </div>\n          </StyledPanelHeader>\n          {config.enabled && template && (\n            <StyledPanelContent className=\"interaction-panel__content\">\n              {template}\n            </StyledPanelContent>\n          )}\n        </StyledInteractionPanel>\n      );\n    }\n  };\n}\n\nexport default InteractionPanelFactory;\n"]}