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

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 (55) hide show
  1. package/dist/aggregate-utils.js +2 -2
  2. package/dist/color-utils.d.ts +4 -0
  3. package/dist/color-utils.js +28 -3
  4. package/dist/data-container-interface.js +1 -1
  5. package/dist/data-container-utils.js +2 -2
  6. package/dist/data-row.js +2 -2
  7. package/dist/data-scale-utils.js +4 -4
  8. package/dist/data-utils.d.ts +10 -12
  9. package/dist/data-utils.js +120 -44
  10. package/dist/dataset-utils.d.ts +12 -1
  11. package/dist/dataset-utils.js +74 -9
  12. package/dist/dom-to-image.d.ts +14 -14
  13. package/dist/dom-to-image.js +23 -69
  14. package/dist/dom-utils.d.ts +3 -0
  15. package/dist/dom-utils.js +29 -3
  16. package/dist/effect-utils.d.ts +13 -0
  17. package/dist/effect-utils.js +129 -0
  18. package/dist/export-map-html.js +2 -2
  19. package/dist/export-utils.js +13 -4
  20. package/dist/filter-utils.d.ts +11 -9
  21. package/dist/filter-utils.js +66 -36
  22. package/dist/format.d.ts +1 -0
  23. package/dist/format.js +33 -0
  24. package/dist/gl-utils.js +2 -2
  25. package/dist/h3-utils.d.ts +2 -1
  26. package/dist/h3-utils.js +5 -4
  27. package/dist/index.d.ts +14 -9
  28. package/dist/index.js +230 -555
  29. package/dist/indexed-data-container.js +2 -2
  30. package/dist/locale-utils.js +2 -2
  31. package/dist/map-info-utils.js +2 -2
  32. package/dist/map-style-utils/mapbox-gl-style-editor.d.ts +2 -1
  33. package/dist/map-style-utils/mapbox-gl-style-editor.js +9 -3
  34. package/dist/map-style-utils/mapbox-utils.js +2 -2
  35. package/dist/map-utils.d.ts +8 -2
  36. package/dist/map-utils.js +24 -7
  37. package/dist/mapbox-utils.js +2 -2
  38. package/dist/noop.d.ts +1 -0
  39. package/dist/noop.js +29 -0
  40. package/dist/notifications-utils.d.ts +14 -26
  41. package/dist/notifications-utils.js +9 -11
  42. package/dist/observe-dimensions.js +10 -6
  43. package/dist/plot.d.ts +6 -0
  44. package/dist/plot.js +46 -0
  45. package/dist/projection-utils.d.ts +9 -0
  46. package/dist/projection-utils.js +36 -2
  47. package/dist/row-data-container.js +2 -2
  48. package/dist/searcher-utils.js +2 -2
  49. package/dist/split-map-utils.d.ts +4 -1
  50. package/dist/split-map-utils.js +10 -4
  51. package/dist/time.d.ts +16 -0
  52. package/dist/time.js +105 -0
  53. package/dist/utils.d.ts +36 -10
  54. package/dist/utils.js +38 -6
  55. package/package.json +11 -11
@@ -1,4 +1,4 @@
1
- // Copyright (c) 2022 Uber Technologies, Inc.
1
+ // Copyright (c) 2023 Uber Technologies, Inc.
2
2
  //
3
3
  // Permission is hereby granted, free of charge, to any person obtaining a copy
4
4
  // of this software and associated documentation files (the "Software"), to deal
@@ -28,9 +28,12 @@ Object.defineProperty(exports, "__esModule", {
28
28
  exports.findDefaultColorField = findDefaultColorField;
29
29
  exports.validateInputData = validateInputData;
30
30
  exports.getSampleForTypeAnalyze = getSampleForTypeAnalyze;
31
+ exports.isHexWkb = isHexWkb;
31
32
  exports.getFieldsFromData = getFieldsFromData;
32
33
  exports.renameDuplicateFields = renameDuplicateFields;
33
34
  exports.analyzerTypeToFieldType = analyzerTypeToFieldType;
35
+ exports.getFieldFormatLabels = getFieldFormatLabels;
36
+ exports.getFormatLabels = getFormatLabels;
34
37
  exports.ACCEPTED_ANALYZER_TYPES = exports.datasetColorMaker = void 0;
35
38
 
36
39
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
@@ -47,8 +50,12 @@ var _typeAnalyzer = require("type-analyzer");
47
50
 
48
51
  var _assert = _interopRequireDefault(require("assert"));
49
52
 
53
+ var _utils = require("./utils");
54
+
50
55
  var _dataUtils = require("./data-utils");
51
56
 
57
+ var _format = require("./format");
58
+
52
59
  var _d3Array = require("d3-array");
53
60
 
54
61
  var _colorUtils = require("./color-utils");
@@ -238,7 +245,7 @@ var IGNORE_DATA_TYPES = Object.keys(_typeAnalyzer.DATA_TYPES).filter(function (t
238
245
  */
239
246
 
240
247
  function validateInputData(data) {
241
- if (!(0, _dataUtils.isPlainObject)(data)) {
248
+ if (!(0, _utils.isPlainObject)(data)) {
242
249
  (0, _assert["default"])('addDataToMap Error: dataset.data cannot be null');
243
250
  return null;
244
251
  } else if (!Array.isArray(data.fields)) {
@@ -253,7 +260,7 @@ function validateInputData(data) {
253
260
  rows = data.rows; // check if all fields has name, format and type
254
261
 
255
262
  var allValid = fields.every(function (f, i) {
256
- if (!(0, _dataUtils.isPlainObject)(f)) {
263
+ if (!(0, _utils.isPlainObject)(f)) {
257
264
  (0, _assert["default"])("fields needs to be an array of object, but find ".concat((0, _typeof2["default"])(f)));
258
265
  fields[i] = {};
259
266
  }
@@ -379,6 +386,30 @@ function getSampleForTypeAnalyze(_ref2) {
379
386
  });
380
387
  return sample;
381
388
  }
389
+ /**
390
+ * Check if string is a valid Well-known binary (WKB) in HEX format
391
+ * https://en.wikipedia.org/wiki/Well-known_text_representation_of_geometry
392
+ *
393
+ * @param str input string
394
+ * @returns true if string is a valid WKB in HEX format
395
+ */
396
+
397
+
398
+ function isHexWkb(str) {
399
+ if (!str) return false; // check if the length of the string is even and is at least 10 characters long
400
+
401
+ if (str.length < 10 || str.length % 2 !== 0) {
402
+ return false;
403
+ } // check if first two characters are 00 or 01
404
+
405
+
406
+ if (!str.startsWith('00') && !str.startsWith('01')) {
407
+ return false;
408
+ } // check if the rest of the string is a valid hex
409
+
410
+
411
+ return /^[0-9a-fA-F]+$/.test(str.slice(2));
412
+ }
382
413
  /**
383
414
  * Analyze field types from data in `string` format, e.g. uploaded csv.
384
415
  * Assign `type`, `fieldIdx` and `format` (timestamp only) to each field
@@ -442,10 +473,14 @@ function getFieldsFromData(data, fieldOrder) {
442
473
  var fieldMeta = metadata.find(function (m) {
443
474
  return m.key === field;
444
475
  });
476
+ var type = fieldMeta.type;
477
+ var format = fieldMeta.format; // check if string is hex wkb
445
478
 
446
- var _ref3 = fieldMeta || {},
447
- type = _ref3.type,
448
- format = _ref3.format;
479
+ if (type === _typeAnalyzer.DATA_TYPES.STRING) {
480
+ type = data.some(function (d) {
481
+ return isHexWkb(d[name]);
482
+ }) ? _typeAnalyzer.DATA_TYPES.GEOMETRY : type;
483
+ }
449
484
 
450
485
  return {
451
486
  name: name,
@@ -543,10 +578,13 @@ function analyzerTypeToFieldType(aType) {
543
578
  case GEOMETRY:
544
579
  case GEOMETRY_FROM_STRING:
545
580
  case PAIR_GEOMETRY_FROM_STRING:
581
+ return _constants.ALL_FIELD_TYPES.geojson;
582
+
546
583
  case ARRAY:
584
+ return _constants.ALL_FIELD_TYPES.array;
585
+
547
586
  case OBJECT:
548
- // TODO: create a new data type for objects and arrays
549
- return _constants.ALL_FIELD_TYPES.geojson;
587
+ return _constants.ALL_FIELD_TYPES.object;
550
588
 
551
589
  case NUMBER:
552
590
  case STRING:
@@ -559,4 +597,31 @@ function analyzerTypeToFieldType(aType) {
559
597
  return _constants.ALL_FIELD_TYPES.string;
560
598
  }
561
599
  }
562
- //# 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","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","metadata","regex","dataType","ignoredDataTypes","renameDuplicateFields","fieldByIndex","result","fieldMeta","m","key","id","displayName","analyzerTypeToFieldType","valueAccessor","dc","valueAt","reduce","accu","allNames","fieldName","counter","aType","date","geojson","string","globalConsole","warn"],"mappings":"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","sourcesContent":["// Copyright (c) 2022 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport {console as globalConsole} from 'global/window';\nimport {ALL_FIELD_TYPES} from '@kepler.gl/constants';\nimport {Analyzer, DATA_TYPES as AnalyzerDATA_TYPES} from 'type-analyzer';\nimport assert from 'assert';\n\nimport {ProcessorResult, RGBColor, RowData, Field, FieldPair} from '@kepler.gl/types';\n\nimport {notNullorUndefined, isPlainObject} from './data-utils';\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: Record<string, unknown>): 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} = 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] = {};\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 (!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};\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 * 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    const {type, format} = fieldMeta || {};\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    case ARRAY:\n    case OBJECT:\n      // TODO: create a new data type for objects and arrays\n      return ALL_FIELD_TYPES.geojson;\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"]}
600
+
601
+ var TIME_DISPLAY = '2020-05-11 14:00';
602
+
603
+ var addTimeLabel = function addTimeLabel(formats) {
604
+ return formats.map(function (f) {
605
+ return _objectSpread(_objectSpread({}, f), {}, {
606
+ 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
607
+ });
608
+ });
609
+ };
610
+
611
+ function getFieldFormatLabels(fieldType) {
612
+ var tooltipTypes = fieldType && _constants.FIELD_OPTS[fieldType].format.tooltip || [];
613
+ var formatLabels = Object.values(_constants.TOOLTIP_FORMATS).filter(function (t) {
614
+ return tooltipTypes.includes(t.type);
615
+ });
616
+ return addTimeLabel(formatLabels);
617
+ }
618
+
619
+ function getFormatLabels(fields, fieldName) {
620
+ var _fields$find;
621
+
622
+ var fieldType = (_fields$find = fields.find(function (f) {
623
+ return f.name === fieldName;
624
+ })) === null || _fields$find === void 0 ? void 0 : _fields$find.type;
625
+ return getFieldFormatLabels(fieldType);
626
+ }
627
+ //# 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","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":["// Copyright (c) 2023 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport {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} 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: Record<string, unknown>): 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} = 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] = {};\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 (!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};\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    let type = fieldMeta.type;\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"]}
@@ -31,20 +31,20 @@ declare const domtoimage: {
31
31
  };
32
32
  };
33
33
  /**
34
- * @param {Node} node - The DOM Node object to render
35
- * @param {Object} options - Rendering options
36
- * @param {Function} [options.filter] - Should return true if passed node should be included in the output
37
- * (excluding node means excluding it's children as well). Not called on the root node.
38
- * @param {String} [options.bgcolor] - color for the background, any valid CSS color value.
39
- * @param {Number} [options.width] - width to be applied to node before rendering.
40
- * @param {Number} [options.height] - height to be applied to node before rendering.
41
- * @param {Object} [options.style] - an object whose properties to be copied to node's style before rendering.
42
- * @param {Number} [options.quality] - a Number between 0 and 1 indicating image quality (applicable to JPEG only),
43
- defaults to 1.0.
44
- * @param {String} [options.imagePlaceholder] - dataURL to use as a placeholder for failed images, default behaviour is to fail fast on images we can't fetch
45
- * @param {Boolean} [options.cacheBust] - set to true to cache bust by appending the time to the request url
46
- * @return {Promise} - A promise that is fulfilled with a SVG image data URL
47
- * */
34
+ * @param {Node} node - The DOM Node object to render
35
+ * @param {Object} options - Rendering options
36
+ * @param {Function} [options.filter] - Should return true if passed node should be included in the output
37
+ * (excluding node means excluding it's children as well). Not called on the root node.
38
+ * @param {String} [options.bgcolor] - color for the background, any valid CSS color value.
39
+ * @param {Number} [options.width] - width to be applied to node before rendering.
40
+ * @param {Number} [options.height] - height to be applied to node before rendering.
41
+ * @param {Object} [options.style] - an object whose properties to be copied to node's style before rendering.
42
+ * @param {Number} [options.quality] - a Number between 0 and 1 indicating image quality (applicable to JPEG only), defaults to 1.0.
43
+ * @param {boolean} [options.escapeXhtmlForWebpack] - whether to apply fix for uglify error in dom-to-image (should be true for webpack builds), defaults to true.
44
+ * @param {String} [options.imagePlaceholder] - dataURL to use as a placeholder for failed images, default behaviour is to fail fast on images we can't fetch
45
+ * @param {Boolean} [options.cacheBust] - set to true to cache bust by appending the time to the request url
46
+ * @return {Promise} - A promise that is fulfilled with a SVG image data URL
47
+ * */
48
48
  declare function toSvg(node: any, options: any): Promise<string>;
49
49
  /**
50
50
  * @param {Node} node - The DOM Node object to render