UNPKG

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