@kepler.gl/utils 3.0.0 → 3.1.0-alpha.0

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 (73) hide show
  1. package/package.json +14 -10
  2. package/dist/aggregate-utils.d.ts +0 -3
  3. package/dist/aggregate-utils.js +0 -75
  4. package/dist/arrow-data-container.d.ts +0 -54
  5. package/dist/arrow-data-container.js +0 -360
  6. package/dist/color-utils.d.ts +0 -51
  7. package/dist/color-utils.js +0 -161
  8. package/dist/data-container-interface.d.ts +0 -133
  9. package/dist/data-container-interface.js +0 -6
  10. package/dist/data-container-utils.d.ts +0 -30
  11. package/dist/data-container-utils.js +0 -88
  12. package/dist/data-row.d.ts +0 -59
  13. package/dist/data-row.js +0 -126
  14. package/dist/data-scale-utils.d.ts +0 -23
  15. package/dist/data-scale-utils.js +0 -62
  16. package/dist/data-utils.d.ts +0 -103
  17. package/dist/data-utils.js +0 -502
  18. package/dist/dataset-utils.d.ts +0 -116
  19. package/dist/dataset-utils.js +0 -614
  20. package/dist/dom-to-image.d.ts +0 -73
  21. package/dist/dom-to-image.js +0 -489
  22. package/dist/dom-utils.d.ts +0 -23
  23. package/dist/dom-utils.js +0 -434
  24. package/dist/effect-utils.d.ts +0 -23
  25. package/dist/effect-utils.js +0 -196
  26. package/dist/export-map-html.d.ts +0 -9
  27. package/dist/export-map-html.js +0 -28
  28. package/dist/export-utils.d.ts +0 -53
  29. package/dist/export-utils.js +0 -262
  30. package/dist/filter-utils.d.ts +0 -326
  31. package/dist/filter-utils.js +0 -1333
  32. package/dist/format.d.ts +0 -1
  33. package/dist/format.js +0 -17
  34. package/dist/gl-utils.d.ts +0 -1
  35. package/dist/gl-utils.js +0 -35
  36. package/dist/h3-utils.d.ts +0 -21
  37. package/dist/h3-utils.js +0 -81
  38. package/dist/index.d.ts +0 -36
  39. package/dist/index.js +0 -772
  40. package/dist/indexed-data-container.d.ts +0 -34
  41. package/dist/indexed-data-container.js +0 -254
  42. package/dist/locale-utils.d.ts +0 -2
  43. package/dist/locale-utils.js +0 -54
  44. package/dist/map-info-utils.d.ts +0 -1
  45. package/dist/map-info-utils.js +0 -15
  46. package/dist/map-style-utils/mapbox-gl-style-editor.d.ts +0 -65
  47. package/dist/map-style-utils/mapbox-gl-style-editor.js +0 -218
  48. package/dist/map-style-utils/mapbox-utils.d.ts +0 -9
  49. package/dist/map-style-utils/mapbox-utils.js +0 -48
  50. package/dist/map-utils.d.ts +0 -9
  51. package/dist/map-utils.js +0 -65
  52. package/dist/mapbox-utils.d.ts +0 -7
  53. package/dist/mapbox-utils.js +0 -22
  54. package/dist/noop.d.ts +0 -1
  55. package/dist/noop.js +0 -11
  56. package/dist/notifications-utils.d.ts +0 -42
  57. package/dist/notifications-utils.js +0 -85
  58. package/dist/observe-dimensions.d.ts +0 -15
  59. package/dist/observe-dimensions.js +0 -151
  60. package/dist/plot.d.ts +0 -6
  61. package/dist/plot.js +0 -31
  62. package/dist/projection-utils.d.ts +0 -21
  63. package/dist/projection-utils.js +0 -100
  64. package/dist/row-data-container.d.ts +0 -31
  65. package/dist/row-data-container.js +0 -252
  66. package/dist/searcher-utils.d.ts +0 -1
  67. package/dist/searcher-utils.js +0 -28
  68. package/dist/split-map-utils.d.ts +0 -32
  69. package/dist/split-map-utils.js +0 -114
  70. package/dist/time.d.ts +0 -16
  71. package/dist/time.js +0 -89
  72. package/dist/utils.d.ts +0 -116
  73. package/dist/utils.js +0 -305
@@ -1,614 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.findDefaultColorField = findDefaultColorField;
9
- exports.validateInputData = validateInputData;
10
- exports.getSampleForTypeAnalyze = getSampleForTypeAnalyze;
11
- exports.isHexWkb = isHexWkb;
12
- exports.getFieldsFromData = getFieldsFromData;
13
- exports.renameDuplicateFields = renameDuplicateFields;
14
- exports.analyzerTypeToFieldType = analyzerTypeToFieldType;
15
- exports.getFieldFormatLabels = getFieldFormatLabels;
16
- exports.getFormatLabels = getFormatLabels;
17
- exports.ACCEPTED_ANALYZER_TYPES = exports.datasetColorMaker = void 0;
18
-
19
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
20
-
21
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
22
-
23
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
24
-
25
- var _window = require("global/window");
26
-
27
- var _constants = require("@kepler.gl/constants");
28
-
29
- var _typeAnalyzer = require("type-analyzer");
30
-
31
- var _assert = _interopRequireDefault(require("assert"));
32
-
33
- var _utils = require("./utils");
34
-
35
- var _dataUtils = require("./data-utils");
36
-
37
- var _format = require("./format");
38
-
39
- var _d3Array = require("d3-array");
40
-
41
- var _colorUtils = require("./color-utils");
42
-
43
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
44
-
45
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
46
-
47
- var _marked = /*#__PURE__*/_regenerator["default"].mark(generateColor);
48
-
49
- // apply a color for each dataset
50
- // to use as label colors
51
- var datasetColors = ['#8F2FBF', '#005CFF', '#C06C84', '#F8B195', '#547A82', '#3EACA8', '#A2D4AB'].map(_colorUtils.hexToRgb);
52
- /**
53
- * Random color generator
54
- */
55
-
56
- function generateColor() {
57
- var index;
58
- return _regenerator["default"].wrap(function generateColor$(_context) {
59
- while (1) {
60
- switch (_context.prev = _context.next) {
61
- case 0:
62
- index = 0;
63
-
64
- case 1:
65
- if (!(index < datasetColors.length + 1)) {
66
- _context.next = 7;
67
- break;
68
- }
69
-
70
- if (index === datasetColors.length) {
71
- index = 0;
72
- }
73
-
74
- _context.next = 5;
75
- return datasetColors[index++];
76
-
77
- case 5:
78
- _context.next = 1;
79
- break;
80
-
81
- case 7:
82
- case "end":
83
- return _context.stop();
84
- }
85
- }
86
- }, _marked);
87
- }
88
-
89
- var datasetColorMaker = generateColor();
90
- /**
91
- * Field name prefixes and suffixes which should not be considered
92
- * as metrics. Fields will still be included if a 'metric word'
93
- * is found on the field name, however.
94
- */
95
-
96
- exports.datasetColorMaker = datasetColorMaker;
97
- var EXCLUDED_DEFAULT_FIELDS = [// Serial numbers and identification numbers
98
- '_id', 'id', 'index', 'uuid', 'guid', 'uid', 'gid', 'serial', // Geographic IDs are unlikely to be interesting to color
99
- 'zip', 'code', 'post', 'region', 'fips', 'cbgs', 'h3', 's2', // Geographic coords (but not z/elevation/altitude
100
- // since that might be a metric)
101
- 'lat', 'lon', 'lng', 'latitude', 'longitude', '_x', '_y'];
102
- /**
103
- * Prefixes and suffixes that indicate a field is a metric.
104
- *
105
- * Note that these are in order of preference, first being
106
- * most preferred.
107
- */
108
-
109
- var METRIC_DEFAULT_FIELDS = ['metric', 'value', 'sum', 'count', 'unique', 'mean', 'mode', 'median', 'max', 'min', 'deviation', 'variance', 'p99', 'p95', 'p75', 'p50', 'p25', 'p05', // Abbreviations are less preferred
110
- 'cnt', 'val'];
111
- /**
112
- * Choose a field to use as the default color field of a layer.
113
- *
114
- * The heuristic is:
115
- *
116
- * First, exclude fields that are on the exclusion list and don't
117
- * have names that suggest they contain metrics. Also exclude
118
- * field names that are blank.
119
- *
120
- * Next, look for a field that is of real type and contains one
121
- * of the preferred names (in order of the preferred names).
122
- *
123
- * Next, look for a field that is of integer type and contains
124
- * one of the preferred names (in order of the preferred names).
125
- *
126
- * Next, look for the first field that is of real type (in order
127
- * of field index).
128
- *
129
- * Next, look for the first field that is of integer type (in
130
- * order of field index).
131
- *
132
- * It's possible no field will be chosen (i.e. because all fields
133
- * are strings.)
134
- *
135
- * @param dataset
136
- */
137
-
138
- function findDefaultColorField(_ref) {
139
- var fields = _ref.fields,
140
- _ref$fieldPairs = _ref.fieldPairs,
141
- fieldPairs = _ref$fieldPairs === void 0 ? [] : _ref$fieldPairs;
142
- var fieldsWithoutExcluded = fields.filter(function (field) {
143
- if (field.type !== _constants.ALL_FIELD_TYPES.real && field.type !== _constants.ALL_FIELD_TYPES.integer) {
144
- // Only select numeric fields.
145
- return false;
146
- }
147
-
148
- if (fieldPairs.find(function (pair) {
149
- return pair.pair.lat.value === field.name || pair.pair.lng.value === field.name;
150
- })) {
151
- // Do not permit lat, lon fields
152
- return false;
153
- }
154
-
155
- var normalizedFieldName = field.name.toLowerCase();
156
-
157
- if (normalizedFieldName === '') {
158
- // Special case excluded name when the name is blank.
159
- return false;
160
- }
161
-
162
- var hasExcluded = EXCLUDED_DEFAULT_FIELDS.find(function (f) {
163
- return normalizedFieldName.startsWith(f) || normalizedFieldName.endsWith(f);
164
- });
165
- var hasInclusion = METRIC_DEFAULT_FIELDS.find(function (f) {
166
- return normalizedFieldName.startsWith(f) || normalizedFieldName.endsWith(f);
167
- });
168
- return !hasExcluded || hasInclusion;
169
- });
170
- var sortedFields = fieldsWithoutExcluded.sort(function (left, right) {
171
- var normalizedLeft = left.name.toLowerCase();
172
- var normalizedRight = right.name.toLowerCase();
173
- var leftHasInclusion = METRIC_DEFAULT_FIELDS.findIndex(function (f) {
174
- return normalizedLeft.startsWith(f) || normalizedLeft.endsWith(f);
175
- });
176
- var rightHasInclusion = METRIC_DEFAULT_FIELDS.findIndex(function (f) {
177
- return normalizedRight.startsWith(f) || normalizedRight.endsWith(f);
178
- });
179
-
180
- if (leftHasInclusion !== rightHasInclusion) {
181
- if (leftHasInclusion === -1) {
182
- // Elements that do not have the inclusion list should go after those that do.
183
- return 1;
184
- } else if (rightHasInclusion === -1) {
185
- // Elements that do have the inclusion list should go before those that don't.
186
- return -1;
187
- } // Compare based on order in the inclusion list
188
-
189
-
190
- return leftHasInclusion - rightHasInclusion;
191
- } // Compare based on type
192
-
193
-
194
- if (left.type !== right.type) {
195
- if (left.type === _constants.ALL_FIELD_TYPES.real) {
196
- return -1;
197
- } // left is an integer and right is not
198
- // and reals come before integers
199
-
200
-
201
- return 1;
202
- } // Finally, order based on the order in the datasets columns
203
- // @ts-expect-error
204
-
205
-
206
- return left.index - right.index;
207
- });
208
-
209
- if (sortedFields.length) {
210
- // There was a best match
211
- return sortedFields[0];
212
- } // No matches
213
-
214
-
215
- return null;
216
- }
217
-
218
- var ACCEPTED_ANALYZER_TYPES = [_typeAnalyzer.DATA_TYPES.DATE, _typeAnalyzer.DATA_TYPES.TIME, _typeAnalyzer.DATA_TYPES.DATETIME, _typeAnalyzer.DATA_TYPES.NUMBER, _typeAnalyzer.DATA_TYPES.INT, _typeAnalyzer.DATA_TYPES.FLOAT, _typeAnalyzer.DATA_TYPES.BOOLEAN, _typeAnalyzer.DATA_TYPES.STRING, _typeAnalyzer.DATA_TYPES.GEOMETRY, _typeAnalyzer.DATA_TYPES.GEOMETRY_FROM_STRING, _typeAnalyzer.DATA_TYPES.PAIR_GEOMETRY_FROM_STRING, _typeAnalyzer.DATA_TYPES.ZIPCODE, _typeAnalyzer.DATA_TYPES.ARRAY, _typeAnalyzer.DATA_TYPES.OBJECT];
219
- exports.ACCEPTED_ANALYZER_TYPES = ACCEPTED_ANALYZER_TYPES;
220
- var IGNORE_DATA_TYPES = Object.keys(_typeAnalyzer.DATA_TYPES).filter(function (type) {
221
- return !ACCEPTED_ANALYZER_TYPES.includes(type);
222
- });
223
- /**
224
- * Validate input data, adding missing field types, rename duplicate columns
225
- */
226
-
227
- function validateInputData(data) {
228
- if (!(0, _utils.isPlainObject)(data)) {
229
- (0, _assert["default"])('addDataToMap Error: dataset.data cannot be null');
230
- return null;
231
- } else if (!Array.isArray(data.fields)) {
232
- (0, _assert["default"])('addDataToMap Error: expect dataset.data.fields to be an array');
233
- return null;
234
- } else if (!Array.isArray(data.rows)) {
235
- (0, _assert["default"])('addDataToMap Error: expect dataset.data.rows to be an array');
236
- return null;
237
- }
238
-
239
- var fields = data.fields,
240
- rows = data.rows,
241
- cols = data.cols; // check if all fields has name, format and type
242
-
243
- var allValid = fields.every(function (f, i) {
244
- if (!(0, _utils.isPlainObject)(f)) {
245
- (0, _assert["default"])("fields needs to be an array of object, but find ".concat((0, _typeof2["default"])(f)));
246
- fields[i] = {
247
- name: "column_".concat(i)
248
- };
249
- }
250
-
251
- if (!f.name) {
252
- (0, _assert["default"])("field.name is required but missing in ".concat(JSON.stringify(f))); // assign a name
253
-
254
- fields[i].name = "column_".concat(i);
255
- }
256
-
257
- if (!f.type || !_constants.ALL_FIELD_TYPES[f.type]) {
258
- (0, _assert["default"])("unknown field type ".concat(f.type));
259
- return false;
260
- }
261
-
262
- if (!fields.every(function (field) {
263
- return field.analyzerType;
264
- })) {
265
- (0, _assert["default"])('field missing analyzerType');
266
- return false;
267
- } // check time format is correct based on first 10 not empty element
268
-
269
-
270
- if (f.type === _constants.ALL_FIELD_TYPES.timestamp) {
271
- var sample = findNonEmptyRowsAtField(rows, i, 10).map(function (r) {
272
- return {
273
- ts: r[i]
274
- };
275
- });
276
-
277
- var analyzedType = _typeAnalyzer.Analyzer.computeColMeta(sample)[0];
278
-
279
- return analyzedType && analyzedType.category === 'TIME' && analyzedType.format === f.format;
280
- }
281
-
282
- return true;
283
- });
284
-
285
- if (allValid) {
286
- return {
287
- rows: rows,
288
- fields: fields,
289
- cols: cols
290
- };
291
- } // if any field has missing type, recalculate it for everyone
292
- // because we simply lost faith in humanity
293
-
294
-
295
- var sampleData = getSampleForTypeAnalyze({
296
- fields: fields.map(function (f) {
297
- return f.name;
298
- }),
299
- rows: rows
300
- });
301
- var fieldOrder = fields.map(function (f) {
302
- return f.name;
303
- });
304
- var meta = getFieldsFromData(sampleData, fieldOrder);
305
- var updatedFields = fields.map(function (f, i) {
306
- return _objectSpread(_objectSpread({}, f), {}, {
307
- type: meta[i].type,
308
- format: meta[i].format,
309
- analyzerType: meta[i].analyzerType
310
- });
311
- });
312
- return {
313
- fields: updatedFields,
314
- rows: rows
315
- };
316
- }
317
-
318
- function findNonEmptyRowsAtField(rows, fieldIdx, total) {
319
- var sample = [];
320
- var i = 0;
321
-
322
- while (sample.length < total && i < rows.length) {
323
- var _rows$i;
324
-
325
- if ((0, _dataUtils.notNullorUndefined)((_rows$i = rows[i]) === null || _rows$i === void 0 ? void 0 : _rows$i[fieldIdx])) {
326
- sample.push(rows[i]);
327
- }
328
-
329
- i++;
330
- }
331
-
332
- return sample;
333
- }
334
- /**
335
- * Getting sample data for analyzing field type.
336
- */
337
-
338
-
339
- function getSampleForTypeAnalyze(_ref2) {
340
- var fields = _ref2.fields,
341
- rows = _ref2.rows,
342
- _ref2$sampleCount = _ref2.sampleCount,
343
- sampleCount = _ref2$sampleCount === void 0 ? 50 : _ref2$sampleCount;
344
- var total = Math.min(sampleCount, rows.length); // const fieldOrder = fields.map(f => f.name);
345
-
346
- var sample = (0, _d3Array.range)(0, total, 1).map(function (d) {
347
- return {};
348
- }); // collect sample data for each field
349
-
350
- fields.forEach(function (field, fieldIdx) {
351
- // data counter
352
- var i = 0; // sample counter
353
-
354
- var j = 0;
355
-
356
- while (j < total) {
357
- if (i >= rows.length) {
358
- // if depleted data pool
359
- sample[j][field] = null;
360
- j++;
361
- } else if ((0, _dataUtils.notNullorUndefined)(rows[i][fieldIdx])) {
362
- var value = rows[i][fieldIdx];
363
- sample[j][field] = typeof value === 'string' ? value.trim() : value;
364
- j++;
365
- i++;
366
- } else {
367
- i++;
368
- }
369
- }
370
- });
371
- return sample;
372
- }
373
- /**
374
- * Check if string is a valid Well-known binary (WKB) in HEX format
375
- * https://en.wikipedia.org/wiki/Well-known_text_representation_of_geometry
376
- *
377
- * @param str input string
378
- * @returns true if string is a valid WKB in HEX format
379
- */
380
-
381
-
382
- function isHexWkb(str) {
383
- if (!str) return false; // check if the length of the string is even and is at least 10 characters long
384
-
385
- if (str.length < 10 || str.length % 2 !== 0) {
386
- return false;
387
- } // check if first two characters are 00 or 01
388
-
389
-
390
- if (!str.startsWith('00') && !str.startsWith('01')) {
391
- return false;
392
- } // check if the rest of the string is a valid hex
393
-
394
-
395
- return /^[0-9a-fA-F]+$/.test(str.slice(2));
396
- }
397
- /**
398
- * Analyze field types from data in `string` format, e.g. uploaded csv.
399
- * Assign `type`, `fieldIdx` and `format` (timestamp only) to each field
400
- *
401
- * @param data array of row object
402
- * @param fieldOrder array of field names as string
403
- * @returns formatted fields
404
- * @public
405
- * @example
406
- *
407
- * import {getFieldsFromData} from 'kepler.gl/processors';
408
- * const data = [{
409
- * time: '2016-09-17 00:09:55',
410
- * value: '4',
411
- * surge: '1.2',
412
- * isTrip: 'true',
413
- * zeroOnes: '0'
414
- * }, {
415
- * time: '2016-09-17 00:30:08',
416
- * value: '3',
417
- * surge: null,
418
- * isTrip: 'false',
419
- * zeroOnes: '1'
420
- * }, {
421
- * time: null,
422
- * value: '2',
423
- * surge: '1.3',
424
- * isTrip: null,
425
- * zeroOnes: '1'
426
- * }];
427
- *
428
- * const fieldOrder = ['time', 'value', 'surge', 'isTrip', 'zeroOnes'];
429
- * const fields = getFieldsFromData(data, fieldOrder);
430
- * // fields = [
431
- * // {name: 'time', format: 'YYYY-M-D H:m:s', fieldIdx: 1, type: 'timestamp'},
432
- * // {name: 'value', format: '', fieldIdx: 4, type: 'integer'},
433
- * // {name: 'surge', format: '', fieldIdx: 5, type: 'real'},
434
- * // {name: 'isTrip', format: '', fieldIdx: 6, type: 'boolean'},
435
- * // {name: 'zeroOnes', format: '', fieldIdx: 7, type: 'integer'}];
436
- *
437
- */
438
-
439
-
440
- function getFieldsFromData(data, fieldOrder) {
441
- // add a check for epoch timestamp
442
- var metadata = _typeAnalyzer.Analyzer.computeColMeta(data, [{
443
- regex: /.*geojson|all_points/g,
444
- dataType: 'GEOMETRY'
445
- }, {
446
- regex: /.*census/g,
447
- dataType: 'STRING'
448
- }], {
449
- ignoredDataTypes: IGNORE_DATA_TYPES
450
- });
451
-
452
- var _renameDuplicateField = renameDuplicateFields(fieldOrder),
453
- fieldByIndex = _renameDuplicateField.fieldByIndex;
454
-
455
- var result = fieldOrder.map(function (field, index) {
456
- var name = fieldByIndex[index];
457
- var fieldMeta = metadata.find(function (m) {
458
- return m.key === field;
459
- }); // fieldMeta could be undefined if the field has no data and Analyzer.computeColMeta
460
- // will ignore the field. In this case, we will simply assign the field type to STRING
461
- // since dropping the column in the RowData could be expensive
462
-
463
- var type = (fieldMeta === null || fieldMeta === void 0 ? void 0 : fieldMeta.type) || 'STRING';
464
- var format = (fieldMeta === null || fieldMeta === void 0 ? void 0 : fieldMeta.format) || ''; // check if string is hex wkb
465
-
466
- if (type === _typeAnalyzer.DATA_TYPES.STRING) {
467
- type = data.some(function (d) {
468
- return isHexWkb(d[name]);
469
- }) ? _typeAnalyzer.DATA_TYPES.GEOMETRY : type;
470
- }
471
-
472
- return {
473
- name: name,
474
- id: name,
475
- displayName: name,
476
- format: format,
477
- fieldIdx: index,
478
- type: analyzerTypeToFieldType(type),
479
- analyzerType: type,
480
- valueAccessor: function valueAccessor(dc) {
481
- return function (d) {
482
- return dc.valueAt(d.index, index);
483
- };
484
- }
485
- };
486
- });
487
- return result;
488
- }
489
- /**
490
- * pass in an array of field names, rename duplicated one
491
- * and return a map from old field index to new name
492
- *
493
- * @param fieldOrder
494
- * @returns new field name by index
495
- */
496
-
497
-
498
- function renameDuplicateFields(fieldOrder) {
499
- return fieldOrder.reduce(function (accu, field, i) {
500
- var allNames = accu.allNames;
501
- var fieldName = field; // add a counter to duplicated names
502
-
503
- if (allNames.includes(field)) {
504
- var counter = 0;
505
-
506
- while (allNames.includes("".concat(field, "-").concat(counter))) {
507
- counter++;
508
- }
509
-
510
- fieldName = "".concat(field, "-").concat(counter);
511
- }
512
-
513
- accu.fieldByIndex[i] = fieldName;
514
- accu.allNames.push(fieldName);
515
- return accu;
516
- }, {
517
- allNames: [],
518
- fieldByIndex: []
519
- });
520
- }
521
- /**
522
- * Convert type-analyzer output to kepler.gl field types
523
- *
524
- * @param aType
525
- * @returns corresponding type in `ALL_FIELD_TYPES`
526
- */
527
-
528
- /* eslint-disable complexity */
529
-
530
-
531
- function analyzerTypeToFieldType(aType) {
532
- var DATE = _typeAnalyzer.DATA_TYPES.DATE,
533
- TIME = _typeAnalyzer.DATA_TYPES.TIME,
534
- DATETIME = _typeAnalyzer.DATA_TYPES.DATETIME,
535
- NUMBER = _typeAnalyzer.DATA_TYPES.NUMBER,
536
- INT = _typeAnalyzer.DATA_TYPES.INT,
537
- FLOAT = _typeAnalyzer.DATA_TYPES.FLOAT,
538
- BOOLEAN = _typeAnalyzer.DATA_TYPES.BOOLEAN,
539
- STRING = _typeAnalyzer.DATA_TYPES.STRING,
540
- GEOMETRY = _typeAnalyzer.DATA_TYPES.GEOMETRY,
541
- GEOMETRY_FROM_STRING = _typeAnalyzer.DATA_TYPES.GEOMETRY_FROM_STRING,
542
- PAIR_GEOMETRY_FROM_STRING = _typeAnalyzer.DATA_TYPES.PAIR_GEOMETRY_FROM_STRING,
543
- ZIPCODE = _typeAnalyzer.DATA_TYPES.ZIPCODE,
544
- ARRAY = _typeAnalyzer.DATA_TYPES.ARRAY,
545
- OBJECT = _typeAnalyzer.DATA_TYPES.OBJECT; // TODO: un recognized types
546
- // CURRENCY PERCENT NONE
547
-
548
- switch (aType) {
549
- case DATE:
550
- return _constants.ALL_FIELD_TYPES.date;
551
-
552
- case TIME:
553
- case DATETIME:
554
- return _constants.ALL_FIELD_TYPES.timestamp;
555
-
556
- case FLOAT:
557
- return _constants.ALL_FIELD_TYPES.real;
558
-
559
- case INT:
560
- return _constants.ALL_FIELD_TYPES.integer;
561
-
562
- case BOOLEAN:
563
- return _constants.ALL_FIELD_TYPES["boolean"];
564
-
565
- case GEOMETRY:
566
- case GEOMETRY_FROM_STRING:
567
- case PAIR_GEOMETRY_FROM_STRING:
568
- return _constants.ALL_FIELD_TYPES.geojson;
569
-
570
- case ARRAY:
571
- return _constants.ALL_FIELD_TYPES.array;
572
-
573
- case OBJECT:
574
- return _constants.ALL_FIELD_TYPES.object;
575
-
576
- case NUMBER:
577
- case STRING:
578
- case ZIPCODE:
579
- return _constants.ALL_FIELD_TYPES.string;
580
-
581
- default:
582
- _window.console.warn("Unsupported analyzer type: ".concat(aType));
583
-
584
- return _constants.ALL_FIELD_TYPES.string;
585
- }
586
- }
587
-
588
- var TIME_DISPLAY = '2020-05-11 14:00';
589
-
590
- var addTimeLabel = function addTimeLabel(formats) {
591
- return formats.map(function (f) {
592
- return _objectSpread(_objectSpread({}, f), {}, {
593
- label: f.type === _constants.TOOLTIP_FORMAT_TYPES.DATE_TIME || f.type === _constants.TOOLTIP_FORMAT_TYPES.DATE ? (0, _dataUtils.getFormatter)((0, _format.getFormatValue)(f))(TIME_DISPLAY) : f.label
594
- });
595
- });
596
- };
597
-
598
- function getFieldFormatLabels(fieldType) {
599
- var tooltipTypes = fieldType && _constants.FIELD_OPTS[fieldType].format.tooltip || [];
600
- var formatLabels = Object.values(_constants.TOOLTIP_FORMATS).filter(function (t) {
601
- return tooltipTypes.includes(t.type);
602
- });
603
- return addTimeLabel(formatLabels);
604
- }
605
-
606
- function getFormatLabels(fields, fieldName) {
607
- var _fields$find;
608
-
609
- var fieldType = (_fields$find = fields.find(function (f) {
610
- return f.name === fieldName;
611
- })) === null || _fields$find === void 0 ? void 0 : _fields$find.type;
612
- return getFieldFormatLabels(fieldType);
613
- }
614
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/dataset-utils.ts"],"names":["generateColor","datasetColors","map","hexToRgb","index","length","datasetColorMaker","EXCLUDED_DEFAULT_FIELDS","METRIC_DEFAULT_FIELDS","findDefaultColorField","fields","fieldPairs","fieldsWithoutExcluded","filter","field","type","ALL_FIELD_TYPES","real","integer","find","pair","lat","value","name","lng","normalizedFieldName","toLowerCase","hasExcluded","f","startsWith","endsWith","hasInclusion","sortedFields","sort","left","right","normalizedLeft","normalizedRight","leftHasInclusion","findIndex","rightHasInclusion","ACCEPTED_ANALYZER_TYPES","AnalyzerDATA_TYPES","DATE","TIME","DATETIME","NUMBER","INT","FLOAT","BOOLEAN","STRING","GEOMETRY","GEOMETRY_FROM_STRING","PAIR_GEOMETRY_FROM_STRING","ZIPCODE","ARRAY","OBJECT","IGNORE_DATA_TYPES","Object","keys","includes","validateInputData","data","Array","isArray","rows","cols","allValid","every","i","JSON","stringify","analyzerType","timestamp","sample","findNonEmptyRowsAtField","r","ts","analyzedType","Analyzer","computeColMeta","category","format","sampleData","getSampleForTypeAnalyze","fieldOrder","meta","getFieldsFromData","updatedFields","fieldIdx","total","push","sampleCount","Math","min","d","forEach","j","trim","isHexWkb","str","test","slice","metadata","regex","dataType","ignoredDataTypes","renameDuplicateFields","fieldByIndex","result","fieldMeta","m","key","some","id","displayName","analyzerTypeToFieldType","valueAccessor","dc","valueAt","reduce","accu","allNames","fieldName","counter","aType","date","geojson","array","object","string","globalConsole","warn","TIME_DISPLAY","addTimeLabel","formats","label","TOOLTIP_FORMAT_TYPES","DATE_TIME","getFieldFormatLabels","fieldType","tooltipTypes","FIELD_OPTS","tooltip","formatLabels","values","TOOLTIP_FORMATS","t","getFormatLabels"],"mappings":"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","sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {console as globalConsole} from 'global/window';\nimport {\n  ALL_FIELD_TYPES,\n  FIELD_OPTS,\n  TOOLTIP_FORMATS,\n  TOOLTIP_FORMAT_TYPES\n} from '@kepler.gl/constants';\nimport {Analyzer, DATA_TYPES as AnalyzerDATA_TYPES} from 'type-analyzer';\nimport assert from 'assert';\n\nimport {\n  ProcessorResult,\n  RGBColor,\n  RowData,\n  Field,\n  FieldPair,\n  TimeLabelFormat,\n  TooltipFields,\n  ProtoDataset\n} from '@kepler.gl/types';\nimport {TooltipFormat} from '@kepler.gl/constants';\n\nimport {isPlainObject} from './utils';\nimport {notNullorUndefined, getFormatter} from './data-utils';\nimport {getFormatValue} from './format';\nimport {range} from 'd3-array';\nimport {hexToRgb} from './color-utils';\n\n// apply a color for each dataset\n// to use as label colors\nconst datasetColors = [\n  '#8F2FBF',\n  '#005CFF',\n  '#C06C84',\n  '#F8B195',\n  '#547A82',\n  '#3EACA8',\n  '#A2D4AB'\n].map(hexToRgb);\n\n/**\n * Random color generator\n */\nfunction* generateColor(): Generator<RGBColor> {\n  let index = 0;\n  while (index < datasetColors.length + 1) {\n    if (index === datasetColors.length) {\n      index = 0;\n    }\n    yield datasetColors[index++];\n  }\n}\n\nexport const datasetColorMaker = generateColor();\n\n/**\n * Field name prefixes and suffixes which should not be considered\n * as metrics. Fields will still be included if a 'metric word'\n * is found on the field name, however.\n */\nconst EXCLUDED_DEFAULT_FIELDS = [\n  // Serial numbers and identification numbers\n  '_id',\n  'id',\n  'index',\n  'uuid',\n  'guid',\n  'uid',\n  'gid',\n  'serial',\n  // Geographic IDs are unlikely to be interesting to color\n  'zip',\n  'code',\n  'post',\n  'region',\n  'fips',\n  'cbgs',\n  'h3',\n  's2',\n  // Geographic coords (but not z/elevation/altitude\n  // since that might be a metric)\n  'lat',\n  'lon',\n  'lng',\n  'latitude',\n  'longitude',\n  '_x',\n  '_y'\n];\n\n/**\n * Prefixes and suffixes that indicate a field is a metric.\n *\n * Note that these are in order of preference, first being\n * most preferred.\n */\nconst METRIC_DEFAULT_FIELDS = [\n  'metric',\n  'value',\n  'sum',\n  'count',\n  'unique',\n  'mean',\n  'mode',\n  'median',\n  'max',\n  'min',\n  'deviation',\n  'variance',\n  'p99',\n  'p95',\n  'p75',\n  'p50',\n  'p25',\n  'p05',\n  // Abbreviations are less preferred\n  'cnt',\n  'val'\n];\n\n/**\n * Choose a field to use as the default color field of a layer.\n *\n * The heuristic is:\n *\n * First, exclude fields that are on the exclusion list and don't\n * have names that suggest they contain metrics. Also exclude\n * field names that are blank.\n *\n * Next, look for a field that is of real type and contains one\n * of the preferred names (in order of the preferred names).\n *\n * Next, look for a field that is of integer type and contains\n * one of the preferred names (in order of the preferred names).\n *\n * Next, look for the first field that is of real type (in order\n * of field index).\n *\n * Next, look for the first field that is of integer type (in\n * order of field index).\n *\n * It's possible no field will be chosen (i.e. because all fields\n * are strings.)\n *\n * @param dataset\n */\nexport function findDefaultColorField({\n  fields,\n  fieldPairs = []\n}: {\n  fields: Field[];\n  fieldPairs: FieldPair[];\n}): null | Field {\n  const fieldsWithoutExcluded = fields.filter(field => {\n    if (field.type !== ALL_FIELD_TYPES.real && field.type !== ALL_FIELD_TYPES.integer) {\n      // Only select numeric fields.\n      return false;\n    }\n    if (\n      fieldPairs.find(\n        pair => pair.pair.lat.value === field.name || pair.pair.lng.value === field.name\n      )\n    ) {\n      // Do not permit lat, lon fields\n      return false;\n    }\n\n    const normalizedFieldName = field.name.toLowerCase();\n    if (normalizedFieldName === '') {\n      // Special case excluded name when the name is blank.\n      return false;\n    }\n    const hasExcluded = EXCLUDED_DEFAULT_FIELDS.find(\n      f => normalizedFieldName.startsWith(f) || normalizedFieldName.endsWith(f)\n    );\n    const hasInclusion = METRIC_DEFAULT_FIELDS.find(\n      f => normalizedFieldName.startsWith(f) || normalizedFieldName.endsWith(f)\n    );\n    return !hasExcluded || hasInclusion;\n  });\n\n  const sortedFields = fieldsWithoutExcluded.sort((left, right) => {\n    const normalizedLeft = left.name.toLowerCase();\n    const normalizedRight = right.name.toLowerCase();\n    const leftHasInclusion = METRIC_DEFAULT_FIELDS.findIndex(\n      f => normalizedLeft.startsWith(f) || normalizedLeft.endsWith(f)\n    );\n    const rightHasInclusion = METRIC_DEFAULT_FIELDS.findIndex(\n      f => normalizedRight.startsWith(f) || normalizedRight.endsWith(f)\n    );\n    if (leftHasInclusion !== rightHasInclusion) {\n      if (leftHasInclusion === -1) {\n        // Elements that do not have the inclusion list should go after those that do.\n        return 1;\n      } else if (rightHasInclusion === -1) {\n        // Elements that do have the inclusion list should go before those that don't.\n        return -1;\n      }\n      // Compare based on order in the inclusion list\n      return leftHasInclusion - rightHasInclusion;\n    }\n\n    // Compare based on type\n    if (left.type !== right.type) {\n      if (left.type === ALL_FIELD_TYPES.real) {\n        return -1;\n      }\n      // left is an integer and right is not\n      // and reals come before integers\n      return 1;\n    }\n\n    // Finally, order based on the order in the datasets columns\n    // @ts-expect-error\n    return left.index - right.index;\n  });\n\n  if (sortedFields.length) {\n    // There was a best match\n    return sortedFields[0];\n  }\n  // No matches\n  return null;\n}\n\nexport const ACCEPTED_ANALYZER_TYPES = [\n  AnalyzerDATA_TYPES.DATE,\n  AnalyzerDATA_TYPES.TIME,\n  AnalyzerDATA_TYPES.DATETIME,\n  AnalyzerDATA_TYPES.NUMBER,\n  AnalyzerDATA_TYPES.INT,\n  AnalyzerDATA_TYPES.FLOAT,\n  AnalyzerDATA_TYPES.BOOLEAN,\n  AnalyzerDATA_TYPES.STRING,\n  AnalyzerDATA_TYPES.GEOMETRY,\n  AnalyzerDATA_TYPES.GEOMETRY_FROM_STRING,\n  AnalyzerDATA_TYPES.PAIR_GEOMETRY_FROM_STRING,\n  AnalyzerDATA_TYPES.ZIPCODE,\n  AnalyzerDATA_TYPES.ARRAY,\n  AnalyzerDATA_TYPES.OBJECT\n];\n\nconst IGNORE_DATA_TYPES = Object.keys(AnalyzerDATA_TYPES).filter(\n  type => !ACCEPTED_ANALYZER_TYPES.includes(type)\n);\n\n/**\n * Validate input data, adding missing field types, rename duplicate columns\n */\nexport function validateInputData(data: ProtoDataset['data']): ProcessorResult {\n  if (!isPlainObject(data)) {\n    assert('addDataToMap Error: dataset.data cannot be null');\n    return null;\n  } else if (!Array.isArray(data.fields)) {\n    assert('addDataToMap Error: expect dataset.data.fields to be an array');\n    return null;\n  } else if (!Array.isArray(data.rows)) {\n    assert('addDataToMap Error: expect dataset.data.rows to be an array');\n    return null;\n  }\n\n  const {fields, rows, cols} = data;\n\n  // check if all fields has name, format and type\n  const allValid = fields.every((f, i) => {\n    if (!isPlainObject(f)) {\n      assert(`fields needs to be an array of object, but find ${typeof f}`);\n      fields[i] = {name: `column_${i}`};\n    }\n\n    if (!f.name) {\n      assert(`field.name is required but missing in ${JSON.stringify(f)}`);\n      // assign a name\n      fields[i].name = `column_${i}`;\n    }\n\n    if (!f.type || !ALL_FIELD_TYPES[f.type]) {\n      assert(`unknown field type ${f.type}`);\n      return false;\n    }\n\n    if (!fields.every(field => field.analyzerType)) {\n      assert('field missing analyzerType');\n      return false;\n    }\n\n    // check time format is correct based on first 10 not empty element\n    if (f.type === ALL_FIELD_TYPES.timestamp) {\n      const sample = findNonEmptyRowsAtField(rows, i, 10).map(r => ({ts: r[i]}));\n      const analyzedType = Analyzer.computeColMeta(sample)[0];\n      return analyzedType && analyzedType.category === 'TIME' && analyzedType.format === f.format;\n    }\n\n    return true;\n  });\n\n  if (allValid) {\n    return {rows, fields, cols};\n  }\n\n  // if any field has missing type, recalculate it for everyone\n  // because we simply lost faith in humanity\n  const sampleData = getSampleForTypeAnalyze({\n    fields: fields.map(f => f.name),\n    rows\n  });\n  const fieldOrder = fields.map(f => f.name);\n  const meta = getFieldsFromData(sampleData, fieldOrder);\n  const updatedFields = fields.map((f, i) => ({\n    ...f,\n    type: meta[i].type,\n    format: meta[i].format,\n    analyzerType: meta[i].analyzerType\n  }));\n\n  return {fields: updatedFields, rows};\n}\n\nfunction findNonEmptyRowsAtField(rows: unknown[][], fieldIdx: number, total: number): any[] {\n  const sample: any[] = [];\n  let i = 0;\n  while (sample.length < total && i < rows.length) {\n    if (notNullorUndefined(rows[i]?.[fieldIdx])) {\n      sample.push(rows[i]);\n    }\n    i++;\n  }\n  return sample;\n}\n/**\n * Getting sample data for analyzing field type.\n */\nexport function getSampleForTypeAnalyze({\n  fields,\n  rows,\n  sampleCount = 50\n}: {\n  fields: string[];\n  rows: unknown[][];\n  sampleCount?: number;\n}): RowData {\n  const total = Math.min(sampleCount, rows.length);\n  // const fieldOrder = fields.map(f => f.name);\n  const sample = range(0, total, 1).map(d => ({}));\n\n  // collect sample data for each field\n  fields.forEach((field, fieldIdx) => {\n    // data counter\n    let i = 0;\n    // sample counter\n    let j = 0;\n\n    while (j < total) {\n      if (i >= rows.length) {\n        // if depleted data pool\n        sample[j][field] = null;\n        j++;\n      } else if (notNullorUndefined(rows[i][fieldIdx])) {\n        const value = rows[i][fieldIdx];\n        sample[j][field] = typeof value === 'string' ? value.trim() : value;\n        j++;\n        i++;\n      } else {\n        i++;\n      }\n    }\n  });\n\n  return sample;\n}\n\n/**\n * Check if string is a valid Well-known binary (WKB) in HEX format\n * https://en.wikipedia.org/wiki/Well-known_text_representation_of_geometry\n *\n * @param str input string\n * @returns true if string is a valid WKB in HEX format\n */\nexport function isHexWkb(str: string | null): boolean {\n  if (!str) return false;\n  // check if the length of the string is even and is at least 10 characters long\n  if (str.length < 10 || str.length % 2 !== 0) {\n    return false;\n  }\n  // check if first two characters are 00 or 01\n  if (!str.startsWith('00') && !str.startsWith('01')) {\n    return false;\n  }\n  // check if the rest of the string is a valid hex\n  return /^[0-9a-fA-F]+$/.test(str.slice(2));\n}\n\n/**\n * Analyze field types from data in `string` format, e.g. uploaded csv.\n * Assign `type`, `fieldIdx` and `format` (timestamp only) to each field\n *\n * @param data array of row object\n * @param fieldOrder array of field names as string\n * @returns formatted fields\n * @public\n * @example\n *\n * import {getFieldsFromData} from 'kepler.gl/processors';\n * const data = [{\n *   time: '2016-09-17 00:09:55',\n *   value: '4',\n *   surge: '1.2',\n *   isTrip: 'true',\n *   zeroOnes: '0'\n * }, {\n *   time: '2016-09-17 00:30:08',\n *   value: '3',\n *   surge: null,\n *   isTrip: 'false',\n *   zeroOnes: '1'\n * }, {\n *   time: null,\n *   value: '2',\n *   surge: '1.3',\n *   isTrip: null,\n *   zeroOnes: '1'\n * }];\n *\n * const fieldOrder = ['time', 'value', 'surge', 'isTrip', 'zeroOnes'];\n * const fields = getFieldsFromData(data, fieldOrder);\n * // fields = [\n * // {name: 'time', format: 'YYYY-M-D H:m:s', fieldIdx: 1, type: 'timestamp'},\n * // {name: 'value', format: '', fieldIdx: 4, type: 'integer'},\n * // {name: 'surge', format: '', fieldIdx: 5, type: 'real'},\n * // {name: 'isTrip', format: '', fieldIdx: 6, type: 'boolean'},\n * // {name: 'zeroOnes', format: '', fieldIdx: 7, type: 'integer'}];\n *\n */\nexport function getFieldsFromData(data: RowData, fieldOrder: string[]): Field[] {\n  // add a check for epoch timestamp\n  const metadata = Analyzer.computeColMeta(\n    data,\n    [\n      {regex: /.*geojson|all_points/g, dataType: 'GEOMETRY'},\n      {regex: /.*census/g, dataType: 'STRING'}\n    ],\n    {ignoredDataTypes: IGNORE_DATA_TYPES}\n  );\n\n  const {fieldByIndex} = renameDuplicateFields(fieldOrder);\n\n  const result = fieldOrder.map((field, index) => {\n    const name = fieldByIndex[index];\n\n    const fieldMeta = metadata.find(m => m.key === field);\n\n    // fieldMeta could be undefined if the field has no data and Analyzer.computeColMeta\n    // will ignore the field. In this case, we will simply assign the field type to STRING\n    // since dropping the column in the RowData could be expensive\n    let type = fieldMeta?.type || 'STRING';\n    const format = fieldMeta?.format || '';\n\n    // check if string is hex wkb\n    if (type === AnalyzerDATA_TYPES.STRING) {\n      type = data.some(d => isHexWkb(d[name])) ? AnalyzerDATA_TYPES.GEOMETRY : type;\n    }\n\n    return {\n      name,\n      id: name,\n      displayName: name,\n      format,\n      fieldIdx: index,\n      type: analyzerTypeToFieldType(type),\n      analyzerType: type,\n      valueAccessor: dc => d => {\n        return dc.valueAt(d.index, index);\n      }\n    };\n  });\n\n  return result;\n}\n\n/**\n * pass in an array of field names, rename duplicated one\n * and return a map from old field index to new name\n *\n * @param fieldOrder\n * @returns new field name by index\n */\nexport function renameDuplicateFields(\n  fieldOrder: string[]\n): {allNames: string[]; fieldByIndex: string[]} {\n  return fieldOrder.reduce<{allNames: string[]; fieldByIndex: string[]}>(\n    (accu, field, i) => {\n      const {allNames} = accu;\n      let fieldName = field;\n\n      // add a counter to duplicated names\n      if (allNames.includes(field)) {\n        let counter = 0;\n        while (allNames.includes(`${field}-${counter}`)) {\n          counter++;\n        }\n        fieldName = `${field}-${counter}`;\n      }\n\n      accu.fieldByIndex[i] = fieldName;\n      accu.allNames.push(fieldName);\n\n      return accu;\n    },\n    {allNames: [], fieldByIndex: []}\n  );\n}\n\n/**\n * Convert type-analyzer output to kepler.gl field types\n *\n * @param aType\n * @returns corresponding type in `ALL_FIELD_TYPES`\n */\n/* eslint-disable complexity */\nexport function analyzerTypeToFieldType(aType: string): string {\n  const {\n    DATE,\n    TIME,\n    DATETIME,\n    NUMBER,\n    INT,\n    FLOAT,\n    BOOLEAN,\n    STRING,\n    GEOMETRY,\n    GEOMETRY_FROM_STRING,\n    PAIR_GEOMETRY_FROM_STRING,\n    ZIPCODE,\n    ARRAY,\n    OBJECT\n  } = AnalyzerDATA_TYPES;\n\n  // TODO: un recognized types\n  // CURRENCY PERCENT NONE\n  switch (aType) {\n    case DATE:\n      return ALL_FIELD_TYPES.date;\n    case TIME:\n    case DATETIME:\n      return ALL_FIELD_TYPES.timestamp;\n    case FLOAT:\n      return ALL_FIELD_TYPES.real;\n    case INT:\n      return ALL_FIELD_TYPES.integer;\n    case BOOLEAN:\n      return ALL_FIELD_TYPES.boolean;\n    case GEOMETRY:\n    case GEOMETRY_FROM_STRING:\n    case PAIR_GEOMETRY_FROM_STRING:\n      return ALL_FIELD_TYPES.geojson;\n    case ARRAY:\n      return ALL_FIELD_TYPES.array;\n    case OBJECT:\n      return ALL_FIELD_TYPES.object;\n    case NUMBER:\n    case STRING:\n    case ZIPCODE:\n      return ALL_FIELD_TYPES.string;\n    default:\n      globalConsole.warn(`Unsupported analyzer type: ${aType}`);\n      return ALL_FIELD_TYPES.string;\n  }\n}\n\nconst TIME_DISPLAY = '2020-05-11 14:00';\n\nconst addTimeLabel = (formats: TimeLabelFormat[]) =>\n  formats.map(f => ({\n    ...f,\n    label:\n      f.type === TOOLTIP_FORMAT_TYPES.DATE_TIME || f.type === TOOLTIP_FORMAT_TYPES.DATE\n        ? getFormatter(getFormatValue(f))(TIME_DISPLAY)\n        : f.label\n  }));\n\nexport function getFieldFormatLabels(fieldType?: string): TooltipFormat[] {\n  const tooltipTypes = (fieldType && FIELD_OPTS[fieldType].format.tooltip) || [];\n  const formatLabels: TimeLabelFormat[] = Object.values(TOOLTIP_FORMATS).filter(t =>\n    tooltipTypes.includes(t.type)\n  );\n  return addTimeLabel(formatLabels);\n}\n\nexport function getFormatLabels(fields: TooltipFields[], fieldName: string) {\n  const fieldType = fields.find(f => f.name === fieldName)?.type;\n  return getFieldFormatLabels(fieldType);\n}\n"]}