kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
106 lines (85 loc) • 15.2 kB
JavaScript
;
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 _localization = require("../../../localization");
var _utils = require("../../../utils/utils");
var _templateObject, _templateObject2, _templateObject3;
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
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;
});
LayerGroupSelectorFactory.deps = [_panelHeaderAction["default"]];
function LayerGroupSelectorFactory(PanelHeaderAction) {
var defaultActionIcons = {
visible: _icons.EyeSeen,
hidden: _icons.EyeUnseen
};
var LayerGroupSelector = function LayerGroupSelector(_ref) {
var layers = _ref.layers,
editableLayers = _ref.editableLayers,
onChange = _ref.onChange,
topLayers = _ref.topLayers,
_ref$actionIcons = _ref.actionIcons,
actionIcons = _ref$actionIcons === void 0 ? defaultActionIcons : _ref$actionIcons;
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, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'mapLayers.title'
}))), /*#__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, {
className: "layer-group__visibility-toggle",
id: "".concat(slug, "-toggle"),
tooltip: layers[slug] ? 'tooltip.hide' : 'tooltip.show',
onClick: function onClick() {
return onChange({
visibleLayerGroups: _objectSpread(_objectSpread({}, layers), {}, (0, _defineProperty2["default"])({}, slug, !layers[slug]))
});
},
IconComponent: layers[slug] ? actionIcons.visible : actionIcons.hidden,
active: layers[slug],
flush: true
}), /*#__PURE__*/_react["default"].createElement(LayerLabel, {
active: layers[slug]
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "mapLayers.".concat((0, _utils.camelize)(slug))
}))), /*#__PURE__*/_react["default"].createElement(_styledComponents2.CenterFlexbox, {
className: "layer-group__bring-top"
}, /*#__PURE__*/_react["default"].createElement(PanelHeaderAction, {
id: "".concat(slug, "-top"),
tooltip: "tooltip.moveToTop",
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 = LayerGroupSelectorFactory;
exports["default"] = _default;
//# 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","deps","PanelHeaderActionFactory","PanelHeaderAction","defaultActionIcons","visible","EyeSeen","hidden","EyeUnseen","LayerGroupSelector","layers","editableLayers","onChange","topLayers","actionIcons","map","slug","visibleLayerGroups","Upload","topLayerGroups"],"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 from 'react';\nimport styled from 'styled-components';\nimport PanelHeaderActionFactory 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';\nimport {FormattedMessage} from 'localization';\nimport {camelize} from 'utils/utils';\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 => (props.active ? props.theme.textColor : props.theme.labelColor)};\n`;\n\nLayerGroupSelectorFactory.deps = [PanelHeaderActionFactory];\n\nfunction LayerGroupSelectorFactory(PanelHeaderAction) {\n  const defaultActionIcons = {\n    visible: EyeSeen,\n    hidden: EyeUnseen\n  };\n  const LayerGroupSelector = ({\n    layers,\n    editableLayers,\n    onChange,\n    topLayers,\n    actionIcons = defaultActionIcons\n  }) => (\n    <StyledInteractionPanel className=\"map-style__layer-group__selector\">\n      <div className=\"layer-group__header\">\n        <PanelLabel>\n          <FormattedMessage id={'mapLayers.title'} />\n        </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] ? 'tooltip.hide' : 'tooltip.show'}\n                onClick={() =>\n                  onChange({\n                    visibleLayerGroups: {\n                      ...layers,\n                      [slug]: !layers[slug]\n                    }\n                  })\n                }\n                IconComponent={layers[slug] ? actionIcons.visible : actionIcons.hidden}\n                active={layers[slug]}\n                flush\n              />\n              <LayerLabel active={layers[slug]}>\n                <FormattedMessage id={`mapLayers.${camelize(slug)}`} />\n              </LayerLabel>\n            </PanelLabelWrapper>\n            <CenterFlexbox className=\"layer-group__bring-top\">\n              <PanelHeaderAction\n                id={`${slug}-top`}\n                tooltip=\"tooltip.moveToTop\"\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"]}