kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
410 lines (342 loc) • 49 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.pointVisConfigs = exports.iconResolver = exports.iconRequiredColumns = exports.iconPosResolver = exports.iconPosAccessor = exports.iconAccessor = exports["default"] = exports.SVG_ICON_URL = void 0;
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
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 _lodash = _interopRequireDefault(require("lodash.memoize"));
var _window = _interopRequireDefault(require("global/window"));
var _colorUtils = require("../../utils/color-utils");
var _svgIconLayer = _interopRequireDefault(require("../../deckgl-layers/svg-icon-layer/svg-icon-layer"));
var _iconLayerIcon = _interopRequireDefault(require("./icon-layer-icon"));
var _defaultSettings = require("../../constants/default-settings");
var _iconInfoModal = _interopRequireDefault(require("./icon-info-modal"));
function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == (0, _typeof2["default"])(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator["return"] && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError((0, _typeof2["default"])(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, "catch": function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
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 SVG_ICON_URL = exports.SVG_ICON_URL = "".concat(_defaultSettings.CLOUDFRONT, "/icons/svg-icons.json");
var iconPosAccessor = exports.iconPosAccessor = function iconPosAccessor(_ref) {
var lat = _ref.lat,
lng = _ref.lng;
return function (d) {
return [d.data[lng.fieldIdx], d.data[lat.fieldIdx]];
};
};
var iconPosResolver = exports.iconPosResolver = function iconPosResolver(_ref2) {
var lat = _ref2.lat,
lng = _ref2.lng;
return "".concat(lat.fieldIdx, "-").concat(lng.fieldIdx);
};
var iconAccessor = exports.iconAccessor = function iconAccessor(_ref3) {
var icon = _ref3.icon;
return function (d) {
return d.data[icon.fieldIdx];
};
};
var iconResolver = exports.iconResolver = function iconResolver(_ref4) {
var icon = _ref4.icon;
return icon.fieldIdx;
};
var iconRequiredColumns = exports.iconRequiredColumns = ['lat', 'lng', 'icon'];
var pointVisConfigs = exports.pointVisConfigs = {
radius: 'radius',
fixedRadius: 'fixedRadius',
opacity: 'opacity',
colorRange: 'colorRange',
radiusRange: 'radiusRange'
};
var IconLayer = exports["default"] = /*#__PURE__*/function (_Layer) {
(0, _inherits2["default"])(IconLayer, _Layer);
var _super = _createSuper(IconLayer);
function IconLayer(props) {
var _this;
(0, _classCallCheck2["default"])(this, IconLayer);
_this = _super.call(this, props);
_this.registerVisConfig(pointVisConfigs);
_this.getPosition = (0, _lodash["default"])(iconPosAccessor, iconPosResolver);
_this.getIcon = (0, _lodash["default"])(iconAccessor, iconResolver); // prepare layer info modal
_this._layerInfoModal = (0, _iconInfoModal["default"])();
_this.getSvgIcons();
return _this;
}
(0, _createClass2["default"])(IconLayer, [{
key: "type",
get: function get() {
return 'icon';
}
}, {
key: "requiredLayerColumns",
get: function get() {
return iconRequiredColumns;
}
}, {
key: "columnPairs",
get: function get() {
return this.defaultPointColumnPairs;
}
}, {
key: "layerIcon",
get: function get() {
return _iconLayerIcon["default"];
}
}, {
key: "visualChannels",
get: function get() {
return _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(IconLayer.prototype), "visualChannels", this)), {}, {
size: _objectSpread(_objectSpread({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(IconLayer.prototype), "visualChannels", this).size), {}, {
range: 'radiusRange',
property: 'radius',
channelScaleType: 'radius'
})
});
}
}, {
key: "layerInfoModal",
get: function get() {
return {
id: 'iconInfo',
template: this._layerInfoModal,
modalProps: {
title: 'How to draw icons'
}
};
}
}, {
key: "getSvgIcons",
value: function () {
var _getSvgIcons = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
var fetchConfig, response, _ref6, svgIcons;
return _regeneratorRuntime().wrap(function _callee$(_context) {
while (1) switch (_context.prev = _context.next) {
case 0:
fetchConfig = {
method: 'GET',
mode: 'cors',
cache: 'no-cache'
};
if (!_window["default"].fetch) {
_context.next = 11;
break;
}
_context.next = 4;
return _window["default"].fetch(SVG_ICON_URL, fetchConfig);
case 4:
response = _context.sent;
_context.next = 7;
return response.json();
case 7:
_ref6 = _context.sent;
svgIcons = _ref6.svgIcons;
this.iconGeometry = svgIcons.reduce(function (accu, curr) {
return _objectSpread(_objectSpread({}, accu), {}, (0, _defineProperty2["default"])({}, curr.id, curr.mesh.cells.reduce(function (prev, cell) {
cell.forEach(function (p) {
Array.prototype.push.apply(prev, curr.mesh.positions[p]);
});
return prev;
}, [])));
}, {});
this._layerInfoModal = (0, _iconInfoModal["default"])(svgIcons);
case 11:
case "end":
return _context.stop();
}
}, _callee, this);
}));
function getSvgIcons() {
return _getSvgIcons.apply(this, arguments);
}
return getSvgIcons;
}()
}, {
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,
radiusRange = _this$config$visConfi.radiusRange,
colorRange = _this$config$visConfi.colorRange; // point color
var cScale = colorField && this.getVisChannelScale(colorScale, colorDomain, colorRange.colors.map(_colorUtils.hexToRgb)); // point radius
var rScale = sizeField && this.getVisChannelScale(sizeScale, sizeDomain, radiusRange, 0);
var getPosition = this.getPosition(columns);
var getIcon = this.getIcon(columns);
if (!oldLayerData || oldLayerData.getPosition !== getPosition) {
this.updateLayerMeta(allData, getPosition);
}
var data;
if (oldLayerData && oldLayerData.data && opt.sameData && oldLayerData.getPosition === getPosition && oldLayerData.getIcon === getIcon) {
data = oldLayerData.data;
} else {
data = filteredIndex.reduce(function (accu, index) {
var pos = getPosition({
data: allData[index]
});
var icon = getIcon({
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) || typeof icon !== 'string') {
return accu;
}
accu.push({
index: index,
icon: icon,
data: allData[index]
});
return accu;
}, []);
}
var getRadius = rScale ? function (d) {
return _this2.getEncodedChannelValue(rScale, d.data, sizeField, 0);
} : 1;
var getColor = cScale ? function (d) {
return _this2.getEncodedChannelValue(cScale, d.data, colorField);
} : color;
return {
data: data,
getPosition: getPosition,
getIcon: getIcon,
getColor: getColor,
getRadius: getRadius
};
}
/* eslint-enable complexity */
}, {
key: "updateLayerMeta",
value: function updateLayerMeta(allData, getPosition) {
var bounds = this.getPointsBounds(allData, function (d) {
return getPosition({
data: d
});
});
this.updateMeta({
bounds: bounds
});
}
}, {
key: "renderLayer",
value: function renderLayer(_ref7) {
var _this3 = this;
var data = _ref7.data,
idx = _ref7.idx,
objectHovered = _ref7.objectHovered,
mapState = _ref7.mapState,
interactionConfig = _ref7.interactionConfig,
layerInteraction = _ref7.layerInteraction;
var layerProps = _objectSpread({
radiusMinPixels: 1,
radiusScale: this.getRadiusScaleByZoom(mapState)
}, this.config.visConfig.fixedRadius ? {} : {
radiusMaxPixels: 500
});
return !this.iconGeometry ? [] : [new _svgIconLayer["default"](_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, layerProps), data), layerInteraction), {}, {
id: this.id,
idx: idx,
opacity: this.config.visConfig.opacity,
getIconGeometry: function getIconGeometry(id) {
return _this3.iconGeometry[id];
},
// picking
autoHighlight: true,
highlightColor: this.config.highlightColor,
pickable: true,
// parameters
parameters: {
depthTest: mapState.dragRotate
},
// update triggers
updateTriggers: {
getRadius: {
sizeField: this.config.colorField,
radiusRange: this.config.visConfig.radiusRange,
sizeScale: this.config.sizeScale
},
getColor: {
color: this.config.color,
colorField: this.config.colorField,
colorRange: this.config.visConfig.colorRange,
colorScale: this.config.colorScale
}
}
}))].concat((0, _toConsumableArray2["default"])(this.isLayerHovered(objectHovered) ? [new _svgIconLayer["default"](_objectSpread(_objectSpread({}, layerProps), {}, {
id: "".concat(this.id, "-hovered"),
data: [objectHovered.object],
getPosition: data.getPosition,
getRadius: data.getRadius,
getColor: this.config.highlightColor,
getIconGeometry: function getIconGeometry(id) {
return _this3.iconGeometry[id];
},
pickable: false
}))] : []));
}
}], [{
key: "findDefaultLayerProps",
value: function findDefaultLayerProps(_ref8) {
var _ref8$fieldPairs = _ref8.fieldPairs,
fieldPairs = _ref8$fieldPairs === void 0 ? [] : _ref8$fieldPairs,
_ref8$fields = _ref8.fields,
fields = _ref8$fields === void 0 ? [] : _ref8$fields;
var notFound = {
props: []
};
if (!fieldPairs.length || !fields.length) {
return notFound;
}
var iconFields = fields.filter(function (_ref9) {
var name = _ref9.name;
return name.replace(/[_,.]+/g, ' ').trim().split(' ').some(function (seg) {
return _defaultSettings.ICON_FIELDS.icon.some(function (t) {
return t.includes(seg);
});
});
});
if (!iconFields.length) {
return notFound;
} // create icon layers for first point pair
var ptPair = fieldPairs[0];
var props = iconFields.map(function (iconField) {
return {
label: iconField.name.replace(/[_,.]+/g, ' ').trim(),
columns: {
lat: ptPair.pair.lat,
lng: ptPair.pair.lng,
icon: {
value: iconField.name,
fieldIdx: iconField.tableFieldIndex - 1
}
},
isVisible: true
};
});
return {
props: props
};
}
}]);
return IconLayer;
}(_baseLayer["default"]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/icon-layer/icon-layer.js"],"names":["SVG_ICON_URL","CLOUDFRONT","iconPosAccessor","lat","lng","d","data","fieldIdx","iconPosResolver","iconAccessor","icon","iconResolver","iconRequiredColumns","pointVisConfigs","radius","fixedRadius","opacity","colorRange","radiusRange","IconLayer","props","registerVisConfig","getPosition","getIcon","_layerInfoModal","getSvgIcons","defaultPointColumnPairs","IconLayerIcon","size","range","property","channelScaleType","id","template","modalProps","title","fetchConfig","method","mode","cache","window","fetch","response","json","svgIcons","iconGeometry","reduce","accu","curr","mesh","cells","prev","cell","forEach","p","Array","prototype","push","apply","positions","_","allData","filteredIndex","oldLayerData","opt","config","colorScale","colorDomain","colorField","color","columns","sizeField","sizeScale","sizeDomain","visConfig","cScale","getVisChannelScale","colors","map","hexToRgb","rScale","updateLayerMeta","sameData","index","pos","every","Number","isFinite","getRadius","getEncodedChannelValue","getColor","bounds","getPointsBounds","updateMeta","idx","objectHovered","mapState","interactionConfig","layerInteraction","layerProps","radiusMinPixels","radiusScale","getRadiusScaleByZoom","radiusMaxPixels","SvgIconLayer","getIconGeometry","autoHighlight","highlightColor","pickable","parameters","depthTest","dragRotate","updateTriggers","isLayerHovered","object","fieldPairs","fields","notFound","length","iconFields","filter","name","replace","trim","split","some","seg","ICON_FIELDS","t","includes","ptPair","iconField","label","pair","value","tableFieldIndex","isVisible","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 Layer from '../base-layer';\nimport memoize from 'lodash.memoize';\nimport window from 'global/window';\n\nimport {hexToRgb} from 'utils/color-utils';\nimport SvgIconLayer from 'deckgl-layers/svg-icon-layer/svg-icon-layer';\nimport IconLayerIcon from './icon-layer-icon';\nimport {ICON_FIELDS, CLOUDFRONT} from 'constants/default-settings';\nimport IconInfoModalFactory from './icon-info-modal';\n\nexport const SVG_ICON_URL = `${CLOUDFRONT}/icons/svg-icons.json`;\n\nexport const iconPosAccessor = ({lat, lng}) => d => [\n  d.data[lng.fieldIdx],\n  d.data[lat.fieldIdx]\n];\n\nexport const iconPosResolver = ({lat, lng}) => `${lat.fieldIdx}-${lng.fieldIdx}`;\n\nexport const iconAccessor = ({icon}) => d => d.data[icon.fieldIdx];\nexport const iconResolver = ({icon}) => icon.fieldIdx;\n\nexport const iconRequiredColumns = ['lat', 'lng', 'icon'];\n\nexport const pointVisConfigs = {\n  radius: 'radius',\n  fixedRadius: 'fixedRadius',\n  opacity: 'opacity',\n  colorRange: 'colorRange',\n  radiusRange: 'radiusRange'\n};\n\nexport default class IconLayer extends Layer {\n  constructor(props) {\n    super(props);\n\n    this.registerVisConfig(pointVisConfigs);\n    this.getPosition = memoize(iconPosAccessor, iconPosResolver);\n    this.getIcon = memoize(iconAccessor, iconResolver);\n\n    // prepare layer info modal\n    this._layerInfoModal = IconInfoModalFactory();\n    this.getSvgIcons();\n  }\n\n  get type() {\n    return 'icon';\n  }\n\n  get requiredLayerColumns() {\n    return iconRequiredColumns;\n  }\n\n  get columnPairs() {\n    return this.defaultPointColumnPairs;\n  }\n\n  get layerIcon() {\n    return IconLayerIcon;\n  }\n\n  get visualChannels() {\n    return {\n      ...super.visualChannels,\n      size: {\n        ...super.visualChannels.size,\n        range: 'radiusRange',\n        property: 'radius',\n        channelScaleType: 'radius'\n      }\n    };\n  }\n\n  get layerInfoModal() {\n    return {\n      id: 'iconInfo',\n      template: this._layerInfoModal,\n      modalProps: {\n        title: 'How to draw icons'\n      }\n    };\n  }\n\n  async getSvgIcons() {\n    const fetchConfig = {\n      method: 'GET',\n      mode: 'cors',\n      cache: 'no-cache'\n    };\n\n    if (window.fetch) {\n      const response = await window.fetch(SVG_ICON_URL, fetchConfig);\n      const {svgIcons} = await response.json();\n\n      this.iconGeometry = svgIcons.reduce(\n        (accu, curr) => ({\n          ...accu,\n          [curr.id]: curr.mesh.cells.reduce((prev, cell) => {\n            cell.forEach(p => {\n              Array.prototype.push.apply(prev, curr.mesh.positions[p]);\n            });\n            return prev;\n          }, [])\n        }),\n        {}\n      );\n      this._layerInfoModal = IconInfoModalFactory(svgIcons);\n    }\n  }\n\n  static findDefaultLayerProps({fieldPairs = [], fields = []}) {\n    const notFound = {props: []};\n    if (!fieldPairs.length || !fields.length) {\n      return notFound;\n    }\n\n    const iconFields = fields.filter(({name}) =>\n      name\n        .replace(/[_,.]+/g, ' ')\n        .trim()\n        .split(' ')\n        .some(seg => ICON_FIELDS.icon.some(t => t.includes(seg)))\n    );\n\n    if (!iconFields.length) {\n      return notFound;\n    }\n\n    // create icon layers for first point pair\n    const ptPair = fieldPairs[0];\n\n    const props = iconFields.map(iconField => ({\n      label: iconField.name.replace(/[_,.]+/g, ' ').trim(),\n      columns: {\n        lat: ptPair.pair.lat,\n        lng: ptPair.pair.lng,\n        icon: {\n          value: iconField.name,\n          fieldIdx: iconField.tableFieldIndex - 1\n        }\n      },\n      isVisible: true\n    }));\n\n    return {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: {radiusRange, colorRange}\n    } = this.config;\n\n    // point color\n    const cScale =\n      colorField &&\n      this.getVisChannelScale(\n        colorScale,\n        colorDomain,\n        colorRange.colors.map(hexToRgb)\n      );\n\n    // point radius\n    const rScale =\n      sizeField && this.getVisChannelScale(sizeScale, sizeDomain, radiusRange, 0);\n\n    const getPosition = this.getPosition(columns);\n    const getIcon = this.getIcon(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      oldLayerData.getIcon === getIcon\n    ) {\n      data = oldLayerData.data;\n    } else {\n      data = filteredIndex.reduce((accu, index) => {\n        const pos = getPosition({data: allData[index]});\n        const icon = getIcon({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) || typeof icon !== 'string') {\n          return accu;\n        }\n\n        accu.push({\n          index,\n          icon,\n          data: allData[index]\n        });\n\n        return accu;\n      }, []);\n    }\n\n    const getRadius = rScale\n      ? d => this.getEncodedChannelValue(rScale, d.data, sizeField, 0)\n      : 1;\n\n    const getColor = cScale\n      ? d => this.getEncodedChannelValue(cScale, d.data, colorField)\n      : color;\n\n    return {\n      data,\n      getPosition,\n      getIcon,\n      getColor,\n      getRadius\n    };\n  }\n  /* eslint-enable complexity */\n\n  updateLayerMeta(allData, getPosition) {\n    const bounds = this.getPointsBounds(allData, d => getPosition({data: d}));\n    this.updateMeta({bounds});\n  }\n\n  renderLayer({\n    data,\n    idx,\n    objectHovered,\n    mapState,\n    interactionConfig,\n    layerInteraction\n  }) {\n    const layerProps = {\n      radiusMinPixels: 1,\n      radiusScale: this.getRadiusScaleByZoom(mapState),\n      ...(this.config.visConfig.fixedRadius ? {} : {radiusMaxPixels: 500})\n    };\n\n    return !this.iconGeometry\n      ? []\n      : [\n          new SvgIconLayer({\n            ...layerProps,\n            ...data,\n            ...layerInteraction,\n            id: this.id,\n            idx,\n            opacity: this.config.visConfig.opacity,\n            getIconGeometry: id => this.iconGeometry[id],\n\n            // picking\n            autoHighlight: true,\n            highlightColor: this.config.highlightColor,\n            pickable: true,\n\n            // parameters\n            parameters: {depthTest: mapState.dragRotate},\n\n            // update triggers\n            updateTriggers: {\n              getRadius: {\n                sizeField: this.config.colorField,\n                radiusRange: this.config.visConfig.radiusRange,\n                sizeScale: this.config.sizeScale\n              },\n              getColor: {\n                color: this.config.color,\n                colorField: this.config.colorField,\n                colorRange: this.config.visConfig.colorRange,\n                colorScale: this.config.colorScale\n              }\n            }\n          }),\n          ...(this.isLayerHovered(objectHovered)\n            ? [\n                new SvgIconLayer({\n                  ...layerProps,\n                  id: `${this.id}-hovered`,\n                  data: [objectHovered.object],\n                  getPosition: data.getPosition,\n                  getRadius: data.getRadius,\n                  getColor: this.config.highlightColor,\n                  getIconGeometry: id => this.iconGeometry[id],\n                  pickable: false\n                })\n              ]\n            : [])\n        ];\n  }\n}\n"]}