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