kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
133 lines (131 loc) • 17.7 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.MVTLayer = void 0;
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
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 _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _extensions = require("@deck.gl/extensions");
var _geoLayers = require("@deck.gl/geo-layers");
var _loadingCounter = require("./loading-counter");
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
/*
Custom MVT layer that works with MVTSource and PMTileSource.
Changes:
- getTileData: handles props.getTileData.
- renderSubLayers: removed coordinates logic present in original MVTLayer:renderSubLayers.
- renderSubLayers: set clipBounds.
- loaders.gl & older deck.gl: geojson-table: data = data.features
*/
// @ts-expect-error need to patch private methods because of newer loaders.gl
var MVTLayer = exports.MVTLayer = /*#__PURE__*/function (_MVTLayer2) {
function MVTLayer() {
(0, _classCallCheck2["default"])(this, MVTLayer);
return _callSuper(this, MVTLayer, arguments);
}
(0, _inherits2["default"])(MVTLayer, _MVTLayer2);
return (0, _createClass2["default"])(MVTLayer, [{
key: "getTileData",
value: function () {
var _getTileData = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(tile) {
var getTileData, data;
return _regenerator["default"].wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
getTileData = this.props.getTileData;
data = this.state.data;
tile.url = typeof data === 'string' || Array.isArray(data) ? (0, _geoLayers._getURLFromTemplate)(data, tile) : null;
if (!getTileData) {
_context.next = 12;
break;
}
(0, _loadingCounter.incrementVectorTileLoading)();
_context.prev = 5;
_context.next = 8;
return getTileData(tile);
case 8:
return _context.abrupt("return", _context.sent);
case 9:
_context.prev = 9;
(0, _loadingCounter.decrementVectorTileLoading)();
return _context.finish(9);
case 12:
return _context.abrupt("return", null);
case 13:
case "end":
return _context.stop();
}
}, _callee, this, [[5,, 9, 12]]);
}));
function getTileData(_x) {
return _getTileData.apply(this, arguments);
}
return getTileData;
}()
}, {
key: "renderSubLayers",
value: function renderSubLayers(props) {
var boundingBox = props.tile.boundingBox;
props.autoHighlight = true;
if (boundingBox) {
props.clipBounds = [].concat((0, _toConsumableArray2["default"])(boundingBox[0]), (0, _toConsumableArray2["default"])(boundingBox[1]));
props.extensions = [].concat((0, _toConsumableArray2["default"])(props.extensions || []), [new _extensions.ClipExtension()]);
}
return this.props.renderSubLayers(props);
}
}, {
key: "getHighlightedObjectIndex",
value: function getHighlightedObjectIndex(tile) {
var _data;
var _this$state = this.state,
hoveredFeatureId = _this$state.hoveredFeatureId,
hoveredFeatureLayerName = _this$state.hoveredFeatureLayerName;
var _this$props = this.props,
uniqueIdProperty = _this$props.uniqueIdProperty,
highlightedFeatureId = _this$props.highlightedFeatureId;
var data = tile.content;
data = ((_data = data) === null || _data === void 0 ? void 0 : _data.shape) === 'geojson-table' ? data.features : data;
var isHighlighted = isFeatureIdDefined(highlightedFeatureId);
var isFeatureIdPresent = isFeatureIdDefined(hoveredFeatureId) || isHighlighted;
if (!isFeatureIdPresent) {
return -1;
}
var featureIdToHighlight = isHighlighted ? highlightedFeatureId : hoveredFeatureId;
// Iterable data
if (Array.isArray(data)) {
return data.findIndex(function (feature) {
var isMatchingId = getFeatureUniqueId(feature, uniqueIdProperty) === featureIdToHighlight;
var isMatchingLayer = isHighlighted || getFeatureLayerName(feature) === hoveredFeatureLayerName;
return isMatchingId && isMatchingLayer;
});
}
return -1;
}
}]);
}(_geoLayers.MVTLayer);
function getFeatureUniqueId(feature, uniqueIdProperty) {
if (feature.properties && uniqueIdProperty) {
return feature.properties[uniqueIdProperty];
}
if ('id' in feature) {
return feature.id;
}
return undefined;
}
function getFeatureLayerName(feature) {
var _feature$properties;
return ((_feature$properties = feature.properties) === null || _feature$properties === void 0 ? void 0 : _feature$properties.layerName) || null;
}
function isFeatureIdDefined(value) {
return value !== undefined && value !== null && value !== '';
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_extensions","require","_geoLayers","_loadingCounter","_callSuper","t","o","e","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","call","MVTLayer","exports","_MVTLayer2","_classCallCheck2","arguments","_inherits2","_createClass2","key","value","_getTileData","_asyncToGenerator2","_regenerator","mark","_callee","tile","getTileData","data","wrap","_callee$","_context","prev","next","props","state","url","Array","isArray","_getURLFromTemplate","incrementVectorTileLoading","abrupt","sent","decrementVectorTileLoading","finish","stop","_x","renderSubLayers","boundingBox","autoHighlight","clipBounds","concat","_toConsumableArray2","extensions","ClipExtension","getHighlightedObjectIndex","_data","_this$state","hoveredFeatureId","hoveredFeatureLayerName","_this$props","uniqueIdProperty","highlightedFeatureId","content","shape","features","isHighlighted","isFeatureIdDefined","isFeatureIdPresent","featureIdToHighlight","findIndex","feature","isMatchingId","getFeatureUniqueId","isMatchingLayer","getFeatureLayerName","_MVTLayer","properties","id","undefined","_feature$properties","layerName"],"sources":["../../src/vector-tile/mvt-layer.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {Layer, LayersList} from '@deck.gl/core';\nimport {ClipExtension} from '@deck.gl/extensions';\nimport {\n  MVTLayer as _MVTLayer,\n  TileLayer,\n  // @ts-expect-error deck.gl 9 internal\n  _getURLFromTemplate,\n  // @ts-expect-error deck.gl 9 internal\n  _TileLoadProps,\n  _Tile2DHeader\n} from '@deck.gl/geo-layers';\nimport {incrementVectorTileLoading, decrementVectorTileLoading} from './loading-counter';\n\n/*\n  Custom MVT layer that works with MVTSource and PMTileSource.\n  Changes:\n    - getTileData: handles props.getTileData.\n    - renderSubLayers: removed coordinates logic present in original MVTLayer:renderSubLayers.\n    - renderSubLayers: set clipBounds.\n    - loaders.gl & older deck.gl: geojson-table: data = data.features\n*/\n\n// @ts-expect-error need to patch private methods because of newer loaders.gl\nexport class MVTLayer<ExtraProps> extends _MVTLayer<ExtraProps> {\n  async getTileData(tile: _TileLoadProps): Promise<any> {\n    const {getTileData} = this.props;\n    const {data} = this.state;\n\n    tile.url =\n      typeof data === 'string' || Array.isArray(data) ? _getURLFromTemplate(data, tile) : null;\n    if (getTileData) {\n      incrementVectorTileLoading();\n      try {\n        return await getTileData(tile);\n      } finally {\n        decrementVectorTileLoading();\n      }\n    }\n    return null;\n  }\n\n  renderSubLayers(\n    props: TileLayer['props'] & {\n      id: string;\n      data: any;\n      _offset: number;\n      tile: any;\n      clipBounds?: number[];\n    }\n  ): Layer | null | LayersList {\n    const {boundingBox} = props.tile;\n\n    props.autoHighlight = true;\n\n    if (boundingBox) {\n      props.clipBounds = [...boundingBox[0], ...boundingBox[1]];\n      props.extensions = [...(props.extensions || []), new ClipExtension()];\n    }\n\n    return this.props.renderSubLayers(props);\n  }\n\n  getHighlightedObjectIndex(tile: _Tile2DHeader): number {\n    const {hoveredFeatureId, hoveredFeatureLayerName} = this.state;\n    const {uniqueIdProperty, highlightedFeatureId} = this.props;\n    let data = tile.content;\n    data = data?.shape === 'geojson-table' ? data.features : data;\n\n    const isHighlighted = isFeatureIdDefined(highlightedFeatureId);\n    const isFeatureIdPresent = isFeatureIdDefined(hoveredFeatureId) || isHighlighted;\n\n    if (!isFeatureIdPresent) {\n      return -1;\n    }\n\n    const featureIdToHighlight = isHighlighted ? highlightedFeatureId : hoveredFeatureId;\n\n    // Iterable data\n    if (Array.isArray(data)) {\n      return data.findIndex(feature => {\n        const isMatchingId = getFeatureUniqueId(feature, uniqueIdProperty) === featureIdToHighlight;\n        const isMatchingLayer =\n          isHighlighted || getFeatureLayerName(feature) === hoveredFeatureLayerName;\n        return isMatchingId && isMatchingLayer;\n      });\n    }\n\n    return -1;\n  }\n}\n\nfunction getFeatureUniqueId(feature, uniqueIdProperty: string | undefined) {\n  if (feature.properties && uniqueIdProperty) {\n    return feature.properties[uniqueIdProperty];\n  }\n\n  if ('id' in feature) {\n    return feature.id;\n  }\n\n  return undefined;\n}\n\nfunction getFeatureLayerName(feature): string | null {\n  return feature.properties?.layerName || null;\n}\n\nfunction isFeatureIdDefined(value: unknown): boolean {\n  return value !== undefined && value !== null && value !== '';\n}\n"],"mappings":"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","ignoreList":[]}