kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
242 lines (187 loc) • 20.7 kB
JavaScript
;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.StyledConfigGroupHeader = exports.StyledLayerConfigGroup = exports.ConfigGroupCollapsibleContent = exports.StyledLayerConfigGroupAction = exports.StyledLayerConfigGroupLabel = 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 _styledComponents = _interopRequireDefault(require("styled-components"));
var _classnames = _interopRequireDefault(require("classnames"));
var _switch = _interopRequireDefault(require("../../common/switch"));
var _icons = require("../../common/icons");
var _infoHelper = _interopRequireDefault(require("../../common/info-helper"));
function _templateObject6() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n &.disabled {\n opacity: 0.3;\n pointer-events: none;\n * {\n pointer-events: none;\n }\n }\n"]);
_templateObject6 = function _templateObject6() {
return data;
};
return data;
}
function _templateObject5() {
var data = (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"]);
_templateObject5 = function _templateObject5() {
return data;
};
return data;
}
function _templateObject4() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n padding-left: 18px;\n margin-bottom: 12px;\n\n &.collapsed {\n .layer-config-group__content {\n .layer-config-group__content__collapsible {\n /* display: none; */\n /* flex: 0; */\n overflow: hidden;\n max-height: 0;\n }\n }\n }\n"]);
_templateObject4 = function _templateObject4() {
return data;
};
return data;
}
function _templateObject3() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n overflow: visible;\n transition: max-height 0.3s ease-out;\n height: max-content;\n max-height: 600px;\n"]);
_templateObject3 = function _templateObject3() {
return data;
};
return data;
}
function _templateObject2() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n color: ", ";\n"]);
_templateObject2 = function _templateObject2() {
return data;
};
return data;
}
function _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n border-left: 2px solid ", ";\n color: ", ";\n font-size: 12px;\n font-weight: 500;\n line-height: 12px;\n margin-left: -12px;\n padding-left: 10px;\n text-transform: capitalize;\n letter-spacing: 0.2px;\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
var StyledLayerConfigGroupLabel = _styledComponents["default"].div(_templateObject(), function (props) {
return props.theme.labelColor;
}, function (props) {
return props.theme.textColor;
});
exports.StyledLayerConfigGroupLabel = StyledLayerConfigGroupLabel;
var StyledLayerConfigGroupAction = _styledComponents["default"].div(_templateObject2(), function (props) {
return props.theme.textColor;
});
exports.StyledLayerConfigGroupAction = StyledLayerConfigGroupAction;
var ConfigGroupCollapsibleContent = _styledComponents["default"].div.attrs({
className: 'layer-config-group__content__collapsible'
})(_templateObject3());
exports.ConfigGroupCollapsibleContent = ConfigGroupCollapsibleContent;
var StyledLayerConfigGroup = _styledComponents["default"].div(_templateObject4());
exports.StyledLayerConfigGroup = StyledLayerConfigGroup;
var StyledConfigGroupHeader = _styledComponents["default"].div(_templateObject5(), function (props) {
return props.theme.textColorHl;
}, function (props) {
return props.theme.textColorHl;
}, function (props) {
return props.theme.textColorHl;
});
exports.StyledConfigGroupHeader = StyledConfigGroupHeader;
var ConfigGroupContent = _styledComponents["default"].div(_templateObject6());
var LayerConfigGroup =
/*#__PURE__*/
function (_Component) {
(0, _inherits2["default"])(LayerConfigGroup, _Component);
function LayerConfigGroup() {
var _getPrototypeOf2;
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 = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(LayerConfigGroup)).call.apply(_getPrototypeOf2, [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,
widget = _this$props.widget,
_onChange2 = _this$props.onChange,
collapsible = _this$props.collapsible,
description = _this$props.description;
var collapsed = this.state.collapsed;
return _react["default"].createElement(StyledLayerConfigGroup, {
className: (0, _classnames["default"])('layer-config-group', {
collapsed: collapsed
})
}, _react["default"].createElement(StyledConfigGroupHeader, {
className: "layer-config-group__header",
onClick: function onClick() {
return _this2.setState({
collapsed: !_this2.state.collapsed
});
}
}, _react["default"].createElement("div", {
style: {
display: 'flex'
}
}, _react["default"].createElement(StyledLayerConfigGroupLabel, {
className: "layer-config-group__label",
style: {
marginTop: '2px'
}
}, label), description && _react["default"].createElement(_infoHelper["default"], {
description: description,
id: "".concat(this.props.id, "-").concat(property)
})), _react["default"].createElement(StyledLayerConfigGroupAction, {
className: "layer-config-group__action"
}, property ? _react["default"].createElement(_switch["default"], {
checked: widget.config[property],
id: "".concat(widget.id, "-").concat(property),
onChange: function onChange() {
return _onChange2((0, _defineProperty2["default"])({}, property, !widget.config[property]));
}
}) : null, collapsible ? _react["default"].createElement(_icons.VertThreeDots, {
height: "18px"
}) : null)), _react["default"].createElement(ConfigGroupContent, {
className: (0, _classnames["default"])('layer-config-group__content', {
disabled: property && !widget.config[property]
})
}, children));
}
}]);
return LayerConfigGroup;
}(_react.Component);
exports["default"] = LayerConfigGroup;
(0, _defineProperty2["default"])(LayerConfigGroup, "defaultProps", {
collapsible: false,
expanded: false,
onChange: function onChange() {}
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/widget-panel/widget-config-group.js"],"names":["StyledLayerConfigGroupLabel","styled","div","props","theme","labelColor","textColor","StyledLayerConfigGroupAction","ConfigGroupCollapsibleContent","attrs","className","StyledLayerConfigGroup","StyledConfigGroupHeader","textColorHl","ConfigGroupContent","LayerConfigGroup","collapsed","_setCollapseState","expanded","nextProps","state","setState","label","children","property","widget","onChange","collapsible","description","display","marginTop","id","config","disabled","Component"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEO,IAAMA,2BAA2B,GAAGC,6BAAOC,GAAV,oBACb,UAAAC,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYC,UAAhB;AAAA,CADQ,EAE7B,UAAAF,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYE,SAAhB;AAAA,CAFwB,CAAjC;;;;AAYA,IAAMC,4BAA4B,GAAGN,6BAAOC,GAAV,qBAG9B,UAAAC,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYE,SAAhB;AAAA,CAHyB,CAAlC;;;;AAMA,IAAME,6BAA6B,GAAGP,6BAAOC,GAAP,CAAWO,KAAX,CAAiB;AAC5DC,EAAAA,SAAS,EAAE;AADiD,CAAjB,CAAH,oBAAnC;;;;AASA,IAAMC,sBAAsB,GAAGV,6BAAOC,GAAV,oBAA5B;;;;AAgBA,IAAMU,uBAAuB,GAAGX,6BAAOC,GAAV,qBASrB,UAAAC,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYS,WAAhB;AAAA,CATgB,EAUL,UAAAV,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYS,WAAhB;AAAA,CAVA,EAcrB,UAAAV,KAAK;AAAA,SAAIA,KAAK,CAACC,KAAN,CAAYS,WAAhB;AAAA,CAdgB,CAA7B;;;;AAmBP,IAAMC,kBAAkB,GAAGb,6BAAOC,GAAV,oBAAxB;;IAUqBa,gB;;;;;;;;;;;;;;;;;8FAOX;AACNC,MAAAA,SAAS,EAAE;AADL,K;;;;;;wCAIY;AAClB,WAAKC,iBAAL,CAAuB,KAAKd,KAAL,CAAWe,QAAlC;AACD;;;8CAEyBC,S,EAAW;AACnC,WAAKF,iBAAL,CAAuBE,SAAS,CAACD,QAAjC;AACD;;;sCAEiBA,Q,EAAU;AAC1B;AACA,UAAIA,QAAQ,IAAI,KAAKE,KAAL,CAAWJ,SAA3B,EAAsC;AACpC,aAAKK,QAAL,CAAc;AAACL,UAAAA,SAAS,EAAE;AAAZ,SAAd;AACD;AACF;;;6BAEQ;AAAA;;AAAA,wBASH,KAAKb,KATF;AAAA,UAELmB,KAFK,eAELA,KAFK;AAAA,UAGLC,QAHK,eAGLA,QAHK;AAAA,UAILC,QAJK,eAILA,QAJK;AAAA,UAKLC,MALK,eAKLA,MALK;AAAA,UAMLC,UANK,eAMLA,QANK;AAAA,UAOLC,WAPK,eAOLA,WAPK;AAAA,UAQLC,WARK,eAQLA,WARK;AAAA,UAWAZ,SAXA,GAWa,KAAKI,KAXlB,CAWAJ,SAXA;AAYP,aACE,gCAAC,sBAAD;AACE,QAAA,SAAS,EAAE,4BAAW,oBAAX,EAAiC;AAACA,UAAAA,SAAS,EAATA;AAAD,SAAjC;AADb,SAGE,gCAAC,uBAAD;AACE,QAAA,SAAS,EAAC,4BADZ;AAEE,QAAA,OAAO,EAAE;AAAA,iBAAM,MAAI,CAACK,QAAL,CAAc;AAACL,YAAAA,SAAS,EAAE,CAAC,MAAI,CAACI,KAAL,CAAWJ;AAAxB,WAAd,CAAN;AAAA;AAFX,SAIE;AAAK,QAAA,KAAK,EAAE;AAACa,UAAAA,OAAO,EAAE;AAAV;AAAZ,SACE,gCAAC,2BAAD;AACE,QAAA,SAAS,EAAC,2BADZ;AAEE,QAAA,KAAK,EAAE;AAACC,UAAAA,SAAS,EAAE;AAAZ;AAFT,SAIGR,KAJH,CADF,EAOGM,WAAW,IACV,gCAAC,sBAAD;AACE,QAAA,WAAW,EAAEA,WADf;AAEE,QAAA,EAAE,YAAK,KAAKzB,KAAL,CAAW4B,EAAhB,cAAsBP,QAAtB;AAFJ,QARJ,CAJF,EAkBE,gCAAC,4BAAD;AAA8B,QAAA,SAAS,EAAC;AAAxC,SACGA,QAAQ,GACP,gCAAC,kBAAD;AACE,QAAA,OAAO,EAAEC,MAAM,CAACO,MAAP,CAAcR,QAAd,CADX;AAEE,QAAA,EAAE,YAAKC,MAAM,CAACM,EAAZ,cAAkBP,QAAlB,CAFJ;AAGE,QAAA,QAAQ,EAAE;AAAA,iBACRE,UAAQ,sCAAGF,QAAH,EAAc,CAACC,MAAM,CAACO,MAAP,CAAcR,QAAd,CAAf,EADA;AAAA;AAHZ,QADO,GAQL,IATN,EAUGG,WAAW,GAAG,gCAAC,oBAAD;AAAe,QAAA,MAAM,EAAC;AAAtB,QAAH,GAAqC,IAVnD,CAlBF,CAHF,EAkCE,gCAAC,kBAAD;AACE,QAAA,SAAS,EAAE,4BAAW,6BAAX,EAA0C;AACnDM,UAAAA,QAAQ,EAAET,QAAQ,IAAI,CAACC,MAAM,CAACO,MAAP,CAAcR,QAAd;AAD4B,SAA1C;AADb,SAKGD,QALH,CAlCF,CADF;AA4CD;;;EAlF2CW,gB;;;iCAAzBnB,gB,kBACG;AACpBY,EAAAA,WAAW,EAAE,KADO;AAEpBT,EAAAA,QAAQ,EAAE,KAFU;AAGpBQ,EAAAA,QAAQ,EAAE,oBAAM,CAAE;AAHE,C","sourcesContent":["// Copyright (c) 2019 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 {VertThreeDots} from 'components/common/icons';\nimport InfoHelper from 'components/common/info-helper';\n\nexport const StyledLayerConfigGroupLabel = styled.div`\n  border-left: 2px solid ${props => props.theme.labelColor};\n  color: ${props => props.theme.textColor};\n  font-size: 12px;\n  font-weight: 500;\n  line-height: 12px;\n  margin-left: -12px;\n  padding-left: 10px;\n  text-transform: capitalize;\n  letter-spacing: 0.2px;\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 StyledLayerConfigGroup = styled.div`\n  padding-left: 18px;\n  margin-bottom: 12px;\n\n  &.collapsed {\n    .layer-config-group__content {\n      .layer-config-group__content__collapsible {\n        /* display: none; */\n        /* flex: 0; */\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  };\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      widget,\n      onChange,\n      collapsible,\n      description\n    } = this.props;\n\n    const {collapsed} = this.state;\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          <div style={{display: 'flex'}}>\n            <StyledLayerConfigGroupLabel\n              className=\"layer-config-group__label\"\n              style={{marginTop: '2px'}}\n            >\n              {label}\n            </StyledLayerConfigGroupLabel>\n            {description && (\n              <InfoHelper\n                description={description}\n                id={`${this.props.id}-${property}`}\n              />\n            )}\n          </div>\n          <StyledLayerConfigGroupAction className=\"layer-config-group__action\">\n            {property ? (\n              <Switch\n                checked={widget.config[property]}\n                id={`${widget.id}-${property}`}\n                onChange={() =>\n                  onChange({[property]: !widget.config[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 && !widget.config[property]\n          })}\n        >\n          {children}\n        </ConfigGroupContent>\n      </StyledLayerConfigGroup>\n    );\n  }\n}\n"]}