@kepler.gl/utils 3.1.0-alpha.1 → 3.1.0-alpha.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (81) hide show
  1. package/dist/aggregation.d.ts +13 -0
  2. package/dist/aggregation.js +84 -0
  3. package/dist/application-config.d.ts +25 -0
  4. package/dist/application-config.js +52 -0
  5. package/dist/arrow-data-container.d.ts +62 -0
  6. package/dist/arrow-data-container.js +331 -0
  7. package/dist/color-utils.d.ts +108 -0
  8. package/dist/color-utils.js +443 -0
  9. package/dist/data-container-interface.d.ts +138 -0
  10. package/dist/data-container-interface.js +6 -0
  11. package/dist/data-container-utils.d.ts +30 -0
  12. package/dist/data-container-utils.js +74 -0
  13. package/dist/data-row.d.ts +59 -0
  14. package/dist/data-row.js +110 -0
  15. package/dist/data-scale-utils.d.ts +119 -0
  16. package/dist/data-scale-utils.js +340 -0
  17. package/dist/data-utils.d.ts +98 -0
  18. package/dist/data-utils.js +436 -0
  19. package/dist/dataset-utils.d.ts +45 -0
  20. package/dist/dataset-utils.js +313 -0
  21. package/dist/dom-to-image.d.ts +73 -0
  22. package/dist/dom-to-image.js +421 -0
  23. package/dist/dom-utils.d.ts +23 -0
  24. package/dist/dom-utils.js +349 -0
  25. package/dist/effect-utils.d.ts +24 -0
  26. package/dist/effect-utils.js +166 -0
  27. package/dist/export-map-html.d.ts +9 -0
  28. package/dist/export-map-html.js +25 -0
  29. package/dist/export-utils.d.ts +40 -0
  30. package/dist/export-utils.js +201 -0
  31. package/dist/filter-utils.d.ts +331 -0
  32. package/dist/filter-utils.js +1214 -0
  33. package/dist/format.d.ts +3 -0
  34. package/dist/format.js +38 -0
  35. package/dist/gl-utils.d.ts +1 -0
  36. package/dist/gl-utils.js +27 -0
  37. package/dist/index.d.ts +42 -0
  38. package/dist/index.js +941 -0
  39. package/dist/indexed-data-container.d.ts +34 -0
  40. package/dist/indexed-data-container.js +214 -0
  41. package/dist/locale-utils.d.ts +2 -0
  42. package/dist/locale-utils.js +39 -0
  43. package/dist/map-info-utils.d.ts +1 -0
  44. package/dist/map-info-utils.js +14 -0
  45. package/dist/map-style-utils/mapbox-gl-style-editor.d.ts +57 -0
  46. package/dist/map-style-utils/mapbox-gl-style-editor.js +188 -0
  47. package/dist/map-style-utils/mapbox-utils.d.ts +14 -0
  48. package/dist/map-style-utils/mapbox-utils.js +51 -0
  49. package/dist/map-utils.d.ts +9 -0
  50. package/dist/map-utils.js +48 -0
  51. package/dist/mapbox-utils.d.ts +7 -0
  52. package/dist/mapbox-utils.js +19 -0
  53. package/dist/noop.d.ts +1 -0
  54. package/dist/noop.js +13 -0
  55. package/dist/notifications-utils.d.ts +42 -0
  56. package/dist/notifications-utils.js +69 -0
  57. package/dist/observe-dimensions.d.ts +15 -0
  58. package/dist/observe-dimensions.js +130 -0
  59. package/dist/plot.d.ts +131 -0
  60. package/dist/plot.js +615 -0
  61. package/dist/position-utils.d.ts +6 -0
  62. package/dist/position-utils.js +26 -0
  63. package/dist/projection-utils.d.ts +22 -0
  64. package/dist/projection-utils.js +83 -0
  65. package/dist/quick-insertion-sort.d.ts +12 -0
  66. package/dist/quick-insertion-sort.js +132 -0
  67. package/dist/row-data-container.d.ts +31 -0
  68. package/dist/row-data-container.js +206 -0
  69. package/dist/searcher-utils.d.ts +1 -0
  70. package/dist/searcher-utils.js +25 -0
  71. package/dist/split-map-utils.d.ts +32 -0
  72. package/dist/split-map-utils.js +99 -0
  73. package/dist/strings.d.ts +4 -0
  74. package/dist/strings.js +16 -0
  75. package/dist/time.d.ts +54 -0
  76. package/dist/time.js +325 -0
  77. package/dist/types.d.ts +18 -0
  78. package/dist/types.js +6 -0
  79. package/dist/utils.d.ts +104 -0
  80. package/dist/utils.js +241 -0
  81. package/package.json +14 -6
package/dist/plot.js ADDED
@@ -0,0 +1,615 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.adjustValueToAnimationWindow = adjustValueToAnimationWindow;
8
+ exports.binByTime = binByTime;
9
+ exports.getAggregationOptiosnBasedOnField = void 0;
10
+ exports.getBinThresholds = getBinThresholds;
11
+ exports.getChartTitle = getChartTitle;
12
+ exports.getDefaultPlotType = getDefaultPlotType;
13
+ exports.getFilterDataFunc = getFilterDataFunc;
14
+ exports.getLineChart = getLineChart;
15
+ exports.getPctChange = getPctChange;
16
+ exports.getRangeFilterBins = getRangeFilterBins;
17
+ exports.getTimeBins = getTimeBins;
18
+ exports.getValueAggrFunc = void 0;
19
+ exports.histogramFromDomain = histogramFromDomain;
20
+ exports.histogramFromThreshold = histogramFromThreshold;
21
+ exports.histogramFromValues = histogramFromValues;
22
+ exports.isPercentField = isPercentField;
23
+ exports.normalizeValue = normalizeValue;
24
+ exports.runGpuFilterForPlot = runGpuFilterForPlot;
25
+ exports.snapToMarks = snapToMarks;
26
+ exports.splitSeries = splitSeries;
27
+ exports.updateAggregationByField = updateAggregationByField;
28
+ exports.updateRangeFilterPlotType = updateRangeFilterPlotType;
29
+ exports.updateTimeFilterPlotType = updateTimeFilterPlotType;
30
+ exports.validBin = validBin;
31
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
32
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
33
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
34
+ var _d3Array = require("d3-array");
35
+ var _lodash = _interopRequireDefault(require("lodash.isequal"));
36
+ var _time = require("./time");
37
+ var _moment = _interopRequireDefault(require("moment"));
38
+ var _commonUtils = require("@kepler.gl/common-utils");
39
+ var _constants = require("@kepler.gl/constants");
40
+ var _dataUtils = require("./data-utils");
41
+ var _aggregation = require("./aggregation");
42
+ var _strings = require("./strings");
43
+ var _format = require("./format");
44
+ var _colorUtils = require("./color-utils");
45
+ function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
46
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
47
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
48
+ 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; }
49
+ 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; } // SPDX-License-Identifier: MIT
50
+ // Copyright contributors to the kepler.gl project
51
+ // TODO kepler-table module isn't accessible from utils. Add compatible interface to types
52
+
53
+ /**
54
+ *
55
+ * @param thresholds
56
+ * @param values
57
+ * @param indexes
58
+ */
59
+ function histogramFromThreshold(thresholds, values, valueAccessor) {
60
+ var filterEmptyBins = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true;
61
+ var getBins = (0, _d3Array.histogram)().domain([thresholds[0], thresholds[thresholds.length - 1]]).thresholds(thresholds);
62
+ if (valueAccessor) {
63
+ getBins.value(valueAccessor);
64
+ }
65
+
66
+ // @ts-ignore
67
+ var bins = getBins(values).map(function (bin) {
68
+ return {
69
+ count: bin.length,
70
+ indexes: bin,
71
+ x0: bin.x0,
72
+ x1: bin.x1
73
+ };
74
+ });
75
+
76
+ // d3-histogram ignores threshold values outside the domain
77
+ // The first bin.x0 is always equal to the minimum domain value, and the last bin.x1 is always equal to the maximum domain value.
78
+
79
+ // bins[0].x0 = thresholds[0];
80
+ // bins[bins.length - 1].x1 = thresholds[thresholds.length - 1];
81
+
82
+ // @ts-ignore
83
+ return filterEmptyBins ? bins.filter(function (b) {
84
+ return b.count > 0;
85
+ }) : bins;
86
+ }
87
+
88
+ /**
89
+ *
90
+ * @param values
91
+ * @param numBins
92
+ * @param valueAccessor
93
+ */
94
+ function histogramFromValues(values, numBins, valueAccessor) {
95
+ var getBins = (0, _d3Array.histogram)().thresholds(numBins);
96
+ if (valueAccessor) {
97
+ getBins.value(valueAccessor);
98
+ }
99
+
100
+ // @ts-ignore d3-array types doesn't match
101
+ return getBins(values).map(function (bin) {
102
+ return {
103
+ count: bin.length,
104
+ indexes: bin,
105
+ x0: bin.x0,
106
+ x1: bin.x1
107
+ };
108
+ }).filter(function (b) {
109
+ var x0 = b.x0,
110
+ x1 = b.x1;
111
+ return (0, _dataUtils.isNumber)(x0) && (0, _dataUtils.isNumber)(x1);
112
+ });
113
+ }
114
+
115
+ /**
116
+ *
117
+ * @param domain
118
+ * @param values
119
+ * @param numBins
120
+ * @param valueAccessor
121
+ */
122
+ function histogramFromDomain(domain, values, numBins, valueAccessor) {
123
+ var getBins = (0, _d3Array.histogram)().thresholds((0, _d3Array.ticks)(domain[0], domain[1], numBins)).domain(domain);
124
+ if (valueAccessor) {
125
+ getBins.value(valueAccessor);
126
+ }
127
+
128
+ // @ts-ignore d3-array types doesn't match
129
+ return getBins(values).map(function (bin) {
130
+ return {
131
+ count: bin.length,
132
+ indexes: bin,
133
+ x0: bin.x0,
134
+ x1: bin.x1
135
+ };
136
+ });
137
+ }
138
+
139
+ /**
140
+ * @param filter
141
+ * @param datasets
142
+ * @param interval
143
+ */
144
+ function getTimeBins(filter, datasets, interval) {
145
+ var bins = filter.timeBins || {};
146
+ filter.dataId.forEach(function (dataId, dataIdIdx) {
147
+ // reuse bins if filterData did not change
148
+ if (bins[dataId] && bins[dataId][interval]) {
149
+ return;
150
+ }
151
+ var dataset = datasets[dataId];
152
+
153
+ // do not apply current filter
154
+ var indexes = runGpuFilterForPlot(dataset, filter);
155
+ bins = _objectSpread(_objectSpread({}, bins), {}, (0, _defineProperty2["default"])({}, dataId, _objectSpread(_objectSpread({}, bins[dataId]), {}, (0, _defineProperty2["default"])({}, interval, binByTime(indexes, dataset, interval, filter)))));
156
+ });
157
+ return bins;
158
+ }
159
+ function binByTime(indexes, dataset, interval, filter) {
160
+ // gpuFilters need to be apply to filteredIndex
161
+ var mappedValue = (0, _time.getFilterMappedValue)(dataset, filter);
162
+ if (!mappedValue) {
163
+ return null;
164
+ }
165
+ var intervalBins = getBinThresholds(interval, filter.domain);
166
+ var valueAccessor = function valueAccessor(idx) {
167
+ return mappedValue[idx];
168
+ };
169
+ var bins = histogramFromThreshold(intervalBins, indexes, valueAccessor);
170
+ return bins;
171
+ }
172
+ function getBinThresholds(interval, domain) {
173
+ var timeInterval = (0, _time.intervalToFunction)(interval);
174
+ var _domain = (0, _slicedToArray2["default"])(domain, 2),
175
+ t0 = _domain[0],
176
+ t1 = _domain[1];
177
+ var floor = timeInterval.floor(t0).getTime();
178
+ var ceiling = timeInterval.ceil(t1).getTime();
179
+ if (!timeInterval) {
180
+ // if time interval is not defined
181
+ // this should not happen
182
+ return [t0, t0 + _constants.durationDay];
183
+ }
184
+ var binThresholds = timeInterval.range(floor, ceiling + 1).map(function (t) {
185
+ return _moment["default"].utc(t).valueOf();
186
+ });
187
+ var lastStep = binThresholds[binThresholds.length - 1];
188
+ if (lastStep === t1) {
189
+ // when last step equal to domain max, add one more step
190
+ binThresholds.push(_moment["default"].utc(timeInterval.offset(lastStep)).valueOf());
191
+ }
192
+ return binThresholds;
193
+ }
194
+
195
+ /**
196
+ * Run GPU filter on current filter result to generate indexes for ploting chart
197
+ * Skip ruuning for the same field
198
+ * @param dataset
199
+ * @param filter
200
+ */
201
+ function runGpuFilterForPlot(dataset, filter) {
202
+ var skipIndexes = getSkipIndexes(dataset, filter);
203
+ var _dataset$gpuFilter = dataset.gpuFilter,
204
+ filterValueUpdateTriggers = _dataset$gpuFilter.filterValueUpdateTriggers,
205
+ filterRange = _dataset$gpuFilter.filterRange,
206
+ filterValueAccessor = _dataset$gpuFilter.filterValueAccessor,
207
+ filteredIndex = dataset.filteredIndex;
208
+ var getFilterValue = filterValueAccessor(dataset.dataContainer)();
209
+ var allChannels = Object.keys(filterValueUpdateTriggers).map(function (_, i) {
210
+ return i;
211
+ }).filter(function (i) {
212
+ return Object.values(filterValueUpdateTriggers)[i];
213
+ });
214
+ var skipAll = !allChannels.filter(function (i) {
215
+ return !skipIndexes.includes(i);
216
+ }).length;
217
+ if (skipAll) {
218
+ return filteredIndex;
219
+ }
220
+ var filterData = getFilterDataFunc(filterRange, getFilterValue, dataset.dataContainer, skipIndexes);
221
+ return filteredIndex.filter(filterData);
222
+ }
223
+ function getSkipIndexes(dataset, filter) {
224
+ // array of gpu filter names
225
+ if (!filter) {
226
+ return [];
227
+ }
228
+ var gpuFilters = Object.values(dataset.gpuFilter.filterValueUpdateTriggers);
229
+ var valueIndex = filter.dataId.findIndex(function (id) {
230
+ return id === dataset.id;
231
+ });
232
+ var filterColumn = filter.name[valueIndex];
233
+ return gpuFilters.reduce(function (accu, item, idx) {
234
+ if (item && filterColumn === item.name) {
235
+ accu.push(idx);
236
+ }
237
+ return accu;
238
+ }, []);
239
+ }
240
+ function getFilterDataFunc(filterRange, getFilterValue, dataContainer, skips) {
241
+ return function (index) {
242
+ return getFilterValue({
243
+ index: index
244
+ }).every(function (val, i) {
245
+ return skips.includes(i) || val >= filterRange[i][0] && val <= filterRange[i][1];
246
+ });
247
+ };
248
+ }
249
+ function validBin(b) {
250
+ return b.x0 !== undefined && b.x1 !== undefined;
251
+ }
252
+
253
+ /**
254
+ * Use in slider, given a number and an array of numbers, return the nears number from the array.
255
+ * Takes a value, timesteps and return the actual step.
256
+ * @param value
257
+ * @param marks
258
+ */
259
+ function snapToMarks(value, marks) {
260
+ // always use bin x0
261
+ if (!marks.length) {
262
+ // @ts-expect-error looking at the usage null return value isn't expected and requires extra handling in a lot of places
263
+ return null;
264
+ }
265
+ var i = (0, _d3Array.bisectLeft)(marks, value);
266
+ if (i === 0) {
267
+ return marks[i];
268
+ } else if (i === marks.length) {
269
+ return marks[i - 1];
270
+ }
271
+ var idx = marks[i] - value < value - marks[i - 1] ? i : i - 1;
272
+ return marks[idx];
273
+ }
274
+ function normalizeValue(val, minValue, step, marks) {
275
+ if (marks && marks.length) {
276
+ return snapToMarks(val, marks);
277
+ }
278
+ return (0, _dataUtils.roundValToStep)(minValue, step, val);
279
+ }
280
+ function isPercentField(field) {
281
+ return field.metadata && field.metadata.numerator && field.metadata.denominator;
282
+ }
283
+ function updateAggregationByField(field, aggregation) {
284
+ // shouldn't apply sum to percent fiele type
285
+ // default aggregation is average
286
+ return field && isPercentField(field) ? _constants.AGGREGATION_TYPES.average : aggregation || _constants.AGGREGATION_TYPES.average;
287
+ }
288
+ var getAgregationType = function getAgregationType(field, aggregation) {
289
+ if (isPercentField(field)) {
290
+ return 'mean_of_percent';
291
+ }
292
+ return aggregation;
293
+ };
294
+ var getAggregationAccessor = function getAggregationAccessor(field, dataContainer, fields) {
295
+ if (isPercentField(field)) {
296
+ var numeratorIdx = fields.findIndex(function (f) {
297
+ return f.name === field.metadata.numerator;
298
+ });
299
+ var denominatorIdx = fields.findIndex(function (f) {
300
+ return f.name === field.metadata.denominator;
301
+ });
302
+ return {
303
+ getNumerator: function getNumerator(i) {
304
+ return dataContainer.valueAt(i, numeratorIdx);
305
+ },
306
+ getDenominator: function getDenominator(i) {
307
+ return dataContainer.valueAt(i, denominatorIdx);
308
+ }
309
+ };
310
+ }
311
+ return function (i) {
312
+ return field.valueAccessor({
313
+ index: i
314
+ });
315
+ };
316
+ };
317
+ var getValueAggrFunc = exports.getValueAggrFunc = function getValueAggrFunc(field, aggregation, dataset) {
318
+ var dataContainer = dataset.dataContainer,
319
+ fields = dataset.fields;
320
+
321
+ // The passed-in field might not have all the fields set (e.g. valueAccessor)
322
+ var datasetField = fields.find(function (f) {
323
+ return field && (f.name === field || f.name === field.name);
324
+ });
325
+ return datasetField && aggregation ? function (bin) {
326
+ return (0, _aggregation.aggregate)(bin.indexes, getAgregationType(datasetField, aggregation),
327
+ // @ts-expect-error can return {getNumerator, getDenominator}
328
+ getAggregationAccessor(datasetField, dataContainer, fields));
329
+ } : function (bin) {
330
+ return bin.count;
331
+ };
332
+ };
333
+ var getAggregationOptiosnBasedOnField = exports.getAggregationOptiosnBasedOnField = function getAggregationOptiosnBasedOnField(field) {
334
+ if (isPercentField(field)) {
335
+ // don't show sum
336
+ return _constants.TIME_AGGREGATION.filter(function (_ref) {
337
+ var id = _ref.id;
338
+ return id !== _constants.AGGREGATION_TYPES.sum;
339
+ });
340
+ }
341
+ return _constants.TIME_AGGREGATION;
342
+ };
343
+ function getDelta(bins, y, interval) {
344
+ // if (WOW[interval]) return getWow(bins, y, interval);
345
+ var lastBin = bins[bins.length - 1];
346
+ return {
347
+ delta: 'last',
348
+ pct: lastBin ? getPctChange(y, lastBin.y) : null
349
+ };
350
+ }
351
+ function getPctChange(y, y0) {
352
+ if (Number.isFinite(y) && Number.isFinite(y0) && y0 !== 0) {
353
+ return (y - y0) / y0;
354
+ }
355
+ return null;
356
+ }
357
+
358
+ /**
359
+ *
360
+ * @param datasets
361
+ * @param filter
362
+ */
363
+ function getLineChart(datasets, filter) {
364
+ var _timeBins;
365
+ var dataId = filter.dataId,
366
+ yAxis = filter.yAxis,
367
+ plotType = filter.plotType,
368
+ lineChart = filter.lineChart;
369
+ var aggregation = plotType.aggregation,
370
+ interval = plotType.interval;
371
+ var seriesDataId = dataId[0];
372
+ var bins = (_timeBins = filter.timeBins) === null || _timeBins === void 0 || (_timeBins = _timeBins[seriesDataId]) === null || _timeBins === void 0 ? void 0 : _timeBins[interval];
373
+ if (lineChart && lineChart.aggregation === aggregation && lineChart.interval === interval && lineChart.yAxis === (yAxis === null || yAxis === void 0 ? void 0 : yAxis.name) &&
374
+ // we need to make sure we validate bins because of cross filter data changes
375
+ (0, _lodash["default"])(bins, lineChart === null || lineChart === void 0 ? void 0 : lineChart.bins)) {
376
+ // don't update lineChart if plotType hasn't change
377
+ return lineChart;
378
+ }
379
+ var dataset = datasets[seriesDataId];
380
+ var getYValue = getValueAggrFunc(yAxis, aggregation, dataset);
381
+ var init = [];
382
+ var series = (bins || []).reduce(function (accu, bin, i) {
383
+ var y = getYValue(bin);
384
+ var delta = getDelta(accu, y, interval);
385
+ accu.push(_objectSpread({
386
+ x: bin.x0,
387
+ y: y
388
+ }, delta));
389
+ return accu;
390
+ }, init);
391
+ var yDomain = (0, _d3Array.extent)(series, function (d) {
392
+ return d.y;
393
+ });
394
+ var xDomain = bins ? [bins[0].x0, bins[bins.length - 1].x1] : [];
395
+
396
+ // treat missing data as another series
397
+ var split = splitSeries(series);
398
+ var aggrName = _aggregation.AGGREGATION_NAME[aggregation];
399
+ return {
400
+ // @ts-ignore
401
+ yDomain: yDomain,
402
+ // @ts-ignore
403
+ xDomain: xDomain,
404
+ interval: interval,
405
+ aggregation: aggregation,
406
+ // @ts-ignore
407
+ series: split,
408
+ title: "".concat(aggrName, ' of ').concat(yAxis ? yAxis.name : 'Count'),
409
+ fieldType: yAxis ? yAxis.type : 'integer',
410
+ yAxis: yAxis ? yAxis.name : null,
411
+ allTime: {
412
+ title: "All Time Average",
413
+ value: (0, _aggregation.aggregate)(series, _constants.AGGREGATION_TYPES.average, function (d) {
414
+ return d.y;
415
+ })
416
+ },
417
+ // @ts-expect-error bins is Bins[], not a Bins map. Refactor to use correct types.
418
+ bins: bins
419
+ };
420
+ }
421
+
422
+ // split into multiple series when see missing data
423
+ function splitSeries(series) {
424
+ var lines = [];
425
+ var temp = [];
426
+ for (var i = 0; i < series.length; i++) {
427
+ var d = series[i];
428
+ if (!(0, _commonUtils.notNullorUndefined)(d.y) && temp.length) {
429
+ // ends temp
430
+ lines.push(temp);
431
+ temp = [];
432
+ } else if ((0, _commonUtils.notNullorUndefined)(d.y)) {
433
+ temp.push(d);
434
+ }
435
+ if (i === series.length - 1 && temp.length) {
436
+ lines.push(temp);
437
+ }
438
+ }
439
+ var markers = lines.length > 1 ? series.filter(function (d) {
440
+ return (0, _commonUtils.notNullorUndefined)(d.y);
441
+ }) : [];
442
+ return {
443
+ lines: lines,
444
+ markers: markers
445
+ };
446
+ }
447
+ function adjustValueToAnimationWindow(state, filter) {
448
+ var plotType = filter.plotType,
449
+ _filter$value = (0, _slicedToArray2["default"])(filter.value, 2),
450
+ value0 = _filter$value[0],
451
+ value1 = _filter$value[1],
452
+ animationWindow = filter.animationWindow;
453
+ var interval = plotType.interval || (0, _time.getInitialInterval)(filter, state.datasets);
454
+ var bins = getTimeBins(filter, state.datasets, interval);
455
+ var datasetBins = bins && Object.keys(bins).length && Object.values(bins)[0][interval];
456
+ var thresholds = (datasetBins || []).map(function (b) {
457
+ return b.x0;
458
+ });
459
+ var val0 = value0;
460
+ var val1 = value1;
461
+ var idx;
462
+ if (animationWindow === _constants.ANIMATION_WINDOW.interval) {
463
+ val0 = snapToMarks(value1, thresholds);
464
+ idx = thresholds.indexOf(val0);
465
+ val1 = idx > -1 ? datasetBins[idx].x1 : NaN;
466
+ } else {
467
+ // fit current value to window
468
+ val0 = snapToMarks(value0, thresholds);
469
+ val1 = snapToMarks(value1, thresholds);
470
+ if (val0 === val1) {
471
+ idx = thresholds.indexOf(val0);
472
+ if (idx === thresholds.length - 1) {
473
+ val0 = thresholds[idx - 1];
474
+ } else {
475
+ val1 = thresholds[idx + 1];
476
+ }
477
+ }
478
+ }
479
+ var updatedFilter = _objectSpread(_objectSpread({}, filter), {}, {
480
+ plotType: _objectSpread(_objectSpread({}, filter.plotType), {}, {
481
+ interval: interval
482
+ }),
483
+ timeBins: bins,
484
+ value: [val0, val1]
485
+ });
486
+ return updatedFilter;
487
+ }
488
+
489
+ /**
490
+ * Create or update colors for a filter plot
491
+ * @param filter
492
+ * @param datasets
493
+ * @param oldColorsByDataId
494
+ */
495
+ function getFilterPlotColorsByDataId(filter, datasets, oldColorsByDataId) {
496
+ var colorsByDataId = oldColorsByDataId || {};
497
+ var _iterator = _createForOfIteratorHelper(filter.dataId),
498
+ _step;
499
+ try {
500
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
501
+ var dataId = _step.value;
502
+ if (!colorsByDataId[dataId] && datasets[dataId]) {
503
+ colorsByDataId = _objectSpread(_objectSpread({}, colorsByDataId), {}, (0, _defineProperty2["default"])({}, dataId, (0, _colorUtils.rgbToHex)(datasets[dataId].color)));
504
+ }
505
+ }
506
+ } catch (err) {
507
+ _iterator.e(err);
508
+ } finally {
509
+ _iterator.f();
510
+ }
511
+ return colorsByDataId;
512
+ }
513
+
514
+ /**
515
+ *
516
+ * @param filter
517
+ * @param plotType
518
+ * @param datasets
519
+ * @param dataId
520
+ */
521
+ function updateTimeFilterPlotType(filter, plotType, datasets, dataId) {
522
+ var nextFilter = filter;
523
+ var nextPlotType = plotType;
524
+ if ((0, _typeof2["default"])(nextPlotType) !== 'object' || !nextPlotType.aggregation || !nextPlotType.interval) {
525
+ nextPlotType = getDefaultPlotType(filter, datasets);
526
+ }
527
+ if (filter.dataId.length > 1) {
528
+ nextPlotType = _objectSpread(_objectSpread({}, nextPlotType), {}, {
529
+ colorsByDataId: getFilterPlotColorsByDataId(filter, datasets, nextPlotType.colorsByDataId)
530
+ });
531
+ }
532
+ nextFilter = _objectSpread(_objectSpread({}, nextFilter), {}, {
533
+ plotType: nextPlotType
534
+ });
535
+ var bins = getTimeBins(nextFilter, datasets, nextPlotType.interval);
536
+ nextFilter = _objectSpread(_objectSpread({}, nextFilter), {}, {
537
+ timeBins: bins
538
+ });
539
+ if (plotType.type === _constants.PLOT_TYPES.histogram) {
540
+ // Histogram is calculated and memoized in the chart itself
541
+ } else if (plotType.type === _constants.PLOT_TYPES.lineChart) {
542
+ // we should be able to move this into its own component so react will do the shallow comparison for us.
543
+ nextFilter = _objectSpread(_objectSpread({}, nextFilter), {}, {
544
+ lineChart: getLineChart(datasets, nextFilter)
545
+ });
546
+ }
547
+ return nextFilter;
548
+ }
549
+ function getRangeFilterBins(filter, datasets, numBins) {
550
+ var domain = filter.domain;
551
+ if (!filter.dataId) return null;
552
+ return filter.dataId.reduce(function (acc, dataId, datasetIdx) {
553
+ var _filter$bins;
554
+ if ((_filter$bins = filter.bins) !== null && _filter$bins !== void 0 && _filter$bins[dataId]) {
555
+ // don't recalculate bins
556
+ acc[dataId] = filter.bins[dataId];
557
+ return acc;
558
+ }
559
+ var fieldName = filter.name[datasetIdx];
560
+ if (dataId && fieldName) {
561
+ var dataset = datasets[dataId];
562
+ var field = dataset === null || dataset === void 0 ? void 0 : dataset.getColumnField(fieldName);
563
+ if (dataset && field) {
564
+ var indexes = runGpuFilterForPlot(dataset, filter);
565
+ var valueAccessor = function valueAccessor(index) {
566
+ return field.valueAccessor({
567
+ index: index
568
+ });
569
+ };
570
+ acc[dataId] = histogramFromDomain(domain, indexes, numBins, valueAccessor);
571
+ }
572
+ }
573
+ return acc;
574
+ }, {});
575
+ }
576
+ function updateRangeFilterPlotType(filter, plotType, datasets, dataId) {
577
+ var nextFilter = _objectSpread(_objectSpread({}, filter), {}, {
578
+ plotType: plotType
579
+ });
580
+
581
+ // if (dataId) {
582
+ // // clear bins
583
+ // nextFilter = {
584
+ // ...nextFilter,
585
+ // bins: {
586
+ // ...nextFilter.bins,
587
+ // [dataId]: null
588
+ // }
589
+ // };
590
+ // }
591
+
592
+ return _objectSpread(_objectSpread({}, filter), {}, {
593
+ plotType: plotType,
594
+ bins: getRangeFilterBins(nextFilter, datasets, _constants.BINS)
595
+ });
596
+ }
597
+ function getChartTitle(yAxis, plotType) {
598
+ var yAxisName = yAxis === null || yAxis === void 0 ? void 0 : yAxis.displayName;
599
+ var aggregation = plotType.aggregation;
600
+ if (yAxisName) {
601
+ return (0, _strings.capitalizeFirstLetter)("".concat(aggregation, " ").concat(yAxisName, " over Time"));
602
+ }
603
+ return "Count of Rows over Time";
604
+ }
605
+ function getDefaultPlotType(filter, datasets) {
606
+ var interval = (0, _time.getInitialInterval)(filter, datasets);
607
+ var defaultTimeFormat = (0, _format.getDefaultTimeFormat)(interval);
608
+ return {
609
+ interval: interval,
610
+ defaultTimeFormat: defaultTimeFormat,
611
+ type: _constants.PLOT_TYPES.histogram,
612
+ aggregation: _constants.AGGREGATION_TYPES.sum
613
+ };
614
+ }
615
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_d3Array","require","_lodash","_interopRequireDefault","_time","_moment","_commonUtils","_constants","_dataUtils","_aggregation","_strings","_format","_colorUtils","_createForOfIteratorHelper","r","e","t","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","_n","F","s","n","done","value","f","TypeError","o","a","u","call","next","_arrayLikeToArray","toString","slice","constructor","name","from","test","ownKeys","Object","keys","getOwnPropertySymbols","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","histogramFromThreshold","thresholds","values","valueAccessor","filterEmptyBins","undefined","getBins","d3Histogram","domain","bins","map","bin","count","indexes","x0","x1","b","histogramFromValues","numBins","isNumber","histogramFromDomain","ticks","getTimeBins","datasets","interval","timeBins","dataId","dataIdIdx","dataset","runGpuFilterForPlot","binByTime","mappedValue","getFilterMappedValue","intervalBins","getBinThresholds","idx","timeInterval","intervalToFunction","_domain","_slicedToArray2","t0","t1","floor","getTime","ceiling","ceil","durationDay","binThresholds","range","moment","utc","valueOf","lastStep","offset","skipIndexes","getSkipIndexes","_dataset$gpuFilter","gpuFilter","filterValueUpdateTriggers","filterRange","filterValueAccessor","filteredIndex","getFilterValue","dataContainer","allChannels","_","i","skipAll","includes","filterData","getFilterDataFunc","gpuFilters","valueIndex","findIndex","id","filterColumn","reduce","accu","item","skips","index","every","val","validBin","snapToMarks","marks","bisectLeft","normalizeValue","minValue","step","roundValToStep","isPercentField","field","metadata","numerator","denominator","updateAggregationByField","aggregation","AGGREGATION_TYPES","average","getAgregationType","getAggregationAccessor","fields","numeratorIdx","denominatorIdx","getNumerator","valueAt","getDenominator","getValueAggrFunc","exports","datasetField","find","aggregate","getAggregationOptiosnBasedOnField","TIME_AGGREGATION","_ref","sum","getDelta","y","lastBin","delta","pct","getPctChange","y0","Number","isFinite","getLineChart","_timeBins","yAxis","plotType","lineChart","seriesDataId","isEqual","getYValue","init","series","x","yDomain","extent","d","xDomain","split","splitSeries","aggrName","AGGREGATION_NAME","title","concat","fieldType","type","allTime","lines","temp","notNullorUndefined","markers","adjustValueToAnimationWindow","state","_filter$value","value0","value1","animationWindow","getInitialInterval","datasetBins","val0","val1","ANIMATION_WINDOW","indexOf","NaN","updatedFilter","getFilterPlotColorsByDataId","oldColorsByDataId","colorsByDataId","_iterator","_step","rgbToHex","color","err","updateTimeFilterPlotType","nextFilter","nextPlotType","_typeof2","getDefaultPlotType","PLOT_TYPES","histogram","getRangeFilterBins","acc","datasetIdx","_filter$bins","fieldName","getColumnField","updateRangeFilterPlotType","BINS","getChartTitle","yAxisName","displayName","capitalizeFirstLetter","defaultTimeFormat","getDefaultTimeFormat"],"sources":["../src/plot.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {bisectLeft, extent, histogram as d3Histogram, ticks} from 'd3-array';\nimport isEqual from 'lodash.isequal';\nimport {getFilterMappedValue, getInitialInterval, intervalToFunction} from './time';\nimport moment from 'moment';\nimport {\n  Bin,\n  TimeBins,\n  Millisecond,\n  TimeRangeFilter,\n  RangeFilter,\n  PlotType,\n  Filter,\n  LineChart,\n  Field,\n  ValueOf,\n  LineDatum\n} from '@kepler.gl/types';\nimport {notNullorUndefined} from '@kepler.gl/common-utils';\nimport {\n  ANIMATION_WINDOW,\n  BINS,\n  durationDay,\n  TIME_AGGREGATION,\n  AGGREGATION_TYPES,\n  PLOT_TYPES,\n  AggregationTypes\n} from '@kepler.gl/constants';\n\nimport {isNumber, roundValToStep} from './data-utils';\nimport {aggregate, AGGREGATION_NAME} from './aggregation';\nimport {capitalizeFirstLetter} from './strings';\nimport {getDefaultTimeFormat} from './format';\nimport {rgbToHex} from './color-utils';\nimport {DataContainerInterface} from '.';\nimport {KeplerTableModel} from './types';\n\n// TODO kepler-table module isn't accessible from utils. Add compatible interface to types\ntype Datasets = any;\n\n/**\n *\n * @param thresholds\n * @param values\n * @param indexes\n */\nexport function histogramFromThreshold(\n  thresholds: number[],\n  values: number[],\n  valueAccessor?: (d: unknown) => number,\n  filterEmptyBins = true\n): Bin[] {\n  const getBins = d3Histogram()\n    .domain([thresholds[0], thresholds[thresholds.length - 1]])\n    .thresholds(thresholds);\n\n  if (valueAccessor) {\n    getBins.value(valueAccessor);\n  }\n\n  // @ts-ignore\n  const bins = getBins(values).map(bin => ({\n    count: bin.length,\n    indexes: bin,\n    x0: bin.x0,\n    x1: bin.x1\n  }));\n\n  // d3-histogram ignores threshold values outside the domain\n  // The first bin.x0 is always equal to the minimum domain value, and the last bin.x1 is always equal to the maximum domain value.\n\n  // bins[0].x0 = thresholds[0];\n  // bins[bins.length - 1].x1 = thresholds[thresholds.length - 1];\n\n  // @ts-ignore\n  return filterEmptyBins ? bins.filter(b => b.count > 0) : bins;\n}\n\n/**\n *\n * @param values\n * @param numBins\n * @param valueAccessor\n */\nexport function histogramFromValues(\n  values: (Millisecond | null | number)[],\n  numBins: number,\n  valueAccessor?: (d: unknown) => number\n) {\n  const getBins = d3Histogram().thresholds(numBins);\n\n  if (valueAccessor) {\n    getBins.value(valueAccessor);\n  }\n\n  // @ts-ignore d3-array types doesn't match\n  return getBins(values)\n    .map(bin => ({\n      count: bin.length,\n      indexes: bin,\n      x0: bin.x0,\n      x1: bin.x1\n    }))\n    .filter(b => {\n      const {x0, x1} = b;\n      return isNumber(x0) && isNumber(x1);\n    });\n}\n\n/**\n *\n * @param domain\n * @param values\n * @param numBins\n * @param valueAccessor\n */\nexport function histogramFromDomain(\n  domain: [number, number],\n  values: (Millisecond | null | number)[],\n  numBins: number,\n  valueAccessor?: (d: unknown) => number\n): Bin[] {\n  const getBins = d3Histogram().thresholds(ticks(domain[0], domain[1], numBins)).domain(domain);\n  if (valueAccessor) {\n    getBins.value(valueAccessor);\n  }\n\n  // @ts-ignore d3-array types doesn't match\n  return getBins(values).map(bin => ({\n    count: bin.length,\n    indexes: bin,\n    x0: bin.x0,\n    x1: bin.x1\n  }));\n}\n\n/**\n * @param filter\n * @param datasets\n * @param interval\n */\nexport function getTimeBins(\n  filter: TimeRangeFilter,\n  datasets: Datasets,\n  interval: PlotType['interval']\n): TimeBins {\n  let bins = filter.timeBins || {};\n\n  filter.dataId.forEach((dataId, dataIdIdx) => {\n    // reuse bins if filterData did not change\n    if (bins[dataId] && bins[dataId][interval]) {\n      return;\n    }\n    const dataset = datasets[dataId];\n\n    // do not apply current filter\n    const indexes = runGpuFilterForPlot(dataset, filter);\n\n    bins = {\n      ...bins,\n      [dataId]: {\n        ...bins[dataId],\n        [interval]: binByTime(indexes, dataset, interval, filter)\n      }\n    };\n  });\n\n  return bins;\n}\n\nexport function binByTime(indexes, dataset, interval, filter) {\n  // gpuFilters need to be apply to filteredIndex\n  const mappedValue = getFilterMappedValue(dataset, filter);\n  if (!mappedValue) {\n    return null;\n  }\n  const intervalBins = getBinThresholds(interval, filter.domain);\n  const valueAccessor = idx => mappedValue[idx];\n  const bins = histogramFromThreshold(intervalBins, indexes, valueAccessor);\n\n  return bins;\n}\n\nexport function getBinThresholds(interval: string, domain: number[]): number[] {\n  const timeInterval = intervalToFunction(interval);\n  const [t0, t1] = domain;\n  const floor = timeInterval.floor(t0).getTime();\n  const ceiling = timeInterval.ceil(t1).getTime();\n\n  if (!timeInterval) {\n    // if time interval is not defined\n    // this should not happen\n    return [t0, t0 + durationDay];\n  }\n  const binThresholds = timeInterval.range(floor, ceiling + 1).map(t => moment.utc(t).valueOf());\n  const lastStep = binThresholds[binThresholds.length - 1];\n  if (lastStep === t1) {\n    // when last step equal to domain max, add one more step\n    binThresholds.push(moment.utc(timeInterval.offset(lastStep)).valueOf());\n  }\n\n  return binThresholds;\n}\n\n/**\n * Run GPU filter on current filter result to generate indexes for ploting chart\n * Skip ruuning for the same field\n * @param dataset\n * @param filter\n */\nexport function runGpuFilterForPlot<K extends KeplerTableModel<K, L>, L>(\n  dataset: K,\n  filter?: Filter\n): number[] {\n  const skipIndexes = getSkipIndexes(dataset, filter);\n\n  const {\n    gpuFilter: {filterValueUpdateTriggers, filterRange, filterValueAccessor},\n    filteredIndex\n  } = dataset;\n  const getFilterValue = filterValueAccessor(dataset.dataContainer)();\n\n  const allChannels = Object.keys(filterValueUpdateTriggers)\n    .map((_, i) => i)\n    .filter(i => Object.values(filterValueUpdateTriggers)[i]);\n  const skipAll = !allChannels.filter(i => !skipIndexes.includes(i)).length;\n  if (skipAll) {\n    return filteredIndex;\n  }\n\n  const filterData = getFilterDataFunc(\n    filterRange,\n    getFilterValue,\n    dataset.dataContainer,\n    skipIndexes\n  );\n\n  return filteredIndex.filter(filterData);\n}\n\nfunction getSkipIndexes(dataset, filter) {\n  // array of gpu filter names\n  if (!filter) {\n    return [];\n  }\n  const gpuFilters = Object.values(dataset.gpuFilter.filterValueUpdateTriggers) as ({\n    name: string;\n  } | null)[];\n  const valueIndex = filter.dataId.findIndex(id => id === dataset.id);\n  const filterColumn = filter.name[valueIndex];\n\n  return gpuFilters.reduce((accu, item, idx) => {\n    if (item && filterColumn === item.name) {\n      accu.push(idx);\n    }\n    return accu;\n  }, [] as number[]);\n}\n\nexport function getFilterDataFunc(\n  filterRange,\n  getFilterValue,\n  dataContainer: DataContainerInterface,\n  skips\n) {\n  return index =>\n    getFilterValue({index}).every(\n      (val, i) => skips.includes(i) || (val >= filterRange[i][0] && val <= filterRange[i][1])\n    );\n}\n\nexport function validBin(b) {\n  return b.x0 !== undefined && b.x1 !== undefined;\n}\n\n/**\n * Use in slider, given a number and an array of numbers, return the nears number from the array.\n * Takes a value, timesteps and return the actual step.\n * @param value\n * @param marks\n */\nexport function snapToMarks(value: number, marks: number[]): number {\n  // always use bin x0\n  if (!marks.length) {\n    // @ts-expect-error looking at the usage null return value isn't expected and requires extra handling in a lot of places\n    return null;\n  }\n  const i = bisectLeft(marks, value);\n  if (i === 0) {\n    return marks[i];\n  } else if (i === marks.length) {\n    return marks[i - 1];\n  }\n  const idx = marks[i] - value < value - marks[i - 1] ? i : i - 1;\n  return marks[idx];\n}\n\nexport function normalizeValue(val, minValue, step, marks) {\n  if (marks && marks.length) {\n    return snapToMarks(val, marks);\n  }\n\n  return roundValToStep(minValue, step, val);\n}\n\nexport function isPercentField(field) {\n  return field.metadata && field.metadata.numerator && field.metadata.denominator;\n}\n\nexport function updateAggregationByField(field: Field, aggregation: ValueOf<AggregationTypes>) {\n  // shouldn't apply sum to percent fiele type\n  // default aggregation is average\n  return field && isPercentField(field)\n    ? AGGREGATION_TYPES.average\n    : aggregation || AGGREGATION_TYPES.average;\n}\n\nconst getAgregationType = (field, aggregation) => {\n  if (isPercentField(field)) {\n    return 'mean_of_percent';\n  }\n  return aggregation;\n};\n\nconst getAggregationAccessor = (field, dataContainer: DataContainerInterface, fields) => {\n  if (isPercentField(field)) {\n    const numeratorIdx = fields.findIndex(f => f.name === field.metadata.numerator);\n    const denominatorIdx = fields.findIndex(f => f.name === field.metadata.denominator);\n\n    return {\n      getNumerator: i => dataContainer.valueAt(i, numeratorIdx),\n      getDenominator: i => dataContainer.valueAt(i, denominatorIdx)\n    };\n  }\n\n  return i => field.valueAccessor({index: i});\n};\n\nexport const getValueAggrFunc = (\n  field: Field | string | null,\n  aggregation: string,\n  dataset: KeplerTableModel<any, any>\n): ((bin: Bin) => number) => {\n  const {dataContainer, fields} = dataset;\n\n  // The passed-in field might not have all the fields set (e.g. valueAccessor)\n  const datasetField = fields.find(\n    f => field && (f.name === field || f.name === (field as Field).name)\n  );\n\n  return datasetField && aggregation\n    ? bin =>\n        aggregate(\n          bin.indexes,\n          getAgregationType(datasetField, aggregation),\n          // @ts-expect-error can return {getNumerator, getDenominator}\n          getAggregationAccessor(datasetField, dataContainer, fields)\n        )\n    : bin => bin.count;\n};\n\nexport const getAggregationOptiosnBasedOnField = field => {\n  if (isPercentField(field)) {\n    // don't show sum\n    return TIME_AGGREGATION.filter(({id}) => id !== AGGREGATION_TYPES.sum);\n  }\n  return TIME_AGGREGATION;\n};\n\nfunction getDelta(\n  bins: LineDatum[],\n  y: number,\n  interval: PlotType['interval']\n): Partial<LineDatum> & {delta: 'last'; pct: number | null} {\n  // if (WOW[interval]) return getWow(bins, y, interval);\n  const lastBin = bins[bins.length - 1];\n\n  return {\n    delta: 'last',\n    pct: lastBin ? getPctChange(y, lastBin.y) : null\n  };\n}\n\nexport function getPctChange(y: unknown, y0: unknown): number | null {\n  if (Number.isFinite(y) && Number.isFinite(y0) && y0 !== 0) {\n    return ((y as number) - (y0 as number)) / (y0 as number);\n  }\n  return null;\n}\n\n/**\n *\n * @param datasets\n * @param filter\n */\nexport function getLineChart(datasets: Datasets, filter: Filter): LineChart {\n  const {dataId, yAxis, plotType, lineChart} = filter;\n  const {aggregation, interval} = plotType;\n  const seriesDataId = dataId[0];\n  const bins = (filter as TimeRangeFilter).timeBins?.[seriesDataId]?.[interval];\n\n  if (\n    lineChart &&\n    lineChart.aggregation === aggregation &&\n    lineChart.interval === interval &&\n    lineChart.yAxis === yAxis?.name &&\n    // we need to make sure we validate bins because of cross filter data changes\n    isEqual(bins, lineChart?.bins)\n  ) {\n    // don't update lineChart if plotType hasn't change\n    return lineChart;\n  }\n\n  const dataset = datasets[seriesDataId];\n  const getYValue = getValueAggrFunc(yAxis, aggregation, dataset);\n\n  const init: LineDatum[] = [];\n  const series = (bins || []).reduce((accu, bin, i) => {\n    const y = getYValue(bin);\n    const delta = getDelta(accu, y, interval);\n    accu.push({\n      x: bin.x0,\n      y,\n      ...delta\n    });\n    return accu;\n  }, init);\n\n  const yDomain = extent<{y: any}>(series, d => d.y);\n  const xDomain = bins ? [bins[0].x0, bins[bins.length - 1].x1] : [];\n\n  // treat missing data as another series\n  const split = splitSeries(series);\n  const aggrName = AGGREGATION_NAME[aggregation];\n\n  return {\n    // @ts-ignore\n    yDomain,\n    // @ts-ignore\n    xDomain,\n    interval,\n    aggregation,\n    // @ts-ignore\n    series: split,\n    title: `${aggrName}${' of '}${yAxis ? yAxis.name : 'Count'}`,\n    fieldType: yAxis ? yAxis.type : 'integer',\n    yAxis: yAxis ? yAxis.name : null,\n    allTime: {\n      title: `All Time Average`,\n      value: aggregate(series, AGGREGATION_TYPES.average, d => d.y)\n    },\n    // @ts-expect-error bins is Bins[], not a Bins map. Refactor to use correct types.\n    bins\n  };\n}\n\n// split into multiple series when see missing data\nexport function splitSeries(series) {\n  const lines: any[] = [];\n  let temp: any[] = [];\n  for (let i = 0; i < series.length; i++) {\n    const d = series[i];\n    if (!notNullorUndefined(d.y) && temp.length) {\n      // ends temp\n      lines.push(temp);\n      temp = [];\n    } else if (notNullorUndefined(d.y)) {\n      temp.push(d);\n    }\n\n    if (i === series.length - 1 && temp.length) {\n      lines.push(temp);\n    }\n  }\n\n  const markers = lines.length > 1 ? series.filter(d => notNullorUndefined(d.y)) : [];\n\n  return {lines, markers};\n}\n\ntype MinVisStateForAnimationWindow = {\n  datasets: Datasets;\n};\n\nexport function adjustValueToAnimationWindow<S extends MinVisStateForAnimationWindow>(\n  state: S,\n  filter: TimeRangeFilter\n) {\n  const {\n    plotType,\n    value: [value0, value1],\n    animationWindow\n  } = filter;\n\n  const interval = plotType.interval || getInitialInterval(filter, state.datasets);\n  const bins = getTimeBins(filter, state.datasets, interval);\n  const datasetBins = bins && Object.keys(bins).length && Object.values(bins)[0][interval];\n  const thresholds = (datasetBins || []).map(b => b.x0);\n\n  let val0 = value0;\n  let val1 = value1;\n  let idx;\n  if (animationWindow === ANIMATION_WINDOW.interval) {\n    val0 = snapToMarks(value1, thresholds);\n    idx = thresholds.indexOf(val0);\n    val1 = idx > -1 ? datasetBins[idx].x1 : NaN;\n  } else {\n    // fit current value to window\n    val0 = snapToMarks(value0, thresholds);\n    val1 = snapToMarks(value1, thresholds);\n\n    if (val0 === val1) {\n      idx = thresholds.indexOf(val0);\n      if (idx === thresholds.length - 1) {\n        val0 = thresholds[idx - 1];\n      } else {\n        val1 = thresholds[idx + 1];\n      }\n    }\n  }\n\n  const updatedFilter = {\n    ...filter,\n    plotType: {\n      ...filter.plotType,\n      interval\n    },\n    timeBins: bins,\n    value: [val0, val1]\n  };\n\n  return updatedFilter;\n}\n\n/**\n * Create or update colors for a filter plot\n * @param filter\n * @param datasets\n * @param oldColorsByDataId\n */\nfunction getFilterPlotColorsByDataId(filter, datasets, oldColorsByDataId) {\n  let colorsByDataId = oldColorsByDataId || {};\n  for (const dataId of filter.dataId) {\n    if (!colorsByDataId[dataId] && datasets[dataId]) {\n      colorsByDataId = {\n        ...colorsByDataId,\n        [dataId]: rgbToHex(datasets[dataId].color)\n      };\n    }\n  }\n  return colorsByDataId;\n}\n\n/**\n *\n * @param filter\n * @param plotType\n * @param datasets\n * @param dataId\n */\nexport function updateTimeFilterPlotType(\n  filter: TimeRangeFilter,\n  plotType: TimeRangeFilter['plotType'],\n  datasets: Datasets,\n  dataId?: string\n): TimeRangeFilter {\n  let nextFilter = filter;\n  let nextPlotType = plotType;\n  if (typeof nextPlotType !== 'object' || !nextPlotType.aggregation || !nextPlotType.interval) {\n    nextPlotType = getDefaultPlotType(filter, datasets);\n  }\n\n  if (filter.dataId.length > 1) {\n    nextPlotType = {\n      ...nextPlotType,\n      colorsByDataId: getFilterPlotColorsByDataId(filter, datasets, nextPlotType.colorsByDataId)\n    };\n  }\n  nextFilter = {\n    ...nextFilter,\n    plotType: nextPlotType\n  };\n\n  const bins = getTimeBins(nextFilter, datasets, nextPlotType.interval);\n\n  nextFilter = {\n    ...nextFilter,\n    timeBins: bins\n  };\n\n  if (plotType.type === PLOT_TYPES.histogram) {\n    // Histogram is calculated and memoized in the chart itself\n  } else if (plotType.type === PLOT_TYPES.lineChart) {\n    // we should be able to move this into its own component so react will do the shallow comparison for us.\n    nextFilter = {\n      ...nextFilter,\n      lineChart: getLineChart(datasets, nextFilter)\n    };\n  }\n\n  return nextFilter;\n}\n\nexport function getRangeFilterBins(filter, datasets, numBins) {\n  const {domain} = filter;\n  if (!filter.dataId) return null;\n\n  return filter.dataId.reduce((acc, dataId, datasetIdx) => {\n    if (filter.bins?.[dataId]) {\n      // don't recalculate bins\n      acc[dataId] = filter.bins[dataId];\n      return acc;\n    }\n    const fieldName = filter.name[datasetIdx];\n    if (dataId && fieldName) {\n      const dataset = datasets[dataId];\n      const field = dataset?.getColumnField(fieldName);\n      if (dataset && field) {\n        const indexes = runGpuFilterForPlot(dataset, filter);\n        const valueAccessor = index => field.valueAccessor({index});\n        acc[dataId] = histogramFromDomain(domain, indexes, numBins, valueAccessor);\n      }\n    }\n    return acc;\n  }, {});\n}\n\nexport function updateRangeFilterPlotType(\n  filter: RangeFilter,\n  plotType: RangeFilter['plotType'],\n  datasets: Datasets,\n  dataId?: string\n): RangeFilter {\n  const nextFilter = {\n    ...filter,\n    plotType\n  };\n\n  // if (dataId) {\n  //   // clear bins\n  //   nextFilter = {\n  //     ...nextFilter,\n  //     bins: {\n  //       ...nextFilter.bins,\n  //       [dataId]: null\n  //     }\n  //   };\n  // }\n\n  return {\n    ...filter,\n    plotType,\n    bins: getRangeFilterBins(nextFilter, datasets, BINS)\n  };\n}\n\nexport function getChartTitle(\n  yAxis: {displayName?: string},\n  plotType: {aggregation: string}\n): string {\n  const yAxisName = yAxis?.displayName;\n  const {aggregation} = plotType;\n\n  if (yAxisName) {\n    return capitalizeFirstLetter(`${aggregation} ${yAxisName} over Time`);\n  }\n\n  return `Count of Rows over Time`;\n}\n\nexport function getDefaultPlotType(filter, datasets) {\n  const interval = getInitialInterval(filter, datasets);\n  const defaultTimeFormat = getDefaultTimeFormat(interval);\n  return {\n    interval,\n    defaultTimeFormat,\n    type: PLOT_TYPES.histogram,\n    aggregation: AGGREGATION_TYPES.sum\n  };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,IAAAA,QAAA,GAAAC,OAAA;AACA,IAAAC,OAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,KAAA,GAAAH,OAAA;AACA,IAAAI,OAAA,GAAAF,sBAAA,CAAAF,OAAA;AAcA,IAAAK,YAAA,GAAAL,OAAA;AACA,IAAAM,UAAA,GAAAN,OAAA;AAUA,IAAAO,UAAA,GAAAP,OAAA;AACA,IAAAQ,YAAA,GAAAR,OAAA;AACA,IAAAS,QAAA,GAAAT,OAAA;AACA,IAAAU,OAAA,GAAAV,OAAA;AACA,IAAAW,WAAA,GAAAX,OAAA;AAAuC,SAAAY,2BAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,yBAAAC,MAAA,IAAAH,CAAA,CAAAG,MAAA,CAAAC,QAAA,KAAAJ,CAAA,qBAAAE,CAAA,QAAAG,KAAA,CAAAC,OAAA,CAAAN,CAAA,MAAAE,CAAA,GAAAK,2BAAA,CAAAP,CAAA,MAAAC,CAAA,IAAAD,CAAA,uBAAAA,CAAA,CAAAQ,MAAA,IAAAN,CAAA,KAAAF,CAAA,GAAAE,CAAA,OAAAO,EAAA,MAAAC,CAAA,YAAAA,EAAA,eAAAC,CAAA,EAAAD,CAAA,EAAAE,CAAA,WAAAA,EAAA,WAAAH,EAAA,IAAAT,CAAA,CAAAQ,MAAA,KAAAK,IAAA,WAAAA,IAAA,MAAAC,KAAA,EAAAd,CAAA,CAAAS,EAAA,UAAAR,CAAA,WAAAA,EAAAD,CAAA,UAAAA,CAAA,KAAAe,CAAA,EAAAL,CAAA,gBAAAM,SAAA,iJAAAC,CAAA,EAAAC,CAAA,OAAAC,CAAA,gBAAAR,CAAA,WAAAA,EAAA,IAAAT,CAAA,GAAAA,CAAA,CAAAkB,IAAA,CAAApB,CAAA,MAAAY,CAAA,WAAAA,EAAA,QAAAZ,CAAA,GAAAE,CAAA,CAAAmB,IAAA,WAAAH,CAAA,GAAAlB,CAAA,CAAAa,IAAA,EAAAb,CAAA,KAAAC,CAAA,WAAAA,EAAAD,CAAA,IAAAmB,CAAA,OAAAF,CAAA,GAAAjB,CAAA,KAAAe,CAAA,WAAAA,EAAA,UAAAG,CAAA,YAAAhB,CAAA,cAAAA,CAAA,8BAAAiB,CAAA,QAAAF,CAAA;AAAA,SAAAV,4BAAAP,CAAA,EAAAkB,CAAA,QAAAlB,CAAA,2BAAAA,CAAA,SAAAsB,iBAAA,CAAAtB,CAAA,EAAAkB,CAAA,OAAAhB,CAAA,MAAAqB,QAAA,CAAAH,IAAA,CAAApB,CAAA,EAAAwB,KAAA,6BAAAtB,CAAA,IAAAF,CAAA,CAAAyB,WAAA,KAAAvB,CAAA,GAAAF,CAAA,CAAAyB,WAAA,CAAAC,IAAA,aAAAxB,CAAA,cAAAA,CAAA,GAAAG,KAAA,CAAAsB,IAAA,CAAA3B,CAAA,oBAAAE,CAAA,+CAAA0B,IAAA,CAAA1B,CAAA,IAAAoB,iBAAA,CAAAtB,CAAA,EAAAkB,CAAA;AAAA,SAAAI,kBAAAtB,CAAA,EAAAkB,CAAA,aAAAA,CAAA,IAAAA,CAAA,GAAAlB,CAAA,CAAAQ,MAAA,MAAAU,CAAA,GAAAlB,CAAA,CAAAQ,MAAA,YAAAP,CAAA,MAAAW,CAAA,GAAAP,KAAA,CAAAa,CAAA,GAAAjB,CAAA,GAAAiB,CAAA,EAAAjB,CAAA,IAAAW,CAAA,CAAAX,CAAA,IAAAD,CAAA,CAAAC,CAAA,UAAAW,CAAA;AAAA,SAAAiB,QAAA5B,CAAA,EAAAD,CAAA,QAAAE,CAAA,GAAA4B,MAAA,CAAAC,IAAA,CAAA9B,CAAA,OAAA6B,MAAA,CAAAE,qBAAA,QAAAf,CAAA,GAAAa,MAAA,CAAAE,qBAAA,CAAA/B,CAAA,GAAAD,CAAA,KAAAiB,CAAA,GAAAA,CAAA,CAAAgB,MAAA,WAAAjC,CAAA,WAAA8B,MAAA,CAAAI,wBAAA,CAAAjC,CAAA,EAAAD,CAAA,EAAAmC,UAAA,OAAAjC,CAAA,CAAAkC,IAAA,CAAAC,KAAA,CAAAnC,CAAA,EAAAe,CAAA,YAAAf,CAAA;AAAA,SAAAoC,cAAArC,CAAA,aAAAD,CAAA,MAAAA,CAAA,GAAAuC,SAAA,CAAA/B,MAAA,EAAAR,CAAA,UAAAE,CAAA,WAAAqC,SAAA,CAAAvC,CAAA,IAAAuC,SAAA,CAAAvC,CAAA,QAAAA,CAAA,OAAA6B,OAAA,CAAAC,MAAA,CAAA5B,CAAA,OAAAsC,OAAA,WAAAxC,CAAA,QAAAyC,gBAAA,aAAAxC,CAAA,EAAAD,CAAA,EAAAE,CAAA,CAAAF,CAAA,SAAA8B,MAAA,CAAAY,yBAAA,GAAAZ,MAAA,CAAAa,gBAAA,CAAA1C,CAAA,EAAA6B,MAAA,CAAAY,yBAAA,CAAAxC,CAAA,KAAA2B,OAAA,CAAAC,MAAA,CAAA5B,CAAA,GAAAsC,OAAA,WAAAxC,CAAA,IAAA8B,MAAA,CAAAc,cAAA,CAAA3C,CAAA,EAAAD,CAAA,EAAA8B,MAAA,CAAAI,wBAAA,CAAAhC,CAAA,EAAAF,CAAA,iBAAAC,CAAA,IAnCvC;AACA;AAsCA;;AAGA;AACA;AACA;AACA;AACA;AACA;AACO,SAAS4C,sBAAsBA,CACpCC,UAAoB,EACpBC,MAAgB,EAChBC,aAAsC,EAE/B;EAAA,IADPC,eAAe,GAAAV,SAAA,CAAA/B,MAAA,QAAA+B,SAAA,QAAAW,SAAA,GAAAX,SAAA,MAAG,IAAI;EAEtB,IAAMY,OAAO,GAAG,IAAAC,kBAAW,EAAC,CAAC,CAC1BC,MAAM,CAAC,CAACP,UAAU,CAAC,CAAC,CAAC,EAAEA,UAAU,CAACA,UAAU,CAACtC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAC1DsC,UAAU,CAACA,UAAU,CAAC;EAEzB,IAAIE,aAAa,EAAE;IACjBG,OAAO,CAACrC,KAAK,CAACkC,aAAa,CAAC;EAC9B;;EAEA;EACA,IAAMM,IAAI,GAAGH,OAAO,CAACJ,MAAM,CAAC,CAACQ,GAAG,CAAC,UAAAC,GAAG;IAAA,OAAK;MACvCC,KAAK,EAAED,GAAG,CAAChD,MAAM;MACjBkD,OAAO,EAAEF,GAAG;MACZG,EAAE,EAAEH,GAAG,CAACG,EAAE;MACVC,EAAE,EAAEJ,GAAG,CAACI;IACV,CAAC;EAAA,CAAC,CAAC;;EAEH;EACA;;EAEA;EACA;;EAEA;EACA,OAAOX,eAAe,GAAGK,IAAI,CAACrB,MAAM,CAAC,UAAA4B,CAAC;IAAA,OAAIA,CAAC,CAACJ,KAAK,GAAG,CAAC;EAAA,EAAC,GAAGH,IAAI;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACO,SAASQ,mBAAmBA,CACjCf,MAAuC,EACvCgB,OAAe,EACff,aAAsC,EACtC;EACA,IAAMG,OAAO,GAAG,IAAAC,kBAAW,EAAC,CAAC,CAACN,UAAU,CAACiB,OAAO,CAAC;EAEjD,IAAIf,aAAa,EAAE;IACjBG,OAAO,CAACrC,KAAK,CAACkC,aAAa,CAAC;EAC9B;;EAEA;EACA,OAAOG,OAAO,CAACJ,MAAM,CAAC,CACnBQ,GAAG,CAAC,UAAAC,GAAG;IAAA,OAAK;MACXC,KAAK,EAAED,GAAG,CAAChD,MAAM;MACjBkD,OAAO,EAAEF,GAAG;MACZG,EAAE,EAAEH,GAAG,CAACG,EAAE;MACVC,EAAE,EAAEJ,GAAG,CAACI;IACV,CAAC;EAAA,CAAC,CAAC,CACF3B,MAAM,CAAC,UAAA4B,CAAC,EAAI;IACX,IAAOF,EAAE,GAAQE,CAAC,CAAXF,EAAE;MAAEC,EAAE,GAAIC,CAAC,CAAPD,EAAE;IACb,OAAO,IAAAI,mBAAQ,EAACL,EAAE,CAAC,IAAI,IAAAK,mBAAQ,EAACJ,EAAE,CAAC;EACrC,CAAC,CAAC;AACN;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASK,mBAAmBA,CACjCZ,MAAwB,EACxBN,MAAuC,EACvCgB,OAAe,EACff,aAAsC,EAC/B;EACP,IAAMG,OAAO,GAAG,IAAAC,kBAAW,EAAC,CAAC,CAACN,UAAU,CAAC,IAAAoB,cAAK,EAACb,MAAM,CAAC,CAAC,CAAC,EAAEA,MAAM,CAAC,CAAC,CAAC,EAAEU,OAAO,CAAC,CAAC,CAACV,MAAM,CAACA,MAAM,CAAC;EAC7F,IAAIL,aAAa,EAAE;IACjBG,OAAO,CAACrC,KAAK,CAACkC,aAAa,CAAC;EAC9B;;EAEA;EACA,OAAOG,OAAO,CAACJ,MAAM,CAAC,CAACQ,GAAG,CAAC,UAAAC,GAAG;IAAA,OAAK;MACjCC,KAAK,EAAED,GAAG,CAAChD,MAAM;MACjBkD,OAAO,EAAEF,GAAG;MACZG,EAAE,EAAEH,GAAG,CAACG,EAAE;MACVC,EAAE,EAAEJ,GAAG,CAACI;IACV,CAAC;EAAA,CAAC,CAAC;AACL;;AAEA;AACA;AACA;AACA;AACA;AACO,SAASO,WAAWA,CACzBlC,MAAuB,EACvBmC,QAAkB,EAClBC,QAA8B,EACpB;EACV,IAAIf,IAAI,GAAGrB,MAAM,CAACqC,QAAQ,IAAI,CAAC,CAAC;EAEhCrC,MAAM,CAACsC,MAAM,CAAC/B,OAAO,CAAC,UAAC+B,MAAM,EAAEC,SAAS,EAAK;IAC3C;IACA,IAAIlB,IAAI,CAACiB,MAAM,CAAC,IAAIjB,IAAI,CAACiB,MAAM,CAAC,CAACF,QAAQ,CAAC,EAAE;MAC1C;IACF;IACA,IAAMI,OAAO,GAAGL,QAAQ,CAACG,MAAM,CAAC;;IAEhC;IACA,IAAMb,OAAO,GAAGgB,mBAAmB,CAACD,OAAO,EAAExC,MAAM,CAAC;IAEpDqB,IAAI,GAAAhB,aAAA,CAAAA,aAAA,KACCgB,IAAI,WAAAb,gBAAA,iBACN8B,MAAM,EAAAjC,aAAA,CAAAA,aAAA,KACFgB,IAAI,CAACiB,MAAM,CAAC,WAAA9B,gBAAA,iBACd4B,QAAQ,EAAGM,SAAS,CAACjB,OAAO,EAAEe,OAAO,EAAEJ,QAAQ,EAAEpC,MAAM,CAAC,IAE5D;EACH,CAAC,CAAC;EAEF,OAAOqB,IAAI;AACb;AAEO,SAASqB,SAASA,CAACjB,OAAO,EAAEe,OAAO,EAAEJ,QAAQ,EAAEpC,MAAM,EAAE;EAC5D;EACA,IAAM2C,WAAW,GAAG,IAAAC,0BAAoB,EAACJ,OAAO,EAAExC,MAAM,CAAC;EACzD,IAAI,CAAC2C,WAAW,EAAE;IAChB,OAAO,IAAI;EACb;EACA,IAAME,YAAY,GAAGC,gBAAgB,CAACV,QAAQ,EAAEpC,MAAM,CAACoB,MAAM,CAAC;EAC9D,IAAML,aAAa,GAAG,SAAhBA,aAAaA,CAAGgC,GAAG;IAAA,OAAIJ,WAAW,CAACI,GAAG,CAAC;EAAA;EAC7C,IAAM1B,IAAI,GAAGT,sBAAsB,CAACiC,YAAY,EAAEpB,OAAO,EAAEV,aAAa,CAAC;EAEzE,OAAOM,IAAI;AACb;AAEO,SAASyB,gBAAgBA,CAACV,QAAgB,EAAEhB,MAAgB,EAAY;EAC7E,IAAM4B,YAAY,GAAG,IAAAC,wBAAkB,EAACb,QAAQ,CAAC;EACjD,IAAAc,OAAA,OAAAC,eAAA,aAAiB/B,MAAM;IAAhBgC,EAAE,GAAAF,OAAA;IAAEG,EAAE,GAAAH,OAAA;EACb,IAAMI,KAAK,GAAGN,YAAY,CAACM,KAAK,CAACF,EAAE,CAAC,CAACG,OAAO,CAAC,CAAC;EAC9C,IAAMC,OAAO,GAAGR,YAAY,CAACS,IAAI,CAACJ,EAAE,CAAC,CAACE,OAAO,CAAC,CAAC;EAE/C,IAAI,CAACP,YAAY,EAAE;IACjB;IACA;IACA,OAAO,CAACI,EAAE,EAAEA,EAAE,GAAGM,sBAAW,CAAC;EAC/B;EACA,IAAMC,aAAa,GAAGX,YAAY,CAACY,KAAK,CAACN,KAAK,EAAEE,OAAO,GAAG,CAAC,CAAC,CAAClC,GAAG,CAAC,UAAArD,CAAC;IAAA,OAAI4F,kBAAM,CAACC,GAAG,CAAC7F,CAAC,CAAC,CAAC8F,OAAO,CAAC,CAAC;EAAA,EAAC;EAC9F,IAAMC,QAAQ,GAAGL,aAAa,CAACA,aAAa,CAACpF,MAAM,GAAG,CAAC,CAAC;EACxD,IAAIyF,QAAQ,KAAKX,EAAE,EAAE;IACnB;IACAM,aAAa,CAACxD,IAAI,CAAC0D,kBAAM,CAACC,GAAG,CAACd,YAAY,CAACiB,MAAM,CAACD,QAAQ,CAAC,CAAC,CAACD,OAAO,CAAC,CAAC,CAAC;EACzE;EAEA,OAAOJ,aAAa;AACtB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACO,SAASlB,mBAAmBA,CACjCD,OAAU,EACVxC,MAAe,EACL;EACV,IAAMkE,WAAW,GAAGC,cAAc,CAAC3B,OAAO,EAAExC,MAAM,CAAC;EAEnD,IAAAoE,kBAAA,GAGI5B,OAAO,CAFT6B,SAAS;IAAGC,yBAAyB,GAAAF,kBAAA,CAAzBE,yBAAyB;IAAEC,WAAW,GAAAH,kBAAA,CAAXG,WAAW;IAAEC,mBAAmB,GAAAJ,kBAAA,CAAnBI,mBAAmB;IACvEC,aAAa,GACXjC,OAAO,CADTiC,aAAa;EAEf,IAAMC,cAAc,GAAGF,mBAAmB,CAAChC,OAAO,CAACmC,aAAa,CAAC,CAAC,CAAC;EAEnE,IAAMC,WAAW,GAAG/E,MAAM,CAACC,IAAI,CAACwE,yBAAyB,CAAC,CACvDhD,GAAG,CAAC,UAACuD,CAAC,EAAEC,CAAC;IAAA,OAAKA,CAAC;EAAA,EAAC,CAChB9E,MAAM,CAAC,UAAA8E,CAAC;IAAA,OAAIjF,MAAM,CAACiB,MAAM,CAACwD,yBAAyB,CAAC,CAACQ,CAAC,CAAC;EAAA,EAAC;EAC3D,IAAMC,OAAO,GAAG,CAACH,WAAW,CAAC5E,MAAM,CAAC,UAAA8E,CAAC;IAAA,OAAI,CAACZ,WAAW,CAACc,QAAQ,CAACF,CAAC,CAAC;EAAA,EAAC,CAACvG,MAAM;EACzE,IAAIwG,OAAO,EAAE;IACX,OAAON,aAAa;EACtB;EAEA,IAAMQ,UAAU,GAAGC,iBAAiB,CAClCX,WAAW,EACXG,cAAc,EACdlC,OAAO,CAACmC,aAAa,EACrBT,WACF,CAAC;EAED,OAAOO,aAAa,CAACzE,MAAM,CAACiF,UAAU,CAAC;AACzC;AAEA,SAASd,cAAcA,CAAC3B,OAAO,EAAExC,MAAM,EAAE;EACvC;EACA,IAAI,CAACA,MAAM,EAAE;IACX,OAAO,EAAE;EACX;EACA,IAAMmF,UAAU,GAAGtF,MAAM,CAACiB,MAAM,CAAC0B,OAAO,CAAC6B,SAAS,CAACC,yBAAyB,CAEjE;EACX,IAAMc,UAAU,GAAGpF,MAAM,CAACsC,MAAM,CAAC+C,SAAS,CAAC,UAAAC,EAAE;IAAA,OAAIA,EAAE,KAAK9C,OAAO,CAAC8C,EAAE;EAAA,EAAC;EACnE,IAAMC,YAAY,GAAGvF,MAAM,CAACP,IAAI,CAAC2F,UAAU,CAAC;EAE5C,OAAOD,UAAU,CAACK,MAAM,CAAC,UAACC,IAAI,EAAEC,IAAI,EAAE3C,GAAG,EAAK;IAC5C,IAAI2C,IAAI,IAAIH,YAAY,KAAKG,IAAI,CAACjG,IAAI,EAAE;MACtCgG,IAAI,CAACtF,IAAI,CAAC4C,GAAG,CAAC;IAChB;IACA,OAAO0C,IAAI;EACb,CAAC,EAAE,EAAc,CAAC;AACpB;AAEO,SAASP,iBAAiBA,CAC/BX,WAAW,EACXG,cAAc,EACdC,aAAqC,EACrCgB,KAAK,EACL;EACA,OAAO,UAAAC,KAAK;IAAA,OACVlB,cAAc,CAAC;MAACkB,KAAK,EAALA;IAAK,CAAC,CAAC,CAACC,KAAK,CAC3B,UAACC,GAAG,EAAEhB,CAAC;MAAA,OAAKa,KAAK,CAACX,QAAQ,CAACF,CAAC,CAAC,IAAKgB,GAAG,IAAIvB,WAAW,CAACO,CAAC,CAAC,CAAC,CAAC,CAAC,IAAIgB,GAAG,IAAIvB,WAAW,CAACO,CAAC,CAAC,CAAC,CAAC,CAAE;IAAA,CACzF,CAAC;EAAA;AACL;AAEO,SAASiB,QAAQA,CAACnE,CAAC,EAAE;EAC1B,OAAOA,CAAC,CAACF,EAAE,KAAKT,SAAS,IAAIW,CAAC,CAACD,EAAE,KAAKV,SAAS;AACjD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACO,SAAS+E,WAAWA,CAACnH,KAAa,EAAEoH,KAAe,EAAU;EAClE;EACA,IAAI,CAACA,KAAK,CAAC1H,MAAM,EAAE;IACjB;IACA,OAAO,IAAI;EACb;EACA,IAAMuG,CAAC,GAAG,IAAAoB,mBAAU,EAACD,KAAK,EAAEpH,KAAK,CAAC;EAClC,IAAIiG,CAAC,KAAK,CAAC,EAAE;IACX,OAAOmB,KAAK,CAACnB,CAAC,CAAC;EACjB,CAAC,MAAM,IAAIA,CAAC,KAAKmB,KAAK,CAAC1H,MAAM,EAAE;IAC7B,OAAO0H,KAAK,CAACnB,CAAC,GAAG,CAAC,CAAC;EACrB;EACA,IAAM/B,GAAG,GAAGkD,KAAK,CAACnB,CAAC,CAAC,GAAGjG,KAAK,GAAGA,KAAK,GAAGoH,KAAK,CAACnB,CAAC,GAAG,CAAC,CAAC,GAAGA,CAAC,GAAGA,CAAC,GAAG,CAAC;EAC/D,OAAOmB,KAAK,CAAClD,GAAG,CAAC;AACnB;AAEO,SAASoD,cAAcA,CAACL,GAAG,EAAEM,QAAQ,EAAEC,IAAI,EAAEJ,KAAK,EAAE;EACzD,IAAIA,KAAK,IAAIA,KAAK,CAAC1H,MAAM,EAAE;IACzB,OAAOyH,WAAW,CAACF,GAAG,EAAEG,KAAK,CAAC;EAChC;EAEA,OAAO,IAAAK,yBAAc,EAACF,QAAQ,EAAEC,IAAI,EAAEP,GAAG,CAAC;AAC5C;AAEO,SAASS,cAAcA,CAACC,KAAK,EAAE;EACpC,OAAOA,KAAK,CAACC,QAAQ,IAAID,KAAK,CAACC,QAAQ,CAACC,SAAS,IAAIF,KAAK,CAACC,QAAQ,CAACE,WAAW;AACjF;AAEO,SAASC,wBAAwBA,CAACJ,KAAY,EAAEK,WAAsC,EAAE;EAC7F;EACA;EACA,OAAOL,KAAK,IAAID,cAAc,CAACC,KAAK,CAAC,GACjCM,4BAAiB,CAACC,OAAO,GACzBF,WAAW,IAAIC,4BAAiB,CAACC,OAAO;AAC9C;AAEA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIR,KAAK,EAAEK,WAAW,EAAK;EAChD,IAAIN,cAAc,CAACC,KAAK,CAAC,EAAE;IACzB,OAAO,iBAAiB;EAC1B;EACA,OAAOK,WAAW;AACpB,CAAC;AAED,IAAMI,sBAAsB,GAAG,SAAzBA,sBAAsBA,CAAIT,KAAK,EAAE7B,aAAqC,EAAEuC,MAAM,EAAK;EACvF,IAAIX,cAAc,CAACC,KAAK,CAAC,EAAE;IACzB,IAAMW,YAAY,GAAGD,MAAM,CAAC7B,SAAS,CAAC,UAAAvG,CAAC;MAAA,OAAIA,CAAC,CAACW,IAAI,KAAK+G,KAAK,CAACC,QAAQ,CAACC,SAAS;IAAA,EAAC;IAC/E,IAAMU,cAAc,GAAGF,MAAM,CAAC7B,SAAS,CAAC,UAAAvG,CAAC;MAAA,OAAIA,CAAC,CAACW,IAAI,KAAK+G,KAAK,CAACC,QAAQ,CAACE,WAAW;IAAA,EAAC;IAEnF,OAAO;MACLU,YAAY,EAAE,SAAdA,YAAYA,CAAEvC,CAAC;QAAA,OAAIH,aAAa,CAAC2C,OAAO,CAACxC,CAAC,EAAEqC,YAAY,CAAC;MAAA;MACzDI,cAAc,EAAE,SAAhBA,cAAcA,CAAEzC,CAAC;QAAA,OAAIH,aAAa,CAAC2C,OAAO,CAACxC,CAAC,EAAEsC,cAAc,CAAC;MAAA;IAC/D,CAAC;EACH;EAEA,OAAO,UAAAtC,CAAC;IAAA,OAAI0B,KAAK,CAACzF,aAAa,CAAC;MAAC6E,KAAK,EAAEd;IAAC,CAAC,CAAC;EAAA;AAC7C,CAAC;AAEM,IAAM0C,gBAAgB,GAAAC,OAAA,CAAAD,gBAAA,GAAG,SAAnBA,gBAAgBA,CAC3BhB,KAA4B,EAC5BK,WAAmB,EACnBrE,OAAmC,EACR;EAC3B,IAAOmC,aAAa,GAAYnC,OAAO,CAAhCmC,aAAa;IAAEuC,MAAM,GAAI1E,OAAO,CAAjB0E,MAAM;;EAE5B;EACA,IAAMQ,YAAY,GAAGR,MAAM,CAACS,IAAI,CAC9B,UAAA7I,CAAC;IAAA,OAAI0H,KAAK,KAAK1H,CAAC,CAACW,IAAI,KAAK+G,KAAK,IAAI1H,CAAC,CAACW,IAAI,KAAM+G,KAAK,CAAW/G,IAAI,CAAC;EAAA,CACtE,CAAC;EAED,OAAOiI,YAAY,IAAIb,WAAW,GAC9B,UAAAtF,GAAG;IAAA,OACD,IAAAqG,sBAAS,EACPrG,GAAG,CAACE,OAAO,EACXuF,iBAAiB,CAACU,YAAY,EAAEb,WAAW,CAAC;IAC5C;IACAI,sBAAsB,CAACS,YAAY,EAAE/C,aAAa,EAAEuC,MAAM,CAC5D,CAAC;EAAA,IACH,UAAA3F,GAAG;IAAA,OAAIA,GAAG,CAACC,KAAK;EAAA;AACtB,CAAC;AAEM,IAAMqG,iCAAiC,GAAAJ,OAAA,CAAAI,iCAAA,GAAG,SAApCA,iCAAiCA,CAAGrB,KAAK,EAAI;EACxD,IAAID,cAAc,CAACC,KAAK,CAAC,EAAE;IACzB;IACA,OAAOsB,2BAAgB,CAAC9H,MAAM,CAAC,UAAA+H,IAAA;MAAA,IAAEzC,EAAE,GAAAyC,IAAA,CAAFzC,EAAE;MAAA,OAAMA,EAAE,KAAKwB,4BAAiB,CAACkB,GAAG;IAAA,EAAC;EACxE;EACA,OAAOF,2BAAgB;AACzB,CAAC;AAED,SAASG,QAAQA,CACf5G,IAAiB,EACjB6G,CAAS,EACT9F,QAA8B,EAC4B;EAC1D;EACA,IAAM+F,OAAO,GAAG9G,IAAI,CAACA,IAAI,CAAC9C,MAAM,GAAG,CAAC,CAAC;EAErC,OAAO;IACL6J,KAAK,EAAE,MAAM;IACbC,GAAG,EAAEF,OAAO,GAAGG,YAAY,CAACJ,CAAC,EAAEC,OAAO,CAACD,CAAC,CAAC,GAAG;EAC9C,CAAC;AACH;AAEO,SAASI,YAAYA,CAACJ,CAAU,EAAEK,EAAW,EAAiB;EACnE,IAAIC,MAAM,CAACC,QAAQ,CAACP,CAAC,CAAC,IAAIM,MAAM,CAACC,QAAQ,CAACF,EAAE,CAAC,IAAIA,EAAE,KAAK,CAAC,EAAE;IACzD,OAAO,CAAEL,CAAC,GAAeK,EAAa,IAAKA,EAAa;EAC1D;EACA,OAAO,IAAI;AACb;;AAEA;AACA;AACA;AACA;AACA;AACO,SAASG,YAAYA,CAACvG,QAAkB,EAAEnC,MAAc,EAAa;EAAA,IAAA2I,SAAA;EAC1E,IAAOrG,MAAM,GAAgCtC,MAAM,CAA5CsC,MAAM;IAAEsG,KAAK,GAAyB5I,MAAM,CAApC4I,KAAK;IAAEC,QAAQ,GAAe7I,MAAM,CAA7B6I,QAAQ;IAAEC,SAAS,GAAI9I,MAAM,CAAnB8I,SAAS;EACzC,IAAOjC,WAAW,GAAcgC,QAAQ,CAAjChC,WAAW;IAAEzE,QAAQ,GAAIyG,QAAQ,CAApBzG,QAAQ;EAC5B,IAAM2G,YAAY,GAAGzG,MAAM,CAAC,CAAC,CAAC;EAC9B,IAAMjB,IAAI,IAAAsH,SAAA,GAAI3I,MAAM,CAAqBqC,QAAQ,cAAAsG,SAAA,gBAAAA,SAAA,GAApCA,SAAA,CAAuCI,YAAY,CAAC,cAAAJ,SAAA,uBAApDA,SAAA,CAAuDvG,QAAQ,CAAC;EAE7E,IACE0G,SAAS,IACTA,SAAS,CAACjC,WAAW,KAAKA,WAAW,IACrCiC,SAAS,CAAC1G,QAAQ,KAAKA,QAAQ,IAC/B0G,SAAS,CAACF,KAAK,MAAKA,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEnJ,IAAI;EAC/B;EACA,IAAAuJ,kBAAO,EAAC3H,IAAI,EAAEyH,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEzH,IAAI,CAAC,EAC9B;IACA;IACA,OAAOyH,SAAS;EAClB;EAEA,IAAMtG,OAAO,GAAGL,QAAQ,CAAC4G,YAAY,CAAC;EACtC,IAAME,SAAS,GAAGzB,gBAAgB,CAACoB,KAAK,EAAE/B,WAAW,EAAErE,OAAO,CAAC;EAE/D,IAAM0G,IAAiB,GAAG,EAAE;EAC5B,IAAMC,MAAM,GAAG,CAAC9H,IAAI,IAAI,EAAE,EAAEmE,MAAM,CAAC,UAACC,IAAI,EAAElE,GAAG,EAAEuD,CAAC,EAAK;IACnD,IAAMoD,CAAC,GAAGe,SAAS,CAAC1H,GAAG,CAAC;IACxB,IAAM6G,KAAK,GAAGH,QAAQ,CAACxC,IAAI,EAAEyC,CAAC,EAAE9F,QAAQ,CAAC;IACzCqD,IAAI,CAACtF,IAAI,CAAAE,aAAA;MACP+I,CAAC,EAAE7H,GAAG,CAACG,EAAE;MACTwG,CAAC,EAADA;IAAC,GACEE,KAAK,CACT,CAAC;IACF,OAAO3C,IAAI;EACb,CAAC,EAAEyD,IAAI,CAAC;EAER,IAAMG,OAAO,GAAG,IAAAC,eAAM,EAAWH,MAAM,EAAE,UAAAI,CAAC;IAAA,OAAIA,CAAC,CAACrB,CAAC;EAAA,EAAC;EAClD,IAAMsB,OAAO,GAAGnI,IAAI,GAAG,CAACA,IAAI,CAAC,CAAC,CAAC,CAACK,EAAE,EAAEL,IAAI,CAACA,IAAI,CAAC9C,MAAM,GAAG,CAAC,CAAC,CAACoD,EAAE,CAAC,GAAG,EAAE;;EAElE;EACA,IAAM8H,KAAK,GAAGC,WAAW,CAACP,MAAM,CAAC;EACjC,IAAMQ,QAAQ,GAAGC,6BAAgB,CAAC/C,WAAW,CAAC;EAE9C,OAAO;IACL;IACAwC,OAAO,EAAPA,OAAO;IACP;IACAG,OAAO,EAAPA,OAAO;IACPpH,QAAQ,EAARA,QAAQ;IACRyE,WAAW,EAAXA,WAAW;IACX;IACAsC,MAAM,EAAEM,KAAK;IACbI,KAAK,KAAAC,MAAA,CAAKH,QAAQ,EAAG,MAAM,EAAAG,MAAA,CAAGlB,KAAK,GAAGA,KAAK,CAACnJ,IAAI,GAAG,OAAO,CAAE;IAC5DsK,SAAS,EAAEnB,KAAK,GAAGA,KAAK,CAACoB,IAAI,GAAG,SAAS;IACzCpB,KAAK,EAAEA,KAAK,GAAGA,KAAK,CAACnJ,IAAI,GAAG,IAAI;IAChCwK,OAAO,EAAE;MACPJ,KAAK,oBAAoB;MACzBhL,KAAK,EAAE,IAAA+I,sBAAS,EAACuB,MAAM,EAAErC,4BAAiB,CAACC,OAAO,EAAE,UAAAwC,CAAC;QAAA,OAAIA,CAAC,CAACrB,CAAC;MAAA;IAC9D,CAAC;IACD;IACA7G,IAAI,EAAJA;EACF,CAAC;AACH;;AAEA;AACO,SAASqI,WAAWA,CAACP,MAAM,EAAE;EAClC,IAAMe,KAAY,GAAG,EAAE;EACvB,IAAIC,IAAW,GAAG,EAAE;EACpB,KAAK,IAAIrF,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGqE,MAAM,CAAC5K,MAAM,EAAEuG,CAAC,EAAE,EAAE;IACtC,IAAMyE,CAAC,GAAGJ,MAAM,CAACrE,CAAC,CAAC;IACnB,IAAI,CAAC,IAAAsF,+BAAkB,EAACb,CAAC,CAACrB,CAAC,CAAC,IAAIiC,IAAI,CAAC5L,MAAM,EAAE;MAC3C;MACA2L,KAAK,CAAC/J,IAAI,CAACgK,IAAI,CAAC;MAChBA,IAAI,GAAG,EAAE;IACX,CAAC,MAAM,IAAI,IAAAC,+BAAkB,EAACb,CAAC,CAACrB,CAAC,CAAC,EAAE;MAClCiC,IAAI,CAAChK,IAAI,CAACoJ,CAAC,CAAC;IACd;IAEA,IAAIzE,CAAC,KAAKqE,MAAM,CAAC5K,MAAM,GAAG,CAAC,IAAI4L,IAAI,CAAC5L,MAAM,EAAE;MAC1C2L,KAAK,CAAC/J,IAAI,CAACgK,IAAI,CAAC;IAClB;EACF;EAEA,IAAME,OAAO,GAAGH,KAAK,CAAC3L,MAAM,GAAG,CAAC,GAAG4K,MAAM,CAACnJ,MAAM,CAAC,UAAAuJ,CAAC;IAAA,OAAI,IAAAa,+BAAkB,EAACb,CAAC,CAACrB,CAAC,CAAC;EAAA,EAAC,GAAG,EAAE;EAEnF,OAAO;IAACgC,KAAK,EAALA,KAAK;IAAEG,OAAO,EAAPA;EAAO,CAAC;AACzB;AAMO,SAASC,4BAA4BA,CAC1CC,KAAQ,EACRvK,MAAuB,EACvB;EACA,IACE6I,QAAQ,GAGN7I,MAAM,CAHR6I,QAAQ;IAAA2B,aAAA,OAAArH,eAAA,aAGNnD,MAAM,CAFRnB,KAAK;IAAG4L,MAAM,GAAAD,aAAA;IAAEE,MAAM,GAAAF,aAAA;IACtBG,eAAe,GACb3K,MAAM,CADR2K,eAAe;EAGjB,IAAMvI,QAAQ,GAAGyG,QAAQ,CAACzG,QAAQ,IAAI,IAAAwI,wBAAkB,EAAC5K,MAAM,EAAEuK,KAAK,CAACpI,QAAQ,CAAC;EAChF,IAAMd,IAAI,GAAGa,WAAW,CAAClC,MAAM,EAAEuK,KAAK,CAACpI,QAAQ,EAAEC,QAAQ,CAAC;EAC1D,IAAMyI,WAAW,GAAGxJ,IAAI,IAAIxB,MAAM,CAACC,IAAI,CAACuB,IAAI,CAAC,CAAC9C,MAAM,IAAIsB,MAAM,CAACiB,MAAM,CAACO,IAAI,CAAC,CAAC,CAAC,CAAC,CAACe,QAAQ,CAAC;EACxF,IAAMvB,UAAU,GAAG,CAACgK,WAAW,IAAI,EAAE,EAAEvJ,GAAG,CAAC,UAAAM,CAAC;IAAA,OAAIA,CAAC,CAACF,EAAE;EAAA,EAAC;EAErD,IAAIoJ,IAAI,GAAGL,MAAM;EACjB,IAAIM,IAAI,GAAGL,MAAM;EACjB,IAAI3H,GAAG;EACP,IAAI4H,eAAe,KAAKK,2BAAgB,CAAC5I,QAAQ,EAAE;IACjD0I,IAAI,GAAG9E,WAAW,CAAC0E,MAAM,EAAE7J,UAAU,CAAC;IACtCkC,GAAG,GAAGlC,UAAU,CAACoK,OAAO,CAACH,IAAI,CAAC;IAC9BC,IAAI,GAAGhI,GAAG,GAAG,CAAC,CAAC,GAAG8H,WAAW,CAAC9H,GAAG,CAAC,CAACpB,EAAE,GAAGuJ,GAAG;EAC7C,CAAC,MAAM;IACL;IACAJ,IAAI,GAAG9E,WAAW,CAACyE,MAAM,EAAE5J,UAAU,CAAC;IACtCkK,IAAI,GAAG/E,WAAW,CAAC0E,MAAM,EAAE7J,UAAU,CAAC;IAEtC,IAAIiK,IAAI,KAAKC,IAAI,EAAE;MACjBhI,GAAG,GAAGlC,UAAU,CAACoK,OAAO,CAACH,IAAI,CAAC;MAC9B,IAAI/H,GAAG,KAAKlC,UAAU,CAACtC,MAAM,GAAG,CAAC,EAAE;QACjCuM,IAAI,GAAGjK,UAAU,CAACkC,GAAG,GAAG,CAAC,CAAC;MAC5B,CAAC,MAAM;QACLgI,IAAI,GAAGlK,UAAU,CAACkC,GAAG,GAAG,CAAC,CAAC;MAC5B;IACF;EACF;EAEA,IAAMoI,aAAa,GAAA9K,aAAA,CAAAA,aAAA,KACdL,MAAM;IACT6I,QAAQ,EAAAxI,aAAA,CAAAA,aAAA,KACHL,MAAM,CAAC6I,QAAQ;MAClBzG,QAAQ,EAARA;IAAQ,EACT;IACDC,QAAQ,EAAEhB,IAAI;IACdxC,KAAK,EAAE,CAACiM,IAAI,EAAEC,IAAI;EAAC,EACpB;EAED,OAAOI,aAAa;AACtB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAASC,2BAA2BA,CAACpL,MAAM,EAAEmC,QAAQ,EAAEkJ,iBAAiB,EAAE;EACxE,IAAIC,cAAc,GAAGD,iBAAiB,IAAI,CAAC,CAAC;EAAC,IAAAE,SAAA,GAAAzN,0BAAA,CACxBkC,MAAM,CAACsC,MAAM;IAAAkJ,KAAA;EAAA;IAAlC,KAAAD,SAAA,CAAA7M,CAAA,MAAA8M,KAAA,GAAAD,SAAA,CAAA5M,CAAA,IAAAC,IAAA,GAAoC;MAAA,IAAzB0D,MAAM,GAAAkJ,KAAA,CAAA3M,KAAA;MACf,IAAI,CAACyM,cAAc,CAAChJ,MAAM,CAAC,IAAIH,QAAQ,CAACG,MAAM,CAAC,EAAE;QAC/CgJ,cAAc,GAAAjL,aAAA,CAAAA,aAAA,KACTiL,cAAc,WAAA9K,gBAAA,iBAChB8B,MAAM,EAAG,IAAAmJ,oBAAQ,EAACtJ,QAAQ,CAACG,MAAM,CAAC,CAACoJ,KAAK,CAAC,EAC3C;MACH;IACF;EAAC,SAAAC,GAAA;IAAAJ,SAAA,CAAAvN,CAAA,CAAA2N,GAAA;EAAA;IAAAJ,SAAA,CAAAzM,CAAA;EAAA;EACD,OAAOwM,cAAc;AACvB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASM,wBAAwBA,CACtC5L,MAAuB,EACvB6I,QAAqC,EACrC1G,QAAkB,EAClBG,MAAe,EACE;EACjB,IAAIuJ,UAAU,GAAG7L,MAAM;EACvB,IAAI8L,YAAY,GAAGjD,QAAQ;EAC3B,IAAI,IAAAkD,QAAA,aAAOD,YAAY,MAAK,QAAQ,IAAI,CAACA,YAAY,CAACjF,WAAW,IAAI,CAACiF,YAAY,CAAC1J,QAAQ,EAAE;IAC3F0J,YAAY,GAAGE,kBAAkB,CAAChM,MAAM,EAAEmC,QAAQ,CAAC;EACrD;EAEA,IAAInC,MAAM,CAACsC,MAAM,CAAC/D,MAAM,GAAG,CAAC,EAAE;IAC5BuN,YAAY,GAAAzL,aAAA,CAAAA,aAAA,KACPyL,YAAY;MACfR,cAAc,EAAEF,2BAA2B,CAACpL,MAAM,EAAEmC,QAAQ,EAAE2J,YAAY,CAACR,cAAc;IAAC,EAC3F;EACH;EACAO,UAAU,GAAAxL,aAAA,CAAAA,aAAA,KACLwL,UAAU;IACbhD,QAAQ,EAAEiD;EAAY,EACvB;EAED,IAAMzK,IAAI,GAAGa,WAAW,CAAC2J,UAAU,EAAE1J,QAAQ,EAAE2J,YAAY,CAAC1J,QAAQ,CAAC;EAErEyJ,UAAU,GAAAxL,aAAA,CAAAA,aAAA,KACLwL,UAAU;IACbxJ,QAAQ,EAAEhB;EAAI,EACf;EAED,IAAIwH,QAAQ,CAACmB,IAAI,KAAKiC,qBAAU,CAACC,SAAS,EAAE;IAC1C;EAAA,CACD,MAAM,IAAIrD,QAAQ,CAACmB,IAAI,KAAKiC,qBAAU,CAACnD,SAAS,EAAE;IACjD;IACA+C,UAAU,GAAAxL,aAAA,CAAAA,aAAA,KACLwL,UAAU;MACb/C,SAAS,EAAEJ,YAAY,CAACvG,QAAQ,EAAE0J,UAAU;IAAC,EAC9C;EACH;EAEA,OAAOA,UAAU;AACnB;AAEO,SAASM,kBAAkBA,CAACnM,MAAM,EAAEmC,QAAQ,EAAEL,OAAO,EAAE;EAC5D,IAAOV,MAAM,GAAIpB,MAAM,CAAhBoB,MAAM;EACb,IAAI,CAACpB,MAAM,CAACsC,MAAM,EAAE,OAAO,IAAI;EAE/B,OAAOtC,MAAM,CAACsC,MAAM,CAACkD,MAAM,CAAC,UAAC4G,GAAG,EAAE9J,MAAM,EAAE+J,UAAU,EAAK;IAAA,IAAAC,YAAA;IACvD,KAAAA,YAAA,GAAItM,MAAM,CAACqB,IAAI,cAAAiL,YAAA,eAAXA,YAAA,CAAchK,MAAM,CAAC,EAAE;MACzB;MACA8J,GAAG,CAAC9J,MAAM,CAAC,GAAGtC,MAAM,CAACqB,IAAI,CAACiB,MAAM,CAAC;MACjC,OAAO8J,GAAG;IACZ;IACA,IAAMG,SAAS,GAAGvM,MAAM,CAACP,IAAI,CAAC4M,UAAU,CAAC;IACzC,IAAI/J,MAAM,IAAIiK,SAAS,EAAE;MACvB,IAAM/J,OAAO,GAAGL,QAAQ,CAACG,MAAM,CAAC;MAChC,IAAMkE,KAAK,GAAGhE,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEgK,cAAc,CAACD,SAAS,CAAC;MAChD,IAAI/J,OAAO,IAAIgE,KAAK,EAAE;QACpB,IAAM/E,OAAO,GAAGgB,mBAAmB,CAACD,OAAO,EAAExC,MAAM,CAAC;QACpD,IAAMe,aAAa,GAAG,SAAhBA,aAAaA,CAAG6E,KAAK;UAAA,OAAIY,KAAK,CAACzF,aAAa,CAAC;YAAC6E,KAAK,EAALA;UAAK,CAAC,CAAC;QAAA;QAC3DwG,GAAG,CAAC9J,MAAM,CAAC,GAAGN,mBAAmB,CAACZ,MAAM,EAAEK,OAAO,EAAEK,OAAO,EAAEf,aAAa,CAAC;MAC5E;IACF;IACA,OAAOqL,GAAG;EACZ,CAAC,EAAE,CAAC,CAAC,CAAC;AACR;AAEO,SAASK,yBAAyBA,CACvCzM,MAAmB,EACnB6I,QAAiC,EACjC1G,QAAkB,EAClBG,MAAe,EACF;EACb,IAAMuJ,UAAU,GAAAxL,aAAA,CAAAA,aAAA,KACXL,MAAM;IACT6I,QAAQ,EAARA;EAAQ,EACT;;EAED;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;EAEA,OAAAxI,aAAA,CAAAA,aAAA,KACKL,MAAM;IACT6I,QAAQ,EAARA,QAAQ;IACRxH,IAAI,EAAE8K,kBAAkB,CAACN,UAAU,EAAE1J,QAAQ,EAAEuK,eAAI;EAAC;AAExD;AAEO,SAASC,aAAaA,CAC3B/D,KAA6B,EAC7BC,QAA+B,EACvB;EACR,IAAM+D,SAAS,GAAGhE,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEiE,WAAW;EACpC,IAAOhG,WAAW,GAAIgC,QAAQ,CAAvBhC,WAAW;EAElB,IAAI+F,SAAS,EAAE;IACb,OAAO,IAAAE,8BAAqB,KAAAhD,MAAA,CAAIjD,WAAW,OAAAiD,MAAA,CAAI8C,SAAS,eAAY,CAAC;EACvE;EAEA;AACF;AAEO,SAASZ,kBAAkBA,CAAChM,MAAM,EAAEmC,QAAQ,EAAE;EACnD,IAAMC,QAAQ,GAAG,IAAAwI,wBAAkB,EAAC5K,MAAM,EAAEmC,QAAQ,CAAC;EACrD,IAAM4K,iBAAiB,GAAG,IAAAC,4BAAoB,EAAC5K,QAAQ,CAAC;EACxD,OAAO;IACLA,QAAQ,EAARA,QAAQ;IACR2K,iBAAiB,EAAjBA,iBAAiB;IACjB/C,IAAI,EAAEiC,qBAAU,CAACC,SAAS;IAC1BrF,WAAW,EAAEC,4BAAiB,CAACkB;EACjC,CAAC;AACH","ignoreList":[]}