kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
378 lines (335 loc) • 39.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.S2VisConfigs = exports.defaultLineWidth = exports.defaultElevation = exports.S2TokenAccessor = exports.s2RequiredColumns = exports.S2_TOKEN_FIELDS = void 0;
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 _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 _colorUtils = require("../../utils/color-utils");
var _defaultSettings = require("../../constants/default-settings");
var _layerFactory = require("../layer-factory");
var _baseLayer = _interopRequireDefault(require("../base-layer"));
var _s2LayerIcon = _interopRequireDefault(require("./s2-layer-icon"));
var _s2Utils = require("./s2-utils");
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 zoomFactorValue = 8;
var S2_TOKEN_FIELDS = {
token: ['s2', 's2_token']
};
exports.S2_TOKEN_FIELDS = S2_TOKEN_FIELDS;
var s2RequiredColumns = ['token'];
exports.s2RequiredColumns = s2RequiredColumns;
var S2TokenAccessor = function S2TokenAccessor(_ref) {
var token = _ref.token;
return function (d) {
return d[token.fieldIdx];
};
};
exports.S2TokenAccessor = S2TokenAccessor;
var defaultElevation = 500;
exports.defaultElevation = defaultElevation;
var defaultLineWidth = 1;
exports.defaultLineWidth = defaultLineWidth;
var S2VisConfigs = {
// Filled color
opacity: 'opacity',
colorRange: 'colorRange',
filled: {
type: 'boolean',
label: 'Fill Color',
defaultValue: true,
property: 'filled'
},
// stroke
thickness: _objectSpread({}, _layerFactory.LAYER_VIS_CONFIGS.thickness, {
defaultValue: 0.5
}),
strokeColor: 'strokeColor',
strokeColorRange: 'strokeColorRange',
sizeRange: 'strokeWidthRange',
stroked: 'stroked',
// height
enable3d: 'enable3d',
elevationScale: 'elevationScale',
heightRange: 'elevationRange',
// wireframe
wireframe: 'wireframe'
};
exports.S2VisConfigs = S2VisConfigs;
var S2GeometryLayer =
/*#__PURE__*/
function (_Layer) {
(0, _inherits2["default"])(S2GeometryLayer, _Layer);
function S2GeometryLayer(props) {
var _this;
(0, _classCallCheck2["default"])(this, S2GeometryLayer);
_this = (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(S2GeometryLayer).call(this, props));
_this.registerVisConfig(S2VisConfigs);
_this.getPositionAccessor = function () {
return S2TokenAccessor(_this.config.columns);
};
return _this;
}
(0, _createClass2["default"])(S2GeometryLayer, [{
key: "getDefaultLayerConfig",
value: function getDefaultLayerConfig() {
var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
return _objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(S2GeometryLayer.prototype), "getDefaultLayerConfig", this).call(this, props), {
// add height visual channel
heightField: null,
heightDomain: [0, 1],
heightScale: 'linear',
// add stroke color visual channel
strokeColorField: null,
strokeColorDomain: [0, 1],
strokeColorScale: 'quantile'
});
}
}, {
key: "calculateDataAttribute",
value: function calculateDataAttribute(_ref2, getS2Token) {
var allData = _ref2.allData,
filteredIndex = _ref2.filteredIndex;
var data = [];
for (var i = 0; i < filteredIndex.length; i++) {
var index = filteredIndex[i];
var token = getS2Token(allData[index]);
if (token) {
data.push({
// keep a reference to the original data index
index: index,
data: allData[index],
token: token
});
}
}
return data;
}
}, {
key: "updateLayerMeta",
value: function updateLayerMeta(allData, getS2Token) {
var centroids = allData.reduce(function (acc, entry) {
var s2Token = getS2Token(entry);
return s2Token ? [].concat((0, _toConsumableArray2["default"])(acc), [(0, _s2Utils.getS2Center)(s2Token)]) : acc;
}, []);
var bounds = this.getPointsBounds(centroids);
this.dataToFeature = {
centroids: centroids
};
this.updateMeta({
bounds: bounds
});
}
/* eslint-disable complexity */
}, {
key: "formatLayerData",
value: function formatLayerData(datasets, oldLayerData) {
var _this2 = this;
var opt = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var _this$config = this.config,
colorScale = _this$config.colorScale,
colorDomain = _this$config.colorDomain,
colorField = _this$config.colorField,
color = _this$config.color,
heightField = _this$config.heightField,
heightDomain = _this$config.heightDomain,
heightScale = _this$config.heightScale,
strokeColorField = _this$config.strokeColorField,
strokeColorScale = _this$config.strokeColorScale,
strokeColorDomain = _this$config.strokeColorDomain,
sizeScale = _this$config.sizeScale,
sizeDomain = _this$config.sizeDomain,
sizeField = _this$config.sizeField,
visConfig = _this$config.visConfig;
var enable3d = visConfig.enable3d,
stroked = visConfig.stroked,
colorRange = visConfig.colorRange,
heightRange = visConfig.heightRange,
sizeRange = visConfig.sizeRange,
strokeColorRange = visConfig.strokeColorRange,
strokeColor = visConfig.strokeColor;
var gpuFilter = datasets[this.config.dataId].gpuFilter;
var getS2Token = this.getPositionAccessor();
var _this$updateData = this.updateData(datasets, oldLayerData),
data = _this$updateData.data;
var cScale = colorField && this.getVisChannelScale(colorScale, colorDomain, colorRange.colors.map(_colorUtils.hexToRgb)); // calculate elevation scale - if extruded = true
var eScale = heightField && enable3d && this.getVisChannelScale(heightScale, heightDomain, heightRange); // stroke color
var scScale = strokeColorField && this.getVisChannelScale(strokeColorScale, strokeColorDomain, strokeColorRange.colors.map(_colorUtils.hexToRgb)); // calculate stroke scale - if stroked = true
var sScale = sizeField && stroked && this.getVisChannelScale(sizeScale, sizeDomain, sizeRange);
return {
data: data,
getS2Token: getS2Token,
getLineColor: function getLineColor(d) {
return scScale ? _this2.getEncodedChannelValue(scScale, d.data, strokeColorField) : strokeColor || color;
},
getLineWidth: function getLineWidth(d) {
return sScale ? _this2.getEncodedChannelValue(sScale, d.data, sizeField, 0) : defaultLineWidth;
},
getFillColor: function getFillColor(d) {
return cScale ? _this2.getEncodedChannelValue(cScale, d.data, colorField) : color;
},
getElevation: function getElevation(d) {
return eScale ? _this2.getEncodedChannelValue(eScale, d.data, heightField, 0) : defaultElevation;
},
getFilterValue: gpuFilter.filterValueAccessor()
};
}
/* eslint-enable complexity */
}, {
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 = {
getLineColor: {
color: visConfig.strokeColor,
colorField: config.strokeColorField,
colorRange: visConfig.strokeColorRange,
colorScale: config.strokeColorScale
},
getLineWidth: {
sizeField: config.sizeField,
sizeRange: visConfig.sizeRange
},
getFillColor: {
color: config.color,
colorField: config.colorField,
colorRange: visConfig.colorRange,
colorScale: config.colorScale
},
getElevation: {
heightField: config.heightField,
heightScaleType: config.heightScale,
heightRange: visConfig.heightRange
},
getFilterValue: gpuFilter.filterValueUpdateTriggers
};
return [new _geoLayers.S2Layer(_objectSpread({}, defaultLayerProps, {}, interactionConfig, {}, data, {
getS2Token: function getS2Token(d) {
return d.token;
},
autoHighlight: visConfig.enable3d,
highlightColor: _defaultSettings.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: "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() {
return _objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(S2GeometryLayer.prototype), "visualChannels", this), {
color: {
property: 'color',
field: 'colorField',
scale: 'colorScale',
domain: 'colorDomain',
range: 'colorRange',
key: 'color',
channelScaleType: _defaultSettings.CHANNEL_SCALES.color
},
size: _objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(S2GeometryLayer.prototype), "visualChannels", this).size, {
property: 'stroke',
condition: function condition(config) {
return config.visConfig.stroked;
}
}),
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.stroked;
}
},
height: {
property: 'height',
field: 'heightField',
scale: 'heightScale',
domain: 'heightDomain',
range: 'heightRange',
key: 'height',
channelScaleType: _defaultSettings.CHANNEL_SCALES.size,
condition: function condition(config) {
return config.visConfig.enable3d;
}
}
});
}
}], [{
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
};
})
};
}
}]);
return S2GeometryLayer;
}(_baseLayer["default"]);
exports["default"] = S2GeometryLayer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/s2-geometry-layer/s2-geometry-layer.js"],"names":["zoomFactorValue","S2_TOKEN_FIELDS","token","s2RequiredColumns","S2TokenAccessor","d","fieldIdx","defaultElevation","defaultLineWidth","S2VisConfigs","opacity","colorRange","filled","type","label","defaultValue","property","thickness","LAYER_VIS_CONFIGS","strokeColor","strokeColorRange","sizeRange","stroked","enable3d","elevationScale","heightRange","wireframe","S2GeometryLayer","props","registerVisConfig","getPositionAccessor","config","columns","heightField","heightDomain","heightScale","strokeColorField","strokeColorDomain","strokeColorScale","getS2Token","allData","filteredIndex","data","i","length","index","push","centroids","reduce","acc","entry","s2Token","bounds","getPointsBounds","dataToFeature","updateMeta","datasets","oldLayerData","opt","colorScale","colorDomain","colorField","color","sizeScale","sizeDomain","sizeField","visConfig","gpuFilter","dataId","updateData","cScale","getVisChannelScale","colors","map","hexToRgb","eScale","scScale","sScale","getLineColor","getEncodedChannelValue","getLineWidth","getFillColor","getElevation","getFilterValue","filterValueAccessor","opts","interactionConfig","mapState","defaultLayerProps","getDefaultDeckLayerProps","eleZoomFactor","getElevationZoomFactor","zoomFactor","getZoomFactor","updateTriggers","heightScaleType","filterValueUpdateTriggers","S2Layer","autoHighlight","highlightColor","HIGHLIGH_COLOR_3D","lineWidthScale","lineMiterLimit","wrapLongitude","extruded","pickable","S2LayerIcon","field","scale","domain","range","key","channelScaleType","CHANNEL_SCALES","size","condition","height","fields","foundColumns","findDefaultColumnField","isVisible","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 {S2Layer} from '@deck.gl/geo-layers';\nimport {hexToRgb} from 'utils/color-utils';\nimport {HIGHLIGH_COLOR_3D, CHANNEL_SCALES} from 'constants/default-settings';\nimport {LAYER_VIS_CONFIGS} from 'layers/layer-factory';\nimport Layer from '../base-layer';\nimport S2LayerIcon from './s2-layer-icon';\nimport {getS2Center} from './s2-utils';\n\nconst zoomFactorValue = 8;\n\nexport const S2_TOKEN_FIELDS = {\n  token: ['s2', 's2_token']\n};\n\nexport const s2RequiredColumns = ['token'];\nexport const S2TokenAccessor = ({token}) => d => d[token.fieldIdx];\nexport const defaultElevation = 500;\nexport const defaultLineWidth = 1;\n\nexport const S2VisConfigs = {\n  // Filled color\n  opacity: 'opacity',\n  colorRange: 'colorRange',\n  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  heightRange: 'elevationRange',\n\n  // wireframe\n  wireframe: 'wireframe'\n};\n\nexport default class S2GeometryLayer extends Layer {\n  constructor(props) {\n    super(props);\n    this.registerVisConfig(S2VisConfigs);\n    this.getPositionAccessor = () => S2TokenAccessor(this.config.columns);\n  }\n\n  get type() {\n    return 's2';\n  }\n\n  get name() {\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    return {\n      ...super.visualChannels,\n      color: {\n        property: 'color',\n        field: 'colorField',\n        scale: 'colorScale',\n        domain: 'colorDomain',\n        range: 'colorRange',\n        key: 'color',\n        channelScaleType: CHANNEL_SCALES.color\n      },\n      size: {\n        ...super.visualChannels.size,\n        property: 'stroke',\n        condition: config => config.visConfig.stroked\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.stroked\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        condition: config => config.visConfig.enable3d\n      }\n    };\n  }\n\n  getDefaultLayerConfig(props = {}) {\n    return {\n      ...super.getDefaultLayerConfig(props),\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    };\n  }\n\n  static findDefaultLayerProps({fields = []}) {\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({allData, filteredIndex}, getS2Token) {\n    const data = [];\n    for (let i = 0; i < filteredIndex.length; i++) {\n      const index = filteredIndex[i];\n      const token = getS2Token(allData[index]);\n\n      if (token) {\n        data.push({\n          // keep a reference to the original data index\n          index,\n          data: allData[index],\n          token\n        });\n      }\n    }\n    return data;\n  }\n\n  updateLayerMeta(allData, getS2Token) {\n    const centroids = allData.reduce((acc, entry) => {\n      const s2Token = getS2Token(entry);\n      return s2Token ? [...acc, getS2Center(s2Token)] : acc;\n    }, []);\n\n    const bounds = this.getPointsBounds(centroids);\n    this.dataToFeature = {centroids};\n    this.updateMeta({bounds});\n  }\n\n  /* eslint-disable complexity */\n  formatLayerData(datasets, oldLayerData, opt = {}) {\n    const {\n      colorScale,\n      colorDomain,\n      colorField,\n      color,\n      heightField,\n      heightDomain,\n      heightScale,\n      strokeColorField,\n      strokeColorScale,\n      strokeColorDomain,\n      sizeScale,\n      sizeDomain,\n      sizeField,\n      visConfig\n    } = this.config;\n\n    const {\n      enable3d,\n      stroked,\n      colorRange,\n      heightRange,\n      sizeRange,\n      strokeColorRange,\n      strokeColor\n    } = visConfig;\n\n    const {gpuFilter} = datasets[this.config.dataId];\n    const getS2Token = this.getPositionAccessor();\n    const {data} = this.updateData(datasets, oldLayerData);\n\n    const cScale =\n      colorField &&\n      this.getVisChannelScale(colorScale, colorDomain, colorRange.colors.map(hexToRgb));\n\n    // calculate elevation scale - if extruded = true\n    const eScale =\n      heightField && enable3d && this.getVisChannelScale(heightScale, heightDomain, heightRange);\n\n    // stroke color\n    const scScale =\n      strokeColorField &&\n      this.getVisChannelScale(\n        strokeColorScale,\n        strokeColorDomain,\n        strokeColorRange.colors.map(hexToRgb)\n      );\n\n    // calculate stroke scale - if stroked = true\n    const sScale =\n      sizeField && stroked && this.getVisChannelScale(sizeScale, sizeDomain, sizeRange);\n\n    return {\n      data,\n      getS2Token,\n      getLineColor: d =>\n        scScale\n          ? this.getEncodedChannelValue(scScale, d.data, strokeColorField)\n          : strokeColor || color,\n      getLineWidth: d =>\n        sScale ? this.getEncodedChannelValue(sScale, d.data, sizeField, 0) : defaultLineWidth,\n      getFillColor: d => (cScale ? this.getEncodedChannelValue(cScale, d.data, colorField) : color),\n      getElevation: d =>\n        eScale ? this.getEncodedChannelValue(eScale, d.data, heightField, 0) : defaultElevation,\n      getFilterValue: gpuFilter.filterValueAccessor()\n    };\n  }\n  /* eslint-enable complexity */\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      getLineColor: {\n        color: visConfig.strokeColor,\n        colorField: config.strokeColorField,\n        colorRange: visConfig.strokeColorRange,\n        colorScale: config.strokeColorScale\n      },\n      getLineWidth: {\n        sizeField: config.sizeField,\n        sizeRange: visConfig.sizeRange\n      },\n      getFillColor: {\n        color: config.color,\n        colorField: config.colorField,\n        colorRange: visConfig.colorRange,\n        colorScale: config.colorScale\n      },\n      getElevation: {\n        heightField: config.heightField,\n        heightScaleType: config.heightScale,\n        heightRange: visConfig.heightRange\n      },\n      getFilterValue: gpuFilter.filterValueUpdateTriggers\n    };\n\n    return [\n      new S2Layer({\n        ...defaultLayerProps,\n        ...interactionConfig,\n        ...data,\n        getS2Token: d => 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"]}