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

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.
@@ -4,9 +4,15 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
+ exports.addCategoricalValuesToColorMap = addCategoricalValuesToColorMap;
8
+ exports.colorBreaksToCategoricalColorMap = colorBreaksToCategoricalColorMap;
7
9
  exports.colorBreaksToColorMap = colorBreaksToColorMap;
10
+ exports.colorMapToCategoricalColorBreaks = colorMapToCategoricalColorBreaks;
8
11
  exports.colorMapToColorBreaks = colorMapToColorBreaks;
12
+ exports.getCategoricalColorMap = getCategoricalColorMap;
13
+ exports.getCategoricalColorScale = getCategoricalColorScale;
9
14
  exports.getDomainStepsbyZoom = getDomainStepsbyZoom;
15
+ exports.getHistogramDomain = getHistogramDomain;
10
16
  exports.getLayerColorScale = getLayerColorScale;
11
17
  exports.getLegendOfScale = getLegendOfScale;
12
18
  exports.getLinearDomain = getLinearDomain;
@@ -19,13 +25,19 @@ exports.getQuantileDomain = getQuantileDomain;
19
25
  exports.getScaleFunction = getScaleFunction;
20
26
  exports.getThresholdsFromQuantiles = getThresholdsFromQuantiles;
21
27
  exports.getVisualChannelScaleByZoom = getVisualChannelScaleByZoom;
28
+ exports.initCustomPaletteByCustomScale = initCustomPaletteByCustomScale;
22
29
  exports.initializeLayerColorMap = initializeLayerColorMap;
23
30
  exports.isDomainQuantile = isDomainQuantile;
24
31
  exports.isDomainStops = isDomainStops;
25
32
  exports.isNumericColorBreaks = isNumericColorBreaks;
33
+ exports.removeCategoricalValueFromColorMap = removeCategoricalValueFromColorMap;
34
+ exports.resetCategoricalColorMapByIndex = resetCategoricalColorMapByIndex;
35
+ exports.selectRestCategoricalColorMapByIndex = selectRestCategoricalColorMapByIndex;
36
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
26
37
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
27
38
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
28
39
  var _d3Array = require("d3-array");
40
+ var _lodash = _interopRequireDefault(require("lodash.uniq"));
29
41
  var _moment = _interopRequireDefault(require("moment"));
30
42
  var _commonUtils = require("@kepler.gl/common-utils");
31
43
  var _constants = require("@kepler.gl/constants");
@@ -36,7 +48,7 @@ var _utils = require("./utils");
36
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; }
37
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
38
50
  // Copyright contributors to the kepler.gl project
39
- // import {Layer, VisualChannel, VisualChannelDomain} from '@kepler.gl/layers';
51
+ // import {FilterProps, KeplerTable} from '@kepler.gl/layers';
40
52
  // TODO isolate types - depends on @kepler.gl/layers
41
53
 
42
54
  /**
@@ -172,9 +184,10 @@ function getQuantLegends(scale, labelFormat) {
172
184
  if (typeof scale.invertExtent !== 'function') {
173
185
  return [];
174
186
  }
175
- var labels = scale.scaleType === 'threshold' || scale.scaleType === 'custom' ? getThresholdLabels(scale, scale.scaleType === 'custom' ? customScaleLabelFormat : function (n) {
176
- return n ? (0, _dataUtils.formatNumber)(n) : 'no value';
177
- }) : getScaleLabels(scale, labelFormat);
187
+ var thresholdLabelFormat = function thresholdLabelFormat(n, type) {
188
+ return n && labelFormat ? labelFormat(n) : n ? (0, _dataUtils.formatNumber)(n, type) : 'no value';
189
+ };
190
+ var labels = scale.scaleType === 'threshold' ? getThresholdLabels(scale, thresholdLabelFormat) : scale.scaleType === 'custom' ? getThresholdLabels(scale, customScaleLabelFormat) : getScaleLabels(scale, labelFormat);
178
191
  var data = scale.range();
179
192
  return labels.map(function (label, index) {
180
193
  return _objectSpread({
@@ -224,7 +237,7 @@ function getLegendOfScale(_ref) {
224
237
  if (!scale || scale.byZoom) {
225
238
  return [];
226
239
  }
227
- if (scaleType === _constants.SCALE_TYPES.ordinal) {
240
+ if (scaleType === _constants.SCALE_TYPES.ordinal || scaleType === _constants.SCALE_TYPES.customOrdinal || fieldType === _constants.ALL_FIELD_TYPES.string) {
228
241
  return getOrdinalLegends(scale);
229
242
  }
230
243
  var formatLabel = labelFormat || getQuantLabelFormat(scale.domain(), fieldType);
@@ -283,6 +296,64 @@ function getVisualChannelScaleByZoom(_ref3) {
283
296
  return scale;
284
297
  }
285
298
 
299
+ /**
300
+ * Get categorical colorMap from colors and domain (unique values)
301
+ */
302
+ function getCategoricalColorMap(colors, domain) {
303
+ // colorMap: [string | string[], hexstring]
304
+ var colorToUniqueValues = {};
305
+ var uniqueValues = (0, _dataUtils.unique)(domain).filter(_commonUtils.notNullorUndefined).sort();
306
+ // each unique value assign to a color, the rest unique values assign to last color
307
+ var lastColor = colors[colors.length - 1];
308
+ for (var i = 0; i < uniqueValues.length; ++i) {
309
+ if (i < colors.length) {
310
+ colorToUniqueValues[colors[i]] = uniqueValues[i];
311
+ } else {
312
+ colorToUniqueValues[lastColor] = [].concat((0, _toConsumableArray2["default"])(Array.isArray(colorToUniqueValues[lastColor]) ? colorToUniqueValues[lastColor] : [colorToUniqueValues[lastColor]]), [uniqueValues[i]]);
313
+ }
314
+ }
315
+ var colorMap = colors.map(function (color) {
316
+ if (color in colorToUniqueValues) {
317
+ return [colorToUniqueValues[color], color];
318
+ }
319
+ return [null, color];
320
+ });
321
+ return colorMap;
322
+ }
323
+
324
+ /**
325
+ * Get categorical colorBreaks from colorMap
326
+ */
327
+ function colorMapToCategoricalColorBreaks(colorMap) {
328
+ if (!colorMap) {
329
+ return null;
330
+ }
331
+ var colorBreaks = colorMap.map(function (_ref4, i) {
332
+ var _ref5 = (0, _slicedToArray2["default"])(_ref4, 2),
333
+ value = _ref5[0],
334
+ color = _ref5[1];
335
+ return {
336
+ data: color,
337
+ label: value
338
+ };
339
+ });
340
+ return colorBreaks;
341
+ }
342
+
343
+ /**
344
+ * create categorical colorMap from colorBreaks
345
+ */
346
+ function colorBreaksToCategoricalColorMap(colorBreaks) {
347
+ // colorMap: [string | string[], hexstring]
348
+ var colors = (0, _lodash["default"])(colorBreaks.map(function (cb) {
349
+ return cb.data;
350
+ }));
351
+ var values = (0, _lodash["default"])(colorBreaks.map(function (cb) {
352
+ return cb.label;
353
+ }));
354
+ return getCategoricalColorMap(colors, values);
355
+ }
356
+
286
357
  /**
287
358
  * Convert color breaks UI input into colorRange.colorMap
288
359
  */
@@ -304,10 +375,10 @@ function colorMapToColorBreaks(colorMap) {
304
375
  if (!colorMap) {
305
376
  return null;
306
377
  }
307
- var colorBreaks = colorMap.map(function (_ref4, i) {
308
- var _ref5 = (0, _slicedToArray2["default"])(_ref4, 2),
309
- value = _ref5[0],
310
- color = _ref5[1];
378
+ var colorBreaks = colorMap.map(function (_ref6, i) {
379
+ var _ref7 = (0, _slicedToArray2["default"])(_ref6, 2),
380
+ value = _ref7[0],
381
+ color = _ref7[1];
311
382
  var range = i === 0 ?
312
383
  // first
313
384
  [-Infinity, value] :
@@ -335,6 +406,196 @@ function colorMapToColorBreaks(colorMap) {
335
406
  * Whether color breaks is for numeric field
336
407
  */
337
408
  function isNumericColorBreaks(colorBreaks) {
338
- return Array.isArray(colorBreaks) && colorBreaks.length && colorBreaks[0].inputs;
409
+ return Boolean(Array.isArray(colorBreaks) && colorBreaks.length && colorBreaks[0].inputs);
410
+ }
411
+
412
+ // return domainMin, domainMax, histogramMean
413
+ function getHistogramDomain(_ref8) {
414
+ var aggregatedBins = _ref8.aggregatedBins,
415
+ columnStats = _ref8.columnStats,
416
+ dataset = _ref8.dataset,
417
+ fieldValueAccessor = _ref8.fieldValueAccessor;
418
+ var domainMin = Number.POSITIVE_INFINITY;
419
+ var domainMax = Number.NEGATIVE_INFINITY;
420
+ var nValid = 0;
421
+ var domainSum = 0;
422
+ if (aggregatedBins) {
423
+ Object.values(aggregatedBins).forEach(function (bin) {
424
+ var val = bin.value;
425
+ if ((0, _dataUtils.isNumber)(val)) {
426
+ if (val < domainMin) domainMin = val;
427
+ if (val > domainMax) domainMax = val;
428
+ domainSum += val;
429
+ nValid += 1;
430
+ }
431
+ });
432
+ } else {
433
+ if (columnStats && columnStats.quantiles && columnStats.mean) {
434
+ // no need to recalcuate min/max/mean if its already in columnStats
435
+ return [columnStats.quantiles[0].value, columnStats.quantiles[columnStats.quantiles.length - 1].value, columnStats.mean];
436
+ }
437
+ if (dataset && fieldValueAccessor) {
438
+ dataset.allIndexes.forEach(function (x, i) {
439
+ var val = fieldValueAccessor(x);
440
+ if ((0, _dataUtils.isNumber)(val)) {
441
+ if (val < domainMin) domainMin = val;
442
+ if (val > domainMax) domainMax = val;
443
+ domainSum += val;
444
+ nValid += 1;
445
+ }
446
+ });
447
+ }
448
+ }
449
+ var histogramMean = nValid > 0 ? domainSum / nValid : 0;
450
+ return [nValid > 0 ? domainMin : 0, nValid > 0 ? domainMax : 0, histogramMean];
451
+ }
452
+ function resetCategoricalColorMapByIndex(colorMap, index) {
453
+ if (!colorMap) {
454
+ return colorMap;
455
+ }
456
+ var newColorMap = colorMap.map(function (cm, i) {
457
+ if (i === index) {
458
+ return [null, cm[1]];
459
+ }
460
+ return cm;
461
+ });
462
+ return newColorMap;
463
+ }
464
+
465
+ /**
466
+ * select rest categorical values for a colorMap by its index
467
+ */
468
+ function selectRestCategoricalColorMapByIndex(colorMap, index, uniqueValues) {
469
+ if (!colorMap || !uniqueValues) {
470
+ return colorMap;
471
+ }
472
+
473
+ // find unique values that has not been used in current colorMap
474
+ var uniqValueDict = Object.fromEntries(uniqueValues.map(function (val) {
475
+ return [val, false];
476
+ }));
477
+ colorMap.forEach(function (cm) {
478
+ (0, _commonUtils.toArray)(cm[0]).forEach(function (v) {
479
+ if (v) uniqValueDict[v] = true;
480
+ });
481
+ });
482
+ var rest = Object.keys(uniqValueDict).filter(function (v) {
483
+ return !uniqValueDict[v];
484
+ });
485
+
486
+ // use the not used unique values in the selected color map
487
+ var newColorMap = colorMap.map(function (cm, i) {
488
+ if (i === index) {
489
+ return [[].concat((0, _toConsumableArray2["default"])(rest), (0, _toConsumableArray2["default"])((0, _commonUtils.toArray)(cm[0]))), cm[1]];
490
+ }
491
+ return cm;
492
+ });
493
+ return newColorMap;
494
+ }
495
+
496
+ /**
497
+ * remove a categorical value from a colorMap by its index
498
+ */
499
+ function removeCategoricalValueFromColorMap(colorMap, item, index) {
500
+ if (!colorMap) {
501
+ return colorMap;
502
+ }
503
+ var newColorMap = colorMap.map(function (cm, i) {
504
+ if (i === index) {
505
+ if (!cm[0]) {
506
+ return [null, cm[1]];
507
+ }
508
+ var currentUniqueValues = (0, _commonUtils.toArray)(cm[0]);
509
+ var updatedUniqueValues = currentUniqueValues.filter(function (v) {
510
+ return v !== item;
511
+ });
512
+ return [updatedUniqueValues, cm[1]];
513
+ }
514
+ return cm;
515
+ });
516
+ return newColorMap;
517
+ }
518
+
519
+ /**
520
+ * add categorical values (from multisel dropdown) to a colorMap by its index
521
+ */
522
+ function addCategoricalValuesToColorMap(colorMap, items, index) {
523
+ if (!colorMap) {
524
+ return colorMap;
525
+ }
526
+ var newColorMap = colorMap.map(function (cm, i) {
527
+ if (i === index) {
528
+ if (!cm[0]) {
529
+ return [items, cm[1]];
530
+ }
531
+ var _currentUniqueValues = (0, _commonUtils.toArray)(cm[0]);
532
+ var updatedUniqueValues = (0, _lodash["default"])(_currentUniqueValues.concat(items));
533
+ return [updatedUniqueValues, cm[1]];
534
+ }
535
+ // remove value from other colorMap
536
+ var currentUniqueValues = cm[0];
537
+ if (Array.isArray(currentUniqueValues)) {
538
+ var _updatedUniqueValues = currentUniqueValues.filter(function (v) {
539
+ return !items.includes(v);
540
+ });
541
+ return [_updatedUniqueValues, cm[1]];
542
+ } else if (currentUniqueValues && items.includes(currentUniqueValues)) {
543
+ return [null, cm[1]];
544
+ }
545
+ return cm;
546
+ });
547
+ return newColorMap;
548
+ }
549
+
550
+ /**
551
+ * get a color scale func for categorical (custom ordinal) scale
552
+ */
553
+ function getCategoricalColorScale(colorDomain, colorRange) {
554
+ var useRgb = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
555
+ var cMap = colorRange.colorMap ? colorRange.colorMap : getCategoricalColorMap(colorRange.colors, colorDomain);
556
+ var range = [];
557
+ var domain = [];
558
+ cMap.forEach(function (cm) {
559
+ if (Array.isArray(cm[0])) {
560
+ cm[0].forEach(function (val) {
561
+ domain.push(val);
562
+ range.push(useRgb ? (0, _colorUtils.hexToRgb)(cm[1]) : cm[1]);
563
+ });
564
+ } else {
565
+ domain.push(cm[0]);
566
+ range.push(useRgb ? (0, _colorUtils.hexToRgb)(cm[1]) : cm[1]);
567
+ }
568
+ });
569
+ var scale = getScaleFunction(_constants.SCALE_TYPES.customOrdinal, range, domain, false);
570
+ scale.unknown(_constants.NO_VALUE_COLOR);
571
+ return scale;
572
+ }
573
+
574
+ /**
575
+ * initialize customPalette by custom scale or customOrdinal scale
576
+ */
577
+ function initCustomPaletteByCustomScale(_ref9) {
578
+ var scale = _ref9.scale,
579
+ field = _ref9.field,
580
+ ordinalDomain = _ref9.ordinalDomain,
581
+ range = _ref9.range,
582
+ colorBreaks = _ref9.colorBreaks;
583
+ var customPaletteName = "color.customPalette.".concat(scale, ".").concat(field.name);
584
+ // reuse range.colorMap if the field and scale not changed
585
+ var reuseColorMap = range.colorMap && range.name === customPaletteName && range.type === scale;
586
+ var colorMap = reuseColorMap ? range.colorMap : scale === _constants.SCALE_TYPES.customOrdinal && ordinalDomain ? getCategoricalColorMap(range.colors, ordinalDomain) : colorBreaks && isNumericColorBreaks(colorBreaks) ? colorBreaksToColorMap(colorBreaks) : null;
587
+ var colors = reuseColorMap ? range.colors : colorMap ? colorMap.map(function (cm) {
588
+ return cm[1];
589
+ }) : range.colors;
590
+
591
+ // update custom breaks
592
+ var customPalette = {
593
+ category: 'Custom',
594
+ name: customPaletteName,
595
+ type: scale,
596
+ colorMap: colorMap,
597
+ colors: colors || []
598
+ };
599
+ return customPalette;
339
600
  }
340
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_d3Array","require","_moment","_interopRequireDefault","_commonUtils","_constants","_colorUtils","_dataUtils","_filterUtils","_utils","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","getQuantileDomain","data","valueAccessor","sortFunc","values","map","notNullorUndefined","sort","getOrdinalDomain","dataContainer","mapIndex","unique","getLinearDomain","range","extent","d","i","undefined","getLogDomain","_getLinearDomain","_getLinearDomain2","_slicedToArray2","d0","d1","isDomainStops","domain","isPlainObject","Array","isArray","stops","z","isDomainQuantile","quantiles","getThresholdsFromQuantiles","buckets","thresholds","Number","isFinite","position","d3Quantile","getDomainStepsbyZoom","steps","bisectLeft","Math","max","getScaleFunction","scale","fixed","scaleFunction","SCALE_FUNC","scaleType","getThresholdLabels","labelFormat","genLength","invert","invertExtent","inputs","reverseFormatNumber","label","concat","getScaleLabels","customScaleLabelFormat","n","formatNumber","getQuantLegends","labels","index","rgbToHex","getOrdinalLegends","datum","isRgbColor","defaultFormat","getTimeLabelFormat","formatter","getTimeWidgetHintFormatter","val","moment","utc","format","getQuantLabelFormat","fieldType","ALL_FIELD_TYPES","timestamp","isNumber","getLegendOfScale","_ref","byZoom","SCALE_TYPES","ordinal","formatLabel","getLayerColorScale","_ref2","layer","getColorScale","initializeLayerColorMap","visualChannel","config","visConfig","field","colorBreaks","type","colorBreaksToColorMap","getVisualChannelScaleByZoom","_ref3","_scale","mapState","_layer$meta","meta","getZoom","zoom","colorMap","colorBreak","colorMapToColorBreaks","_ref4","_ref5","value","color","Infinity","isNumericColorBreaks"],"sources":["../src/data-scale-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {bisectLeft, quantileSorted as d3Quantile, extent} from 'd3-array';\nimport moment from 'moment';\n\nimport {notNullorUndefined} from '@kepler.gl/common-utils';\nimport {ALL_FIELD_TYPES, SCALE_FUNC, SCALE_TYPES} from '@kepler.gl/constants';\n// import {Layer, VisualChannel, VisualChannelDomain} from '@kepler.gl/layers';\nimport {ColorMap, ColorRange, HexColor, MapState} from '@kepler.gl/types';\n\nimport {isRgbColor, rgbToHex} from './color-utils';\nimport {DataContainerInterface} from './data-container-interface';\nimport {formatNumber, isNumber, reverseFormatNumber, unique} from './data-utils';\nimport {getTimeWidgetHintFormatter} from './filter-utils';\nimport {isPlainObject} from './utils';\n\nexport type ColorBreak = {\n  data: HexColor;\n  label: string;\n  range: number[];\n  inputs: number[];\n};\nexport type ColorBreakOrdinal = {\n  data: HexColor;\n  label: string;\n};\n\nexport type D3ScaleFunction = Record<string, any> & ((x: any) => any);\n\n// TODO isolate types - depends on @kepler.gl/layers\ntype Layer = any;\ntype VisualChannel = any;\ntype VisualChannelDomain = any;\n\nexport type LabelFormat = (n: number) => string;\ntype dataValueAccessor = <T>(param: T) => T;\ntype dataContainerValueAccessor = (d: {index: number}, dc: DataContainerInterface) => any;\ntype sort = (a: any, b: any) => any;\n/**\n * return quantile domain for an array of data\n */\nexport function getQuantileDomain(\n  data: any[],\n  valueAccessor?: dataValueAccessor,\n  sortFunc?: sort\n): number[] {\n  const values = typeof valueAccessor === 'function' ? data.map(valueAccessor) : data;\n\n  return values.filter(notNullorUndefined).sort(sortFunc);\n}\n\n/**\n * return ordinal domain for a data container\n */\nexport function getOrdinalDomain(\n  dataContainer: DataContainerInterface,\n  valueAccessor: dataContainerValueAccessor\n): string[] {\n  const values = dataContainer.mapIndex(valueAccessor);\n\n  return unique(values).filter(notNullorUndefined).sort();\n}\n\n/**\n * return linear domain for an array of data\n */\nexport function getLinearDomain(\n  data: number[],\n  valueAccessor?: dataValueAccessor\n): [number, number] {\n  const range = typeof valueAccessor === 'function' ? extent(data, valueAccessor) : extent(data);\n  return range.map((d: undefined | number, i: number) => (d === undefined ? i : d)) as [\n    number,\n    number\n  ];\n}\n\n/**\n * return linear domain for an array of data. A log scale domain cannot contain 0\n */\nexport function getLogDomain(data: any[], valueAccessor: dataValueAccessor): [number, number] {\n  const [d0, d1] = getLinearDomain(data, valueAccessor);\n  return [d0 === 0 ? 1e-5 : d0, d1];\n}\n\nexport type DomainStops = {\n  stops: number[];\n  z: number[];\n};\n\n/**\n * whether field domain is stops\n */\nexport function isDomainStops(domain: unknown): domain is DomainStops {\n  return isPlainObject(domain) && Array.isArray(domain.stops) && Array.isArray(domain.z);\n}\n\nexport type DomainQuantiles = {\n  quantiles: number[];\n  z: number[];\n};\n\n/**\n * whether field domain is quantiles\n */\nexport function isDomainQuantile(domain: any): domain is DomainQuantiles {\n  return isPlainObject(domain) && Array.isArray(domain.quantiles) && Array.isArray(domain.z);\n}\n\n/**\n * get the domain at zoom\n */\nexport function getThresholdsFromQuantiles(\n  quantiles: number[],\n  buckets: number\n): (number | undefined)[] {\n  const thresholds = [];\n  if (!Number.isFinite(buckets) || buckets < 1) {\n    return [quantiles[0], quantiles[quantiles.length - 1]];\n  }\n  for (let i = 1; i < buckets; i++) {\n    // position in sorted array\n    const position = i / buckets;\n    // @ts-ignore\n    thresholds.push(d3Quantile(quantiles, position));\n  }\n\n  return thresholds;\n}\n\n/**\n * get the domain at zoom\n */\nexport function getDomainStepsbyZoom(domain: any[], steps: number[], z: number): any {\n  const i = bisectLeft(steps, z);\n\n  if (steps[i] === z) {\n    // If z is an integer value exactly matching a step, return the corresponding domain\n    return domain[i];\n  }\n  // Otherwise, return the next coarsest domain\n  return domain[Math.max(i - 1, 0)];\n}\n\n/**\n * Get d3 scale function\n */\nexport function getScaleFunction(\n  scale: string,\n  range: any[] | IterableIterator<any>,\n  domain: (number | undefined)[] | string[] | IterableIterator<any>,\n  fixed?: boolean\n): D3ScaleFunction {\n  const scaleFunction = SCALE_FUNC[fixed ? 'linear' : scale]()\n    .domain(domain)\n    .range(fixed ? domain : range);\n  scaleFunction.scaleType = fixed ? 'linear' : scale;\n  return scaleFunction;\n}\n\n/**\n * Get threshold scale color labels\n */\nfunction getThresholdLabels(\n  scale: D3ScaleFunction,\n  labelFormat: LabelFormat\n): Omit<ColorBreak, 'data'>[] {\n  const genLength = scale.range().length;\n  return scale.range().map((d, i) => {\n    const invert = scale.invertExtent(d);\n    const inputs = [\n      i === 0 ? null : reverseFormatNumber(labelFormat(invert[0])),\n      i === genLength - 1 ? null : reverseFormatNumber(labelFormat(invert[1]))\n    ];\n    return {\n      // raw value\n      range: invert,\n      // formatted value\n      inputs,\n      label:\n        i === 0\n          ? `Less than ${labelFormat(invert[1])}`\n          : i === genLength - 1\n          ? `${labelFormat(invert[0])} or more`\n          : `${labelFormat(invert[0])} to ${labelFormat(invert[1])}`\n    };\n  });\n}\n\n/**\n * Get linear / quant scale color labels\n */\nfunction getScaleLabels(\n  scale: D3ScaleFunction,\n  labelFormat: LabelFormat\n): Omit<ColorBreak, 'data'>[] {\n  return scale.range().map((d, i) => {\n    // @ts-ignore\n    const invert = scale.invertExtent(d);\n    const inputs = [\n      reverseFormatNumber(labelFormat(invert[0])),\n      reverseFormatNumber(labelFormat(invert[1]))\n    ];\n\n    return {\n      label: `${labelFormat(invert[0])} to ${labelFormat(invert[1])}`,\n      // raw value\n      range: invert,\n      // formatted value\n      inputs\n    };\n  });\n}\n\nconst customScaleLabelFormat = n => (n ? formatNumber(n, 'real') : 'no value');\n/**\n * Get linear / quant scale color breaks\n */\nexport function getQuantLegends(scale: D3ScaleFunction, labelFormat: LabelFormat): ColorBreak[] {\n  if (typeof scale.invertExtent !== 'function') {\n    return [];\n  }\n  const labels =\n    scale.scaleType === 'threshold' || scale.scaleType === 'custom'\n      ? getThresholdLabels(\n          scale,\n          scale.scaleType === 'custom'\n            ? customScaleLabelFormat\n            : n => (n ? formatNumber(n) : 'no value')\n        )\n      : getScaleLabels(scale, labelFormat);\n\n  const data = scale.range();\n\n  return labels.map((label, index) => ({\n    data: Array.isArray(data[index]) ? rgbToHex(data[index]) : data[index],\n    ...label\n  }));\n}\n\n/**\n * Get ordinal color scale legends\n */\nexport function getOrdinalLegends(scale: D3ScaleFunction): ColorBreakOrdinal[] {\n  const domain = scale.domain();\n  const labels = scale.domain();\n  const data = domain.map(scale);\n\n  return data.map((datum, index) => ({\n    data: isRgbColor(datum) ? rgbToHex(datum) : datum,\n    label: labels[index]\n  }));\n}\n\nconst defaultFormat = d => d;\n\nconst getTimeLabelFormat = domain => {\n  const formatter = getTimeWidgetHintFormatter(domain);\n  return val => moment.utc(val).format(formatter);\n};\n\nexport function getQuantLabelFormat(domain, fieldType) {\n  // quant scale can only be assigned to linear Fields: real, timestamp, integer\n  return fieldType === ALL_FIELD_TYPES.timestamp\n    ? getTimeLabelFormat(domain)\n    : !fieldType\n    ? defaultFormat\n    : n => (isNumber(n) ? formatNumber(n, fieldType) : 'no value');\n}\n\n/**\n * Get legends for scale\n */\nexport function getLegendOfScale({\n  scale,\n  scaleType,\n  labelFormat,\n  fieldType\n}: {\n  scale?: D3ScaleFunction | null;\n  scaleType: string;\n  labelFormat?: LabelFormat;\n  fieldType: string | null | undefined;\n}): ColorBreak[] | ColorBreakOrdinal[] {\n  if (!scale || scale.byZoom) {\n    return [];\n  }\n  if (scaleType === SCALE_TYPES.ordinal) {\n    return getOrdinalLegends(scale);\n  }\n\n  const formatLabel = labelFormat || getQuantLabelFormat(scale.domain(), fieldType);\n\n  return getQuantLegends(scale, formatLabel);\n}\n\n/**\n * Get color scale function\n */\nexport function getLayerColorScale({\n  range,\n  domain,\n  scaleType,\n  layer\n}: {\n  range: ColorRange | null | undefined;\n  domain: VisualChannelDomain;\n  scaleType: string;\n  layer: Layer;\n  isFixed?: boolean;\n}): D3ScaleFunction | null {\n  if (range && domain && scaleType) {\n    return layer.getColorScale(scaleType, domain, range);\n  }\n  return null;\n}\n\n/**\n * Convert colorRange.colorMap into color breaks UI input\n */\nexport function initializeLayerColorMap(layer: Layer, visualChannel: VisualChannel): ColorMap {\n  const domain = layer.config[visualChannel.domain];\n  const range = layer.config.visConfig[visualChannel.range];\n  const scaleType = layer.config[visualChannel.scale];\n  const field = layer.config[visualChannel.field];\n\n  const scale = getLayerColorScale({\n    range,\n    domain,\n    scaleType,\n    layer\n  });\n\n  const colorBreaks = getLegendOfScale({\n    scale: scale?.byZoom ? scale(0) : scale,\n    scaleType,\n    fieldType: field.type\n  });\n  return colorBreaksToColorMap(colorBreaks);\n}\n\n/**\n * Get visual chanel scale function if it's based on zoom\n */\nexport function getVisualChannelScaleByZoom({\n  scale,\n  layer,\n  mapState\n}: {\n  scale: D3ScaleFunction | null;\n  layer: Layer;\n  mapState?: MapState;\n}): D3ScaleFunction | null {\n  if (scale?.byZoom) {\n    const z = layer.meta?.getZoom ? layer.meta.getZoom(mapState) : mapState?.zoom;\n    scale = Number.isFinite(z) ? scale(z) : null;\n  }\n  return scale;\n}\n\n/**\n * Convert color breaks UI input into colorRange.colorMap\n */\nexport function colorBreaksToColorMap(colorBreaks: ColorBreak[] | ColorBreakOrdinal[]): ColorMap {\n  const colorMap = colorBreaks.map((colorBreak, i) => {\n    // [value, hex]\n    return [\n      colorBreak.inputs\n        ? i === colorBreaks.length - 1\n          ? null // last\n          : colorBreak.inputs[1]\n        : colorBreak.label,\n      colorBreak.data\n    ];\n  });\n\n  // @ts-ignore tuple\n  return colorMap;\n}\n\n/**\n * Convert colorRange.colorMap into color breaks UI input\n */\nexport function colorMapToColorBreaks(colorMap?: ColorMap): ColorBreak[] | null {\n  if (!colorMap) {\n    return null;\n  }\n  const colorBreaks = colorMap.map(([value, color], i) => {\n    const range =\n      i === 0\n        ? // first\n          [-Infinity, value]\n        : // last\n        i === colorMap.length - 1\n        ? [colorMap[i - 1][0], Infinity]\n        : // else\n          [colorMap[i - 1][0], value];\n    return {\n      data: color,\n      range,\n      inputs: range,\n      label:\n        // first\n        i === 0\n          ? `Less than ${value}`\n          : // last\n          i === colorMap.length - 1\n          ? `${colorMap[i - 1][0]} or more`\n          : `${colorMap[i - 1][0]} to ${value}`\n    };\n  });\n\n  // @ts-ignore implement conversion for ordinal\n  return colorBreaks;\n}\n\n/**\n * Whether color breaks is for numeric field\n */\nexport function isNumericColorBreaks(colorBreaks: unknown): colorBreaks is ColorBreak[] {\n  return Array.isArray(colorBreaks) && colorBreaks.length && colorBreaks[0].inputs;\n}\n"],"mappings":"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","ignoreList":[]}
601
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_d3Array","require","_lodash","_interopRequireDefault","_moment","_commonUtils","_constants","_colorUtils","_dataUtils","_filterUtils","_utils","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","getQuantileDomain","data","valueAccessor","sortFunc","values","map","notNullorUndefined","sort","getOrdinalDomain","dataContainer","mapIndex","unique","getLinearDomain","range","extent","d","i","undefined","getLogDomain","_getLinearDomain","_getLinearDomain2","_slicedToArray2","d0","d1","isDomainStops","domain","isPlainObject","Array","isArray","stops","z","isDomainQuantile","quantiles","getThresholdsFromQuantiles","buckets","thresholds","Number","isFinite","position","d3Quantile","getDomainStepsbyZoom","steps","bisectLeft","Math","max","getScaleFunction","scale","fixed","scaleFunction","SCALE_FUNC","scaleType","getThresholdLabels","labelFormat","genLength","invert","invertExtent","inputs","reverseFormatNumber","label","concat","getScaleLabels","customScaleLabelFormat","n","formatNumber","getQuantLegends","thresholdLabelFormat","type","labels","index","rgbToHex","getOrdinalLegends","datum","isRgbColor","defaultFormat","getTimeLabelFormat","formatter","getTimeWidgetHintFormatter","val","moment","utc","format","getQuantLabelFormat","fieldType","ALL_FIELD_TYPES","timestamp","isNumber","getLegendOfScale","_ref","byZoom","SCALE_TYPES","ordinal","customOrdinal","string","formatLabel","getLayerColorScale","_ref2","layer","getColorScale","initializeLayerColorMap","visualChannel","config","visConfig","field","colorBreaks","colorBreaksToColorMap","getVisualChannelScaleByZoom","_ref3","_scale","mapState","_layer$meta","meta","getZoom","zoom","getCategoricalColorMap","colors","colorToUniqueValues","uniqueValues","lastColor","_toConsumableArray2","colorMap","color","colorMapToCategoricalColorBreaks","_ref4","_ref5","value","colorBreaksToCategoricalColorMap","uniq","cb","colorBreak","colorMapToColorBreaks","_ref6","_ref7","Infinity","isNumericColorBreaks","Boolean","getHistogramDomain","_ref8","aggregatedBins","columnStats","dataset","fieldValueAccessor","domainMin","POSITIVE_INFINITY","domainMax","NEGATIVE_INFINITY","nValid","domainSum","bin","mean","allIndexes","x","histogramMean","resetCategoricalColorMapByIndex","newColorMap","cm","selectRestCategoricalColorMapByIndex","uniqValueDict","fromEntries","toArray","v","rest","removeCategoricalValueFromColorMap","item","currentUniqueValues","updatedUniqueValues","addCategoricalValuesToColorMap","items","includes","getCategoricalColorScale","colorDomain","colorRange","useRgb","cMap","hexToRgb","unknown","NO_VALUE_COLOR","initCustomPaletteByCustomScale","_ref9","ordinalDomain","customPaletteName","name","reuseColorMap","customPalette","category"],"sources":["../src/data-scale-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {bisectLeft, quantileSorted as d3Quantile, extent} from 'd3-array';\nimport uniq from 'lodash.uniq';\nimport moment from 'moment';\n\nimport {notNullorUndefined, toArray} from '@kepler.gl/common-utils';\nimport {ALL_FIELD_TYPES, SCALE_FUNC, SCALE_TYPES, NO_VALUE_COLOR} from '@kepler.gl/constants';\n// import {FilterProps, KeplerTable} from '@kepler.gl/layers';\nimport {\n  AggregatedBin,\n  ColorMap,\n  ColorRange,\n  HexColor,\n  KeplerLayer as Layer,\n  MapState,\n  VisualChannel,\n  VisualChannelDomain,\n  RGBColor,\n  RGBAColor,\n  ColorUI,\n  Field\n} from '@kepler.gl/types';\n\nimport {isRgbColor, rgbToHex, hexToRgb} from './color-utils';\nimport {DataContainerInterface} from './data-container-interface';\nimport {formatNumber, isNumber, reverseFormatNumber, unique} from './data-utils';\nimport {getTimeWidgetHintFormatter} from './filter-utils';\nimport {isPlainObject} from './utils';\n\nexport type ColorBreak = {\n  data: HexColor;\n  label: string;\n  range: number[];\n  inputs: number[];\n};\nexport type ColorBreakOrdinal = {\n  data: HexColor;\n  label: string | number | string[] | number[] | null;\n};\n\nexport type D3ScaleFunction = Record<string, any> & ((x: any) => any);\n\n// TODO isolate types - depends on @kepler.gl/layers\ntype FilterProps = any;\ntype KeplerTable = any;\n\nexport type LabelFormat = (n: number, type?: string) => string;\ntype dataValueAccessor = <T>(param: T) => T;\ntype dataContainerValueAccessor = (d: {index: number}, dc: DataContainerInterface) => any;\ntype sort = (a: any, b: any) => any;\n/**\n * return quantile domain for an array of data\n */\nexport function getQuantileDomain(\n  data: any[],\n  valueAccessor?: dataValueAccessor,\n  sortFunc?: sort\n): number[] {\n  const values = typeof valueAccessor === 'function' ? data.map(valueAccessor) : data;\n\n  return values.filter(notNullorUndefined).sort(sortFunc);\n}\n\n/**\n * return ordinal domain for a data container\n */\nexport function getOrdinalDomain(\n  dataContainer: DataContainerInterface,\n  valueAccessor: dataContainerValueAccessor\n): string[] {\n  const values = dataContainer.mapIndex(valueAccessor);\n\n  return unique(values).filter(notNullorUndefined).sort();\n}\n\n/**\n * return linear domain for an array of data\n */\nexport function getLinearDomain(\n  data: number[],\n  valueAccessor?: dataValueAccessor\n): [number, number] {\n  const range = typeof valueAccessor === 'function' ? extent(data, valueAccessor) : extent(data);\n  return range.map((d: undefined | number, i: number) => (d === undefined ? i : d)) as [\n    number,\n    number\n  ];\n}\n\n/**\n * return linear domain for an array of data. A log scale domain cannot contain 0\n */\nexport function getLogDomain(data: any[], valueAccessor: dataValueAccessor): [number, number] {\n  const [d0, d1] = getLinearDomain(data, valueAccessor);\n  return [d0 === 0 ? 1e-5 : d0, d1];\n}\n\nexport type DomainStops = {\n  stops: number[];\n  z: number[];\n};\n\n/**\n * whether field domain is stops\n */\nexport function isDomainStops(domain: unknown): domain is DomainStops {\n  return isPlainObject(domain) && Array.isArray(domain.stops) && Array.isArray(domain.z);\n}\n\nexport type DomainQuantiles = {\n  quantiles: number[];\n  z: number[];\n};\n\n/**\n * whether field domain is quantiles\n */\nexport function isDomainQuantile(domain: any): domain is DomainQuantiles {\n  return isPlainObject(domain) && Array.isArray(domain.quantiles) && Array.isArray(domain.z);\n}\n\n/**\n * get the domain at zoom\n */\nexport function getThresholdsFromQuantiles(\n  quantiles: number[],\n  buckets: number\n): (number | undefined)[] {\n  const thresholds = [];\n  if (!Number.isFinite(buckets) || buckets < 1) {\n    return [quantiles[0], quantiles[quantiles.length - 1]];\n  }\n  for (let i = 1; i < buckets; i++) {\n    // position in sorted array\n    const position = i / buckets;\n    // @ts-ignore\n    thresholds.push(d3Quantile(quantiles, position));\n  }\n\n  return thresholds;\n}\n\n/**\n * get the domain at zoom\n */\nexport function getDomainStepsbyZoom(domain: any[], steps: number[], z: number): any {\n  const i = bisectLeft(steps, z);\n\n  if (steps[i] === z) {\n    // If z is an integer value exactly matching a step, return the corresponding domain\n    return domain[i];\n  }\n  // Otherwise, return the next coarsest domain\n  return domain[Math.max(i - 1, 0)];\n}\n\n/**\n * Get d3 scale function\n */\nexport function getScaleFunction(\n  scale: string,\n  range: any[] | IterableIterator<any>,\n  domain: (number | undefined)[] | string[] | IterableIterator<any>,\n  fixed?: boolean\n): D3ScaleFunction {\n  const scaleFunction = SCALE_FUNC[fixed ? 'linear' : scale]()\n    .domain(domain)\n    .range(fixed ? domain : range);\n  scaleFunction.scaleType = fixed ? 'linear' : scale;\n  return scaleFunction;\n}\n\n/**\n * Get threshold scale color labels\n */\nfunction getThresholdLabels(\n  scale: D3ScaleFunction,\n  labelFormat: LabelFormat\n): Omit<ColorBreak, 'data'>[] {\n  const genLength = scale.range().length;\n  return scale.range().map((d, i) => {\n    const invert = scale.invertExtent(d);\n    const inputs = [\n      i === 0 ? null : reverseFormatNumber(labelFormat(invert[0])),\n      i === genLength - 1 ? null : reverseFormatNumber(labelFormat(invert[1]))\n    ];\n    return {\n      // raw value\n      range: invert,\n      // formatted value\n      inputs,\n      label:\n        i === 0\n          ? `Less than ${labelFormat(invert[1])}`\n          : i === genLength - 1\n          ? `${labelFormat(invert[0])} or more`\n          : `${labelFormat(invert[0])} to ${labelFormat(invert[1])}`\n    };\n  });\n}\n\n/**\n * Get linear / quant scale color labels\n */\nfunction getScaleLabels(\n  scale: D3ScaleFunction,\n  labelFormat: LabelFormat\n): Omit<ColorBreak, 'data'>[] {\n  return scale.range().map((d, i) => {\n    // @ts-ignore\n    const invert = scale.invertExtent(d);\n    const inputs = [\n      reverseFormatNumber(labelFormat(invert[0])),\n      reverseFormatNumber(labelFormat(invert[1]))\n    ];\n\n    return {\n      label: `${labelFormat(invert[0])} to ${labelFormat(invert[1])}`,\n      // raw value\n      range: invert,\n      // formatted value\n      inputs\n    };\n  });\n}\n\nconst customScaleLabelFormat = n => (n ? formatNumber(n, 'real') : 'no value');\n/**\n * Get linear / quant scale color breaks\n */\nexport function getQuantLegends(scale: D3ScaleFunction, labelFormat: LabelFormat): ColorBreak[] {\n  if (typeof scale.invertExtent !== 'function') {\n    return [];\n  }\n  const thresholdLabelFormat = (n, type) =>\n    n && labelFormat ? labelFormat(n) : n ? formatNumber(n, type) : 'no value';\n  const labels =\n    scale.scaleType === 'threshold'\n      ? getThresholdLabels(scale, thresholdLabelFormat)\n      : scale.scaleType === 'custom'\n      ? getThresholdLabels(scale, customScaleLabelFormat)\n      : getScaleLabels(scale, labelFormat);\n\n  const data = scale.range();\n\n  return labels.map((label, index) => ({\n    data: Array.isArray(data[index]) ? rgbToHex(data[index]) : data[index],\n    ...label\n  }));\n}\n\n/**\n * Get ordinal color scale legends\n */\nexport function getOrdinalLegends(scale: D3ScaleFunction): ColorBreakOrdinal[] {\n  const domain = scale.domain();\n  const labels = scale.domain();\n  const data = domain.map(scale);\n\n  return data.map((datum, index) => ({\n    data: isRgbColor(datum) ? rgbToHex(datum) : datum,\n    label: labels[index]\n  }));\n}\n\nconst defaultFormat = d => d;\n\nconst getTimeLabelFormat = domain => {\n  const formatter = getTimeWidgetHintFormatter(domain);\n  return val => moment.utc(val).format(formatter);\n};\n\nexport function getQuantLabelFormat(domain, fieldType) {\n  // quant scale can only be assigned to linear Fields: real, timestamp, integer\n  return fieldType === ALL_FIELD_TYPES.timestamp\n    ? getTimeLabelFormat(domain)\n    : !fieldType\n    ? defaultFormat\n    : n => (isNumber(n) ? formatNumber(n, fieldType) : 'no value');\n}\n\n/**\n * Get legends for scale\n */\nexport function getLegendOfScale({\n  scale,\n  scaleType,\n  labelFormat,\n  fieldType\n}: {\n  scale?: D3ScaleFunction | null;\n  scaleType: string;\n  labelFormat?: LabelFormat;\n  fieldType: string | null | undefined;\n}): ColorBreak[] | ColorBreakOrdinal[] {\n  if (!scale || scale.byZoom) {\n    return [];\n  }\n  if (\n    scaleType === SCALE_TYPES.ordinal ||\n    scaleType === SCALE_TYPES.customOrdinal ||\n    fieldType === ALL_FIELD_TYPES.string\n  ) {\n    return getOrdinalLegends(scale);\n  }\n\n  const formatLabel = labelFormat || getQuantLabelFormat(scale.domain(), fieldType);\n\n  return getQuantLegends(scale, formatLabel);\n}\n\n/**\n * Get color scale function\n */\nexport function getLayerColorScale({\n  range,\n  domain,\n  scaleType,\n  layer\n}: {\n  range: ColorRange | null | undefined;\n  domain: VisualChannelDomain;\n  scaleType: string;\n  layer: Layer;\n  isFixed?: boolean;\n}): D3ScaleFunction | null {\n  if (range && domain && scaleType) {\n    return layer.getColorScale(scaleType, domain, range);\n  }\n  return null;\n}\n\n/**\n * Convert colorRange.colorMap into color breaks UI input\n */\nexport function initializeLayerColorMap(layer: Layer, visualChannel: VisualChannel): ColorMap {\n  const domain = layer.config[visualChannel.domain];\n  const range = layer.config.visConfig[visualChannel.range];\n  const scaleType = layer.config[visualChannel.scale];\n  const field = layer.config[visualChannel.field];\n\n  const scale = getLayerColorScale({\n    range,\n    domain,\n    scaleType,\n    layer\n  });\n\n  const colorBreaks = getLegendOfScale({\n    scale: scale?.byZoom ? scale(0) : scale,\n    scaleType,\n    fieldType: field.type\n  });\n  return colorBreaksToColorMap(colorBreaks);\n}\n\n/**\n * Get visual chanel scale function if it's based on zoom\n */\nexport function getVisualChannelScaleByZoom({\n  scale,\n  layer,\n  mapState\n}: {\n  scale: D3ScaleFunction | null;\n  layer: Layer;\n  mapState?: MapState;\n}): D3ScaleFunction | null {\n  if (scale?.byZoom) {\n    const z = layer.meta?.getZoom ? layer.meta.getZoom(mapState) : mapState?.zoom;\n    scale = Number.isFinite(z) ? scale(z) : null;\n  }\n  return scale;\n}\n\n/**\n * Get categorical colorMap from colors and domain (unique values)\n */\nexport function getCategoricalColorMap(\n  colors: string[],\n  domain: (string | number | string[] | number[] | null)[]\n): any {\n  // colorMap: [string | string[], hexstring]\n  const colorToUniqueValues = {};\n  const uniqueValues = unique(domain).filter(notNullorUndefined).sort();\n  // each unique value assign to a color, the rest unique values assign to last color\n  const lastColor = colors[colors.length - 1];\n  for (let i = 0; i < uniqueValues.length; ++i) {\n    if (i < colors.length) {\n      colorToUniqueValues[colors[i]] = uniqueValues[i];\n    } else {\n      colorToUniqueValues[lastColor] = [\n        ...(Array.isArray(colorToUniqueValues[lastColor])\n          ? colorToUniqueValues[lastColor]\n          : [colorToUniqueValues[lastColor]]),\n        uniqueValues[i]\n      ];\n    }\n  }\n\n  const colorMap = colors.map(color => {\n    if (color in colorToUniqueValues) {\n      return [colorToUniqueValues[color], color];\n    }\n    return [null, color];\n  });\n\n  return colorMap;\n}\n\n/**\n * Get categorical colorBreaks from colorMap\n */\nexport function colorMapToCategoricalColorBreaks(\n  colorMap?: ColorMap | null\n): ColorBreakOrdinal[] | null {\n  if (!colorMap) {\n    return null;\n  }\n  const colorBreaks = colorMap.map(([value, color], i) => {\n    return {\n      data: color,\n      label: value\n    };\n  });\n\n  return colorBreaks;\n}\n\n/**\n * create categorical colorMap from colorBreaks\n */\nexport function colorBreaksToCategoricalColorMap(colorBreaks: ColorBreakOrdinal[]): ColorMap {\n  // colorMap: [string | string[], hexstring]\n  const colors = uniq(colorBreaks.map(cb => cb.data));\n  const values = uniq(colorBreaks.map(cb => cb.label));\n\n  return getCategoricalColorMap(colors, values);\n}\n\n/**\n * Convert color breaks UI input into colorRange.colorMap\n */\nexport function colorBreaksToColorMap(colorBreaks: ColorBreak[] | ColorBreakOrdinal[]): ColorMap {\n  const colorMap = colorBreaks.map((colorBreak, i) => {\n    // [value, hex]\n    return [\n      colorBreak.inputs\n        ? i === colorBreaks.length - 1\n          ? null // last\n          : colorBreak.inputs[1]\n        : colorBreak.label,\n      colorBreak.data\n    ];\n  });\n\n  // @ts-ignore tuple\n  return colorMap;\n}\n\n/**\n * Convert colorRange.colorMap into color breaks UI input\n */\nexport function colorMapToColorBreaks(colorMap?: ColorMap | null): ColorBreak[] | null {\n  if (!colorMap) {\n    return null;\n  }\n  const colorBreaks = colorMap.map(([value, color], i) => {\n    const range =\n      i === 0\n        ? // first\n          [-Infinity, value]\n        : // last\n        i === colorMap.length - 1\n        ? [colorMap[i - 1][0], Infinity]\n        : // else\n          [colorMap[i - 1][0], value];\n    return {\n      data: color,\n      range,\n      inputs: range,\n      label:\n        // first\n        i === 0\n          ? `Less than ${value}`\n          : // last\n          i === colorMap.length - 1\n          ? `${colorMap[i - 1][0]} or more`\n          : `${colorMap[i - 1][0]} to ${value}`\n    };\n  });\n\n  // @ts-ignore implement conversion for ordinal\n  return colorBreaks;\n}\n\n/**\n * Whether color breaks is for numeric field\n */\nexport function isNumericColorBreaks(colorBreaks: unknown): colorBreaks is ColorBreak[] {\n  return Boolean(Array.isArray(colorBreaks) && colorBreaks.length && colorBreaks[0].inputs);\n}\n\n// return domainMin, domainMax, histogramMean\nexport function getHistogramDomain({\n  aggregatedBins,\n  columnStats,\n  dataset,\n  fieldValueAccessor\n}: {\n  aggregatedBins?: AggregatedBin[];\n  columnStats?: FilterProps['columnStats'];\n  dataset?: KeplerTable;\n  fieldValueAccessor: (idx: unknown) => number;\n}) {\n  let domainMin = Number.POSITIVE_INFINITY;\n  let domainMax = Number.NEGATIVE_INFINITY;\n  let nValid = 0;\n  let domainSum = 0;\n\n  if (aggregatedBins) {\n    Object.values(aggregatedBins).forEach(bin => {\n      const val = bin.value;\n      if (isNumber(val)) {\n        if (val < domainMin) domainMin = val;\n        if (val > domainMax) domainMax = val;\n        domainSum += val;\n        nValid += 1;\n      }\n    });\n  } else {\n    if (columnStats && columnStats.quantiles && columnStats.mean) {\n      // no need to recalcuate min/max/mean if its already in columnStats\n      return [\n        columnStats.quantiles[0].value,\n        columnStats.quantiles[columnStats.quantiles.length - 1].value,\n        columnStats.mean\n      ];\n    }\n    if (dataset && fieldValueAccessor) {\n      dataset.allIndexes.forEach((x, i) => {\n        const val = fieldValueAccessor(x);\n        if (isNumber(val)) {\n          if (val < domainMin) domainMin = val;\n          if (val > domainMax) domainMax = val;\n          domainSum += val;\n          nValid += 1;\n        }\n      });\n    }\n  }\n  const histogramMean = nValid > 0 ? domainSum / nValid : 0;\n  return [nValid > 0 ? domainMin : 0, nValid > 0 ? domainMax : 0, histogramMean];\n}\n\nexport function resetCategoricalColorMapByIndex(colorMap: ColorMap, index: number): any {\n  if (!colorMap) {\n    return colorMap;\n  }\n  const newColorMap = colorMap.map((cm, i) => {\n    if (i === index) {\n      return [null, cm[1]];\n    }\n    return cm;\n  });\n  return newColorMap;\n}\n\n/**\n * select rest categorical values for a colorMap by its index\n */\nexport function selectRestCategoricalColorMapByIndex(\n  colorMap: ColorMap | null,\n  index: number,\n  uniqueValues?: number[] | string[]\n): ColorMap | undefined | null {\n  if (!colorMap || !uniqueValues) {\n    return colorMap;\n  }\n\n  // find unique values that has not been used in current colorMap\n  const uniqValueDict = Object.fromEntries(uniqueValues.map(val => [val, false]));\n  colorMap.forEach(cm => {\n    toArray(cm[0]).forEach(v => {\n      if (v) uniqValueDict[v] = true;\n    });\n  });\n  const rest = Object.keys(uniqValueDict).filter(v => !uniqValueDict[v]);\n\n  // use the not used unique values in the selected color map\n  const newColorMap = colorMap.map((cm, i) => {\n    if (i === index) {\n      return [[...rest, ...toArray(cm[0])], cm[1]];\n    }\n    return cm;\n  }) as ColorMap;\n\n  return newColorMap;\n}\n\n/**\n * remove a categorical value from a colorMap by its index\n */\nexport function removeCategoricalValueFromColorMap(\n  colorMap: ColorMap | null | undefined,\n  item: number | string,\n  index: number\n): ColorMap | null | undefined {\n  if (!colorMap) {\n    return colorMap;\n  }\n  const newColorMap = colorMap.map((cm, i) => {\n    if (i === index) {\n      if (!cm[0]) {\n        return [null, cm[1]];\n      }\n      const currentUniqueValues = toArray(cm[0]);\n      const updatedUniqueValues = currentUniqueValues.filter(v => v !== item);\n      return [updatedUniqueValues, cm[1]];\n    }\n    return cm;\n  }) as ColorMap;\n\n  return newColorMap;\n}\n\n/**\n * add categorical values (from multisel dropdown) to a colorMap by its index\n */\nexport function addCategoricalValuesToColorMap(\n  colorMap: ColorMap,\n  items: (string | number)[],\n  index: number\n): ColorMap {\n  if (!colorMap) {\n    return colorMap;\n  }\n\n  const newColorMap = colorMap.map((cm, i) => {\n    if (i === index) {\n      if (!cm[0]) {\n        return [items, cm[1]];\n      }\n      const currentUniqueValues = toArray(cm[0]);\n      const updatedUniqueValues = uniq(currentUniqueValues.concat(items));\n      return [updatedUniqueValues, cm[1]];\n    }\n    // remove value from other colorMap\n    const currentUniqueValues = cm[0];\n    if (Array.isArray(currentUniqueValues)) {\n      const updatedUniqueValues: string[] | number[] = (currentUniqueValues as any[]).filter(\n        v => !items.includes(v)\n      );\n      return [updatedUniqueValues, cm[1]];\n    } else if (currentUniqueValues && items.includes(currentUniqueValues)) {\n      return [null, cm[1]];\n    }\n\n    return cm;\n  }) as ColorMap;\n\n  return newColorMap;\n}\n\n/**\n * get a color scale func for categorical (custom ordinal) scale\n */\nexport function getCategoricalColorScale(\n  colorDomain: number[] | string[],\n  colorRange: ColorRange,\n  useRgb = true\n): (categoryValue: string | number) => RGBColor | RGBAColor {\n  const cMap = colorRange.colorMap\n    ? colorRange.colorMap\n    : getCategoricalColorMap(colorRange.colors, colorDomain);\n\n  const range: number[][] = [];\n  const domain: string[] = [];\n  cMap.forEach(cm => {\n    if (Array.isArray(cm[0])) {\n      cm[0].forEach(val => {\n        domain.push(val);\n        range.push(useRgb ? hexToRgb(cm[1]) : cm[1]);\n      });\n    } else {\n      domain.push(cm[0]);\n      range.push(useRgb ? hexToRgb(cm[1]) : cm[1]);\n    }\n  });\n\n  const scale = getScaleFunction(SCALE_TYPES.customOrdinal, range, domain, false);\n  scale.unknown(NO_VALUE_COLOR);\n  return scale as any;\n}\n\n/**\n * initialize customPalette by custom scale or customOrdinal scale\n */\nexport function initCustomPaletteByCustomScale({\n  scale,\n  field,\n  ordinalDomain,\n  range,\n  colorBreaks\n}: {\n  scale: string;\n  field: Field;\n  ordinalDomain?: number[] | string[];\n  range: ColorRange;\n  colorBreaks: ColorBreakOrdinal[] | null;\n}): ColorUI['customPalette'] {\n  const customPaletteName = `color.customPalette.${scale}.${field.name}`;\n  // reuse range.colorMap if the field and scale not changed\n  const reuseColorMap = range.colorMap && range.name === customPaletteName && range.type === scale;\n  const colorMap = reuseColorMap\n    ? range.colorMap\n    : scale === SCALE_TYPES.customOrdinal && ordinalDomain\n    ? getCategoricalColorMap(range.colors, ordinalDomain)\n    : colorBreaks && isNumericColorBreaks(colorBreaks)\n    ? colorBreaksToColorMap(colorBreaks)\n    : null;\n  const colors = reuseColorMap ? range.colors : colorMap ? colorMap.map(cm => cm[1]) : range.colors;\n\n  // update custom breaks\n  const customPalette: ColorUI['customPalette'] = {\n    category: 'Custom',\n    name: customPaletteName,\n    type: scale,\n    colorMap,\n    colors: colors || []\n  };\n\n  return customPalette;\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,6 +1,36 @@
1
1
  import { TooltipFormat } from '@kepler.gl/constants';
2
2
  import { Field, Millisecond } from '@kepler.gl/types';
3
3
  export declare type FieldFormatter = (value: any) => string;
4
+ export declare const MAX_LATITUDE = 89.9;
5
+ export declare const MIN_LATITUDE = -89.9;
6
+ export declare const MAX_LONGITUDE = 180;
7
+ export declare const MIN_LONGITUDE = -180;
8
+ /**
9
+ * Validates a latitude value.
10
+ * Ensures that the latitude is within the defined minimum and maximum latitude bounds.
11
+ * If the value is out of bounds, it returns the nearest bound value.
12
+ * @param latitude - The latitude value to validate.
13
+ * @returns The validated latitude value.
14
+ */
15
+ export declare function validateLatitude(latitude: number | undefined): number;
16
+ /**
17
+ * Validates a longitude value.
18
+ * Ensures that the longitude is within the defined minimum and maximum longitude bounds.
19
+ * If the value is out of bounds, it returns the nearest bound value.
20
+ * @param longitude - The longitude value to validate.
21
+ * @returns The validated longitude value.
22
+ */
23
+ export declare function validateLongitude(longitude: number | undefined): number;
24
+ /**
25
+ * Validates a coordinate value.
26
+ * Ensures that the value is within the specified minimum and maximum bounds.
27
+ * If the value is out of bounds, it returns the nearest bound value.
28
+ * @param value - The coordinate value to validate.
29
+ * @param minValue - The minimum bound for the value.
30
+ * @param maxValue - The maximum bound for the value.
31
+ * @returns The validated coordinate value.
32
+ */
33
+ export declare function validateCoordinate(value: number, minValue: number, maxValue: number): number;
4
34
  /**
5
35
  * simple getting unique values of an array
6
36
  *
@@ -50,7 +80,7 @@ export declare function getRoundingDecimalFromStep(step: number): number;
50
80
  * @param step
51
81
  * @param marks
52
82
  */
53
- export declare function normalizeSliderValue(val: number, minValue: number, step: number, marks?: number[] | null): number;
83
+ export declare function normalizeSliderValue(val: number, minValue: number | undefined, step: number, marks?: number[] | null): number;
54
84
  /**
55
85
  * round the value to step for the slider
56
86
  * @param minValue
@@ -58,7 +88,7 @@ export declare function normalizeSliderValue(val: number, minValue: number, step
58
88
  * @param val
59
89
  * @returns - rounded number
60
90
  */
61
- export declare function roundValToStep(minValue: number, step: number, val: number): number;
91
+ export declare function roundValToStep(minValue: number | undefined, step: number, val: number): number;
62
92
  /**
63
93
  * Get the value format based on field and format options
64
94
  * Used in render tooltip value
@@ -78,7 +108,7 @@ export declare const parseFieldValue: (value: any, type: string) => string;
78
108
  * @param format
79
109
  * @param field
80
110
  */
81
- export declare function getFormatter(format: string | Record<string, string> | null, field?: Field): FieldFormatter;
111
+ export declare function getFormatter(format?: string | Record<string, string> | null, field?: Field): FieldFormatter;
82
112
  export declare function getColumnFormatter(field: Pick<Field, 'type'> & Partial<Pick<Field, 'format' | 'displayFormat'>>): FieldFormatter;
83
113
  export declare function applyValueMap(format: any): (v: any) => any;
84
114
  export declare function applyDefaultFormat(tooltipFormat: TooltipFormat): (v: any) => string;