UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

338 lines (295 loc) 33.4 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 _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _geoLayers = require("@deck.gl/geo-layers"); var _defaultSettings = require("../../constants/default-settings"); var _layerFactory = require("../layer-factory"); var _tableUtils = require("../../utils/table-utils"); var _baseLayer = _interopRequireDefault(require("../base-layer")); var _s2LayerIcon = _interopRequireDefault(require("./s2-layer-icon")); var _s2Utils = require("./s2-utils"); function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } 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 (dc) { return function (d) { return dc.valueAt(d.index, 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(_objectSpread({}, _layerFactory.LAYER_VIS_CONFIGS.thickness), {}, { defaultValue: 0.5 }), strokeColor: 'strokeColor', strokeColorRange: 'strokeColorRange', sizeRange: 'strokeWidthRange', stroked: 'stroked', // height enable3d: 'enable3d', elevationScale: 'elevationScale', enableElevationZoomFactor: 'enableElevationZoomFactor', heightRange: 'elevationRange', // wireframe wireframe: 'wireframe' }; exports.S2VisConfigs = S2VisConfigs; var S2GeometryLayer = /*#__PURE__*/function (_Layer) { (0, _inherits2["default"])(S2GeometryLayer, _Layer); var _super = _createSuper(S2GeometryLayer); function S2GeometryLayer(props) { var _this; (0, _classCallCheck2["default"])(this, S2GeometryLayer); _this = _super.call(this, props); _this.registerVisConfig(S2VisConfigs); _this.getPositionAccessor = function (dataContainer) { return S2TokenAccessor(_this.config.columns)(dataContainer); }; return _this; } (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 = (0, _get2["default"])((0, _getPrototypeOf2["default"])(S2GeometryLayer.prototype), "visualChannels", this); 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: _defaultSettings.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: _defaultSettings.CHANNEL_SCALES.size, accessor: 'getElevation', condition: function condition(config) { return config.visConfig.enable3d; }, nullValue: 0, defaultValue: defaultElevation } }; } }, { key: "getDefaultLayerConfig", value: function getDefaultLayerConfig() { var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; return _objectSpread(_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 dataContainer = _ref2.dataContainer, filteredIndex = _ref2.filteredIndex; var data = []; for (var i = 0; i < filteredIndex.length; i++) { var index = filteredIndex[i]; var token = getS2Token({ index: index }); if (token) { data.push({ index: index, token: token }); } } return data; } }, { key: "updateLayerMeta", value: function updateLayerMeta(dataContainer, getS2Token) { // add safe row flag var centroids = dataContainer.reduce(function (acc, entry, index) { var s2Token = getS2Token({ index: index }); if (s2Token) { acc.push((0, _s2Utils.getS2Center)(s2Token)); } return acc; }, [], true); var centroidsDataContainer = (0, _tableUtils.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) { var opt = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; 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: _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: "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","dc","d","valueAt","index","fieldIdx","defaultElevation","defaultLineWidth","S2VisConfigs","opacity","colorRange","filled","type","label","defaultValue","property","thickness","LAYER_VIS_CONFIGS","strokeColor","strokeColorRange","sizeRange","stroked","enable3d","elevationScale","enableElevationZoomFactor","heightRange","wireframe","S2GeometryLayer","props","registerVisConfig","getPositionAccessor","dataContainer","config","columns","S2LayerIcon","visualChannels","color","accessor","size","condition","visConfig","field","scale","domain","range","key","channelScaleType","CHANNEL_SCALES","nullValue","height","heightField","heightDomain","heightScale","strokeColorField","strokeColorDomain","strokeColorScale","getS2Token","filteredIndex","data","i","length","push","centroids","reduce","acc","entry","s2Token","centroidsDataContainer","bounds","getPointsBounds","dataToFeature","updateMeta","datasets","oldLayerData","opt","dataId","gpuFilter","updateData","accessors","getAttributeAccessors","getFilterValue","filterValueAccessor","opts","interactionConfig","mapState","defaultLayerProps","getDefaultDeckLayerProps","eleZoomFactor","getElevationZoomFactor","zoomFactor","getZoomFactor","updateTriggers","getVisualChannelUpdateTriggers","filterValueUpdateTriggers","S2Layer","autoHighlight","highlightColor","HIGHLIGH_COLOR_3D","lineWidthScale","lineMiterLimit","wrapLongitude","extruded","pickable","fields","foundColumns","findDefaultColumnField","map","isVisible","Layer"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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 {HIGHLIGH_COLOR_3D, CHANNEL_SCALES} from 'constants/default-settings';\nimport {LAYER_VIS_CONFIGS} from 'layers/layer-factory';\nimport {createDataContainer} from 'utils/table-utils';\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}) => dc => d => 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: {\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  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 = dataContainer => S2TokenAccessor(this.config.columns)(dataContainer);\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    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 = {}) {\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({dataContainer, filteredIndex}, getS2Token) {\n    const data = [];\n    for (let i = 0; i < filteredIndex.length; i++) {\n      const index = filteredIndex[i];\n      const token = getS2Token({index});\n\n      if (token) {\n        data.push({\n          index,\n          token\n        });\n      }\n    }\n    return data;\n  }\n\n  updateLayerMeta(dataContainer, getS2Token) {\n    // add safe row flag\n    const centroids = dataContainer.reduce(\n      (acc, entry, index) => {\n        const s2Token = getS2Token({index});\n        if (s2Token) {\n          acc.push(getS2Center(s2Token));\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, opt = {}) {\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 => 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"]}