kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
395 lines (346 loc) • 43.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 _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
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 _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
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 _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; }
var pointPosAccessor = function pointPosAccessor(_ref) {
var lat = _ref.lat,
lng = _ref.lng,
altitude = _ref.altitude;
return function (d) {
return [// lng
d.data[lng.fieldIdx], // lat
d.data[lat.fieldIdx], altitude && altitude.fieldIdx > -1 ? d.data[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);
function PointLayer(props) {
var _this;
(0, _classCallCheck2["default"])(this, PointLayer);
_this = (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(PointLayer).call(this, props));
_this.registerVisConfig(pointVisConfigs);
_this.getPositionAccessor = function () {
return pointPosAccessor(_this.config.columns);
};
return _this;
}
(0, _createClass2["default"])(PointLayer, [{
key: "getDefaultLayerConfig",
value: function getDefaultLayerConfig() {
var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
return _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 allData = _ref2.allData,
filteredIndex = _ref2.filteredIndex;
var data = [];
for (var i = 0; i < filteredIndex.length; i++) {
var index = filteredIndex[i];
var pos = getPosition({
data: allData[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({
data: allData[index],
position: pos,
// index is important for filter
index: index
});
}
}
return data;
}
}, {
key: "formatLayerData",
value: function formatLayerData(datasets, oldLayerData) {
var _this2 = this;
var _this$config = this.config,
colorScale = _this$config.colorScale,
colorDomain = _this$config.colorDomain,
colorField = _this$config.colorField,
strokeColorField = _this$config.strokeColorField,
strokeColorScale = _this$config.strokeColorScale,
strokeColorDomain = _this$config.strokeColorDomain,
color = _this$config.color,
sizeField = _this$config.sizeField,
sizeScale = _this$config.sizeScale,
sizeDomain = _this$config.sizeDomain,
textLabel = _this$config.textLabel,
_this$config$visConfi = _this$config.visConfig,
radiusRange = _this$config$visConfi.radiusRange,
fixedRadius = _this$config$visConfi.fixedRadius,
colorRange = _this$config$visConfi.colorRange,
strokeColorRange = _this$config$visConfi.strokeColorRange,
strokeColor = _this$config$visConfi.strokeColor;
var gpuFilter = datasets[this.config.dataId].gpuFilter;
var _this$updateData = this.updateData(datasets, oldLayerData),
data = _this$updateData.data,
triggerChanged = _this$updateData.triggerChanged;
var getPosition = this.getPositionAccessor(); // point color
var cScale = colorField && this.getVisChannelScale(colorScale, colorDomain, colorRange.colors.map(_colorUtils.hexToRgb)); // stroke color
var scScale = strokeColorField && this.getVisChannelScale(strokeColorScale, strokeColorDomain, strokeColorRange.colors.map(_colorUtils.hexToRgb)); // point radius
var rScale = sizeField && this.getVisChannelScale(sizeScale, sizeDomain, radiusRange, fixedRadius);
var getRadius = rScale ? function (d) {
return _this2.getEncodedChannelValue(rScale, d.data, sizeField, 0);
} : 1;
var getFillColor = cScale ? function (d) {
return _this2.getEncodedChannelValue(cScale, d.data, colorField);
} : color;
var getLineColor = scScale ? function (d) {
return _this2.getEncodedChannelValue(scScale, d.data, strokeColorField);
} : strokeColor || color; // get all distinct characters in the text labels
var textLabels = (0, _layerTextLabel.formatTextLabelData)({
textLabel: textLabel,
triggerChanged: triggerChanged,
oldLayerData: oldLayerData,
data: data
});
return {
data: data,
getPosition: getPosition,
getFillColor: getFillColor,
getLineColor: getLineColor,
getFilterValue: gpuFilter.filterValueAccessor(),
getRadius: getRadius,
textLabels: textLabels
};
}
/* eslint-enable complexity */
}, {
key: "updateLayerMeta",
value: function updateLayerMeta(allData) {
var getPosition = this.getPositionAccessor();
var bounds = this.getPointsBounds(allData, function (d) {
return getPosition({
data: d
});
});
this.updateMeta({
bounds: bounds
});
}
}, {
key: "renderLayer",
value: function renderLayer(opts) {
var data = opts.data,
gpuFilter = opts.gpuFilter,
objectHovered = opts.objectHovered,
mapState = opts.mapState,
interactionConfig = opts.interactionConfig;
var radiusScale = this.getRadiusScaleByZoom(mapState);
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 = {
getPosition: this.config.columns,
getRadius: {
sizeField: this.config.sizeField,
radiusRange: this.config.visConfig.radiusRange,
fixedRadius: this.config.visConfig.fixedRadius,
sizeScale: this.config.sizeScale
},
getFillColor: {
color: this.config.color,
colorField: this.config.colorField,
colorRange: this.config.visConfig.colorRange,
colorScale: this.config.colorScale
},
getLineColor: {
color: this.config.visConfig.strokeColor,
colorField: this.config.strokeColorField,
colorRange: this.config.visConfig.strokeColorRange,
colorScale: this.config.strokeColorScale
},
getFilterValue: gpuFilter.filterValueUpdateTriggers
};
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
}, brushingProps);
return [new _layers.ScatterplotLayer(_objectSpread({}, defaultLayerProps, {}, brushingProps, {}, layerProps, {}, data, {
parameters: {
// circles will be flat on the map when the altitude column is not used
depthTest: this.config.columns.altitude.fieldIdx > -1
},
lineWidthUnits: 'pixels',
updateTriggers: updateTriggers,
extensions: extensions
}))].concat((0, _toConsumableArray2["default"])(this.isLayerHovered(objectHovered) ? [new _layers.ScatterplotLayer(_objectSpread({}, this.getDefaultHoverLayerProps(), {}, layerProps, {
data: [objectHovered.object],
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: "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({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(PointLayer.prototype), "visualChannels", this).color, {
condition: function condition(config) {
return config.visConfig.filled;
}
}),
strokeColor: {
property: 'strokeColor',
field: 'strokeColorField',
scale: 'strokeColorScale',
domain: 'strokeColorDomain',
range: 'strokeColorRange',
key: 'strokeColor',
channelScaleType: _defaultSettings.CHANNEL_SCALES.color,
condition: function condition(config) {
return config.visConfig.outline;
}
},
size: _objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(PointLayer.prototype), "visualChannels", this).size, {
range: 'radiusRange',
property: 'radius',
channelScaleType: 'radius'
})
};
}
}], [{
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) {
// find fields for tableFieldIndex
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","d","data","fieldIdx","pointRequiredColumns","pointOptionalColumns","brushingExtension","BrushingExtension","pointVisConfigs","radius","fixedRadius","opacity","outline","thickness","strokeColor","colorRange","strokeColorRange","radiusRange","filled","type","label","defaultValue","property","PointLayer","props","registerVisConfig","getPositionAccessor","config","columns","strokeColorField","strokeColorDomain","strokeColorScale","getPosition","allData","filteredIndex","i","length","index","pos","every","Number","isFinite","push","position","datasets","oldLayerData","colorScale","colorDomain","colorField","color","sizeField","sizeScale","sizeDomain","textLabel","visConfig","gpuFilter","dataId","updateData","triggerChanged","cScale","getVisChannelScale","colors","map","hexToRgb","scScale","rScale","getRadius","getEncodedChannelValue","getFillColor","getLineColor","textLabels","getFilterValue","filterValueAccessor","bounds","getPointsBounds","updateMeta","opts","objectHovered","mapState","interactionConfig","radiusScale","getRadiusScaleByZoom","layerProps","stroked","lineWidthScale","radiusMaxPixels","updateTriggers","filterValueUpdateTriggers","defaultLayerProps","getDefaultDeckLayerProps","brushingProps","getBrushingExtensionProps","getPixelOffset","extensions","sharedProps","filterRange","ScatterplotLayer","parameters","depthTest","lineWidthUnits","isLayerHovered","getDefaultHoverLayerProps","object","highlightColor","renderTextLabelLayer","PointLayerIcon","defaultPointColumnPairs","condition","field","scale","domain","range","key","channelScaleType","CHANNEL_SCALES","size","fieldPairs","forEach","pair","latField","lngField","layerName","defaultName","prop","value","DEFAULT_LAYER_COLOR","isVisible","optional","Layer"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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 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}) => d => [\n  // lng\n  d.data[lng.fieldIdx],\n  // lat\n  d.data[lat.fieldIdx],\n  altitude && altitude.fieldIdx > -1 ? d.data[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 = () => pointPosAccessor(this.config.columns);\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        condition: config => config.visConfig.filled\n      },\n      strokeColor: {\n        property: 'strokeColor',\n        field: 'strokeColorField',\n        scale: 'strokeColorScale',\n        domain: 'strokeColorDomain',\n        range: 'strokeColorRange',\n        key: 'strokeColor',\n        channelScaleType: CHANNEL_SCALES.color,\n        condition: config => config.visConfig.outline\n      },\n      size: {\n        ...super.visualChannels.size,\n        range: 'radiusRange',\n        property: 'radius',\n        channelScaleType: 'radius'\n      }\n    };\n  }\n\n  static findDefaultLayerProps({fieldPairs = []}) {\n    const props = [];\n\n    // Make layer for each pair\n    fieldPairs.forEach(pair => {\n      // find fields for tableFieldIndex\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({allData, filteredIndex}, getPosition) {\n    const data = [];\n\n    for (let i = 0; i < filteredIndex.length; i++) {\n      const index = filteredIndex[i];\n      const pos = getPosition({data: allData[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          data: allData[index],\n          position: pos,\n          // index is important for filter\n          index\n        });\n      }\n    }\n    return data;\n  }\n\n  formatLayerData(datasets, oldLayerData) {\n    const {\n      colorScale,\n      colorDomain,\n      colorField,\n      strokeColorField,\n      strokeColorScale,\n      strokeColorDomain,\n      color,\n      sizeField,\n      sizeScale,\n      sizeDomain,\n      textLabel,\n      visConfig: {radiusRange, fixedRadius, colorRange, strokeColorRange, strokeColor}\n    } = this.config;\n\n    const {gpuFilter} = datasets[this.config.dataId];\n    const {data, triggerChanged} = this.updateData(datasets, oldLayerData);\n    const getPosition = this.getPositionAccessor();\n    // point color\n\n    const cScale =\n      colorField &&\n      this.getVisChannelScale(colorScale, colorDomain, colorRange.colors.map(hexToRgb));\n\n    // stroke color\n    const scScale =\n      strokeColorField &&\n      this.getVisChannelScale(\n        strokeColorScale,\n        strokeColorDomain,\n        strokeColorRange.colors.map(hexToRgb)\n      );\n\n    // point radius\n    const rScale =\n      sizeField && this.getVisChannelScale(sizeScale, sizeDomain, radiusRange, fixedRadius);\n\n    const getRadius = rScale ? d => this.getEncodedChannelValue(rScale, d.data, sizeField, 0) : 1;\n\n    const getFillColor = cScale\n      ? d => this.getEncodedChannelValue(cScale, d.data, colorField)\n      : color;\n\n    const getLineColor = scScale\n      ? d => this.getEncodedChannelValue(scScale, d.data, strokeColorField)\n      : strokeColor || color;\n\n    // get all distinct characters in the text labels\n    const textLabels = formatTextLabelData({\n      textLabel,\n      triggerChanged,\n      oldLayerData,\n      data\n    });\n\n    return {\n      data,\n      getPosition,\n      getFillColor,\n      getLineColor,\n      getFilterValue: gpuFilter.filterValueAccessor(),\n      getRadius,\n      textLabels\n    };\n  }\n  /* eslint-enable complexity */\n\n  updateLayerMeta(allData) {\n    const getPosition = this.getPositionAccessor();\n    const bounds = this.getPointsBounds(allData, d => getPosition({data: d}));\n    this.updateMeta({bounds});\n  }\n\n  renderLayer(opts) {\n    const {data, gpuFilter, objectHovered, mapState, interactionConfig} = opts;\n\n    const radiusScale = this.getRadiusScaleByZoom(mapState);\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      getRadius: {\n        sizeField: this.config.sizeField,\n        radiusRange: this.config.visConfig.radiusRange,\n        fixedRadius: this.config.visConfig.fixedRadius,\n        sizeScale: this.config.sizeScale\n      },\n      getFillColor: {\n        color: this.config.color,\n        colorField: this.config.colorField,\n        colorRange: this.config.visConfig.colorRange,\n        colorScale: this.config.colorScale\n      },\n      getLineColor: {\n        color: this.config.visConfig.strokeColor,\n        colorField: this.config.strokeColorField,\n        colorRange: this.config.visConfig.strokeColorRange,\n        colorScale: this.config.strokeColorScale\n      },\n      getFilterValue: gpuFilter.filterValueUpdateTriggers\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      ...brushingProps\n    };\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      ...(this.isLayerHovered(objectHovered)\n        ? [\n            new ScatterplotLayer({\n              ...this.getDefaultHoverLayerProps(),\n              ...layerProps,\n              data: [objectHovered.object],\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"]}