kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
143 lines (120 loc) • 15.9 kB
JavaScript
;
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 _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _arcLayer = _interopRequireDefault(require("../arc-layer/arc-layer"));
var _lineLayer = _interopRequireDefault(require("../../deckgl-layers/line-layer/line-layer"));
var _lineLayerIcon = _interopRequireDefault(require("./line-layer-icon"));
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
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; } }
var LineLayer = exports["default"] = /*#__PURE__*/function (_ArcLayer) {
(0, _inherits2["default"])(LineLayer, _ArcLayer);
var _super = _createSuper(LineLayer);
function LineLayer() {
(0, _classCallCheck2["default"])(this, LineLayer);
return _super.apply(this, arguments);
}
(0, _createClass2["default"])(LineLayer, [{
key: "type",
get: function get() {
return 'line';
}
}, {
key: "layerIcon",
get: function get() {
return _lineLayerIcon["default"];
}
}, {
key: "renderLayer",
value: function renderLayer(_ref) {
var data = _ref.data,
idx = _ref.idx,
layerInteraction = _ref.layerInteraction,
objectHovered = _ref.objectHovered,
mapState = _ref.mapState,
interactionConfig = _ref.interactionConfig;
var brush = interactionConfig.brush;
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 interaction = {
// auto highlighting
pickable: true,
autoHighlight: !brush.enabled,
highlightColor: this.config.highlightColor,
// brushing
brushRadius: brush.config.size * 1000,
brushSource: true,
brushTarget: true,
enableBrushing: brush.enabled
};
return [// base layer
new _lineLayer["default"](_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, layerInteraction), data), interaction), {}, {
getColor: data.getSourceColor,
id: this.id,
idx: idx,
opacity: this.config.visConfig.opacity,
strokeScale: this.config.visConfig.thickness,
// parameters
parameters: {
depthTest: mapState.dragRotate
},
updateTriggers: {
getWidth: {
sizeField: this.config.sizeField,
sizeRange: this.config.visConfig.sizeRange
},
getColor: colorUpdateTriggers,
getTargetColor: colorUpdateTriggers
}
}))].concat((0, _toConsumableArray2["default"])(this.isLayerHovered(objectHovered) ? [new _lineLayer["default"]({
id: "".concat(this.id, "-hovered"),
data: [objectHovered.object],
strokeScale: this.config.visConfig.thickness,
getColor: this.config.highlightColor,
getTargetColor: this.config.highlightColor,
getWidth: data.getWidth,
pickable: false
})] : []));
}
}], [{
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 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"]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/line-layer/line-layer.js"],"names":["LineLayer","LineLayerIcon","data","idx","layerInteraction","objectHovered","mapState","interactionConfig","brush","colorUpdateTriggers","color","config","colorField","colorRange","visConfig","colorScale","targetColor","interaction","pickable","autoHighlight","enabled","highlightColor","brushRadius","size","brushSource","brushTarget","enableBrushing","DeckGLLineLayer","getColor","getSourceColor","id","opacity","strokeScale","thickness","parameters","depthTest","dragRotate","updateTriggers","getWidth","sizeField","sizeRange","getTargetColor","isLayerHovered","object","fieldPairs","length","props","columns","lat0","pair","lat","lng0","lng","lat1","lng1","label","defaultName","ArcLayer"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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 ArcLayer from '../arc-layer/arc-layer';\nimport DeckGLLineLayer from 'deckgl-layers/line-layer/line-layer';\nimport LineLayerIcon from './line-layer-icon';\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} -> ${\n      fieldPairs[1].defaultName\n    } line`;\n\n    return {props: [props]};\n  }\n\n  renderLayer({\n    data,\n    idx,\n    layerInteraction,\n    objectHovered,\n    mapState,\n    interactionConfig\n  }) {\n    const {brush} = interactionConfig;\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 interaction = {\n      // auto highlighting\n      pickable: true,\n      autoHighlight: !brush.enabled,\n      highlightColor: this.config.highlightColor,\n\n      // brushing\n      brushRadius: brush.config.size * 1000,\n      brushSource: true,\n      brushTarget: true,\n      enableBrushing: brush.enabled\n    };\n\n    return [\n      // base layer\n      new DeckGLLineLayer({\n        ...layerInteraction,\n        ...data,\n        ...interaction,\n        getColor: data.getSourceColor,\n        id: this.id,\n        idx,\n        opacity: this.config.visConfig.opacity,\n        strokeScale: this.config.visConfig.thickness,\n        // parameters\n        parameters: {depthTest: mapState.dragRotate},\n        updateTriggers: {\n          getWidth: {\n            sizeField: this.config.sizeField,\n            sizeRange: this.config.visConfig.sizeRange\n          },\n          getColor: colorUpdateTriggers,\n          getTargetColor: colorUpdateTriggers\n        }\n      }),\n      // hover layer\n      ...(this.isLayerHovered(objectHovered)\n        ? [\n            new DeckGLLineLayer({\n              id: `${this.id}-hovered`,\n              data: [objectHovered.object],\n              strokeScale: this.config.visConfig.thickness,\n              getColor: this.config.highlightColor,\n              getTargetColor: this.config.highlightColor,\n              getWidth: data.getWidth,\n              pickable: false\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}