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
JavaScript
;
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"]}