UNPKG

kepler.gl

Version:

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

209 lines (174 loc) 22.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.lineVisConfigs = exports.lineColumnLabels = exports.lineOptionalColumns = exports.lineRequiredColumns = exports.linePosAccessor = 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 _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 _extensions = require("@deck.gl/extensions"); var _layerFactory = require("../layer-factory"); var _lineLayerIcon = _interopRequireDefault(require("./line-layer-icon")); var _arcLayer = _interopRequireDefault(require("../arc-layer/arc-layer")); var _lineLayer = _interopRequireDefault(require("../../deckgl-layers/line-layer/line-layer")); 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 linePosAccessor = function linePosAccessor(_ref) { var lat0 = _ref.lat0, lng0 = _ref.lng0, lat1 = _ref.lat1, lng1 = _ref.lng1, alt0 = _ref.alt0, alt1 = _ref.alt1; return function (dc) { return function (d) { return [dc.valueAt(d.index, lng0.fieldIdx), dc.valueAt(d.index, lat0.fieldIdx), (alt0 === null || alt0 === void 0 ? void 0 : alt0.fieldIdx) > -1 ? dc.valueAt(d.index, alt0.fieldIdx) : 0, dc.valueAt(d.index, lng1.fieldIdx), dc.valueAt(d.index, lat1.fieldIdx), (alt1 === null || alt1 === void 0 ? void 0 : alt1.fieldIdx) > -1 ? dc.valueAt(d.index, alt1.fieldIdx) : 0]; }; }; }; exports.linePosAccessor = linePosAccessor; var lineRequiredColumns = ['lat0', 'lng0', 'lat1', 'lng1']; exports.lineRequiredColumns = lineRequiredColumns; var lineOptionalColumns = ['alt0', 'alt1']; exports.lineOptionalColumns = lineOptionalColumns; var lineColumnLabels = { lat0: 'arc.lat0', lng0: 'arc.lng0', lat1: 'arc.lat1', lng1: 'arc.lng1', alt0: 'line.alt0', alt1: 'line.alt1' }; exports.lineColumnLabels = lineColumnLabels; var lineVisConfigs = { opacity: 'opacity', thickness: 'thickness', colorRange: 'colorRange', sizeRange: 'strokeWidthRange', targetColor: 'targetColor', elevationScale: _objectSpread(_objectSpread({}, _layerFactory.LAYER_VIS_CONFIGS.elevationScale), {}, { defaultValue: 1 }) }; exports.lineVisConfigs = lineVisConfigs; var LineLayer = /*#__PURE__*/function (_ArcLayer) { (0, _inherits2["default"])(LineLayer, _ArcLayer); var _super = _createSuper(LineLayer); function LineLayer(props) { var _this; (0, _classCallCheck2["default"])(this, LineLayer); _this = _super.call(this, props); _this.registerVisConfig(lineVisConfigs); _this.getPositionAccessor = function (dataContainer) { return linePosAccessor(_this.config.columns)(dataContainer); }; return _this; } (0, _createClass2["default"])(LineLayer, [{ key: "type", get: function get() { return 'line'; } }, { key: "layerIcon", get: function get() { return _lineLayerIcon["default"]; } }, { key: "requiredLayerColumns", get: function get() { return lineRequiredColumns; } }, { key: "optionalColumns", get: function get() { return lineOptionalColumns; } }, { key: "columnLabels", get: function get() { return lineColumnLabels; } }, { key: "visualChannels", get: function get() { var visualChannels = (0, _get2["default"])((0, _getPrototypeOf2["default"])(LineLayer.prototype), "visualChannels", this); return _objectSpread(_objectSpread({}, visualChannels), {}, { sourceColor: _objectSpread(_objectSpread({}, visualChannels.sourceColor), {}, { accessor: 'getColor' }) }); } }, { key: "renderLayer", value: function renderLayer(opts) { var data = opts.data, gpuFilter = opts.gpuFilter, objectHovered = opts.objectHovered, interactionConfig = opts.interactionConfig; var layerProps = { widthScale: this.config.visConfig.thickness, elevationScale: this.config.visConfig.elevationScale }; var updateTriggers = _objectSpread({ getPosition: this.config.columns, getFilterValue: gpuFilter.filterValueUpdateTriggers }, this.getVisualChannelUpdateTriggers()); var defaultLayerProps = this.getDefaultDeckLayerProps(opts); var hoveredObject = this.hasHoveredObject(objectHovered); return [// base layer new _lineLayer["default"](_objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, defaultLayerProps), this.getBrushingExtensionProps(interactionConfig, 'source_target')), data), layerProps), {}, { updateTriggers: updateTriggers, extensions: [].concat((0, _toConsumableArray2["default"])(defaultLayerProps.extensions), [new _extensions.BrushingExtension()]) }))].concat((0, _toConsumableArray2["default"])(hoveredObject ? [new _lineLayer["default"](_objectSpread(_objectSpread(_objectSpread({}, this.getDefaultHoverLayerProps()), layerProps), {}, { data: [hoveredObject], getColor: this.config.highlightColor, getTargetColor: this.config.highlightColor, getWidth: data.getWidth }))] : [])); } }], [{ key: "findDefaultLayerProps", value: function findDefaultLayerProps(_ref2) { var _ref2$fieldPairs = _ref2.fieldPairs, fieldPairs = _ref2$fieldPairs === void 0 ? [] : _ref2$fieldPairs; if (fieldPairs.length < 2) { return { props: [] }; } var props = {}; // connect the first two point layer with line props.columns = { lat0: fieldPairs[0].pair.lat, lng0: fieldPairs[0].pair.lng, alt0: { value: null, fieldIdx: -1, optional: true }, lat1: fieldPairs[1].pair.lat, lng1: fieldPairs[1].pair.lng, alt1: { value: null, fieldIdx: -1, optional: true } }; props.label = "".concat(fieldPairs[0].defaultName, " -> ").concat(fieldPairs[1].defaultName, " line"); return { props: [props] }; } }]); return LineLayer; }(_arcLayer["default"]); exports["default"] = LineLayer; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/line-layer/line-layer.js"],"names":["linePosAccessor","lat0","lng0","lat1","lng1","alt0","alt1","dc","d","valueAt","index","fieldIdx","lineRequiredColumns","lineOptionalColumns","lineColumnLabels","lineVisConfigs","opacity","thickness","colorRange","sizeRange","targetColor","elevationScale","LAYER_VIS_CONFIGS","defaultValue","LineLayer","props","registerVisConfig","getPositionAccessor","dataContainer","config","columns","LineLayerIcon","visualChannels","sourceColor","accessor","opts","data","gpuFilter","objectHovered","interactionConfig","layerProps","widthScale","visConfig","updateTriggers","getPosition","getFilterValue","filterValueUpdateTriggers","getVisualChannelUpdateTriggers","defaultLayerProps","getDefaultDeckLayerProps","hoveredObject","hasHoveredObject","EnhancedLineLayer","getBrushingExtensionProps","extensions","BrushingExtension","getDefaultHoverLayerProps","getColor","highlightColor","getTargetColor","getWidth","fieldPairs","length","pair","lat","lng","value","optional","label","defaultName","ArcLayer"],"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 {BrushingExtension} from '@deck.gl/extensions';\n\nimport {LAYER_VIS_CONFIGS} from 'layers/layer-factory';\nimport LineLayerIcon from './line-layer-icon';\nimport ArcLayer from '../arc-layer/arc-layer';\nimport EnhancedLineLayer from 'deckgl-layers/line-layer/line-layer';\n\nexport const linePosAccessor = ({lat0, lng0, lat1, lng1, alt0, alt1}) => dc => d => [\n  dc.valueAt(d.index, lng0.fieldIdx),\n  dc.valueAt(d.index, lat0.fieldIdx),\n  alt0?.fieldIdx > -1 ? dc.valueAt(d.index, alt0.fieldIdx) : 0,\n  dc.valueAt(d.index, lng1.fieldIdx),\n  dc.valueAt(d.index, lat1.fieldIdx),\n  alt1?.fieldIdx > -1 ? dc.valueAt(d.index, alt1.fieldIdx) : 0\n];\n\nexport const lineRequiredColumns = ['lat0', 'lng0', 'lat1', 'lng1'];\nexport const lineOptionalColumns = ['alt0', 'alt1'];\n\nexport const lineColumnLabels = {\n  lat0: 'arc.lat0',\n  lng0: 'arc.lng0',\n  lat1: 'arc.lat1',\n  lng1: 'arc.lng1',\n  alt0: 'line.alt0',\n  alt1: 'line.alt1'\n};\n\nexport const lineVisConfigs = {\n  opacity: 'opacity',\n  thickness: 'thickness',\n  colorRange: 'colorRange',\n  sizeRange: 'strokeWidthRange',\n  targetColor: 'targetColor',\n  elevationScale: {\n    ...LAYER_VIS_CONFIGS.elevationScale,\n    defaultValue: 1\n  }\n};\n\nexport default class LineLayer extends ArcLayer {\n  constructor(props) {\n    super(props);\n\n    this.registerVisConfig(lineVisConfigs);\n    this.getPositionAccessor = dataContainer => linePosAccessor(this.config.columns)(dataContainer);\n  }\n\n  get type() {\n    return 'line';\n  }\n\n  get layerIcon() {\n    return LineLayerIcon;\n  }\n\n  get requiredLayerColumns() {\n    return lineRequiredColumns;\n  }\n\n  get optionalColumns() {\n    return lineOptionalColumns;\n  }\n\n  get columnLabels() {\n    return lineColumnLabels;\n  }\n\n  get visualChannels() {\n    const visualChannels = super.visualChannels;\n    return {\n      ...visualChannels,\n      sourceColor: {\n        ...visualChannels.sourceColor,\n        accessor: 'getColor'\n      }\n    };\n  }\n\n  static findDefaultLayerProps({fieldPairs = []}) {\n    if (fieldPairs.length < 2) {\n      return {props: []};\n    }\n    const props = {};\n\n    // connect the first two point layer with line\n    props.columns = {\n      lat0: fieldPairs[0].pair.lat,\n      lng0: fieldPairs[0].pair.lng,\n      alt0: {value: null, fieldIdx: -1, optional: true},\n      lat1: fieldPairs[1].pair.lat,\n      lng1: fieldPairs[1].pair.lng,\n      alt1: {value: null, fieldIdx: -1, optional: true}\n    };\n    props.label = `${fieldPairs[0].defaultName} -> ${fieldPairs[1].defaultName} line`;\n\n    return {props: [props]};\n  }\n\n  renderLayer(opts) {\n    const {data, gpuFilter, objectHovered, interactionConfig} = opts;\n\n    const layerProps = {\n      widthScale: this.config.visConfig.thickness,\n      elevationScale: this.config.visConfig.elevationScale\n    };\n\n    const updateTriggers = {\n      getPosition: this.config.columns,\n      getFilterValue: gpuFilter.filterValueUpdateTriggers,\n      ...this.getVisualChannelUpdateTriggers()\n    };\n    const defaultLayerProps = this.getDefaultDeckLayerProps(opts);\n    const hoveredObject = this.hasHoveredObject(objectHovered);\n\n    return [\n      // base layer\n      new EnhancedLineLayer({\n        ...defaultLayerProps,\n        ...this.getBrushingExtensionProps(interactionConfig, 'source_target'),\n        ...data,\n        ...layerProps,\n        updateTriggers,\n        extensions: [...defaultLayerProps.extensions, new BrushingExtension()]\n      }),\n      // hover layer\n      ...(hoveredObject\n        ? [\n            new EnhancedLineLayer({\n              ...this.getDefaultHoverLayerProps(),\n              ...layerProps,\n              data: [hoveredObject],\n              getColor: this.config.highlightColor,\n              getTargetColor: this.config.highlightColor,\n              getWidth: data.getWidth\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}