UNPKG

kepler.gl

Version:

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

376 lines (322 loc) 40.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.pointVisConfigs = exports.pointOptionalColumns = exports.pointRequiredColumns = exports.pointPosAccessor = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _extensions = require("@deck.gl/extensions"); var _layers = require("@deck.gl/layers"); var _baseLayer = _interopRequireDefault(require("../base-layer")); var _colorUtils = require("../../utils/color-utils"); var _datasetUtils = require("../../utils/dataset-utils"); var _pointLayerIcon = _interopRequireDefault(require("./point-layer-icon")); var _defaultSettings = require("../../constants/default-settings"); var _layerTextLabel = require("../layer-text-label"); 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; } function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } var pointPosAccessor = function pointPosAccessor(_ref) { var lat = _ref.lat, lng = _ref.lng, altitude = _ref.altitude; return function (dc) { return function (d) { return [dc.valueAt(d.index, lng.fieldIdx), dc.valueAt(d.index, lat.fieldIdx), altitude && altitude.fieldIdx > -1 ? dc.valueAt(d.index, altitude.fieldIdx) : 0]; }; }; }; exports.pointPosAccessor = pointPosAccessor; var pointRequiredColumns = ['lat', 'lng']; exports.pointRequiredColumns = pointRequiredColumns; var pointOptionalColumns = ['altitude']; exports.pointOptionalColumns = pointOptionalColumns; var brushingExtension = new _extensions.BrushingExtension(); var pointVisConfigs = { radius: 'radius', fixedRadius: 'fixedRadius', opacity: 'opacity', outline: 'outline', thickness: 'thickness', strokeColor: 'strokeColor', colorRange: 'colorRange', strokeColorRange: 'strokeColorRange', radiusRange: 'radiusRange', filled: { type: 'boolean', label: 'layer.fillColor', defaultValue: true, property: 'filled' } }; exports.pointVisConfigs = pointVisConfigs; var PointLayer = /*#__PURE__*/function (_Layer) { (0, _inherits2["default"])(PointLayer, _Layer); var _super = _createSuper(PointLayer); function PointLayer(props) { var _this; (0, _classCallCheck2["default"])(this, PointLayer); _this = _super.call(this, props); _this.registerVisConfig(pointVisConfigs); _this.getPositionAccessor = function (dataContainer) { return pointPosAccessor(_this.config.columns)(dataContainer); }; return _this; } (0, _createClass2["default"])(PointLayer, [{ key: "type", get: function get() { return 'point'; } }, { key: "isAggregated", get: function get() { return false; } }, { key: "layerIcon", get: function get() { return _pointLayerIcon["default"]; } }, { key: "requiredLayerColumns", get: function get() { return pointRequiredColumns; } }, { key: "optionalColumns", get: function get() { return pointOptionalColumns; } }, { key: "columnPairs", get: function get() { return this.defaultPointColumnPairs; } }, { key: "noneLayerDataAffectingProps", get: function get() { return [].concat((0, _toConsumableArray2["default"])((0, _get2["default"])((0, _getPrototypeOf2["default"])(PointLayer.prototype), "noneLayerDataAffectingProps", this)), ['radius']); } }, { key: "visualChannels", get: function get() { return { color: _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(PointLayer.prototype), "visualChannels", this).color), {}, { accessor: 'getFillColor', condition: function condition(config) { return config.visConfig.filled; }, defaultValue: function defaultValue(config) { return config.color; } }), strokeColor: { property: 'strokeColor', key: 'strokeColor', field: 'strokeColorField', scale: 'strokeColorScale', domain: 'strokeColorDomain', range: 'strokeColorRange', channelScaleType: _defaultSettings.CHANNEL_SCALES.color, accessor: 'getLineColor', condition: function condition(config) { return config.visConfig.outline; }, defaultValue: function defaultValue(config) { return config.visConfig.strokeColor || config.color; } }, size: _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(PointLayer.prototype), "visualChannels", this).size), {}, { property: 'radius', range: 'radiusRange', fixed: 'fixedRadius', channelScaleType: 'radius', accessor: 'getRadius', defaultValue: 1 }) }; } }, { key: "setInitialLayerConfig", value: function setInitialLayerConfig(dataset) { var defaultColorField = (0, _datasetUtils.findDefaultColorField)(dataset); if (defaultColorField) { this.updateLayerConfig({ colorField: defaultColorField }); this.updateLayerVisualChannel(dataset, 'color'); } return this; } }, { key: "getDefaultLayerConfig", value: function getDefaultLayerConfig() { var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; return _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(PointLayer.prototype), "getDefaultLayerConfig", this).call(this, props)), {}, { // add stroke color visual channel strokeColorField: null, strokeColorDomain: [0, 1], strokeColorScale: 'quantile' }); } }, { key: "calculateDataAttribute", value: function calculateDataAttribute(_ref2, getPosition) { var filteredIndex = _ref2.filteredIndex; var data = []; for (var i = 0; i < filteredIndex.length; i++) { var index = filteredIndex[i]; var pos = getPosition({ index: index }); // if doesn't have point lat or lng, do not add the point // deck.gl can't handle position = null if (pos.every(Number.isFinite)) { data.push({ position: pos, index: index }); } } return data; } }, { key: "formatLayerData", value: function formatLayerData(datasets, oldLayerData) { var textLabel = this.config.textLabel; var _datasets$this$config = datasets[this.config.dataId], gpuFilter = _datasets$this$config.gpuFilter, dataContainer = _datasets$this$config.dataContainer; var _this$updateData = this.updateData(datasets, oldLayerData), data = _this$updateData.data, triggerChanged = _this$updateData.triggerChanged; var getPosition = this.getPositionAccessor(dataContainer); // get all distinct characters in the text labels var textLabels = (0, _layerTextLabel.formatTextLabelData)({ textLabel: textLabel, triggerChanged: triggerChanged, oldLayerData: oldLayerData, data: data, dataContainer: dataContainer }); var accessors = this.getAttributeAccessors({ dataContainer: dataContainer }); return _objectSpread({ data: data, getPosition: getPosition, getFilterValue: gpuFilter.filterValueAccessor(dataContainer)(), textLabels: textLabels }, accessors); } /* eslint-enable complexity */ }, { key: "updateLayerMeta", value: function updateLayerMeta(dataContainer) { var getPosition = this.getPositionAccessor(dataContainer); var bounds = this.getPointsBounds(dataContainer, getPosition); this.updateMeta({ bounds: bounds }); } }, { key: "renderLayer", value: function renderLayer(opts) { var _this$config$columns$; var data = opts.data, gpuFilter = opts.gpuFilter, objectHovered = opts.objectHovered, mapState = opts.mapState, interactionConfig = opts.interactionConfig; // if no field size is defined we need to pass fixed radius = false var fixedRadius = this.config.visConfig.fixedRadius && Boolean(this.config.sizeField); var radiusScale = this.getRadiusScaleByZoom(mapState, fixedRadius); var layerProps = _objectSpread({ stroked: this.config.visConfig.outline, filled: this.config.visConfig.filled, lineWidthScale: this.config.visConfig.thickness, radiusScale: radiusScale }, this.config.visConfig.fixedRadius ? {} : { radiusMaxPixels: 500 }); var updateTriggers = _objectSpread({ getPosition: this.config.columns, getFilterValue: gpuFilter.filterValueUpdateTriggers }, this.getVisualChannelUpdateTriggers()); var defaultLayerProps = this.getDefaultDeckLayerProps(opts); var brushingProps = this.getBrushingExtensionProps(interactionConfig); var getPixelOffset = (0, _layerTextLabel.getTextOffsetByRadius)(radiusScale, data.getRadius, mapState); var extensions = [].concat((0, _toConsumableArray2["default"])(defaultLayerProps.extensions), [brushingExtension]); var sharedProps = _objectSpread({ getFilterValue: data.getFilterValue, extensions: extensions, filterRange: defaultLayerProps.filterRange, visible: defaultLayerProps.visible }, brushingProps); var hoveredObject = this.hasHoveredObject(objectHovered); return [new _layers.ScatterplotLayer(_objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, defaultLayerProps), brushingProps), layerProps), data), {}, { parameters: { // circles will be flat on the map when the altitude column is not used depthTest: ((_this$config$columns$ = this.config.columns.altitude) === null || _this$config$columns$ === void 0 ? void 0 : _this$config$columns$.fieldIdx) > -1 }, lineWidthUnits: 'pixels', updateTriggers: updateTriggers, extensions: extensions }))].concat((0, _toConsumableArray2["default"])(hoveredObject ? [new _layers.ScatterplotLayer(_objectSpread(_objectSpread(_objectSpread({}, this.getDefaultHoverLayerProps()), layerProps), {}, { data: [hoveredObject], getLineColor: this.config.highlightColor, getFillColor: this.config.highlightColor, getRadius: data.getRadius, getPosition: data.getPosition }))] : []), (0, _toConsumableArray2["default"])(this.renderTextLabelLayer({ getPosition: data.getPosition, sharedProps: sharedProps, getPixelOffset: getPixelOffset, updateTriggers: updateTriggers }, opts))); } }], [{ key: "findDefaultLayerProps", value: function findDefaultLayerProps(_ref3) { var _ref3$fieldPairs = _ref3.fieldPairs, fieldPairs = _ref3$fieldPairs === void 0 ? [] : _ref3$fieldPairs; var props = []; // Make layer for each pair fieldPairs.forEach(function (pair) { var latField = pair.pair.lat; var lngField = pair.pair.lng; var layerName = pair.defaultName; var prop = { label: layerName.length ? layerName : 'Point' }; // default layer color for begintrip and dropoff point if (latField.value in _defaultSettings.DEFAULT_LAYER_COLOR) { prop.color = (0, _colorUtils.hexToRgb)(_defaultSettings.DEFAULT_LAYER_COLOR[latField.value]); } // set the first layer to be visible if (props.length === 0) { prop.isVisible = true; } prop.columns = { lat: latField, lng: lngField, altitude: { value: null, fieldIdx: -1, optional: true } }; props.push(prop); }); return { props: props }; } }]); return PointLayer; }(_baseLayer["default"]); exports["default"] = PointLayer; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/point-layer/point-layer.js"],"names":["pointPosAccessor","lat","lng","altitude","dc","d","valueAt","index","fieldIdx","pointRequiredColumns","pointOptionalColumns","brushingExtension","BrushingExtension","pointVisConfigs","radius","fixedRadius","opacity","outline","thickness","strokeColor","colorRange","strokeColorRange","radiusRange","filled","type","label","defaultValue","property","PointLayer","props","registerVisConfig","getPositionAccessor","dataContainer","config","columns","PointLayerIcon","defaultPointColumnPairs","color","accessor","condition","visConfig","key","field","scale","domain","range","channelScaleType","CHANNEL_SCALES","size","fixed","dataset","defaultColorField","updateLayerConfig","colorField","updateLayerVisualChannel","strokeColorField","strokeColorDomain","strokeColorScale","getPosition","filteredIndex","data","i","length","pos","every","Number","isFinite","push","position","datasets","oldLayerData","textLabel","dataId","gpuFilter","updateData","triggerChanged","textLabels","accessors","getAttributeAccessors","getFilterValue","filterValueAccessor","bounds","getPointsBounds","updateMeta","opts","objectHovered","mapState","interactionConfig","Boolean","sizeField","radiusScale","getRadiusScaleByZoom","layerProps","stroked","lineWidthScale","radiusMaxPixels","updateTriggers","filterValueUpdateTriggers","getVisualChannelUpdateTriggers","defaultLayerProps","getDefaultDeckLayerProps","brushingProps","getBrushingExtensionProps","getPixelOffset","getRadius","extensions","sharedProps","filterRange","visible","hoveredObject","hasHoveredObject","ScatterplotLayer","parameters","depthTest","lineWidthUnits","getDefaultHoverLayerProps","getLineColor","highlightColor","getFillColor","renderTextLabelLayer","fieldPairs","forEach","pair","latField","lngField","layerName","defaultName","prop","value","DEFAULT_LAYER_COLOR","isVisible","optional","Layer"],"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 {BrushingExtension} from '@deck.gl/extensions';\nimport {ScatterplotLayer} from '@deck.gl/layers';\n\nimport Layer from '../base-layer';\nimport {hexToRgb} from 'utils/color-utils';\nimport {findDefaultColorField} from 'utils/dataset-utils';\nimport PointLayerIcon from './point-layer-icon';\nimport {DEFAULT_LAYER_COLOR, CHANNEL_SCALES} from 'constants/default-settings';\n\nimport {getTextOffsetByRadius, formatTextLabelData} from '../layer-text-label';\n\nexport const pointPosAccessor = ({lat, lng, altitude}) => dc => d => [\n  dc.valueAt(d.index, lng.fieldIdx),\n  dc.valueAt(d.index, lat.fieldIdx),\n  altitude && altitude.fieldIdx > -1 ? dc.valueAt(d.index, altitude.fieldIdx) : 0\n];\n\nexport const pointRequiredColumns = ['lat', 'lng'];\nexport const pointOptionalColumns = ['altitude'];\n\nconst brushingExtension = new BrushingExtension();\n\nexport const pointVisConfigs = {\n  radius: 'radius',\n  fixedRadius: 'fixedRadius',\n  opacity: 'opacity',\n  outline: 'outline',\n  thickness: 'thickness',\n  strokeColor: 'strokeColor',\n  colorRange: 'colorRange',\n  strokeColorRange: 'strokeColorRange',\n  radiusRange: 'radiusRange',\n  filled: {\n    type: 'boolean',\n    label: 'layer.fillColor',\n    defaultValue: true,\n    property: 'filled'\n  }\n};\n\nexport default class PointLayer extends Layer {\n  constructor(props) {\n    super(props);\n\n    this.registerVisConfig(pointVisConfigs);\n    this.getPositionAccessor = dataContainer =>\n      pointPosAccessor(this.config.columns)(dataContainer);\n  }\n\n  get type() {\n    return 'point';\n  }\n\n  get isAggregated() {\n    return false;\n  }\n\n  get layerIcon() {\n    return PointLayerIcon;\n  }\n  get requiredLayerColumns() {\n    return pointRequiredColumns;\n  }\n\n  get optionalColumns() {\n    return pointOptionalColumns;\n  }\n\n  get columnPairs() {\n    return this.defaultPointColumnPairs;\n  }\n\n  get noneLayerDataAffectingProps() {\n    return [...super.noneLayerDataAffectingProps, 'radius'];\n  }\n\n  get visualChannels() {\n    return {\n      color: {\n        ...super.visualChannels.color,\n        accessor: 'getFillColor',\n        condition: config => config.visConfig.filled,\n        defaultValue: config => config.color\n      },\n      strokeColor: {\n        property: 'strokeColor',\n        key: 'strokeColor',\n        field: 'strokeColorField',\n        scale: 'strokeColorScale',\n        domain: 'strokeColorDomain',\n        range: 'strokeColorRange',\n        channelScaleType: CHANNEL_SCALES.color,\n        accessor: 'getLineColor',\n        condition: config => config.visConfig.outline,\n        defaultValue: config => config.visConfig.strokeColor || config.color\n      },\n      size: {\n        ...super.visualChannels.size,\n        property: 'radius',\n        range: 'radiusRange',\n        fixed: 'fixedRadius',\n        channelScaleType: 'radius',\n        accessor: 'getRadius',\n        defaultValue: 1\n      }\n    };\n  }\n\n  setInitialLayerConfig(dataset) {\n    const defaultColorField = findDefaultColorField(dataset);\n\n    if (defaultColorField) {\n      this.updateLayerConfig({\n        colorField: defaultColorField\n      });\n      this.updateLayerVisualChannel(dataset, 'color');\n    }\n\n    return this;\n  }\n\n  static findDefaultLayerProps({fieldPairs = []}) {\n    const props = [];\n\n    // Make layer for each pair\n    fieldPairs.forEach(pair => {\n      const latField = pair.pair.lat;\n      const lngField = pair.pair.lng;\n      const layerName = pair.defaultName;\n\n      const prop = {\n        label: layerName.length ? layerName : 'Point'\n      };\n\n      // default layer color for begintrip and dropoff point\n      if (latField.value in DEFAULT_LAYER_COLOR) {\n        prop.color = hexToRgb(DEFAULT_LAYER_COLOR[latField.value]);\n      }\n\n      // set the first layer to be visible\n      if (props.length === 0) {\n        prop.isVisible = true;\n      }\n\n      prop.columns = {\n        lat: latField,\n        lng: lngField,\n        altitude: {value: null, fieldIdx: -1, optional: true}\n      };\n\n      props.push(prop);\n    });\n\n    return {props};\n  }\n\n  getDefaultLayerConfig(props = {}) {\n    return {\n      ...super.getDefaultLayerConfig(props),\n\n      // add stroke color visual channel\n      strokeColorField: null,\n      strokeColorDomain: [0, 1],\n      strokeColorScale: 'quantile'\n    };\n  }\n\n  calculateDataAttribute({filteredIndex}, getPosition) {\n    const data = [];\n\n    for (let i = 0; i < filteredIndex.length; i++) {\n      const index = filteredIndex[i];\n      const pos = getPosition({index});\n\n      // if doesn't have point lat or lng, do not add the point\n      // deck.gl can't handle position = null\n      if (pos.every(Number.isFinite)) {\n        data.push({\n          position: pos,\n          index\n        });\n      }\n    }\n    return data;\n  }\n\n  formatLayerData(datasets, oldLayerData) {\n    const {textLabel} = this.config;\n    const {gpuFilter, dataContainer} = datasets[this.config.dataId];\n    const {data, triggerChanged} = this.updateData(datasets, oldLayerData);\n    const getPosition = this.getPositionAccessor(dataContainer);\n\n    // get all distinct characters in the text labels\n    const textLabels = formatTextLabelData({\n      textLabel,\n      triggerChanged,\n      oldLayerData,\n      data,\n      dataContainer\n    });\n\n    const accessors = this.getAttributeAccessors({dataContainer});\n\n    return {\n      data,\n      getPosition,\n      getFilterValue: gpuFilter.filterValueAccessor(dataContainer)(),\n      textLabels,\n      ...accessors\n    };\n  }\n  /* eslint-enable complexity */\n\n  updateLayerMeta(dataContainer) {\n    const getPosition = this.getPositionAccessor(dataContainer);\n    const bounds = this.getPointsBounds(dataContainer, getPosition);\n    this.updateMeta({bounds});\n  }\n\n  renderLayer(opts) {\n    const {data, gpuFilter, objectHovered, mapState, interactionConfig} = opts;\n\n    // if no field size is defined we need to pass fixed radius = false\n    const fixedRadius = this.config.visConfig.fixedRadius && Boolean(this.config.sizeField);\n    const radiusScale = this.getRadiusScaleByZoom(mapState, fixedRadius);\n\n    const layerProps = {\n      stroked: this.config.visConfig.outline,\n      filled: this.config.visConfig.filled,\n      lineWidthScale: this.config.visConfig.thickness,\n      radiusScale,\n      ...(this.config.visConfig.fixedRadius ? {} : {radiusMaxPixels: 500})\n    };\n\n    const updateTriggers = {\n      getPosition: this.config.columns,\n      getFilterValue: gpuFilter.filterValueUpdateTriggers,\n      ...this.getVisualChannelUpdateTriggers()\n    };\n\n    const defaultLayerProps = this.getDefaultDeckLayerProps(opts);\n    const brushingProps = this.getBrushingExtensionProps(interactionConfig);\n    const getPixelOffset = getTextOffsetByRadius(radiusScale, data.getRadius, mapState);\n    const extensions = [...defaultLayerProps.extensions, brushingExtension];\n\n    const sharedProps = {\n      getFilterValue: data.getFilterValue,\n      extensions,\n      filterRange: defaultLayerProps.filterRange,\n      visible: defaultLayerProps.visible,\n      ...brushingProps\n    };\n    const hoveredObject = this.hasHoveredObject(objectHovered);\n\n    return [\n      new ScatterplotLayer({\n        ...defaultLayerProps,\n        ...brushingProps,\n        ...layerProps,\n        ...data,\n        parameters: {\n          // circles will be flat on the map when the altitude column is not used\n          depthTest: this.config.columns.altitude?.fieldIdx > -1\n        },\n        lineWidthUnits: 'pixels',\n        updateTriggers,\n        extensions\n      }),\n      // hover layer\n      ...(hoveredObject\n        ? [\n            new ScatterplotLayer({\n              ...this.getDefaultHoverLayerProps(),\n              ...layerProps,\n              data: [hoveredObject],\n              getLineColor: this.config.highlightColor,\n              getFillColor: this.config.highlightColor,\n              getRadius: data.getRadius,\n              getPosition: data.getPosition\n            })\n          ]\n        : []),\n      // text label layer\n      ...this.renderTextLabelLayer(\n        {\n          getPosition: data.getPosition,\n          sharedProps,\n          getPixelOffset,\n          updateTriggers\n        },\n        opts\n      )\n    ];\n  }\n}\n"]}