kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
295 lines (294 loc) • 40.5 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.s2RequiredColumns = exports.defaultLineWidth = exports.defaultElevation = exports["default"] = exports.S2_TOKEN_FIELDS = exports.S2VisConfigs = exports.S2TokenAccessor = void 0;
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 _geoLayers = require("@deck.gl/geo-layers");
var _constants = require("@kepler.gl/constants");
var _baseLayer = _interopRequireDefault(require("../base-layer"));
var _s2LayerIcon = _interopRequireDefault(require("./s2-layer-icon"));
var _s2Utils = require("./s2-utils");
var _utils = require("@kepler.gl/utils");
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; }
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; } // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
var zoomFactorValue = 8;
var S2_TOKEN_FIELDS = exports.S2_TOKEN_FIELDS = {
token: ['s2', 's2_token']
};
var s2RequiredColumns = exports.s2RequiredColumns = ['token'];
var S2TokenAccessor = exports.S2TokenAccessor = function S2TokenAccessor(_ref) {
var token = _ref.token;
return function (dc) {
return function (d) {
return dc.valueAt(d.index, token.fieldIdx);
};
};
};
var defaultElevation = exports.defaultElevation = 500;
var defaultLineWidth = exports.defaultLineWidth = 1;
var S2VisConfigs = exports.S2VisConfigs = {
// Filled color
opacity: 'opacity',
colorRange: 'colorRange',
filled: _objectSpread(_objectSpread({}, _constants.LAYER_VIS_CONFIGS.filled), {}, {
type: 'boolean',
label: 'Fill Color',
defaultValue: true,
property: 'filled'
}),
// stroke
thickness: _objectSpread(_objectSpread({}, _constants.LAYER_VIS_CONFIGS.thickness), {}, {
defaultValue: 0.5
}),
strokeColor: 'strokeColor',
strokeColorRange: 'strokeColorRange',
sizeRange: 'strokeWidthRange',
stroked: 'stroked',
// height
enable3d: 'enable3d',
elevationScale: 'elevationScale',
enableElevationZoomFactor: 'enableElevationZoomFactor',
fixedHeight: 'fixedHeight',
heightRange: 'elevationRange',
// wireframe
wireframe: 'wireframe'
};
var S2GeometryLayer = exports["default"] = /*#__PURE__*/function (_Layer) {
function S2GeometryLayer(props) {
var _this;
(0, _classCallCheck2["default"])(this, S2GeometryLayer);
_this = _callSuper(this, S2GeometryLayer, [props]);
(0, _defineProperty2["default"])(_this, "dataToFeature", void 0);
_this.registerVisConfig(S2VisConfigs);
_this.getPositionAccessor = function (dataContainer) {
return S2TokenAccessor(_this.config.columns)(dataContainer);
};
return _this;
}
(0, _inherits2["default"])(S2GeometryLayer, _Layer);
return (0, _createClass2["default"])(S2GeometryLayer, [{
key: "type",
get: function get() {
return 's2';
}
}, {
key: "name",
get: function get() {
return 'S2';
}
}, {
key: "requiredLayerColumns",
get: function get() {
return s2RequiredColumns;
}
}, {
key: "layerIcon",
get: function get() {
return _s2LayerIcon["default"];
}
}, {
key: "visualChannels",
get: function get() {
var visualChannels = _superPropGet(S2GeometryLayer, "visualChannels", this, 1);
return {
color: _objectSpread(_objectSpread({}, visualChannels.color), {}, {
accessor: 'getFillColor'
}),
size: _objectSpread(_objectSpread({}, visualChannels.size), {}, {
property: 'stroke',
accessor: 'getLineWidth',
condition: function condition(config) {
return config.visConfig.stroked;
},
defaultValue: defaultLineWidth
}),
strokeColor: {
property: 'strokeColor',
field: 'strokeColorField',
scale: 'strokeColorScale',
domain: 'strokeColorDomain',
range: 'strokeColorRange',
key: 'strokeColor',
channelScaleType: _constants.CHANNEL_SCALES.color,
accessor: 'getLineColor',
condition: function condition(config) {
return config.visConfig.stroked;
},
nullValue: visualChannels.color.nullValue,
defaultValue: function defaultValue(config) {
return config.visConfig.strokeColor || config.color;
}
},
height: {
property: 'height',
field: 'heightField',
scale: 'heightScale',
domain: 'heightDomain',
range: 'heightRange',
key: 'height',
channelScaleType: _constants.CHANNEL_SCALES.size,
accessor: 'getElevation',
condition: function condition(config) {
return config.visConfig.enable3d;
},
nullValue: 0,
defaultValue: defaultElevation
}
};
}
}, {
key: "getDefaultLayerConfig",
value: function getDefaultLayerConfig(props) {
var defaultLayerConfig = _superPropGet(S2GeometryLayer, "getDefaultLayerConfig", this, 3)([props !== null && props !== void 0 ? props : {}]);
return _objectSpread(_objectSpread({}, defaultLayerConfig), {}, {
// add height visual channel
heightField: null,
heightDomain: [0, 1],
heightScale: 'linear',
// add stroke color visual channel
strokeColorField: null,
strokeColorDomain: [0, 1],
strokeColorScale: 'quantile',
colorUI: _objectSpread(_objectSpread({}, defaultLayerConfig.colorUI), {}, {
strokeColorRange: _constants.DEFAULT_COLOR_UI
})
});
}
}, {
key: "calculateDataAttribute",
value: function calculateDataAttribute(_ref2, getS2Token) {
var filteredIndex = _ref2.filteredIndex;
var data = [];
for (var i = 0; i < filteredIndex.length; i++) {
var index = filteredIndex[i];
var token = getS2Token({
index: index
});
if ((0, _s2Utils.validS2Token)(token)) {
data.push({
index: index,
token: token
});
}
}
return data;
}
}, {
key: "updateLayerMeta",
value: function updateLayerMeta(dataset, getS2Token) {
var dataContainer = dataset.dataContainer;
// add safe row flag
var centroids = dataContainer.reduce(function (acc, entry, index) {
var s2Token = getS2Token({
index: index
});
if ((0, _s2Utils.validS2Token)(s2Token)) {
acc.push((0, _s2Utils.getS2Center)(s2Token));
}
return acc;
}, [], true);
var centroidsDataContainer = (0, _utils.createDataContainer)(centroids);
var bounds = this.getPointsBounds(centroidsDataContainer, function (d, dc) {
return [dc.valueAt(d.index, 0), dc.valueAt(d.index, 1)];
});
this.dataToFeature = {
centroids: centroids
};
this.updateMeta({
bounds: bounds
});
}
}, {
key: "formatLayerData",
value: function formatLayerData(datasets, oldLayerData) {
if (this.config.dataId === null) {
return {};
}
var _datasets$this$config = datasets[this.config.dataId],
gpuFilter = _datasets$this$config.gpuFilter,
dataContainer = _datasets$this$config.dataContainer;
var getS2Token = this.getPositionAccessor(dataContainer);
var _this$updateData = this.updateData(datasets, oldLayerData),
data = _this$updateData.data;
var accessors = this.getAttributeAccessors({
dataContainer: dataContainer
});
return _objectSpread({
data: data,
getS2Token: getS2Token,
getFilterValue: gpuFilter.filterValueAccessor(dataContainer)()
}, accessors);
}
}, {
key: "renderLayer",
value: function renderLayer(opts) {
var data = opts.data,
gpuFilter = opts.gpuFilter,
interactionConfig = opts.interactionConfig,
mapState = opts.mapState;
var defaultLayerProps = this.getDefaultDeckLayerProps(opts);
var eleZoomFactor = this.getElevationZoomFactor(mapState);
var zoomFactor = this.getZoomFactor(mapState);
var config = this.config;
var visConfig = config.visConfig;
var updateTriggers = _objectSpread(_objectSpread({}, this.getVisualChannelUpdateTriggers()), {}, {
getFilterValue: gpuFilter.filterValueUpdateTriggers
});
return [new _geoLayers.S2Layer(_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, defaultLayerProps), interactionConfig), data), {}, {
getS2Token: function getS2Token(d) {
return d.token;
},
autoHighlight: visConfig.enable3d,
highlightColor: _constants.HIGHLIGH_COLOR_3D,
// stroke
lineWidthScale: visConfig.thickness * zoomFactor * zoomFactorValue,
stroked: visConfig.stroked,
lineMiterLimit: 2,
// Filled color
filled: visConfig.filled,
opacity: visConfig.opacity,
wrapLongitude: false,
// Elevation
elevationScale: visConfig.elevationScale * eleZoomFactor,
extruded: visConfig.enable3d,
wireframe: visConfig.wireframe,
pickable: true,
updateTriggers: updateTriggers
}))];
}
}], [{
key: "findDefaultLayerProps",
value: function findDefaultLayerProps(_ref3) {
var _ref3$fields = _ref3.fields,
fields = _ref3$fields === void 0 ? [] : _ref3$fields;
var foundColumns = this.findDefaultColumnField(S2_TOKEN_FIELDS, fields);
if (!foundColumns || !foundColumns.length) {
return {
props: []
};
}
return {
props: foundColumns.map(function (columns) {
return {
isVisible: true,
label: 'S2',
columns: columns
};
})
};
}
}]);
}(_baseLayer["default"]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_geoLayers","require","_constants","_baseLayer","_interopRequireDefault","_s2LayerIcon","_s2Utils","_utils","_callSuper","t","o","e","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","call","_superPropGet","r","p","_get2","ownKeys","Object","keys","getOwnPropertySymbols","filter","getOwnPropertyDescriptor","enumerable","push","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","zoomFactorValue","S2_TOKEN_FIELDS","exports","token","s2RequiredColumns","S2TokenAccessor","_ref","dc","d","valueAt","index","fieldIdx","defaultElevation","defaultLineWidth","S2VisConfigs","opacity","colorRange","filled","LAYER_VIS_CONFIGS","type","label","defaultValue","property","thickness","strokeColor","strokeColorRange","sizeRange","stroked","enable3d","elevationScale","enableElevationZoomFactor","fixedHeight","heightRange","wireframe","S2GeometryLayer","_Layer","props","_this","_classCallCheck2","registerVisConfig","getPositionAccessor","dataContainer","config","columns","_inherits2","_createClass2","key","get","S2LayerIcon","visualChannels","color","accessor","size","condition","visConfig","field","scale","domain","range","channelScaleType","CHANNEL_SCALES","nullValue","height","value","getDefaultLayerConfig","defaultLayerConfig","heightField","heightDomain","heightScale","strokeColorField","strokeColorDomain","strokeColorScale","colorUI","DEFAULT_COLOR_UI","calculateDataAttribute","_ref2","getS2Token","filteredIndex","data","i","validS2Token","updateLayerMeta","dataset","centroids","reduce","acc","entry","s2Token","getS2Center","centroidsDataContainer","createDataContainer","bounds","getPointsBounds","dataToFeature","updateMeta","formatLayerData","datasets","oldLayerData","dataId","_datasets$this$config","gpuFilter","_this$updateData","updateData","accessors","getAttributeAccessors","getFilterValue","filterValueAccessor","renderLayer","opts","interactionConfig","mapState","defaultLayerProps","getDefaultDeckLayerProps","eleZoomFactor","getElevationZoomFactor","zoomFactor","getZoomFactor","updateTriggers","getVisualChannelUpdateTriggers","filterValueUpdateTriggers","S2Layer","autoHighlight","highlightColor","HIGHLIGH_COLOR_3D","lineWidthScale","lineMiterLimit","wrapLongitude","extruded","pickable","findDefaultLayerProps","_ref3","_ref3$fields","fields","foundColumns","findDefaultColumnField","map","isVisible","Layer"],"sources":["../../src/s2-geometry-layer/s2-geometry-layer.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {S2Layer} from '@deck.gl/geo-layers';\nimport {\n  HIGHLIGH_COLOR_3D,\n  CHANNEL_SCALES,\n  LAYER_VIS_CONFIGS,\n  DEFAULT_COLOR_UI\n} from '@kepler.gl/constants';\nimport {default as KeplerTable} from '@kepler.gl/table';\nimport Layer, {\n  LayerBaseConfig,\n  LayerBaseConfigPartial,\n  LayerColorConfig,\n  LayerSizeConfig,\n  LayerStrokeColorConfig,\n  LayerHeightConfig\n} from '../base-layer';\nimport {\n  ColorRange,\n  Merge,\n  RGBColor,\n  VisConfigBoolean,\n  VisConfigColorRange,\n  VisConfigColorSelect,\n  VisConfigNumber,\n  VisConfigRange,\n  LayerColumn\n} from '@kepler.gl/types';\nimport S2LayerIcon from './s2-layer-icon';\nimport {getS2Center, validS2Token} from './s2-utils';\nimport {DataContainerInterface, createDataContainer} from '@kepler.gl/utils';\n\nexport type S2GeometryLayerVisConfigSettings = {\n  opacity: VisConfigNumber;\n  colorRange: VisConfigColorRange;\n  filled: VisConfigBoolean;\n  thickness: VisConfigNumber;\n  strokeColor: VisConfigColorSelect;\n  strokeColorRange: VisConfigColorRange;\n  sizeRange: VisConfigRange;\n  stroked: VisConfigBoolean;\n  enable3d: VisConfigBoolean;\n  elevationScale: VisConfigNumber;\n  enableElevationZoomFactor: VisConfigBoolean;\n  heightRange: VisConfigRange;\n  wireframe: VisConfigBoolean;\n};\n\nexport type S2GeometryLayerColumnsConfig = {\n  token: LayerColumn;\n};\n\nexport type S2GeometryLayerVisConfig = {\n  opacity: number;\n  colorRange: ColorRange;\n  filled: boolean;\n  thickness: number;\n  strokeColor: RGBColor;\n  strokeColorRange: ColorRange;\n  sizeRange: [number, number];\n  stroked: boolean;\n  enable3d: boolean;\n  elevationScale: number;\n  enableElevationZoomFactor: boolean;\n  heightRange: [number, number];\n  wireframe: boolean;\n};\n\nexport type S2GeometryLayerVisualChannelConfig = LayerColorConfig &\n  LayerSizeConfig &\n  LayerStrokeColorConfig &\n  LayerHeightConfig;\nexport type S2GeometryLayerConfig = Merge<\n  LayerBaseConfig,\n  {columns: S2GeometryLayerColumnsConfig; visConfig: S2GeometryLayerVisConfig}\n> &\n  S2GeometryLayerVisualChannelConfig;\n\nexport type S2GeometryLayerData = {\n  index: number;\n  token: any;\n};\n\nconst zoomFactorValue = 8;\n\nexport const S2_TOKEN_FIELDS: {\n  token: ['s2', 's2_token'];\n} = {\n  token: ['s2', 's2_token']\n};\n\nexport const s2RequiredColumns: ['token'] = ['token'];\nexport const S2TokenAccessor =\n  ({token}: S2GeometryLayerColumnsConfig) =>\n  (dc: DataContainerInterface) =>\n  d =>\n    dc.valueAt(d.index, token.fieldIdx);\n\nexport const defaultElevation = 500;\nexport const defaultLineWidth = 1;\n\nexport const S2VisConfigs: {\n  // Filled color\n  opacity: 'opacity';\n  colorRange: 'colorRange';\n  filled: VisConfigBoolean;\n\n  // stroke\n  thickness: VisConfigNumber;\n  strokeColor: 'strokeColor';\n  strokeColorRange: 'strokeColorRange';\n  sizeRange: 'strokeWidthRange';\n  stroked: 'stroked';\n\n  // height\n  enable3d: 'enable3d';\n  elevationScale: 'elevationScale';\n  enableElevationZoomFactor: 'enableElevationZoomFactor';\n  fixedHeight: 'fixedHeight';\n  heightRange: 'elevationRange';\n\n  // wireframe\n  wireframe: 'wireframe';\n} = {\n  // Filled color\n  opacity: 'opacity',\n  colorRange: 'colorRange',\n  filled: {\n    ...LAYER_VIS_CONFIGS.filled,\n    type: 'boolean',\n    label: 'Fill Color',\n    defaultValue: true,\n    property: 'filled'\n  },\n\n  // stroke\n  thickness: {\n    ...LAYER_VIS_CONFIGS.thickness,\n    defaultValue: 0.5\n  },\n  strokeColor: 'strokeColor',\n  strokeColorRange: 'strokeColorRange',\n  sizeRange: 'strokeWidthRange',\n  stroked: 'stroked',\n\n  // height\n  enable3d: 'enable3d',\n  elevationScale: 'elevationScale',\n  enableElevationZoomFactor: 'enableElevationZoomFactor',\n  fixedHeight: 'fixedHeight',\n  heightRange: 'elevationRange',\n\n  // wireframe\n  wireframe: 'wireframe'\n};\n\nexport default class S2GeometryLayer extends Layer {\n  dataToFeature: any;\n  declare visConfigSettings: S2GeometryLayerVisConfigSettings;\n  declare config: S2GeometryLayerConfig;\n  constructor(props) {\n    super(props);\n    this.registerVisConfig(S2VisConfigs);\n    this.getPositionAccessor = (dataContainer: DataContainerInterface) =>\n      S2TokenAccessor(this.config.columns)(dataContainer);\n  }\n\n  get type(): 's2' {\n    return 's2';\n  }\n\n  get name(): 'S2' {\n    return 'S2';\n  }\n\n  get requiredLayerColumns() {\n    return s2RequiredColumns;\n  }\n\n  get layerIcon() {\n    return S2LayerIcon;\n  }\n\n  get visualChannels() {\n    const visualChannels = super.visualChannels;\n    return {\n      color: {\n        ...visualChannels.color,\n        accessor: 'getFillColor'\n      },\n      size: {\n        ...visualChannels.size,\n        property: 'stroke',\n        accessor: 'getLineWidth',\n        condition: config => config.visConfig.stroked,\n        defaultValue: defaultLineWidth\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        accessor: 'getLineColor',\n        condition: config => config.visConfig.stroked,\n        nullValue: visualChannels.color.nullValue,\n        defaultValue: config => config.visConfig.strokeColor || config.color\n      },\n      height: {\n        property: 'height',\n        field: 'heightField',\n        scale: 'heightScale',\n        domain: 'heightDomain',\n        range: 'heightRange',\n        key: 'height',\n        channelScaleType: CHANNEL_SCALES.size,\n        accessor: 'getElevation',\n        condition: config => config.visConfig.enable3d,\n        nullValue: 0,\n        defaultValue: defaultElevation\n      }\n    };\n  }\n\n  getDefaultLayerConfig(props: LayerBaseConfigPartial) {\n    const defaultLayerConfig = super.getDefaultLayerConfig(props ?? {});\n    return {\n      ...defaultLayerConfig,\n\n      // add height visual channel\n      heightField: null,\n      heightDomain: [0, 1],\n      heightScale: 'linear',\n\n      // add stroke color visual channel\n      strokeColorField: null,\n      strokeColorDomain: [0, 1],\n      strokeColorScale: 'quantile',\n      colorUI: {\n        ...defaultLayerConfig.colorUI,\n        strokeColorRange: DEFAULT_COLOR_UI\n      }\n    };\n  }\n\n  static findDefaultLayerProps({fields = []}: KeplerTable) {\n    const foundColumns = this.findDefaultColumnField(S2_TOKEN_FIELDS, fields);\n    if (!foundColumns || !foundColumns.length) {\n      return {props: []};\n    }\n\n    return {\n      props: foundColumns.map(columns => ({\n        isVisible: true,\n        label: 'S2',\n        columns\n      }))\n    };\n  }\n\n  calculateDataAttribute({filteredIndex}: KeplerTable, getS2Token) {\n    const data: S2GeometryLayerData[] = [];\n    for (let i = 0; i < filteredIndex.length; i++) {\n      const index = filteredIndex[i];\n      const token = getS2Token({index});\n      if (validS2Token(token)) {\n        data.push({\n          index,\n          token\n        });\n      }\n    }\n    return data;\n  }\n\n  updateLayerMeta(dataset: KeplerTable, getS2Token) {\n    const {dataContainer} = dataset;\n    // add safe row flag\n    const centroids = dataContainer.reduce(\n      (acc, entry, index) => {\n        const s2Token = getS2Token({index});\n        if (validS2Token(s2Token)) {\n          acc.push(getS2Center(s2Token));\n        }\n\n        return acc;\n      },\n      [],\n      true\n    );\n\n    const centroidsDataContainer = createDataContainer(centroids);\n    const bounds = this.getPointsBounds(centroidsDataContainer, (d, dc) => [\n      dc.valueAt(d.index, 0),\n      dc.valueAt(d.index, 1)\n    ]);\n    this.dataToFeature = {centroids};\n    this.updateMeta({bounds});\n  }\n\n  formatLayerData(datasets, oldLayerData) {\n    if (this.config.dataId === null) {\n      return {};\n    }\n    const {gpuFilter, dataContainer} = datasets[this.config.dataId];\n    const getS2Token = this.getPositionAccessor(dataContainer);\n    const {data} = this.updateData(datasets, oldLayerData);\n\n    const accessors = this.getAttributeAccessors({dataContainer});\n\n    return {\n      data,\n      getS2Token,\n      getFilterValue: gpuFilter.filterValueAccessor(dataContainer)(),\n      ...accessors\n    };\n  }\n\n  renderLayer(opts) {\n    const {data, gpuFilter, interactionConfig, mapState} = opts;\n\n    const defaultLayerProps = this.getDefaultDeckLayerProps(opts);\n\n    const eleZoomFactor = this.getElevationZoomFactor(mapState);\n    const zoomFactor = this.getZoomFactor(mapState);\n    const {config} = this;\n    const {visConfig} = config;\n\n    const updateTriggers = {\n      ...this.getVisualChannelUpdateTriggers(),\n      getFilterValue: gpuFilter.filterValueUpdateTriggers\n    };\n\n    return [\n      new S2Layer({\n        ...defaultLayerProps,\n        ...interactionConfig,\n        ...data,\n        getS2Token: (d: any) => d.token,\n\n        autoHighlight: visConfig.enable3d,\n        highlightColor: HIGHLIGH_COLOR_3D,\n\n        // stroke\n        lineWidthScale: visConfig.thickness * zoomFactor * zoomFactorValue,\n        stroked: visConfig.stroked,\n        lineMiterLimit: 2,\n\n        // Filled color\n        filled: visConfig.filled,\n        opacity: visConfig.opacity,\n        wrapLongitude: false,\n\n        // Elevation\n        elevationScale: visConfig.elevationScale * eleZoomFactor,\n        extruded: visConfig.enable3d,\n\n        wireframe: visConfig.wireframe,\n\n        pickable: true,\n\n        updateTriggers\n      })\n    ];\n  }\n}\n"],"mappings":"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","ignoreList":[]}
;