kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
220 lines (172 loc) • 26.2 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.LayerConfigGroupLabelFactory = LayerConfigGroupLabelFactory;
exports["default"] = exports.StyledLayerConfigGroup = exports.ConfigGroupCollapsibleHeader = exports.ConfigGroupCollapsibleContent = exports.StyledLayerConfigGroupAction = 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 _reactLifecyclesCompat = require("react-lifecycles-compat");
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _classnames = _interopRequireDefault(require("classnames"));
var _reactIntl = require("react-intl");
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 _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 StyledLayerConfigGroupAction = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n color: ", ";\n"])), function (props) {
return props.theme.textColor;
});
exports.StyledLayerConfigGroupAction = StyledLayerConfigGroupAction;
var ConfigGroupCollapsibleContent = _styledComponents["default"].div.attrs({
className: 'layer-config-group__content__collapsible'
})(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: visible;\n transition: max-height 0.3s ease-out;\n height: max-content;\n max-height: 600px;\n"])));
exports.ConfigGroupCollapsibleContent = ConfigGroupCollapsibleContent;
var ConfigGroupCollapsibleHeader = _styledComponents["default"].div.attrs({
className: 'layer-config-group__header__collapsible'
})(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: visible;\n overflow: hidden;\n max-height: 0;\n"])));
exports.ConfigGroupCollapsibleHeader = ConfigGroupCollapsibleHeader;
var StyledLayerConfigGroup = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n padding-left: ", "px;\n margin-bottom: ", "px;\n\n &.disabled {\n opacity: 0.3;\n pointer-events: none;\n }\n &.collapsed {\n .layer-config-group__header__collapsible {\n overflow: visible;\n max-height: 600px;\n }\n .layer-config-group__content {\n .layer-config-group__content__collapsible {\n overflow: hidden;\n max-height: 0;\n }\n }\n }\n"])), function (props) {
return props.theme.layerConfigGroupPaddingLeft;
}, function (props) {
return props.theme.layerConfigGroupMarginBottom;
});
exports.StyledLayerConfigGroup = StyledLayerConfigGroup;
var StyledConfigGroupHeader = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (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 }\n\n .layer-config-group__action {\n color: ", ";\n }\n }\n"])), function (props) {
return props.theme.textColorHl;
}, function (props) {
return props.theme.textColorHl;
});
var ConfigGroupContent = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n &.disabled {\n opacity: 0.3;\n pointer-events: none;\n * {\n pointer-events: none;\n }\n }\n"])));
LayerConfigGroupLabelFactory.deps = [_infoHelper["default"]];
function LayerConfigGroupLabelFactory(InfoHelper) {
var StyledLayerConfigGroupLabel = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n border-left: ", " solid\n ", ";\n line-height: 12px;\n margin-left: ", ";\n padding-left: ", ";\n\n display: flex;\n align-items: center;\n\n span {\n color: ", ";\n font-weight: 500;\n letter-spacing: 0.2px;\n text-transform: capitalize;\n margin-left: ", ";\n font-size: ", ";\n }\n "])), function (props) {
return props.theme.layerConfigGroupLabelBorderLeft;
}, function (props) {
return props.theme.labelColor;
}, function (props) {
return props.theme.layerConfigGroupLabelMargin;
}, function (props) {
return props.theme.layerConfigGroupLabelPadding;
}, function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.layerConfigGroupLabelLabelMargin;
}, function (props) {
return props.theme.layerConfigGroupLabelLabelFontSize;
});
var LayerConfigGroupLabel = function LayerConfigGroupLabel(_ref) {
var label = _ref.label,
description = _ref.description;
return /*#__PURE__*/_react["default"].createElement(StyledLayerConfigGroupLabel, {
className: "layer-config-group__label"
}, /*#__PURE__*/_react["default"].createElement("span", null, /*#__PURE__*/_react["default"].createElement(_reactIntl.FormattedMessage, {
id: label || 'misc.empty',
defaultMessage: label
})), description && /*#__PURE__*/_react["default"].createElement(InfoHelper, {
description: description,
id: label
}));
};
return LayerConfigGroupLabel;
}
LayerConfigGroupFactory.deps = [LayerConfigGroupLabelFactory];
function LayerConfigGroupFactory(LayerConfigGroupLabel) {
var LayerConfigGroup = /*#__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: "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,
disabled = _this$props.disabled;
var collapsed = this.state.collapsed;
return /*#__PURE__*/_react["default"].createElement(StyledLayerConfigGroup, {
className: (0, _classnames["default"])('layer-config-group', {
collapsed: collapsed,
disabled: disabled
})
}, /*#__PURE__*/_react["default"].createElement(StyledConfigGroupHeader, {
className: "layer-config-group__header",
onClick: function onClick() {
return _this2.setState({
collapsed: !_this2.state.collapsed
});
}
}, /*#__PURE__*/_react["default"].createElement(LayerConfigGroupLabel, {
label: label,
description: description
}), /*#__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));
}
}], [{
key: "getDerivedStateFromProps",
value: function getDerivedStateFromProps(props, state) {
// invoked after a component is instantiated as well as before it is re-rendered
if (props.expanded && state.collapsed) {
return {
collapsed: false
};
}
return null;
}
}]);
return LayerConfigGroup;
}(_react.Component);
(0, _defineProperty2["default"])(LayerConfigGroup, "defaultProps", {
collapsible: false,
expanded: false,
onChange: function onChange() {},
description: null,
disabled: false
});
(0, _reactLifecyclesCompat.polyfill)(LayerConfigGroup);
return LayerConfigGroup;
}
var _default = LayerConfigGroupFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/layer-config-group.js"],"names":["StyledLayerConfigGroupAction","styled","div","props","theme","textColor","ConfigGroupCollapsibleContent","attrs","className","ConfigGroupCollapsibleHeader","StyledLayerConfigGroup","layerConfigGroupPaddingLeft","layerConfigGroupMarginBottom","StyledConfigGroupHeader","textColorHl","ConfigGroupContent","LayerConfigGroupLabelFactory","deps","InfoHelperFactory","InfoHelper","StyledLayerConfigGroupLabel","layerConfigGroupLabelBorderLeft","labelColor","layerConfigGroupLabelMargin","layerConfigGroupLabelPadding","layerConfigGroupLabelLabelMargin","layerConfigGroupLabelLabelFontSize","LayerConfigGroupLabel","label","description","LayerConfigGroupFactory","LayerConfigGroup","collapsed","children","property","layer","onChange","collapsible","disabled","state","setState","config","visConfig","id","expanded","Component"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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 {polyfill} from 'react-lifecycles-compat';\nimport styled from 'styled-components';\nimport classnames from 'classnames';\nimport {FormattedMessage} from 'react-intl';\nimport Switch from 'components/common/switch';\nimport InfoHelperFactory from 'components/common/info-helper';\nimport {VertThreeDots} from 'components/common/icons';\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: ${props => props.theme.layerConfigGroupPaddingLeft}px;\n  margin-bottom: ${props => props.theme.layerConfigGroupMarginBottom}px;\n\n  &.disabled {\n    opacity: 0.3;\n    pointer-events: none;\n  }\n  &.collapsed {\n    .layer-config-group__header__collapsible {\n      overflow: visible;\n      max-height: 600px;\n    }\n    .layer-config-group__content {\n      .layer-config-group__content__collapsible {\n        overflow: hidden;\n        max-height: 0;\n      }\n    }\n  }\n`;\n\nconst 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    }\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\nLayerConfigGroupLabelFactory.deps = [InfoHelperFactory];\n\nexport function LayerConfigGroupLabelFactory(InfoHelper) {\n  const StyledLayerConfigGroupLabel = styled.div`\n    border-left: ${props => props.theme.layerConfigGroupLabelBorderLeft} solid\n      ${props => props.theme.labelColor};\n    line-height: 12px;\n    margin-left: ${props => props.theme.layerConfigGroupLabelMargin};\n    padding-left: ${props => props.theme.layerConfigGroupLabelPadding};\n\n    display: flex;\n    align-items: center;\n\n    span {\n      color: ${props => props.theme.textColor};\n      font-weight: 500;\n      letter-spacing: 0.2px;\n      text-transform: capitalize;\n      margin-left: ${props => props.theme.layerConfigGroupLabelLabelMargin};\n      font-size: ${props => props.theme.layerConfigGroupLabelLabelFontSize};\n    }\n  `;\n\n  const LayerConfigGroupLabel = ({label, description}) => (\n    <StyledLayerConfigGroupLabel className=\"layer-config-group__label\">\n      <span>\n        <FormattedMessage id={label || 'misc.empty'} defaultMessage={label} />\n      </span>\n      {description && <InfoHelper description={description} id={label} />}\n    </StyledLayerConfigGroupLabel>\n  );\n\n  return LayerConfigGroupLabel;\n}\n\nLayerConfigGroupFactory.deps = [LayerConfigGroupLabelFactory];\n\nfunction LayerConfigGroupFactory(LayerConfigGroupLabel) {\n  class LayerConfigGroup extends Component {\n    static defaultProps = {\n      collapsible: false,\n      expanded: false,\n      onChange: () => {},\n      description: null,\n      disabled: false\n    };\n\n    static getDerivedStateFromProps(props, state) {\n      //  invoked after a component is instantiated as well as before it is re-rendered\n      if (props.expanded && state.collapsed) {\n        return {collapsed: false};\n      }\n\n      return null;\n    }\n\n    state = {\n      collapsed: true\n    };\n\n    render() {\n      const {\n        label,\n        children,\n        property,\n        layer,\n        onChange,\n        collapsible,\n        description,\n        disabled\n      } = this.props;\n\n      const {collapsed} = this.state;\n\n      return (\n        <StyledLayerConfigGroup className={classnames('layer-config-group', {collapsed, disabled})}>\n          <StyledConfigGroupHeader\n            className=\"layer-config-group__header\"\n            onClick={() => this.setState({collapsed: !this.state.collapsed})}\n          >\n            <LayerConfigGroupLabel label={label} description={description} />\n            <StyledLayerConfigGroupAction className=\"layer-config-group__action\">\n              {property ? (\n                <Switch\n                  checked={layer.config.visConfig[property]}\n                  id={`${layer.id}-${property}`}\n                  onChange={() => onChange({[property]: !layer.config.visConfig[property]})}\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\n  polyfill(LayerConfigGroup);\n\n  return LayerConfigGroup;\n}\n\nexport default LayerConfigGroupFactory;\n"]}