UNPKG

kepler.gl.geoiq

Version:

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

91 lines (73 loc) 13.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _panelHeaderAction = _interopRequireDefault(require("../panel-header-action")); var _icons = require("../../common/icons"); var _styledComponents2 = require("../../common/styled-components"); var _templateObject, _templateObject2, _templateObject3; 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; } var StyledInteractionPanel = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding-bottom: 12px;\n"]))); var StyledLayerGroupItem = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin-bottom: 10px;\n display: flex;\n justify-content: space-between;\n\n &:last-child {\n margin-bottom: 0;\n }\n\n .layer-group__visibility-toggle {\n margin-right: 12px;\n }\n"]))); var LayerLabel = (0, _styledComponents["default"])(_styledComponents2.PanelLabelBold)(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n"])), function (props) { return props.active ? props.theme.textColor : props.theme.labelColor; }); function LayerGroupSelectorFactory() { var LayerGroupSelector = function LayerGroupSelector(_ref) { var layers = _ref.layers, editableLayers = _ref.editableLayers, onChange = _ref.onChange, topLayers = _ref.topLayers; return (/*#__PURE__*/_react["default"].createElement(StyledInteractionPanel, { className: "map-style__layer-group__selector" }, /*#__PURE__*/_react["default"].createElement("div", { className: "layer-group__header" }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, "Map Layers")), /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelContent, { className: "map-style__layer-group" }, editableLayers.map(function (slug) { return (/*#__PURE__*/_react["default"].createElement(StyledLayerGroupItem, { className: "layer-group__select", key: slug }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabelWrapper, null, /*#__PURE__*/_react["default"].createElement(_panelHeaderAction["default"], { className: "layer-group__visibility-toggle", id: "".concat(slug, "-toggle"), tooltip: layers[slug] ? 'hide' : 'show', onClick: function onClick() { return onChange({ visibleLayerGroups: _objectSpread(_objectSpread({}, layers), {}, (0, _defineProperty2["default"])({}, slug, !layers[slug])) }); }, IconComponent: layers[slug] ? _icons.EyeSeen : _icons.EyeUnseen, active: layers[slug], flush: true }), /*#__PURE__*/_react["default"].createElement(LayerLabel, { active: layers[slug] }, slug)), /*#__PURE__*/_react["default"].createElement(_styledComponents2.CenterFlexbox, { className: "layer-group__bring-top" }, /*#__PURE__*/_react["default"].createElement(_panelHeaderAction["default"], { id: "".concat(slug, "-top"), tooltip: "Move to top of data layers", disabled: !layers[slug], IconComponent: _icons.Upload, active: topLayers[slug], onClick: function onClick() { return onChange({ topLayerGroups: _objectSpread(_objectSpread({}, topLayers), {}, (0, _defineProperty2["default"])({}, slug, !topLayers[slug])) }); } }))) ); }))) ); }; return LayerGroupSelector; } var _default = exports["default"] = LayerGroupSelectorFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/map-style-panel/map-layer-selector.js"],"names":["StyledInteractionPanel","styled","div","StyledLayerGroupItem","LayerLabel","PanelLabelBold","props","active","theme","textColor","labelColor","LayerGroupSelectorFactory","LayerGroupSelector","layers","editableLayers","onChange","topLayers","map","slug","visibleLayerGroups","EyeSeen","EyeUnseen","Upload","topLayerGroups"],"mappings":";;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AACA;;AAEA;;;;;;;;AAQA,IAAMA,sBAAsB,GAAGC,6BAAOC,GAAV,iHAA5B;;AAIA,IAAMC,oBAAoB,GAAGF,6BAAOC,GAAV,4RAA1B;;AAcA,IAAME,UAAU,GAAG,kCAAOC,iCAAP,CAAH,2GACL,UAAAC,KAAK;AAAA,SACZA,KAAK,CAACC,MAAN,GAAeD,KAAK,CAACE,KAAN,CAAYC,SAA3B,GAAuCH,KAAK,CAACE,KAAN,CAAYE,UADvC;AAAA,CADA,CAAhB;;AAKA,SAASC,yBAAT,GAAqC;AACnC,MAAMC,kBAAkB,GAAG,SAArBA,kBAAqB;AAAA,QACzBC,MADyB,QACzBA,MADyB;AAAA,QAEzBC,cAFyB,QAEzBA,cAFyB;AAAA,QAGzBC,QAHyB,QAGzBA,QAHyB;AAAA,QAIzBC,SAJyB,QAIzBA,SAJyB;AAAA,yBAMzB,gCAAC,sBAAD;AAAwB,QAAA,SAAS,EAAC;AAAlC,sBACE;AAAK,QAAA,SAAS,EAAC;AAAf,sBACE,gCAAC,6BAAD,qBADF,CADF,eAIE,gCAAC,+BAAD;AAAc,QAAA,SAAS,EAAC;AAAxB,SACGF,cAAc,CAACG,GAAf,CAAmB,UAAAC,IAAI;AAAA,6BACtB,gCAAC,oBAAD;AAAsB,YAAA,SAAS,EAAC,qBAAhC;AAAsD,YAAA,GAAG,EAAEA;AAA3D,0BACE,gCAAC,oCAAD,qBACE,gCAAC,6BAAD;AACE,YAAA,SAAS,EAAC,gCADZ;AAEE,YAAA,EAAE,YAAKA,IAAL,YAFJ;AAGE,YAAA,OAAO,EAAEL,MAAM,CAACK,IAAD,CAAN,GAAe,MAAf,GAAwB,MAHnC;AAIE,YAAA,OAAO,EAAE;AAAA,qBACPH,QAAQ,CAAC;AACPI,gBAAAA,kBAAkB,kCACbN,MADa,4CAEfK,IAFe,EAER,CAACL,MAAM,CAACK,IAAD,CAFC;AADX,eAAD,CADD;AAAA,aAJX;AAYE,YAAA,aAAa,EAAEL,MAAM,CAACK,IAAD,CAAN,GAAeE,cAAf,GAAyBC,gBAZ1C;AAaE,YAAA,MAAM,EAAER,MAAM,CAACK,IAAD,CAbhB;AAcE,YAAA,KAAK;AAdP,YADF,eAiBE,gCAAC,UAAD;AAAY,YAAA,MAAM,EAAEL,MAAM,CAACK,IAAD;AAA1B,aAAmCA,IAAnC,CAjBF,CADF,eAoBE,gCAAC,gCAAD;AAAe,YAAA,SAAS,EAAC;AAAzB,0BACE,gCAAC,6BAAD;AACE,YAAA,EAAE,YAAKA,IAAL,SADJ;AAEE,YAAA,OAAO,EAAC,4BAFV;AAGE,YAAA,QAAQ,EAAE,CAACL,MAAM,CAACK,IAAD,CAHnB;AAIE,YAAA,aAAa,EAAEI,aAJjB;AAKE,YAAA,MAAM,EAAEN,SAAS,CAACE,IAAD,CALnB;AAME,YAAA,OAAO,EAAE;AAAA,qBACPH,QAAQ,CAAC;AACPQ,gBAAAA,cAAc,kCACTP,SADS,4CAEXE,IAFW,EAEJ,CAACF,SAAS,CAACE,IAAD,CAFN;AADP,eAAD,CADD;AAAA;AANX,YADF,CApBF;AADsB;AAAA,OAAvB,CADH,CAJF;AANyB;AAAA,GAA3B;;AAuDA,SAAON,kBAAP;AACD;;oCAEcD,yB","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 from 'react';\nimport styled from 'styled-components';\nimport PanelHeaderAction from 'components/side-panel/panel-header-action';\nimport {EyeSeen, EyeUnseen, Upload} from 'components/common/icons';\n\nimport {\n  PanelLabel,\n  PanelContent,\n  PanelLabelBold,\n  PanelLabelWrapper,\n  CenterFlexbox\n} from 'components/common/styled-components';\n\nconst StyledInteractionPanel = styled.div`\n  padding-bottom: 12px;\n`;\n\nconst StyledLayerGroupItem = styled.div`\n  margin-bottom: 10px;\n  display: flex;\n  justify-content: space-between;\n\n  &:last-child {\n    margin-bottom: 0;\n  }\n\n  .layer-group__visibility-toggle {\n    margin-right: 12px;\n  }\n`;\n\nconst LayerLabel = styled(PanelLabelBold)`\n  color: ${props =>\n    props.active ? props.theme.textColor : props.theme.labelColor};\n`;\n\nfunction LayerGroupSelectorFactory() {\n  const LayerGroupSelector = ({\n    layers,\n    editableLayers,\n    onChange,\n    topLayers\n  }) => (\n    <StyledInteractionPanel className=\"map-style__layer-group__selector\">\n      <div className=\"layer-group__header\">\n        <PanelLabel>Map Layers</PanelLabel>\n      </div>\n      <PanelContent className=\"map-style__layer-group\">\n        {editableLayers.map(slug => (\n          <StyledLayerGroupItem className=\"layer-group__select\" key={slug}>\n            <PanelLabelWrapper>\n              <PanelHeaderAction\n                className=\"layer-group__visibility-toggle\"\n                id={`${slug}-toggle`}\n                tooltip={layers[slug] ? 'hide' : 'show'}\n                onClick={() =>\n                  onChange({\n                    visibleLayerGroups: {\n                      ...layers,\n                      [slug]: !layers[slug]\n                    }\n                  })\n                }\n                IconComponent={layers[slug] ? EyeSeen : EyeUnseen}\n                active={layers[slug]}\n                flush\n              />\n              <LayerLabel active={layers[slug]}>{slug}</LayerLabel>\n            </PanelLabelWrapper>\n            <CenterFlexbox className=\"layer-group__bring-top\">\n              <PanelHeaderAction\n                id={`${slug}-top`}\n                tooltip=\"Move to top of data layers\"\n                disabled={!layers[slug]}\n                IconComponent={Upload}\n                active={topLayers[slug]}\n                onClick={() =>\n                  onChange({\n                    topLayerGroups: {\n                      ...topLayers,\n                      [slug]: !topLayers[slug]\n                    }\n                  })\n                }\n              />\n            </CenterFlexbox>\n          </StyledLayerGroupItem>\n        ))}\n      </PanelContent>\n    </StyledInteractionPanel>\n  );\n\n  return LayerGroupSelector;\n}\n\nexport default LayerGroupSelectorFactory;\n"]}