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