UNPKG

kepler.gl

Version:

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

125 lines (103 loc) 14.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); 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 _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _extensions = require("@deck.gl/extensions"); 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 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 LineLayer = /*#__PURE__*/ function (_ArcLayer) { (0, _inherits2["default"])(LineLayer, _ArcLayer); function LineLayer() { (0, _classCallCheck2["default"])(this, LineLayer); return (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(LineLayer).apply(this, arguments)); } (0, _createClass2["default"])(LineLayer, [{ 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 }; var colorUpdateTriggers = { color: this.config.color, colorField: this.config.colorField, colorRange: this.config.visConfig.colorRange, colorScale: this.config.colorScale, targetColor: this.config.visConfig.targetColor }; var defaultLayerProps = this.getDefaultDeckLayerProps(opts); return [// base layer new _lineLayer["default"](_objectSpread({}, defaultLayerProps, {}, this.getBrushingExtensionProps(interactionConfig, 'source_target'), {}, data, {}, layerProps, { getColor: data.getSourceColor, updateTriggers: { getFilterValue: gpuFilter.filterValueUpdateTriggers, getWidth: { sizeField: this.config.sizeField, sizeRange: this.config.visConfig.sizeRange, sizeScale: this.config.sizeScale }, getColor: colorUpdateTriggers, getTargetColor: colorUpdateTriggers }, extensions: [].concat((0, _toConsumableArray2["default"])(defaultLayerProps.extensions), [new _extensions.BrushingExtension()]) }))].concat((0, _toConsumableArray2["default"])(this.isLayerHovered(objectHovered) ? [new _lineLayer["default"](_objectSpread({}, this.getDefaultHoverLayerProps(), {}, layerProps, { data: [objectHovered.object], getColor: this.config.highlightColor, getTargetColor: this.config.highlightColor, getWidth: data.getWidth }))] : [])); } }, { key: "type", get: function get() { return 'line'; } }, { key: "layerIcon", get: function get() { return _lineLayerIcon["default"]; } }], [{ key: "findDefaultLayerProps", value: function findDefaultLayerProps(_ref) { var _ref$fieldPairs = _ref.fieldPairs, fieldPairs = _ref$fieldPairs === void 0 ? [] : _ref$fieldPairs; if (fieldPairs.length < 2) { return { props: [] }; } var props = {}; // connect the first two point layer with arc props.columns = { lat0: fieldPairs[0].pair.lat, lng0: fieldPairs[0].pair.lng, lat1: fieldPairs[1].pair.lat, lng1: fieldPairs[1].pair.lng }; 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":["LineLayer","opts","data","gpuFilter","objectHovered","interactionConfig","layerProps","widthScale","config","visConfig","thickness","colorUpdateTriggers","color","colorField","colorRange","colorScale","targetColor","defaultLayerProps","getDefaultDeckLayerProps","EnhancedLineLayer","getBrushingExtensionProps","getColor","getSourceColor","updateTriggers","getFilterValue","filterValueUpdateTriggers","getWidth","sizeField","sizeRange","sizeScale","getTargetColor","extensions","BrushingExtension","isLayerHovered","getDefaultHoverLayerProps","object","highlightColor","LineLayerIcon","fieldPairs","length","props","columns","lat0","pair","lat","lng0","lng","lat1","lng1","label","defaultName","ArcLayer"],"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 {BrushingExtension} from '@deck.gl/extensions';\n\nimport LineLayerIcon from './line-layer-icon';\nimport ArcLayer from '../arc-layer/arc-layer';\nimport EnhancedLineLayer from 'deckgl-layers/line-layer/line-layer';\n\nexport default class LineLayer extends ArcLayer {\n  get type() {\n    return 'line';\n  }\n\n  get layerIcon() {\n    return LineLayerIcon;\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 arc\n    props.columns = {\n      lat0: fieldPairs[0].pair.lat,\n      lng0: fieldPairs[0].pair.lng,\n      lat1: fieldPairs[1].pair.lat,\n      lng1: fieldPairs[1].pair.lng\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    };\n\n    const colorUpdateTriggers = {\n      color: this.config.color,\n      colorField: this.config.colorField,\n      colorRange: this.config.visConfig.colorRange,\n      colorScale: this.config.colorScale,\n      targetColor: this.config.visConfig.targetColor\n    };\n\n    const defaultLayerProps = this.getDefaultDeckLayerProps(opts);\n    return [\n      // base layer\n      new EnhancedLineLayer({\n        ...defaultLayerProps,\n        ...this.getBrushingExtensionProps(interactionConfig, 'source_target'),\n        ...data,\n        ...layerProps,\n        getColor: data.getSourceColor,\n        updateTriggers: {\n          getFilterValue: gpuFilter.filterValueUpdateTriggers,\n          getWidth: {\n            sizeField: this.config.sizeField,\n            sizeRange: this.config.visConfig.sizeRange,\n            sizeScale: this.config.sizeScale\n          },\n          getColor: colorUpdateTriggers,\n          getTargetColor: colorUpdateTriggers\n        },\n        extensions: [...defaultLayerProps.extensions, new BrushingExtension()]\n      }),\n      // hover layer\n      ...(this.isLayerHovered(objectHovered)\n        ? [\n            new EnhancedLineLayer({\n              ...this.getDefaultHoverLayerProps(),\n              ...layerProps,\n              data: [objectHovered.object],\n              getColor: this.config.highlightColor,\n              getTargetColor: this.config.highlightColor,\n              getWidth: data.getWidth\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}