kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
276 lines (271 loc) • 39.4 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.pointRequiredColumns = exports.pointPosAccessor = exports.pointColResolver = exports.heatmapVisConfigs = exports.geoarrowRequiredColumns = exports.geoarrowPosAccessor = exports["default"] = exports.MAX_ZOOM_LEVEL = exports.COLUMN_MODE_POINTS = exports.COLUMN_MODE_GEOARROW = void 0;
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _reselect = require("reselect");
var _constants = require("@kepler.gl/constants");
var _mapboxglLayer = _interopRequireDefault(require("../mapboxgl-layer"));
var _heatmapLayerIcon = _interopRequireDefault(require("./heatmap-layer-icon"));
var _utils = require("@kepler.gl/utils");
var _layerUtils = require("../layer-utils");
var _excluded = ["colorField", "colorDomain", "colorScale"];
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
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; })(); }
function _superPropGet(t, e, r, o) { var p = (0, _get2["default"])((0, _getPrototypeOf2["default"])(1 & o ? t.prototype : t), e, r); return 2 & o ? function (t) { return p.apply(r, t); } : p; } // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
var MAX_ZOOM_LEVEL = exports.MAX_ZOOM_LEVEL = 18;
var pointPosAccessor = exports.pointPosAccessor = function pointPosAccessor(_ref) {
var lat = _ref.lat,
lng = _ref.lng;
return function (dc) {
return function (d) {
return [dc.valueAt(d.index, lng.fieldIdx), dc.valueAt(d.index, lat.fieldIdx)];
};
};
};
var geoarrowPosAccessor = exports.geoarrowPosAccessor = function geoarrowPosAccessor(_ref2) {
var geoarrow = _ref2.geoarrow;
return function (dc) {
return function (d) {
var row = dc.valueAt(d.index, geoarrow.fieldIdx);
return [row.get(0), row.get(1)];
};
};
};
var pointColResolver = exports.pointColResolver = function pointColResolver(_ref3, columnMode) {
var lat = _ref3.lat,
lng = _ref3.lng,
geoarrow = _ref3.geoarrow;
if (columnMode === COLUMN_MODE_POINTS) {
return "".concat(lat.fieldIdx, "-").concat(lng.fieldIdx);
}
return "geoarrow-".concat(geoarrow.fieldIdx);
};
var heatmapVisConfigs = exports.heatmapVisConfigs = {
opacity: 'opacity',
colorRange: 'colorRange',
radius: 'heatmapRadius'
};
var pointRequiredColumns = exports.pointRequiredColumns = ['lat', 'lng'];
var geoarrowRequiredColumns = exports.geoarrowRequiredColumns = ['geoarrow'];
var COLUMN_MODE_POINTS = exports.COLUMN_MODE_POINTS = 'points';
var COLUMN_MODE_GEOARROW = exports.COLUMN_MODE_GEOARROW = 'geoarrow';
var SUPPORTED_COLUMN_MODES = [{
key: COLUMN_MODE_POINTS,
label: 'Points',
requiredColumns: pointRequiredColumns
}, {
key: COLUMN_MODE_GEOARROW,
label: 'Geoarrow Points',
requiredColumns: geoarrowRequiredColumns
}];
var DEFAULT_COLUMN_MODE = COLUMN_MODE_POINTS;
/**
*
* @param colorRange
* @return [
* 0, "rgba(33,102,172,0)",
* 0.2, "rgb(103,169,207)",
* 0.4, "rgb(209,229,240)",
* 0.6, "rgb(253,219,199)",
* 0.8, "rgb(239,138,98)",
* 1, "rgb(178,24,43)"
* ]
*/
var heatmapDensity = function heatmapDensity(colorRange) {
var colors = ['#000000'].concat((0, _toConsumableArray2["default"])(colorRange.colors));
var colorDensity = [];
colors.forEach(function (color, index) {
colorDensity.push(index / colors.length);
colorDensity.push("rgb(".concat((0, _utils.hexToRgb)(color).join(','), ")"));
});
colorDensity[1] = 'rgba(0,0,0,0)';
return colorDensity;
};
var HeatmapLayer = /*#__PURE__*/function (_MapboxGLLayer) {
function HeatmapLayer(props) {
var _this;
(0, _classCallCheck2["default"])(this, HeatmapLayer);
_this = _callSuper(this, HeatmapLayer, [props]);
(0, _defineProperty2["default"])(_this, "columnsSelector", function (config) {
return pointColResolver(config.columns, config.columnMode);
});
(0, _defineProperty2["default"])(_this, "visConfigSelector", function (config) {
return config.visConfig;
});
(0, _defineProperty2["default"])(_this, "weightFieldSelector", function (config) {
return config.weightField ? config.weightField.name : null;
});
(0, _defineProperty2["default"])(_this, "weightDomainSelector", function (config) {
return config.weightDomain;
});
(0, _defineProperty2["default"])(_this, "paintSelector", (0, _reselect.createSelector)(_this.visConfigSelector, _this.weightFieldSelector, _this.weightDomainSelector, function (visConfig, weightField, weightDomain) {
return {
'heatmap-weight': weightField ? ['interpolate', ['linear'], ['get', weightField], weightDomain[0], 0, weightDomain[1], 1] : 1,
'heatmap-intensity': ['interpolate', ['linear'], ['zoom'], 0, 1, MAX_ZOOM_LEVEL, 3],
'heatmap-color': ['interpolate', ['linear'], ['heatmap-density']].concat((0, _toConsumableArray2["default"])(heatmapDensity(visConfig.colorRange))),
'heatmap-radius': ['interpolate', ['linear'], ['zoom'], 0, 2, MAX_ZOOM_LEVEL, visConfig.radius // radius
],
'heatmap-opacity': visConfig.opacity
};
}));
(0, _defineProperty2["default"])(_this, "computeHeatmapConfiguration", (0, _reselect.createSelector)(_this.sourceSelector, _this.filterSelector, _this.paintSelector, function (source, filter, paint) {
return _objectSpread({
type: 'heatmap',
id: _this.id,
source: source,
layout: {
visibility: 'visible'
},
paint: paint
}, _this.isValidFilter(filter) ? {
filter: filter
} : {});
}));
_this.registerVisConfig(heatmapVisConfigs);
_this.getPositionAccessor = function (dataContainer) {
switch (_this.config.columnMode) {
case COLUMN_MODE_GEOARROW:
return geoarrowPosAccessor(_this.config.columns)(dataContainer);
default:
// COLUMN_MODE_POINTS
return pointPosAccessor(_this.config.columns)(dataContainer);
}
};
return _this;
}
(0, _inherits2["default"])(HeatmapLayer, _MapboxGLLayer);
return (0, _createClass2["default"])(HeatmapLayer, [{
key: "type",
get: function get() {
return 'heatmap';
}
}, {
key: "supportedColumnModes",
get: function get() {
return SUPPORTED_COLUMN_MODES;
}
}, {
key: "hasAllColumns",
value: function hasAllColumns() {
var _this$config = this.config,
columns = _this$config.columns,
columnMode = _this$config.columnMode;
if (columnMode === COLUMN_MODE_GEOARROW) {
return this.hasColumnValue(columns.geoarrow);
}
return _superPropGet(HeatmapLayer, "hasAllColumns", this, 3)([]);
}
}, {
key: "visualChannels",
get: function get() {
return {
// @ts-expect-error
weight: {
property: 'weight',
field: 'weightField',
scale: 'weightScale',
domain: 'weightDomain',
key: 'weight',
// supportedFieldTypes can be determined by channelScaleType
// or specified here
defaultMeasure: 'property.density',
supportedFieldTypes: [_constants.ALL_FIELD_TYPES.real, _constants.ALL_FIELD_TYPES.integer],
channelScaleType: _constants.CHANNEL_SCALES.size
}
};
}
}, {
key: "layerIcon",
get: function get() {
return _heatmapLayerIcon["default"];
}
}, {
key: "getVisualChannelDescription",
value: function getVisualChannelDescription(channel) {
return channel === 'color' ? {
label: 'property.color',
measure: 'property.density'
} : {
label: 'property.weight',
measure: this.config.weightField ? this.config.weightField.name : 'property.density'
};
}
}, {
key: "getDefaultLayerConfig",
value: function getDefaultLayerConfig(props) {
var _props$columnMode;
// mapbox heatmap layer color is always based on density
// no need to set colorField, colorDomain and colorScale
// eslint-disable-next-line @typescript-eslint/no-unused-vars
var _superPropGet$columnM = _objectSpread(_objectSpread({}, _superPropGet(HeatmapLayer, "getDefaultLayerConfig", this, 3)([props])), {}, {
columnMode: (_props$columnMode = props === null || props === void 0 ? void 0 : props.columnMode) !== null && _props$columnMode !== void 0 ? _props$columnMode : DEFAULT_COLUMN_MODE,
weightField: null,
weightDomain: [0, 1],
weightScale: 'linear'
}),
colorField = _superPropGet$columnM.colorField,
colorDomain = _superPropGet$columnM.colorDomain,
colorScale = _superPropGet$columnM.colorScale,
layerConfig = (0, _objectWithoutProperties2["default"])(_superPropGet$columnM, _excluded);
// @ts-expect-error
return layerConfig;
}
}, {
key: "updateLayerMeta",
value: function updateLayerMeta(dataset) {
var dataContainer = dataset.dataContainer;
var getPosition = this.getPositionAccessor(dataContainer);
var bounds = this.getPointsBounds(dataContainer, getPosition);
this.updateMeta({
bounds: bounds
});
}
}, {
key: "formatLayerData",
value: function formatLayerData(datasets, oldLayerData) {
if (this.config.dataId === null) {
return {};
}
var weightField = this.config.weightField;
var dataContainer = datasets[this.config.dataId].dataContainer;
var getPosition = this.getPositionAccessor(dataContainer);
var _this$updateData = this.updateData(datasets, oldLayerData),
data = _this$updateData.data;
// @ts-ignore
var newConfig = this.computeHeatmapConfiguration(this.config, datasets);
newConfig.id = this.id;
return {
columns: this.config.columns,
config: newConfig,
data: data,
weightField: weightField,
getPosition: getPosition
};
}
}], [{
key: "findDefaultLayerProps",
value: function findDefaultLayerProps(dataset) {
var altProps = (0, _layerUtils.getGeoArrowPointLayerProps)(dataset);
return {
props: [],
altProps: altProps
};
}
}]);
}(_mapboxglLayer["default"]);
var _default = exports["default"] = HeatmapLayer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_reselect","require","_constants","_mapboxglLayer","_interopRequireDefault","_heatmapLayerIcon","_utils","_layerUtils","_excluded","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","Boolean","prototype","valueOf","call","_superPropGet","p","_get2","MAX_ZOOM_LEVEL","exports","pointPosAccessor","_ref","lat","lng","dc","d","valueAt","index","fieldIdx","geoarrowPosAccessor","_ref2","geoarrow","row","get","pointColResolver","_ref3","columnMode","COLUMN_MODE_POINTS","concat","heatmapVisConfigs","opacity","colorRange","radius","pointRequiredColumns","geoarrowRequiredColumns","COLUMN_MODE_GEOARROW","SUPPORTED_COLUMN_MODES","key","label","requiredColumns","DEFAULT_COLUMN_MODE","heatmapDensity","colors","_toConsumableArray2","colorDensity","color","hexToRgb","join","HeatmapLayer","_MapboxGLLayer","props","_this","_classCallCheck2","config","columns","visConfig","weightField","name","weightDomain","createSelector","visConfigSelector","weightFieldSelector","weightDomainSelector","sourceSelector","filterSelector","paintSelector","source","paint","type","id","layout","visibility","isValidFilter","registerVisConfig","getPositionAccessor","dataContainer","_inherits2","_createClass2","value","hasAllColumns","_this$config","hasColumnValue","weight","property","field","scale","domain","defaultMeasure","supportedFieldTypes","ALL_FIELD_TYPES","real","integer","channelScaleType","CHANNEL_SCALES","size","HeatmapLayerIcon","getVisualChannelDescription","channel","measure","getDefaultLayerConfig","_props$columnMode","_superPropGet$columnM","weightScale","colorField","colorDomain","colorScale","layerConfig","_objectWithoutProperties2","updateLayerMeta","dataset","getPosition","bounds","getPointsBounds","updateMeta","formatLayerData","datasets","oldLayerData","dataId","_this$updateData","updateData","data","newConfig","computeHeatmapConfiguration","findDefaultLayerProps","altProps","getGeoArrowPointLayerProps","MapboxGLLayer","_default"],"sources":["../../src/heatmap-layer/heatmap-layer.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {createSelector} from 'reselect';\nimport {CHANNEL_SCALES, ALL_FIELD_TYPES} from '@kepler.gl/constants';\nimport MapboxGLLayer, {MapboxLayerGLConfig} from '../mapboxgl-layer';\nimport HeatmapLayerIcon from './heatmap-layer-icon';\nimport {LayerBaseConfigPartial, LayerWeightConfig, VisualChannels} from '../base-layer';\nimport {\n  ColorRange,\n  VisConfigColorRange,\n  VisConfigNumber,\n  HexColor,\n  Merge,\n  LayerColumn\n} from '@kepler.gl/types';\nimport {hexToRgb, DataContainerInterface} from '@kepler.gl/utils';\nimport {KeplerTable} from '@kepler.gl/table';\n\nimport {getGeoArrowPointLayerProps, FindDefaultLayerPropsReturnValue} from '../layer-utils';\n\nexport type HeatmapLayerVisConfigSettings = {\n  opacity: VisConfigNumber;\n  colorRange: VisConfigColorRange;\n  radius: VisConfigNumber;\n};\n\nexport type HeatmapLayerColumnsConfig = {\n  // COLUMN_MODE_POINTS\n  lat: LayerColumn;\n  lng: LayerColumn;\n\n  // COLUMN_MODE_GEOARROW\n  geoarrow: LayerColumn;\n};\n\nexport type HeatmapLayerVisConfig = {\n  opacity: number;\n  colorRange: ColorRange;\n  radius: number;\n};\n\nexport type HeatmapLayerVisualChannelConfig = LayerWeightConfig;\nexport type HeatmapLayerConfig = Merge<\n  MapboxLayerGLConfig,\n  {columns: HeatmapLayerColumnsConfig; visConfig: HeatmapLayerVisConfig}\n> &\n  HeatmapLayerVisualChannelConfig;\n\nexport const MAX_ZOOM_LEVEL = 18;\n\nexport const pointPosAccessor =\n  ({lat, lng}: HeatmapLayerColumnsConfig) =>\n  (dc: DataContainerInterface) =>\n  (d: {index: number}): number[] =>\n    [dc.valueAt(d.index, lng.fieldIdx), dc.valueAt(d.index, lat.fieldIdx)];\n\nexport const geoarrowPosAccessor =\n  ({geoarrow}: HeatmapLayerColumnsConfig) =>\n  (dc: DataContainerInterface) =>\n  (d: {index: number}): number[] => {\n    const row = dc.valueAt(d.index, geoarrow.fieldIdx);\n    return [row.get(0), row.get(1)];\n  };\n\nexport const pointColResolver = ({lat, lng, geoarrow}: HeatmapLayerColumnsConfig, columnMode) => {\n  if (columnMode === COLUMN_MODE_POINTS) {\n    return `${lat.fieldIdx}-${lng.fieldIdx}`;\n  }\n  return `geoarrow-${geoarrow.fieldIdx}`;\n};\n\nexport const heatmapVisConfigs: {\n  opacity: 'opacity';\n  colorRange: 'colorRange';\n  radius: 'heatmapRadius';\n} = {\n  opacity: 'opacity',\n  colorRange: 'colorRange',\n  radius: 'heatmapRadius'\n};\n\nexport const pointRequiredColumns = ['lat', 'lng'];\nexport const geoarrowRequiredColumns = ['geoarrow'];\n\nexport const COLUMN_MODE_POINTS = 'points';\nexport const COLUMN_MODE_GEOARROW = 'geoarrow';\nconst SUPPORTED_COLUMN_MODES = [\n  {\n    key: COLUMN_MODE_POINTS,\n    label: 'Points',\n    requiredColumns: pointRequiredColumns\n  },\n  {\n    key: COLUMN_MODE_GEOARROW,\n    label: 'Geoarrow Points',\n    requiredColumns: geoarrowRequiredColumns\n  }\n];\nconst DEFAULT_COLUMN_MODE = COLUMN_MODE_POINTS;\n\n/**\n *\n * @param colorRange\n * @return [\n *  0, \"rgba(33,102,172,0)\",\n *  0.2, \"rgb(103,169,207)\",\n *  0.4, \"rgb(209,229,240)\",\n *  0.6, \"rgb(253,219,199)\",\n *  0.8, \"rgb(239,138,98)\",\n *  1, \"rgb(178,24,43)\"\n * ]\n */\nconst heatmapDensity = (colorRange: ColorRange): (string | number)[] => {\n  const colors: HexColor[] = ['#000000', ...colorRange.colors];\n\n  const colorDensity: (string | number)[] = [];\n  colors.forEach((color, index) => {\n    colorDensity.push(index / colors.length);\n    colorDensity.push(`rgb(${hexToRgb(color).join(',')})`);\n  });\n\n  colorDensity[1] = 'rgba(0,0,0,0)';\n  return colorDensity;\n};\n\nclass HeatmapLayer extends MapboxGLLayer {\n  declare visConfigSettings: HeatmapLayerVisConfigSettings;\n  declare config: HeatmapLayerConfig;\n\n  constructor(props) {\n    super(props);\n    this.registerVisConfig(heatmapVisConfigs);\n\n    this.getPositionAccessor = (dataContainer: DataContainerInterface) => {\n      switch (this.config.columnMode) {\n        case COLUMN_MODE_GEOARROW:\n          return geoarrowPosAccessor(this.config.columns)(dataContainer);\n        default:\n          // COLUMN_MODE_POINTS\n          return pointPosAccessor(this.config.columns)(dataContainer);\n      }\n    };\n  }\n\n  get type(): 'heatmap' {\n    return 'heatmap';\n  }\n\n  get supportedColumnModes() {\n    return SUPPORTED_COLUMN_MODES;\n  }\n\n  hasAllColumns() {\n    const {columns, columnMode} = this.config;\n    if (columnMode === COLUMN_MODE_GEOARROW) {\n      return this.hasColumnValue(columns.geoarrow);\n    }\n    return super.hasAllColumns();\n  }\n\n  static findDefaultLayerProps(dataset: KeplerTable): FindDefaultLayerPropsReturnValue {\n    const altProps = getGeoArrowPointLayerProps(dataset);\n\n    return {\n      props: [],\n      altProps\n    };\n  }\n\n  get visualChannels(): VisualChannels {\n    return {\n      // @ts-expect-error\n      weight: {\n        property: 'weight',\n        field: 'weightField',\n        scale: 'weightScale',\n        domain: 'weightDomain',\n        key: 'weight',\n        // supportedFieldTypes can be determined by channelScaleType\n        // or specified here\n        defaultMeasure: 'property.density',\n        supportedFieldTypes: [ALL_FIELD_TYPES.real, ALL_FIELD_TYPES.integer],\n        channelScaleType: CHANNEL_SCALES.size\n      }\n    };\n  }\n\n  get layerIcon() {\n    return HeatmapLayerIcon;\n  }\n\n  getVisualChannelDescription(channel) {\n    return channel === 'color'\n      ? {\n          label: 'property.color',\n          measure: 'property.density'\n        }\n      : {\n          label: 'property.weight',\n          measure: this.config.weightField ? this.config.weightField.name : 'property.density'\n        };\n  }\n\n  getDefaultLayerConfig(props: LayerBaseConfigPartial): HeatmapLayerConfig {\n    // mapbox heatmap layer color is always based on density\n    // no need to set colorField, colorDomain and colorScale\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    const {colorField, colorDomain, colorScale, ...layerConfig} = {\n      ...super.getDefaultLayerConfig(props),\n      columnMode: props?.columnMode ?? DEFAULT_COLUMN_MODE,\n\n      weightField: null,\n      weightDomain: [0, 1],\n      weightScale: 'linear'\n    };\n\n    // @ts-expect-error\n    return layerConfig;\n  }\n\n  updateLayerMeta(dataset: KeplerTable) {\n    const {dataContainer} = dataset;\n\n    const getPosition = this.getPositionAccessor(dataContainer);\n    const bounds = this.getPointsBounds(dataContainer, getPosition);\n    this.updateMeta({bounds});\n  }\n\n  columnsSelector = config => pointColResolver(config.columns, config.columnMode);\n  visConfigSelector = config => config.visConfig;\n  weightFieldSelector = config => (config.weightField ? config.weightField.name : null);\n  weightDomainSelector = config => config.weightDomain;\n\n  paintSelector = createSelector(\n    this.visConfigSelector,\n    this.weightFieldSelector,\n    this.weightDomainSelector,\n    (visConfig, weightField, weightDomain) => ({\n      'heatmap-weight': weightField\n        ? ['interpolate', ['linear'], ['get', weightField], weightDomain[0], 0, weightDomain[1], 1]\n        : 1,\n      'heatmap-intensity': ['interpolate', ['linear'], ['zoom'], 0, 1, MAX_ZOOM_LEVEL, 3],\n      'heatmap-color': [\n        'interpolate',\n        ['linear'],\n        ['heatmap-density'],\n        ...heatmapDensity(visConfig.colorRange)\n      ],\n      'heatmap-radius': [\n        'interpolate',\n        ['linear'],\n        ['zoom'],\n        0,\n        2,\n        MAX_ZOOM_LEVEL,\n        visConfig.radius // radius\n      ],\n      'heatmap-opacity': visConfig.opacity\n    })\n  );\n\n  computeHeatmapConfiguration = createSelector(\n    this.sourceSelector,\n    this.filterSelector,\n    this.paintSelector,\n    (source, filter, paint) => {\n      return {\n        type: 'heatmap',\n        id: this.id,\n        source,\n        layout: {\n          visibility: 'visible'\n        },\n        paint,\n        ...(this.isValidFilter(filter) ? {filter} : {})\n      };\n    }\n  );\n\n  formatLayerData(datasets, oldLayerData) {\n    if (this.config.dataId === null) {\n      return {};\n    }\n    const {weightField} = this.config;\n    const {dataContainer} = datasets[this.config.dataId];\n    const getPosition = this.getPositionAccessor(dataContainer);\n    const {data} = this.updateData(datasets, oldLayerData);\n\n    // @ts-ignore\n    const newConfig = this.computeHeatmapConfiguration(this.config, datasets);\n    newConfig.id = this.id;\n\n    return {\n      columns: this.config.columns,\n      config: newConfig,\n      data,\n      weightField,\n      getPosition\n    };\n  }\n}\n\nexport default HeatmapLayer;\n"],"mappings":"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","ignoreList":[]}
;