UNPKG

kepler.gl.geoiq

Version:

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

178 lines (140 loc) 22.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.StyledLayerConfigGroupLabel = exports.StyledLayerConfigGroupAction = exports.StyledLayerConfigGroup = exports.StyledConfigGroupHeader = exports.ConfigGroupCollapsibleHeader = exports.ConfigGroupCollapsibleContent = 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 _styledComponents = _interopRequireDefault(require("styled-components")); var _classnames = _interopRequireDefault(require("classnames")); var _switch = _interopRequireDefault(require("../../common/switch")); var _infoHelper = _interopRequireDefault(require("../../common/info-helper")); var _icons = require("../../common/icons"); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7; 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 _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 StyledLayerConfigGroupLabel = exports.StyledLayerConfigGroupLabel = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n border-left: 2px solid ", ";\n line-height: 12px;\n margin-left: -12px;\n padding-left: 10px;\n display: flex;\n align-items: center;\n\n span {\n color: ", ";\n font-size: 12px;\n font-weight: 500;\n letter-spacing: 0.2px;\n text-transform: capitalize;\n }\n"])), function (props) { return props.theme.labelColor; }, function (props) { return props.theme.textColor; }); var StyledLayerConfigGroupAction = exports.StyledLayerConfigGroupAction = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n color: ", ";\n"])), function (props) { return props.theme.textColor; }); var ConfigGroupCollapsibleContent = exports.ConfigGroupCollapsibleContent = _styledComponents["default"].div.attrs({ className: 'layer-config-group__content__collapsible' })(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: visible;\n transition: max-height 0.3s ease-out;\n height: max-content;\n max-height: 600px;\n"]))); var ConfigGroupCollapsibleHeader = exports.ConfigGroupCollapsibleHeader = _styledComponents["default"].div.attrs({ className: 'layer-config-group__header__collapsible' })(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: visible;\n overflow: hidden;\n max-height: 0;\n"]))); var StyledLayerConfigGroup = exports.StyledLayerConfigGroup = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n padding-left: 18px;\n margin-bottom: 12px;\n\n &.collapsed {\n .layer-config-group__header__collapsible {\n overflow: visible;\n max-height: 600px;\n }\n .layer-config-group__content {\n\n .layer-config-group__content__collapsible {\n overflow: hidden;\n max-height: 0;\n }\n }\n }\n"]))); var StyledConfigGroupHeader = exports.StyledConfigGroupHeader = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 12px;\n\n :hover {\n cursor: pointer;\n .layer-config-group__label {\n color: ", ";\n border-left: 2px solid ", ";\n }\n\n .layer-config-group__action {\n color: ", ";\n }\n }\n"])), function (props) { return props.theme.textColorHl; }, function (props) { return props.theme.textColorHl; }, function (props) { return props.theme.textColorHl; }); var ConfigGroupContent = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n &.disabled {\n opacity: 0.3;\n pointer-events: none;\n * {\n pointer-events: none;\n }\n }\n"]))); var LayerConfigGroup = exports["default"] = /*#__PURE__*/function (_Component) { (0, _inherits2["default"])(LayerConfigGroup, _Component); var _super = _createSuper(LayerConfigGroup); function LayerConfigGroup() { var _this; (0, _classCallCheck2["default"])(this, LayerConfigGroup); 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", { collapsed: true }); return _this; } (0, _createClass2["default"])(LayerConfigGroup, [{ key: "componentDidMount", value: function componentDidMount() { this._setCollapseState(this.props.expanded); } }, { key: "componentWillReceiveProps", value: function componentWillReceiveProps(nextProps) { this._setCollapseState(nextProps.expanded); } }, { key: "_setCollapseState", value: function _setCollapseState(expanded) { // if props,expanded, and state collapsed, set collapsed to be false if (expanded && this.state.collapsed) { this.setState({ collapsed: false }); } } }, { key: "render", value: function render() { var _this2 = this; var _this$props = this.props, label = _this$props.label, children = _this$props.children, property = _this$props.property, layer = _this$props.layer, _onChange2 = _this$props.onChange, collapsible = _this$props.collapsible, description = _this$props.description; var collapsed = this.state.collapsed; return (/*#__PURE__*/_react["default"].createElement(StyledLayerConfigGroup, { className: (0, _classnames["default"])('layer-config-group', { collapsed: collapsed }) }, /*#__PURE__*/_react["default"].createElement(StyledConfigGroupHeader, { className: "layer-config-group__header", onClick: function onClick() { return _this2.setState({ collapsed: !_this2.state.collapsed }); } }, /*#__PURE__*/_react["default"].createElement(StyledLayerConfigGroupLabel, { className: "layer-config-group__label" }, /*#__PURE__*/_react["default"].createElement("span", null, label), description && /*#__PURE__*/_react["default"].createElement(_infoHelper["default"], { description: description, id: label })), /*#__PURE__*/_react["default"].createElement(StyledLayerConfigGroupAction, { className: "layer-config-group__action" }, property ? /*#__PURE__*/_react["default"].createElement(_switch["default"], { checked: layer.config.visConfig[property], id: "".concat(layer.id, "-").concat(property), onChange: function onChange() { return _onChange2((0, _defineProperty2["default"])({}, property, !layer.config.visConfig[property])); } }) : null, collapsible ? /*#__PURE__*/_react["default"].createElement(_icons.VertThreeDots, { height: "18px" }) : null)), /*#__PURE__*/_react["default"].createElement(ConfigGroupContent, { className: (0, _classnames["default"])('layer-config-group__content', { disabled: property && !layer.config.visConfig[property] }) }, children)) ); } }]); return LayerConfigGroup; }(_react.Component); (0, _defineProperty2["default"])(LayerConfigGroup, "defaultProps", { collapsible: false, expanded: false, onChange: function onChange() {}, description: null }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/layer-config-group.js"],"names":["StyledLayerConfigGroupLabel","styled","div","props","theme","labelColor","textColor","StyledLayerConfigGroupAction","ConfigGroupCollapsibleContent","attrs","className","ConfigGroupCollapsibleHeader","StyledLayerConfigGroup","StyledConfigGroupHeader","textColorHl","ConfigGroupContent","LayerConfigGroup","collapsed","_setCollapseState","expanded","nextProps","state","setState","label","children","property","layer","onChange","collapsible","description","config","visConfig","id","disabled","Component"],"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 classnames from 'classnames';\nimport Switch from 'components/common/switch';\nimport InfoHelper from 'components/common/info-helper';\nimport {VertThreeDots} from 'components/common/icons';\n\nexport const StyledLayerConfigGroupLabel = styled.div`\n  border-left: 2px solid ${props => props.theme.labelColor};\n  line-height: 12px;\n  margin-left: -12px;\n  padding-left: 10px;\n  display: flex;\n  align-items: center;\n\n  span {\n    color: ${props => props.theme.textColor};\n    font-size: 12px;\n    font-weight: 500;\n    letter-spacing: 0.2px;\n    text-transform: capitalize;\n  }\n`;\n\nexport const StyledLayerConfigGroupAction = styled.div`\n  display: flex;\n  align-items: center;\n  color: ${props => props.theme.textColor};\n`;\n\nexport const ConfigGroupCollapsibleContent = styled.div.attrs({\n  className: 'layer-config-group__content__collapsible'\n})`\n  overflow: visible;\n  transition: max-height 0.3s ease-out;\n  height: max-content;\n  max-height: 600px;\n`;\n\nexport const ConfigGroupCollapsibleHeader = styled.div.attrs({\n  className: 'layer-config-group__header__collapsible'\n})`\n  overflow: visible;\n  overflow: hidden;\n  max-height: 0;\n`;\n\nexport const StyledLayerConfigGroup = styled.div`\n  padding-left: 18px;\n  margin-bottom: 12px;\n\n  &.collapsed {\n    .layer-config-group__header__collapsible {\n      overflow: visible;\n      max-height: 600px;\n    }\n    .layer-config-group__content {\n\n      .layer-config-group__content__collapsible {\n        overflow: hidden;\n        max-height: 0;\n      }\n    }\n  }\n`;\n\nexport const StyledConfigGroupHeader = styled.div`\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  margin-bottom: 12px;\n\n  :hover {\n    cursor: pointer;\n    .layer-config-group__label {\n      color: ${props => props.theme.textColorHl};\n      border-left: 2px solid ${props => props.theme.textColorHl};\n    }\n\n    .layer-config-group__action {\n      color: ${props => props.theme.textColorHl};\n    }\n  }\n`;\n\nconst ConfigGroupContent = styled.div`\n  &.disabled {\n    opacity: 0.3;\n    pointer-events: none;\n    * {\n      pointer-events: none;\n    }\n  }\n`;\n\nexport default class LayerConfigGroup extends Component {\n  static defaultProps = {\n    collapsible: false,\n    expanded: false,\n    onChange: () => {},\n    description: null\n  };\n\n  state = {\n    collapsed: true\n  };\n\n  componentDidMount() {\n    this._setCollapseState(this.props.expanded);\n  }\n\n  componentWillReceiveProps(nextProps) {\n    this._setCollapseState(nextProps.expanded);\n  }\n\n  _setCollapseState(expanded) {\n    // if props,expanded, and state collapsed, set collapsed to be false\n    if (expanded && this.state.collapsed) {\n      this.setState({collapsed: false});\n    }\n  }\n\n  render() {\n    const {\n      label,\n      children,\n      property,\n      layer,\n      onChange,\n      collapsible,\n      description\n    } = this.props;\n\n    const {collapsed} = this.state;\n\n    return (\n      <StyledLayerConfigGroup\n        className={classnames('layer-config-group', {collapsed})}\n      >\n        <StyledConfigGroupHeader\n          className=\"layer-config-group__header\"\n          onClick={() => this.setState({collapsed: !this.state.collapsed})}\n        >\n          <StyledLayerConfigGroupLabel className=\"layer-config-group__label\">\n            <span>{label}</span>\n            {description && (\n              <InfoHelper\n                description={description}\n                id={label}\n              />\n            )}\n          </StyledLayerConfigGroupLabel>\n          <StyledLayerConfigGroupAction className=\"layer-config-group__action\">\n            {property ? (\n              <Switch\n                checked={layer.config.visConfig[property]}\n                id={`${layer.id}-${property}`}\n                onChange={() =>\n                  onChange({[property]: !layer.config.visConfig[property]})\n                }\n              />\n            ) : null}\n            {collapsible ? <VertThreeDots height=\"18px\" /> : null}\n          </StyledLayerConfigGroupAction>\n        </StyledConfigGroupHeader>\n        <ConfigGroupContent\n          className={classnames('layer-config-group__content', {\n            disabled: property && !layer.config.visConfig[property]\n          })}\n        >\n          {children}\n        </ConfigGroupContent>\n      </StyledLayerConfigGroup>\n    );\n  }\n}\n"]}