kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
307 lines (263 loc) • 34.4 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.arcVisConfigs = exports.arcRequiredColumns = exports.arcPosResolver = exports.arcPosAccessor = void 0;
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
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 _lodash = _interopRequireDefault(require("lodash.memoize"));
var _baseLayer = _interopRequireDefault(require("../base-layer"));
var _arcBrushingLayer = _interopRequireDefault(require("../../deckgl-layers/arc-brushing-layer/arc-brushing-layer"));
var _colorUtils = require("../../utils/color-utils");
var _arcLayerIcon = _interopRequireDefault(require("./arc-layer-icon"));
var _defaultSettings = require("../../constants/default-settings");
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 arcPosAccessor = exports.arcPosAccessor = function arcPosAccessor(_ref) {
var lat0 = _ref.lat0,
lng0 = _ref.lng0,
lat1 = _ref.lat1,
lng1 = _ref.lng1;
return function (d) {
return [d.data[lng0.fieldIdx], d.data[lat0.fieldIdx], 0, d.data[lng1.fieldIdx], d.data[lat1.fieldIdx], 0];
};
};
var arcPosResolver = exports.arcPosResolver = function arcPosResolver(_ref2) {
var lat0 = _ref2.lat0,
lng0 = _ref2.lng0,
lat1 = _ref2.lat1,
lng1 = _ref2.lng1;
return "".concat(lat0.fieldIdx, "-").concat(lng0.fieldIdx, "-").concat(lat1.fieldIdx, "-").concat(lat1.fieldIdx, "}");
};
var arcRequiredColumns = exports.arcRequiredColumns = ['lat0', 'lng0', 'lat1', 'lng1'];
var arcVisConfigs = exports.arcVisConfigs = {
opacity: 'opacity',
thickness: 'thickness',
colorRange: 'colorRange',
sizeRange: 'strokeWidthRange',
targetColor: 'targetColor'
};
var ArcLayer = exports["default"] = /*#__PURE__*/function (_Layer) {
(0, _inherits2["default"])(ArcLayer, _Layer);
var _super = _createSuper(ArcLayer);
function ArcLayer(props) {
var _this;
(0, _classCallCheck2["default"])(this, ArcLayer);
_this = _super.call(this, props);
_this.registerVisConfig(arcVisConfigs);
_this.getPosition = (0, _lodash["default"])(arcPosAccessor, arcPosResolver);
return _this;
}
(0, _createClass2["default"])(ArcLayer, [{
key: "type",
get: function get() {
return 'arc';
}
}, {
key: "isAggregated",
get: function get() {
return false;
}
}, {
key: "layerIcon",
get: function get() {
return _arcLayerIcon["default"];
}
}, {
key: "requiredLayerColumns",
get: function get() {
return arcRequiredColumns;
}
}, {
key: "columnPairs",
get: function get() {
return this.defaultLinkColumnPairs;
}
}, {
key: "visualChannels",
get: function get() {
return _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(ArcLayer.prototype), "visualChannels", this)), {}, {
size: _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(ArcLayer.prototype), "visualChannels", this).size), {}, {
property: 'stroke'
})
});
}
}, {
key: "formatLayerData",
value: // TODO: fix complexity
/* eslint-disable complexity */
function formatLayerData(_, allData, filteredIndex, oldLayerData) {
var _this2 = this;
var opt = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
var _this$config = this.config,
colorScale = _this$config.colorScale,
colorDomain = _this$config.colorDomain,
colorField = _this$config.colorField,
color = _this$config.color,
columns = _this$config.columns,
sizeField = _this$config.sizeField,
sizeScale = _this$config.sizeScale,
sizeDomain = _this$config.sizeDomain,
_this$config$visConfi = _this$config.visConfig,
sizeRange = _this$config$visConfi.sizeRange,
colorRange = _this$config$visConfi.colorRange,
targetColor = _this$config$visConfi.targetColor; // arc color
var cScale = colorField && this.getVisChannelScale(colorScale, colorDomain, colorRange.colors.map(_colorUtils.hexToRgb)); // arc thickness
var sScale = sizeField && this.getVisChannelScale(sizeScale, sizeDomain, sizeRange);
var getPosition = this.getPosition(columns);
if (!oldLayerData || oldLayerData.getPosition !== getPosition) {
this.updateLayerMeta(allData, getPosition);
}
var data;
if (oldLayerData && oldLayerData.data && opt.sameData && oldLayerData.getPosition === getPosition) {
data = oldLayerData.data;
} else {
data = filteredIndex.reduce(function (accu, index) {
var pos = getPosition({
data: allData[index]
}); // if doesn't have point lat or lng, do not add the arc
// deck.gl can't handle position == null
if (!pos.every(Number.isFinite)) {
return accu;
}
accu.push({
index: index,
sourcePosition: [pos[0], pos[1], pos[2]],
targetPosition: [pos[3], pos[4], pos[5]],
data: allData[index]
});
return accu;
}, []);
}
var getStrokeWidth = sScale ? function (d) {
return _this2.getEncodedChannelValue(sScale, d.data, sizeField, 0);
} : 1;
var getColor = cScale ? function (d) {
return _this2.getEncodedChannelValue(cScale, d.data, colorField);
} : color;
var getTargetColor = cScale ? function (d) {
return _this2.getEncodedChannelValue(cScale, d.data, colorField);
} : targetColor || color;
return {
data: data,
getColor: getColor,
getSourceColor: getColor,
getTargetColor: getTargetColor,
getWidth: getStrokeWidth
};
}
/* eslint-enable complexity */
}, {
key: "updateLayerMeta",
value: function updateLayerMeta(allData, getPosition) {
// get bounds from arcs
var sBounds = this.getPointsBounds(allData, function (d) {
var pos = getPosition({
data: d
});
return [pos[0], pos[1]];
});
var tBounds = this.getPointsBounds(allData, function (d) {
var pos = getPosition({
data: d
});
return [pos[3], pos[4]];
});
var bounds = tBounds && sBounds ? [Math.min(sBounds[0], tBounds[0]), Math.min(sBounds[1], tBounds[1]), Math.max(sBounds[2], tBounds[2]), Math.max(sBounds[3], tBounds[3])] : sBounds || tBounds;
this.updateMeta({
bounds: bounds
});
}
}, {
key: "renderLayer",
value: function renderLayer(_ref3) {
var data = _ref3.data,
idx = _ref3.idx,
objectHovered = _ref3.objectHovered,
layerInteraction = _ref3.layerInteraction,
mapState = _ref3.mapState,
interactionConfig = _ref3.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 [new _arcBrushingLayer["default"](_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, data), interaction), layerInteraction), {}, {
id: this.id,
idx: idx,
opacity: this.config.visConfig.opacity,
pickedColor: this.config.highlightColor,
strokeScale: this.config.visConfig.thickness,
// parameters
parameters: {
depthTest: mapState.dragRotate
},
updateTriggers: {
getWidth: {
sizeField: this.config.sizeField,
sizeRange: this.config.visConfig.sizeRange
},
getSourceColor: colorUpdateTriggers,
getTargetColor: colorUpdateTriggers
}
}))].concat((0, _toConsumableArray2["default"])(this.isLayerHovered(objectHovered) ? [new _arcBrushingLayer["default"]({
id: "".concat(this.id, "-hovered"),
data: [objectHovered.object],
strokeScale: this.config.visConfig.thickness,
getSourceColor: this.config.highlightColor,
getTargetColor: this.config.highlightColor,
getWidth: data.getWidth,
pickable: false
})] : []));
}
}], [{
key: "findDefaultLayerProps",
value: function findDefaultLayerProps(_ref4) {
var _ref4$fieldPairs = _ref4.fieldPairs,
fieldPairs = _ref4$fieldPairs === void 0 ? [] : _ref4$fieldPairs;
if (fieldPairs.length < 2) {
return {
props: []
};
}
var props = {
color: (0, _colorUtils.hexToRgb)(_defaultSettings.DEFAULT_LAYER_COLOR.tripArc)
}; // 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, " arc");
return {
props: [props]
};
}
}]);
return ArcLayer;
}(_baseLayer["default"]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/arc-layer/arc-layer.js"],"names":["arcPosAccessor","lat0","lng0","lat1","lng1","d","data","fieldIdx","arcPosResolver","arcRequiredColumns","arcVisConfigs","opacity","thickness","colorRange","sizeRange","targetColor","ArcLayer","props","registerVisConfig","getPosition","ArcLayerIcon","defaultLinkColumnPairs","size","property","_","allData","filteredIndex","oldLayerData","opt","config","colorScale","colorDomain","colorField","color","columns","sizeField","sizeScale","sizeDomain","visConfig","cScale","getVisChannelScale","colors","map","hexToRgb","sScale","updateLayerMeta","sameData","reduce","accu","index","pos","every","Number","isFinite","push","sourcePosition","targetPosition","getStrokeWidth","getEncodedChannelValue","getColor","getTargetColor","getSourceColor","getWidth","sBounds","getPointsBounds","tBounds","bounds","Math","min","max","updateMeta","idx","objectHovered","layerInteraction","mapState","interactionConfig","brush","colorUpdateTriggers","interaction","pickable","autoHighlight","enabled","highlightColor","brushRadius","brushSource","brushTarget","enableBrushing","ArcBrushingLayer","id","pickedColor","strokeScale","parameters","depthTest","dragRotate","updateTriggers","isLayerHovered","object","fieldPairs","length","DEFAULT_LAYER_COLOR","tripArc","pair","lat","lng","label","defaultName","Layer"],"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 memoize from 'lodash.memoize';\n\nimport Layer from '../base-layer';\nimport ArcBrushingLayer from 'deckgl-layers/arc-brushing-layer/arc-brushing-layer';\nimport {hexToRgb} from 'utils/color-utils';\nimport ArcLayerIcon from './arc-layer-icon';\nimport {DEFAULT_LAYER_COLOR} from 'constants/default-settings';\n\nexport const arcPosAccessor = ({lat0, lng0, lat1, lng1}) => d => [\n  d.data[lng0.fieldIdx],\n  d.data[lat0.fieldIdx],\n  0,\n  d.data[lng1.fieldIdx],\n  d.data[lat1.fieldIdx],\n  0\n];\n\nexport const arcPosResolver = ({lat0, lng0, lat1, lng1}) =>\n  `${lat0.fieldIdx}-${lng0.fieldIdx}-${lat1.fieldIdx}-${lat1.fieldIdx}}`;\n\nexport const arcRequiredColumns = ['lat0', 'lng0', 'lat1', 'lng1'];\n\nexport const arcVisConfigs = {\n  opacity: 'opacity',\n  thickness: 'thickness',\n  colorRange: 'colorRange',\n  sizeRange: 'strokeWidthRange',\n  targetColor: 'targetColor'\n};\n\nexport default class ArcLayer extends Layer {\n  constructor(props) {\n    super(props);\n    this.registerVisConfig(arcVisConfigs);\n    this.getPosition = memoize(arcPosAccessor, arcPosResolver);\n  }\n\n  get type() {\n    return 'arc';\n  }\n\n  get isAggregated() {\n    return false;\n  }\n\n  get layerIcon() {\n    return ArcLayerIcon;\n  }\n\n  get requiredLayerColumns() {\n    return arcRequiredColumns;\n  }\n\n  get columnPairs() {\n    return this.defaultLinkColumnPairs;\n  }\n\n  get visualChannels() {\n    return {\n      ...super.visualChannels,\n      size: {\n        ...super.visualChannels.size,\n        property: 'stroke'\n      }\n    };\n  }\n\n  static findDefaultLayerProps({fieldPairs = []}) {\n    if (fieldPairs.length < 2) {\n      return {props: []};\n    }\n\n    const props = {\n      color: hexToRgb(DEFAULT_LAYER_COLOR.tripArc)\n    };\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} arc`;\n\n    return {props: [props]};\n  }\n\n  // TODO: fix complexity\n  /* eslint-disable complexity */\n  formatLayerData(_, allData, filteredIndex, oldLayerData, opt = {}) {\n    const {\n      colorScale,\n      colorDomain,\n      colorField,\n      color,\n      columns,\n      sizeField,\n      sizeScale,\n      sizeDomain,\n      visConfig: {sizeRange, colorRange, targetColor}\n    } = this.config;\n\n    // arc color\n    const cScale =\n      colorField &&\n      this.getVisChannelScale(\n        colorScale,\n        colorDomain,\n        colorRange.colors.map(hexToRgb)\n      );\n\n    // arc thickness\n    const sScale =\n      sizeField && this.getVisChannelScale(sizeScale, sizeDomain, sizeRange);\n\n    const getPosition = this.getPosition(columns);\n\n    if (!oldLayerData || oldLayerData.getPosition !== getPosition) {\n      this.updateLayerMeta(allData, getPosition);\n    }\n\n    let data;\n    if (\n      oldLayerData &&\n      oldLayerData.data &&\n      opt.sameData &&\n      oldLayerData.getPosition === getPosition\n    ) {\n      data = oldLayerData.data;\n    } else {\n      data = filteredIndex.reduce((accu, index) => {\n        const pos = getPosition({data: allData[index]});\n\n        // if doesn't have point lat or lng, do not add the arc\n        // deck.gl can't handle position == null\n        if (!pos.every(Number.isFinite)) {\n          return accu;\n        }\n\n        accu.push({\n          index,\n          sourcePosition: [pos[0], pos[1], pos[2]],\n          targetPosition: [pos[3], pos[4], pos[5]],\n          data: allData[index]\n        });\n\n        return accu;\n      }, []);\n    }\n\n    const getStrokeWidth = sScale\n      ? d => this.getEncodedChannelValue(sScale, d.data, sizeField, 0)\n      : 1;\n\n    const getColor = cScale\n      ? d => this.getEncodedChannelValue(cScale, d.data, colorField)\n      : color;\n\n    const getTargetColor = cScale\n      ? d => this.getEncodedChannelValue(cScale, d.data, colorField)\n      : targetColor || color;\n\n    return {\n      data,\n      getColor,\n      getSourceColor: getColor,\n      getTargetColor,\n      getWidth: getStrokeWidth\n    };\n  }\n  /* eslint-enable complexity */\n\n  updateLayerMeta(allData, getPosition) {\n    // get bounds from arcs\n    const sBounds = this.getPointsBounds(allData, d => {\n      const pos = getPosition({data: d});\n      return [pos[0], pos[1]];\n    });\n\n    const tBounds = this.getPointsBounds(allData, d => {\n      const pos = getPosition({data: d});\n      return [pos[3], pos[4]];\n    });\n\n    const bounds =\n      tBounds && sBounds\n        ? [\n            Math.min(sBounds[0], tBounds[0]),\n            Math.min(sBounds[1], tBounds[1]),\n            Math.max(sBounds[2], tBounds[2]),\n            Math.max(sBounds[3], tBounds[3])\n          ]\n        : sBounds || tBounds;\n\n    this.updateMeta({bounds});\n  }\n\n  renderLayer({\n    data,\n    idx,\n    objectHovered,\n    layerInteraction,\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      new ArcBrushingLayer({\n        ...data,\n        ...interaction,\n        ...layerInteraction,\n        id: this.id,\n        idx,\n        opacity: this.config.visConfig.opacity,\n        pickedColor: this.config.highlightColor,\n        strokeScale: this.config.visConfig.thickness,\n\n        // parameters\n        parameters: {depthTest: mapState.dragRotate},\n\n        updateTriggers: {\n          getWidth: {\n            sizeField: this.config.sizeField,\n            sizeRange: this.config.visConfig.sizeRange\n          },\n          getSourceColor: colorUpdateTriggers,\n          getTargetColor: colorUpdateTriggers\n        }\n      }),\n      // hover layer\n      ...(this.isLayerHovered(objectHovered)\n        ? [\n            new ArcBrushingLayer({\n              id: `${this.id}-hovered`,\n              data: [objectHovered.object],\n              strokeScale: this.config.visConfig.thickness,\n              getSourceColor: this.config.highlightColor,\n              getTargetColor: this.config.highlightColor,\n              getWidth: data.getWidth,\n              pickable: false\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}