kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
296 lines (254 loc) • 32.1 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.arcVisConfigs = exports.arcColumnLabels = exports.arcRequiredColumns = exports.arcPosAccessor = 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 _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _baseLayer = _interopRequireDefault(require("../base-layer"));
var _extensions = require("@deck.gl/extensions");
var _layers = require("@deck.gl/layers");
var _colorUtils = require("../../utils/color-utils");
var _arcLayerIcon = _interopRequireDefault(require("./arc-layer-icon"));
var _defaultSettings = require("../../constants/default-settings");
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 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];
};
};
exports.arcPosAccessor = arcPosAccessor;
var arcRequiredColumns = ['lat0', 'lng0', 'lat1', 'lng1'];
exports.arcRequiredColumns = arcRequiredColumns;
var arcColumnLabels = {
lat0: 'arc.lat0',
lng0: 'arc.lng0',
lat1: 'arc.lat1',
lng1: 'arc.lng1'
};
exports.arcColumnLabels = arcColumnLabels;
var arcVisConfigs = {
opacity: 'opacity',
thickness: 'thickness',
colorRange: 'colorRange',
sizeRange: 'strokeWidthRange',
targetColor: 'targetColor'
};
exports.arcVisConfigs = arcVisConfigs;
var ArcLayer =
/*#__PURE__*/
function (_Layer) {
(0, _inherits2["default"])(ArcLayer, _Layer);
function ArcLayer(props) {
var _this;
(0, _classCallCheck2["default"])(this, ArcLayer);
_this = (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(ArcLayer).call(this, props));
_this.registerVisConfig(arcVisConfigs);
_this.getPositionAccessor = function () {
return arcPosAccessor(_this.config.columns);
};
return _this;
}
(0, _createClass2["default"])(ArcLayer, [{
key: "calculateDataAttribute",
value: function calculateDataAttribute(_ref2, getPosition) {
var allData = _ref2.allData,
filteredIndex = _ref2.filteredIndex;
var data = [];
for (var i = 0; i < filteredIndex.length; i++) {
// data = filteredIndex.reduce((accu, index) => {
var index = filteredIndex[i];
var pos = getPosition({
data: allData[index]
}); // if doesn't have point lat or lng, do not add the point
// deck.gl can't handle position = null
if (pos.every(Number.isFinite)) {
data.push({
index: index,
sourcePosition: [pos[0], pos[1], pos[2]],
targetPosition: [pos[3], pos[4], pos[5]],
data: allData[index]
});
}
}
return data;
} // TODO: fix complexity
/* eslint-disable complexity */
}, {
key: "formatLayerData",
value: function formatLayerData(datasets, oldLayerData) {
var _this2 = this;
var opt = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var _this$config = this.config,
colorScale = _this$config.colorScale,
colorDomain = _this$config.colorDomain,
colorField = _this$config.colorField,
color = _this$config.color,
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;
var gpuFilter = datasets[this.config.dataId].gpuFilter;
var _this$updateData = this.updateData(datasets, oldLayerData),
data = _this$updateData.data; // 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 getStrokeWidth = sScale ? function (d) {
return _this2.getEncodedChannelValue(sScale, d.data, sizeField, 0);
} : 1;
var getSourceColor = 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,
getSourceColor: getSourceColor,
getTargetColor: getTargetColor,
getWidth: getStrokeWidth,
getFilterValue: gpuFilter.filterValueAccessor()
};
}
/* eslint-enable complexity */
}, {
key: "updateLayerMeta",
value: function updateLayerMeta(allData) {
// get bounds from arcs
var getPosition = this.getPositionAccessor();
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(opts) {
var data = opts.data,
gpuFilter = opts.gpuFilter,
objectHovered = opts.objectHovered,
interactionConfig = opts.interactionConfig;
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 [new _layers.ArcLayer(_objectSpread({}, defaultLayerProps, {}, this.getBrushingExtensionProps(interactionConfig, 'source_target'), {}, data, {
widthScale: this.config.visConfig.thickness,
updateTriggers: {
getFilterValue: gpuFilter.filterValueUpdateTriggers,
getWidth: {
sizeField: this.config.sizeField,
sizeScale: this.config.sizeScale,
sizeRange: this.config.visConfig.sizeRange
},
getSourceColor: colorUpdateTriggers,
getTargetColor: colorUpdateTriggers
},
extensions: [].concat((0, _toConsumableArray2["default"])(defaultLayerProps.extensions), [new _extensions.BrushingExtension()])
}))].concat((0, _toConsumableArray2["default"])(this.isLayerHovered(objectHovered) ? [new _layers.ArcLayer(_objectSpread({}, this.getDefaultHoverLayerProps(), {
data: [objectHovered.object],
widthScale: this.config.visConfig.thickness,
getSourceColor: this.config.highlightColor,
getTargetColor: this.config.highlightColor,
getWidth: data.getWidth
}))] : []));
}
}, {
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: "columnLabels",
get: function get() {
return arcColumnLabels;
}
}, {
key: "columnPairs",
get: function get() {
return this.defaultLinkColumnPairs;
}
}, {
key: "visualChannels",
get: function get() {
return _objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(ArcLayer.prototype), "visualChannels", this), {
size: _objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(ArcLayer.prototype), "visualChannels", this).size, {
property: 'stroke'
})
});
}
}], [{
key: "findDefaultLayerProps",
value: function findDefaultLayerProps(_ref3) {
var _ref3$fieldPairs = _ref3.fieldPairs,
fieldPairs = _ref3$fieldPairs === void 0 ? [] : _ref3$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"]);
exports["default"] = ArcLayer;
//# 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","arcRequiredColumns","arcColumnLabels","arcVisConfigs","opacity","thickness","colorRange","sizeRange","targetColor","ArcLayer","props","registerVisConfig","getPositionAccessor","config","columns","getPosition","allData","filteredIndex","i","length","index","pos","every","Number","isFinite","push","sourcePosition","targetPosition","datasets","oldLayerData","opt","colorScale","colorDomain","colorField","color","sizeField","sizeScale","sizeDomain","visConfig","gpuFilter","dataId","updateData","cScale","getVisChannelScale","colors","map","hexToRgb","sScale","getStrokeWidth","getEncodedChannelValue","getSourceColor","getTargetColor","getWidth","getFilterValue","filterValueAccessor","sBounds","getPointsBounds","tBounds","bounds","Math","min","max","updateMeta","opts","objectHovered","interactionConfig","colorUpdateTriggers","defaultLayerProps","getDefaultDeckLayerProps","DeckArcLayer","getBrushingExtensionProps","widthScale","updateTriggers","filterValueUpdateTriggers","extensions","BrushingExtension","isLayerHovered","getDefaultHoverLayerProps","object","highlightColor","ArcLayerIcon","defaultLinkColumnPairs","size","property","fieldPairs","DEFAULT_LAYER_COLOR","tripArc","pair","lat","lng","label","defaultName","Layer"],"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 Layer from '../base-layer';\nimport {BrushingExtension} from '@deck.gl/extensions';\nimport {ArcLayer as DeckArcLayer} from '@deck.gl/layers';\n\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 arcRequiredColumns = ['lat0', 'lng0', 'lat1', 'lng1'];\nexport const arcColumnLabels = {\n  lat0: 'arc.lat0',\n  lng0: 'arc.lng0',\n  lat1: 'arc.lat1',\n  lng1: 'arc.lng1'\n};\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\n    this.registerVisConfig(arcVisConfigs);\n    this.getPositionAccessor = () => arcPosAccessor(this.config.columns);\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 columnLabels() {\n    return arcColumnLabels;\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  calculateDataAttribute({allData, filteredIndex}, getPosition) {\n    const data = [];\n    for (let i = 0; i < filteredIndex.length; i++) {\n      // data = filteredIndex.reduce((accu, index) => {\n      const index = filteredIndex[i];\n      const pos = getPosition({data: allData[index]});\n\n      // if doesn't have point lat or lng, do not add the point\n      // deck.gl can't handle position = null\n      if (pos.every(Number.isFinite)) {\n        data.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    }\n\n    return data;\n  }\n\n  // TODO: fix complexity\n  /* eslint-disable complexity */\n  formatLayerData(datasets, oldLayerData, opt = {}) {\n    const {\n      colorScale,\n      colorDomain,\n      colorField,\n      color,\n      sizeField,\n      sizeScale,\n      sizeDomain,\n      visConfig: {sizeRange, colorRange, targetColor}\n    } = this.config;\n\n    const {gpuFilter} = datasets[this.config.dataId];\n    const {data} = this.updateData(datasets, oldLayerData);\n\n    // arc color\n    const cScale =\n      colorField &&\n      this.getVisChannelScale(colorScale, colorDomain, colorRange.colors.map(hexToRgb));\n\n    // arc thickness\n    const sScale = sizeField && this.getVisChannelScale(sizeScale, sizeDomain, sizeRange);\n\n    const getStrokeWidth = sScale\n      ? d => this.getEncodedChannelValue(sScale, d.data, sizeField, 0)\n      : 1;\n\n    const getSourceColor = 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      getSourceColor,\n      getTargetColor,\n      getWidth: getStrokeWidth,\n      getFilterValue: gpuFilter.filterValueAccessor()\n    };\n  }\n  /* eslint-enable complexity */\n\n  updateLayerMeta(allData) {\n    // get bounds from arcs\n    const getPosition = this.getPositionAccessor();\n\n    const sBounds = this.getPointsBounds(allData, d => {\n      const pos = getPosition({data: d});\n      return [pos[0], pos[1]];\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(opts) {\n    const {data, gpuFilter, objectHovered, interactionConfig} = opts;\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\n    return [\n      new DeckArcLayer({\n        ...defaultLayerProps,\n        ...this.getBrushingExtensionProps(interactionConfig, 'source_target'),\n        ...data,\n        widthScale: this.config.visConfig.thickness,\n        updateTriggers: {\n          getFilterValue: gpuFilter.filterValueUpdateTriggers,\n          getWidth: {\n            sizeField: this.config.sizeField,\n            sizeScale: this.config.sizeScale,\n            sizeRange: this.config.visConfig.sizeRange\n          },\n          getSourceColor: colorUpdateTriggers,\n          getTargetColor: colorUpdateTriggers\n        },\n        extensions: [...defaultLayerProps.extensions, new BrushingExtension()]\n      }),\n      // hover layer\n      ...(this.isLayerHovered(objectHovered)\n        ? [\n            new DeckArcLayer({\n              ...this.getDefaultHoverLayerProps(),\n              data: [objectHovered.object],\n              widthScale: this.config.visConfig.thickness,\n              getSourceColor: this.config.highlightColor,\n              getTargetColor: this.config.highlightColor,\n              getWidth: data.getWidth\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}