kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
172 lines (128 loc) • 18.6 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
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 _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 _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 _templateObject, _templateObject2;
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 || _typeof(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; } }
var StyledPanelContent = (0, _styledComponents["default"])(_styledComponents2.PanelContent)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n border-top: 1px solid ", ";\n"])), function (props) {
return props.theme.panelBorderColor;
});
var StyledInteractionPanel = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n padding-bottom: 6px;\n"])));
InteractionPanelFactory.deps = [_tooltipConfig["default"], _brushConfig["default"]];
function InteractionPanelFactory(TooltipConfig, BrushConfig) {
var _class, _temp;
return _temp = _class = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(InteractionPanel, _Component);
var _super = _createSuper(InteractionPanel);
function InteractionPanel() {
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 = _super.call.apply(_super, [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(_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 = /*#__PURE__*/_react["default"].createElement(TooltipConfig, {
datasets: datasets,
config: config.config,
onChange: onChange
});
break;
case 'brush':
template = /*#__PURE__*/_react["default"].createElement(BrushConfig, {
config: config.config,
onChange: onChange
});
break;
default:
break;
}
return (/*#__PURE__*/_react["default"].createElement(StyledInteractionPanel, {
className: "interaction-panel"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledPanelHeader, {
className: "interaction-panel__header",
onClick: this._enableConfig
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelHeaderContent, {
className: "interaction-panel__header__content"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "interaction-panel__header__icon icon"
}, /*#__PURE__*/_react["default"].createElement(config.iconComponent, {
height: "12px"
})), /*#__PURE__*/_react["default"].createElement("div", {
className: "interaction-panel__header__title"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelHeaderTitle, null, config.id))), /*#__PURE__*/_react["default"].createElement("div", {
className: "interaction-panel__header__actions"
}, /*#__PURE__*/_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 && /*#__PURE__*/_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 = exports["default"] = InteractionPanelFactory;
//# 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","enabled","Component","PropTypes","object","isRequired","func"],"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 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';\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\n              datasets={datasets}\n              config={config.config}\n              onChange={onChange}\n            />\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\n            className=\"interaction-panel__header\"\n            onClick={this._enableConfig}\n          >\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                <PanelHeaderTitle>{config.id}</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"]}