kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
275 lines (233 loc) • 29.5 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 _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 _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; }
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 = function arcPosAccessor(_ref) {
var lat0 = _ref.lat0,
lng0 = _ref.lng0,
lat1 = _ref.lat1,
lng1 = _ref.lng1;
return function (dc) {
return function (d) {
return [dc.valueAt(d.index, lng0.fieldIdx), dc.valueAt(d.index, lat0.fieldIdx), 0, dc.valueAt(d.index, lng1.fieldIdx), dc.valueAt(d.index, 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);
var _super = _createSuper(ArcLayer);
function ArcLayer(props) {
var _this;
(0, _classCallCheck2["default"])(this, ArcLayer);
_this = _super.call(this, props);
_this.registerVisConfig(arcVisConfigs);
_this.getPositionAccessor = function (dataContainer) {
return arcPosAccessor(_this.config.columns)(dataContainer);
};
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: "columnLabels",
get: function get() {
return arcColumnLabels;
}
}, {
key: "columnPairs",
get: function get() {
return this.defaultLinkColumnPairs;
}
}, {
key: "visualChannels",
get: function get() {
return {
sourceColor: _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(ArcLayer.prototype), "visualChannels", this).color), {}, {
property: 'color',
key: 'sourceColor',
accessor: 'getSourceColor',
defaultValue: function defaultValue(config) {
return config.color;
}
}),
targetColor: _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(ArcLayer.prototype), "visualChannels", this).color), {}, {
property: 'targetColor',
key: 'targetColor',
accessor: 'getTargetColor',
defaultValue: function defaultValue(config) {
return config.visConfig.targetColor || config.color;
}
}),
size: _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(ArcLayer.prototype), "visualChannels", this).size), {}, {
accessor: 'getWidth',
property: 'stroke'
})
};
}
}, {
key: "calculateDataAttribute",
value: function calculateDataAttribute(_ref2, getPosition) {
var dataContainer = _ref2.dataContainer,
filteredIndex = _ref2.filteredIndex;
var data = [];
for (var i = 0; i < filteredIndex.length; i++) {
var index = filteredIndex[i];
var pos = getPosition({
index: 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]]
});
}
}
return data;
}
}, {
key: "formatLayerData",
value: function formatLayerData(datasets, oldLayerData) {
var _datasets$this$config = datasets[this.config.dataId],
gpuFilter = _datasets$this$config.gpuFilter,
dataContainer = _datasets$this$config.dataContainer;
var _this$updateData = this.updateData(datasets, oldLayerData),
data = _this$updateData.data;
var accessors = this.getAttributeAccessors({
dataContainer: dataContainer
});
return _objectSpread({
data: data,
getFilterValue: gpuFilter.filterValueAccessor(dataContainer)()
}, accessors);
}
/* eslint-enable complexity */
}, {
key: "updateLayerMeta",
value: function updateLayerMeta(dataContainer) {
// get bounds from arcs
var getPosition = this.getPositionAccessor(dataContainer);
var sBounds = this.getPointsBounds(dataContainer, function (d, i) {
var pos = getPosition(d);
return [pos[0], pos[1]];
});
var tBounds = this.getPointsBounds(dataContainer, function (d, i) {
var pos = getPosition(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 updateTriggers = _objectSpread({
getPosition: this.config.columns,
getFilterValue: gpuFilter.filterValueUpdateTriggers
}, this.getVisualChannelUpdateTriggers());
var defaultLayerProps = this.getDefaultDeckLayerProps(opts);
var hoveredObject = this.hasHoveredObject(objectHovered);
return [new _layers.ArcLayer(_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, defaultLayerProps), this.getBrushingExtensionProps(interactionConfig, 'source_target')), data), {}, {
widthScale: this.config.visConfig.thickness,
updateTriggers: updateTriggers,
extensions: [].concat((0, _toConsumableArray2["default"])(defaultLayerProps.extensions), [new _extensions.BrushingExtension()])
}))].concat((0, _toConsumableArray2["default"])(hoveredObject ? [new _layers.ArcLayer(_objectSpread(_objectSpread({}, this.getDefaultHoverLayerProps()), {}, {
data: [hoveredObject],
widthScale: this.config.visConfig.thickness,
getSourceColor: this.config.highlightColor,
getTargetColor: this.config.highlightColor,
getWidth: data.getWidth
}))] : []));
}
}], [{
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","dc","d","valueAt","index","fieldIdx","arcRequiredColumns","arcColumnLabels","arcVisConfigs","opacity","thickness","colorRange","sizeRange","targetColor","ArcLayer","props","registerVisConfig","getPositionAccessor","dataContainer","config","columns","ArcLayerIcon","defaultLinkColumnPairs","sourceColor","color","property","key","accessor","defaultValue","visConfig","size","getPosition","filteredIndex","data","i","length","pos","every","Number","isFinite","push","sourcePosition","targetPosition","datasets","oldLayerData","dataId","gpuFilter","updateData","accessors","getAttributeAccessors","getFilterValue","filterValueAccessor","sBounds","getPointsBounds","tBounds","bounds","Math","min","max","updateMeta","opts","objectHovered","interactionConfig","updateTriggers","filterValueUpdateTriggers","getVisualChannelUpdateTriggers","defaultLayerProps","getDefaultDeckLayerProps","hoveredObject","hasHoveredObject","DeckArcLayer","getBrushingExtensionProps","widthScale","extensions","BrushingExtension","getDefaultHoverLayerProps","getSourceColor","highlightColor","getTargetColor","getWidth","fieldPairs","DEFAULT_LAYER_COLOR","tripArc","pair","lat","lng","label","defaultName","Layer"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AACA;;AAEA;;AACA;;AACA;;;;;;;;;;AAEO,IAAMA,cAAc,GAAG,SAAjBA,cAAiB;AAAA,MAAEC,IAAF,QAAEA,IAAF;AAAA,MAAQC,IAAR,QAAQA,IAAR;AAAA,MAAcC,IAAd,QAAcA,IAAd;AAAA,MAAoBC,IAApB,QAAoBA,IAApB;AAAA,SAA8B,UAAAC,EAAE;AAAA,WAAI,UAAAC,CAAC;AAAA,aAAI,CACrED,EAAE,CAACE,OAAH,CAAWD,CAAC,CAACE,KAAb,EAAoBN,IAAI,CAACO,QAAzB,CADqE,EAErEJ,EAAE,CAACE,OAAH,CAAWD,CAAC,CAACE,KAAb,EAAoBP,IAAI,CAACQ,QAAzB,CAFqE,EAGrE,CAHqE,EAIrEJ,EAAE,CAACE,OAAH,CAAWD,CAAC,CAACE,KAAb,EAAoBJ,IAAI,CAACK,QAAzB,CAJqE,EAKrEJ,EAAE,CAACE,OAAH,CAAWD,CAAC,CAACE,KAAb,EAAoBL,IAAI,CAACM,QAAzB,CALqE,EAMrE,CANqE,CAAJ;AAAA,KAAL;AAAA,GAAhC;AAAA,CAAvB;;;AASA,IAAMC,kBAAkB,GAAG,CAAC,MAAD,EAAS,MAAT,EAAiB,MAAjB,EAAyB,MAAzB,CAA3B;;AACA,IAAMC,eAAe,GAAG;AAC7BV,EAAAA,IAAI,EAAE,UADuB;AAE7BC,EAAAA,IAAI,EAAE,UAFuB;AAG7BC,EAAAA,IAAI,EAAE,UAHuB;AAI7BC,EAAAA,IAAI,EAAE;AAJuB,CAAxB;;AAOA,IAAMQ,aAAa,GAAG;AAC3BC,EAAAA,OAAO,EAAE,SADkB;AAE3BC,EAAAA,SAAS,EAAE,WAFgB;AAG3BC,EAAAA,UAAU,EAAE,YAHe;AAI3BC,EAAAA,SAAS,EAAE,kBAJgB;AAK3BC,EAAAA,WAAW,EAAE;AALc,CAAtB;;;IAQcC,Q;;;;;AACnB,oBAAYC,KAAZ,EAAmB;AAAA;;AAAA;AACjB,8BAAMA,KAAN;;AAEA,UAAKC,iBAAL,CAAuBR,aAAvB;;AACA,UAAKS,mBAAL,GAA2B,UAAAC,aAAa;AAAA,aAAItB,cAAc,CAAC,MAAKuB,MAAL,CAAYC,OAAb,CAAd,CAAoCF,aAApC,CAAJ;AAAA,KAAxC;;AAJiB;AAKlB;;;;SAED,eAAW;AACT,aAAO,KAAP;AACD;;;SAED,eAAmB;AACjB,aAAO,KAAP;AACD;;;SAED,eAAgB;AACd,aAAOG,wBAAP;AACD;;;SAED,eAA2B;AACzB,aAAOf,kBAAP;AACD;;;SAED,eAAmB;AACjB,aAAOC,eAAP;AACD;;;SACD,eAAkB;AAChB,aAAO,KAAKe,sBAAZ;AACD;;;SAED,eAAqB;AACnB,aAAO;AACLC,QAAAA,WAAW,kCACN,oGAAqBC,KADf;AAETC,UAAAA,QAAQ,EAAE,OAFD;AAGTC,UAAAA,GAAG,EAAE,aAHI;AAITC,UAAAA,QAAQ,EAAE,gBAJD;AAKTC,UAAAA,YAAY,EAAE,sBAAAT,MAAM;AAAA,mBAAIA,MAAM,CAACK,KAAX;AAAA;AALX,UADN;AAQLX,QAAAA,WAAW,kCACN,oGAAqBW,KADf;AAETC,UAAAA,QAAQ,EAAE,aAFD;AAGTC,UAAAA,GAAG,EAAE,aAHI;AAITC,UAAAA,QAAQ,EAAE,gBAJD;AAKTC,UAAAA,YAAY,EAAE,sBAAAT,MAAM;AAAA,mBAAIA,MAAM,CAACU,SAAP,CAAiBhB,WAAjB,IAAgCM,MAAM,CAACK,KAA3C;AAAA;AALX,UARN;AAeLM,QAAAA,IAAI,kCACC,oGAAqBA,IADtB;AAEFH,UAAAA,QAAQ,EAAE,UAFR;AAGFF,UAAAA,QAAQ,EAAE;AAHR;AAfC,OAAP;AAqBD;;;WAuBD,uCAAuDM,WAAvD,EAAoE;AAAA,UAA5Cb,aAA4C,SAA5CA,aAA4C;AAAA,UAA7Bc,aAA6B,SAA7BA,aAA6B;AAClE,UAAMC,IAAI,GAAG,EAAb;;AACA,WAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGF,aAAa,CAACG,MAAlC,EAA0CD,CAAC,EAA3C,EAA+C;AAC7C,YAAM9B,KAAK,GAAG4B,aAAa,CAACE,CAAD,CAA3B;AACA,YAAME,GAAG,GAAGL,WAAW,CAAC;AAAC3B,UAAAA,KAAK,EAALA;AAAD,SAAD,CAAvB,CAF6C,CAI7C;AACA;;AACA,YAAIgC,GAAG,CAACC,KAAJ,CAAUC,MAAM,CAACC,QAAjB,CAAJ,EAAgC;AAC9BN,UAAAA,IAAI,CAACO,IAAL,CAAU;AACRpC,YAAAA,KAAK,EAALA,KADQ;AAERqC,YAAAA,cAAc,EAAE,CAACL,GAAG,CAAC,CAAD,CAAJ,EAASA,GAAG,CAAC,CAAD,CAAZ,EAAiBA,GAAG,CAAC,CAAD,CAApB,CAFR;AAGRM,YAAAA,cAAc,EAAE,CAACN,GAAG,CAAC,CAAD,CAAJ,EAASA,GAAG,CAAC,CAAD,CAAZ,EAAiBA,GAAG,CAAC,CAAD,CAApB;AAHR,WAAV;AAKD;AACF;;AAED,aAAOH,IAAP;AACD;;;WAED,yBAAgBU,QAAhB,EAA0BC,YAA1B,EAAwC;AAAA,kCACHD,QAAQ,CAAC,KAAKxB,MAAL,CAAY0B,MAAb,CADL;AAAA,UAC/BC,SAD+B,yBAC/BA,SAD+B;AAAA,UACpB5B,aADoB,yBACpBA,aADoB;;AAAA,6BAEvB,KAAK6B,UAAL,CAAgBJ,QAAhB,EAA0BC,YAA1B,CAFuB;AAAA,UAE/BX,IAF+B,oBAE/BA,IAF+B;;AAGtC,UAAMe,SAAS,GAAG,KAAKC,qBAAL,CAA2B;AAAC/B,QAAAA,aAAa,EAAbA;AAAD,OAA3B,CAAlB;AACA;AACEe,QAAAA,IAAI,EAAJA,IADF;AAEEiB,QAAAA,cAAc,EAAEJ,SAAS,CAACK,mBAAV,CAA8BjC,aAA9B;AAFlB,SAGK8B,SAHL;AAKD;AACD;;;;WAEA,yBAAgB9B,aAAhB,EAA+B;AAC7B;AACA,UAAMa,WAAW,GAAG,KAAKd,mBAAL,CAAyBC,aAAzB,CAApB;AAEA,UAAMkC,OAAO,GAAG,KAAKC,eAAL,CAAqBnC,aAArB,EAAoC,UAAChB,CAAD,EAAIgC,CAAJ,EAAU;AAC5D,YAAME,GAAG,GAAGL,WAAW,CAAC7B,CAAD,CAAvB;AACA,eAAO,CAACkC,GAAG,CAAC,CAAD,CAAJ,EAASA,GAAG,CAAC,CAAD,CAAZ,CAAP;AACD,OAHe,CAAhB;AAIA,UAAMkB,OAAO,GAAG,KAAKD,eAAL,CAAqBnC,aAArB,EAAoC,UAAChB,CAAD,EAAIgC,CAAJ,EAAU;AAC5D,YAAME,GAAG,GAAGL,WAAW,CAAC7B,CAAD,CAAvB;AACA,eAAO,CAACkC,GAAG,CAAC,CAAD,CAAJ,EAASA,GAAG,CAAC,CAAD,CAAZ,CAAP;AACD,OAHe,CAAhB;AAKA,UAAMmB,MAAM,GACVD,OAAO,IAAIF,OAAX,GACI,CACEI,IAAI,CAACC,GAAL,CAASL,OAAO,CAAC,CAAD,CAAhB,EAAqBE,OAAO,CAAC,CAAD,CAA5B,CADF,EAEEE,IAAI,CAACC,GAAL,CAASL,OAAO,CAAC,CAAD,CAAhB,EAAqBE,OAAO,CAAC,CAAD,CAA5B,CAFF,EAGEE,IAAI,CAACE,GAAL,CAASN,OAAO,CAAC,CAAD,CAAhB,EAAqBE,OAAO,CAAC,CAAD,CAA5B,CAHF,EAIEE,IAAI,CAACE,GAAL,CAASN,OAAO,CAAC,CAAD,CAAhB,EAAqBE,OAAO,CAAC,CAAD,CAA5B,CAJF,CADJ,GAOIF,OAAO,IAAIE,OARjB;AAUA,WAAKK,UAAL,CAAgB;AAACJ,QAAAA,MAAM,EAANA;AAAD,OAAhB;AACD;;;WAED,qBAAYK,IAAZ,EAAkB;AAAA,UACT3B,IADS,GAC4C2B,IAD5C,CACT3B,IADS;AAAA,UACHa,SADG,GAC4Cc,IAD5C,CACHd,SADG;AAAA,UACQe,aADR,GAC4CD,IAD5C,CACQC,aADR;AAAA,UACuBC,iBADvB,GAC4CF,IAD5C,CACuBE,iBADvB;;AAEhB,UAAMC,cAAc;AAClBhC,QAAAA,WAAW,EAAE,KAAKZ,MAAL,CAAYC,OADP;AAElB8B,QAAAA,cAAc,EAAEJ,SAAS,CAACkB;AAFR,SAGf,KAAKC,8BAAL,EAHe,CAApB;;AAKA,UAAMC,iBAAiB,GAAG,KAAKC,wBAAL,CAA8BP,IAA9B,CAA1B;AACA,UAAMQ,aAAa,GAAG,KAAKC,gBAAL,CAAsBR,aAAtB,CAAtB;AACA,cACE,IAAIS,gBAAJ,6DACKJ,iBADL,GAEK,KAAKK,yBAAL,CAA+BT,iBAA/B,EAAkD,eAAlD,CAFL,GAGK7B,IAHL;AAIEuC,QAAAA,UAAU,EAAE,KAAKrD,MAAL,CAAYU,SAAZ,CAAsBnB,SAJpC;AAKEqD,QAAAA,cAAc,EAAdA,cALF;AAMEU,QAAAA,UAAU,gDAAMP,iBAAiB,CAACO,UAAxB,IAAoC,IAAIC,6BAAJ,EAApC;AANZ,SADF,6CAUMN,aAAa,GACb,CACE,IAAIE,gBAAJ,iCACK,KAAKK,yBAAL,EADL;AAEE1C,QAAAA,IAAI,EAAE,CAACmC,aAAD,CAFR;AAGEI,QAAAA,UAAU,EAAE,KAAKrD,MAAL,CAAYU,SAAZ,CAAsBnB,SAHpC;AAIEkE,QAAAA,cAAc,EAAE,KAAKzD,MAAL,CAAY0D,cAJ9B;AAKEC,QAAAA,cAAc,EAAE,KAAK3D,MAAL,CAAY0D,cAL9B;AAMEE,QAAAA,QAAQ,EAAE9C,IAAI,CAAC8C;AANjB,SADF,CADa,GAWb,EArBN;AAuBD;;;WA/GD,sCAAgD;AAAA,mCAAlBC,UAAkB;AAAA,UAAlBA,UAAkB,iCAAL,EAAK;;AAC9C,UAAIA,UAAU,CAAC7C,MAAX,GAAoB,CAAxB,EAA2B;AACzB,eAAO;AAACpB,UAAAA,KAAK,EAAE;AAAR,SAAP;AACD;;AAED,UAAMA,KAAK,GAAG;AACZS,QAAAA,KAAK,EAAE,0BAASyD,qCAAoBC,OAA7B;AADK,OAAd,CAL8C,CAS9C;;AACAnE,MAAAA,KAAK,CAACK,OAAN,GAAgB;AACdvB,QAAAA,IAAI,EAAEmF,UAAU,CAAC,CAAD,CAAV,CAAcG,IAAd,CAAmBC,GADX;AAEdtF,QAAAA,IAAI,EAAEkF,UAAU,CAAC,CAAD,CAAV,CAAcG,IAAd,CAAmBE,GAFX;AAGdtF,QAAAA,IAAI,EAAEiF,UAAU,CAAC,CAAD,CAAV,CAAcG,IAAd,CAAmBC,GAHX;AAIdpF,QAAAA,IAAI,EAAEgF,UAAU,CAAC,CAAD,CAAV,CAAcG,IAAd,CAAmBE;AAJX,OAAhB;AAMAtE,MAAAA,KAAK,CAACuE,KAAN,aAAiBN,UAAU,CAAC,CAAD,CAAV,CAAcO,WAA/B,iBAAiDP,UAAU,CAAC,CAAD,CAAV,CAAcO,WAA/D;AAEA,aAAO;AAACxE,QAAAA,KAAK,EAAE,CAACA,KAAD;AAAR,OAAP;AACD;;;EA1EmCyE,qB","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 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}) => dc => d => [\n  dc.valueAt(d.index, lng0.fieldIdx),\n  dc.valueAt(d.index, lat0.fieldIdx),\n  0,\n  dc.valueAt(d.index, lng1.fieldIdx),\n  dc.valueAt(d.index, 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 = dataContainer => arcPosAccessor(this.config.columns)(dataContainer);\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      sourceColor: {\n        ...super.visualChannels.color,\n        property: 'color',\n        key: 'sourceColor',\n        accessor: 'getSourceColor',\n        defaultValue: config => config.color\n      },\n      targetColor: {\n        ...super.visualChannels.color,\n        property: 'targetColor',\n        key: 'targetColor',\n        accessor: 'getTargetColor',\n        defaultValue: config => config.visConfig.targetColor || config.color\n      },\n      size: {\n        ...super.visualChannels.size,\n        accessor: 'getWidth',\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({dataContainer, filteredIndex}, getPosition) {\n    const data = [];\n    for (let i = 0; i < filteredIndex.length; i++) {\n      const index = filteredIndex[i];\n      const pos = getPosition({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        });\n      }\n    }\n\n    return data;\n  }\n\n  formatLayerData(datasets, oldLayerData) {\n    const {gpuFilter, dataContainer} = datasets[this.config.dataId];\n    const {data} = this.updateData(datasets, oldLayerData);\n    const accessors = this.getAttributeAccessors({dataContainer});\n    return {\n      data,\n      getFilterValue: gpuFilter.filterValueAccessor(dataContainer)(),\n      ...accessors\n    };\n  }\n  /* eslint-enable complexity */\n\n  updateLayerMeta(dataContainer) {\n    // get bounds from arcs\n    const getPosition = this.getPositionAccessor(dataContainer);\n\n    const sBounds = this.getPointsBounds(dataContainer, (d, i) => {\n      const pos = getPosition(d);\n      return [pos[0], pos[1]];\n    });\n    const tBounds = this.getPointsBounds(dataContainer, (d, i) => {\n      const pos = getPosition(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    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    return [\n      new DeckArcLayer({\n        ...defaultLayerProps,\n        ...this.getBrushingExtensionProps(interactionConfig, 'source_target'),\n        ...data,\n        widthScale: this.config.visConfig.thickness,\n        updateTriggers,\n        extensions: [...defaultLayerProps.extensions, new BrushingExtension()]\n      }),\n      // hover layer\n      ...(hoveredObject\n        ? [\n            new DeckArcLayer({\n              ...this.getDefaultHoverLayerProps(),\n              data: [hoveredObject],\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"]}