UNPKG

kepler.gl.geoiq

Version:

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

121 lines (103 loc) 14.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = MapTooltipContainer; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _react = _interopRequireDefault(require("react")); var _mapPopover = _interopRequireDefault(require("./map-popover")); var _viewportMercatorProject = _interopRequireDefault(require("viewport-mercator-project")); // Copyright (c) 2023 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. MapTooltipContainer.deps = [_mapPopover["default"]]; var getHoverXY = function getHoverXY(viewport, lngLat) { var screenCoord = !viewport || !lngLat ? null : viewport.project(lngLat); return screenCoord && { x: screenCoord[0], y: screenCoord[1] }; }; function MapTooltipContainer(MapPopover) { /* eslint-disable complexity */ var MapTooltip = _react["default"].memo(function (_ref) { var mapState = _ref.mapState, hoverInfo = _ref.hoverInfo, clicked = _ref.clicked, datasets = _ref.datasets, interactionConfig = _ref.interactionConfig, layers = _ref.layers, mapLayers = _ref.mapLayers, _ref$mousePos = _ref.mousePos, mousePosition = _ref$mousePos.mousePosition, coordinate = _ref$mousePos.coordinate, pinned = _ref$mousePos.pinned, onClose = _ref.onClose; if (!mousePosition) { return null; } // if clicked something, ignore hover behavior var objectInfo = clicked || hoverInfo; var layerHoverProp = null; var position = { x: mousePosition[0], y: mousePosition[1] }; if (interactionConfig.tooltip.enabled && objectInfo && objectInfo.picked) { // if anything hovered var object = objectInfo.object, overlay = objectInfo.layer; // deckgl layer to kepler-gl layer var layer = layers[overlay.props.idx]; if (layer.config.isVisible && layer.getHoverData && (!mapLayers || mapLayers[layer.id].isVisible)) { // if layer is visible and have hovered data var dataId = layer.config.dataId; var _datasets$dataId2 = datasets[dataId], allData = _datasets$dataId2.allData, fields = _datasets$dataId2.fields; var data = layer.getHoverData(object, allData); var fieldsToShow = interactionConfig.tooltip.config.fieldsToShow[dataId]; layerHoverProp = { data: data, fields: fields, fieldsToShow: fieldsToShow, layer: layer }; } } if (pinned || clicked) { // project lnglat to screen so that tooltip follows the object on zoom var viewport = new _viewportMercatorProject["default"](mapState); var lngLat = clicked ? clicked.lngLat : pinned.coordinate; position = getHoverXY(viewport, lngLat); } return (/*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(MapPopover, (0, _extends2["default"])({}, position, { layerHoverProp: layerHoverProp, coordinate: interactionConfig.coordinate.enabled && ((pinned || {}).coordinate || coordinate), freezed: Boolean(clicked || pinned), onClose: onClose, mapW: mapState.width, mapH: mapState.height }))) ); }); MapTooltip.displayName = 'MapTooltip'; return MapTooltip; } /* eslint-enable complexity */ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/map/map-tooltip.js"],"names":["MapTooltipContainer","deps","MapPopoverFactory","getHoverXY","viewport","lngLat","screenCoord","project","x","y","MapPopover","MapTooltip","React","memo","mapState","hoverInfo","clicked","datasets","interactionConfig","layers","mapLayers","mousePos","mousePosition","coordinate","pinned","onClose","objectInfo","layerHoverProp","position","tooltip","enabled","picked","object","overlay","layer","props","idx","config","isVisible","getHoverData","id","dataId","allData","fields","data","fieldsToShow","WebMercatorViewport","Boolean","width","height","displayName"],"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 from 'react';\nimport MapPopoverFactory from 'components/map/map-popover';\nimport WebMercatorViewport from 'viewport-mercator-project';\n\nMapTooltipContainer.deps = [MapPopoverFactory];\n\nconst getHoverXY = (viewport, lngLat) => {\n  const screenCoord = !viewport || !lngLat ? null : viewport.project(lngLat);\n  return screenCoord && {x: screenCoord[0], y: screenCoord[1]};\n};\n\nexport default function MapTooltipContainer(MapPopover) {\n  /* eslint-disable complexity */\n  const MapTooltip = React.memo(({\n                                   mapState,\n                                   hoverInfo,\n                                   clicked,\n                                   datasets,\n                                   interactionConfig,\n                                   layers,\n                                   mapLayers,\n                                   mousePos: {mousePosition, coordinate, pinned},\n                                   onClose\n                                 }) => {\n    if (!mousePosition) {\n      return null;\n    }\n\n    // if clicked something, ignore hover behavior\n    const objectInfo = clicked || hoverInfo;\n    let layerHoverProp = null;\n    let position = {x: mousePosition[0], y: mousePosition[1]};\n\n    if (\n      interactionConfig.tooltip.enabled &&\n      objectInfo &&\n      objectInfo.picked\n    ) {\n      // if anything hovered\n      const {object, layer: overlay} = objectInfo;\n\n      // deckgl layer to kepler-gl layer\n      const layer = layers[overlay.props.idx];\n\n      if (\n        layer.config.isVisible &&\n        layer.getHoverData &&\n        (!mapLayers || mapLayers[layer.id].isVisible)\n      ) {\n\n        // if layer is visible and have hovered data\n        const {config: {dataId}} = layer;\n        const {allData, fields} = datasets[dataId];\n        const data = layer.getHoverData(object, allData);\n        const fieldsToShow = interactionConfig.tooltip.config.fieldsToShow[dataId];\n\n        layerHoverProp = {\n          data,\n          fields,\n          fieldsToShow,\n          layer\n        }\n      }\n    }\n\n    if (pinned || clicked) {\n      // project lnglat to screen so that tooltip follows the object on zoom\n      const viewport = new WebMercatorViewport(mapState);\n      const lngLat = clicked ? clicked.lngLat : pinned.coordinate;\n      position = getHoverXY(viewport, lngLat);\n    }\n\n    return (\n      <div>\n        <MapPopover\n          {...position}\n          layerHoverProp={layerHoverProp}\n          coordinate={interactionConfig.coordinate.enabled && ((pinned || {}).coordinate || coordinate)}\n          freezed={Boolean(clicked || pinned)}\n          onClose={onClose}\n          mapW={mapState.width}\n          mapH={mapState.height}\n        />\n      </div>\n    );\n  });\n\n  MapTooltip.displayName = 'MapTooltip';\n\n  return MapTooltip;\n}\n/* eslint-enable complexity */\n"]}