@kepler.gl/utils 3.1.9 → 3.1.10
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.
- package/dist/data-scale-utils.js +35 -16
- package/dist/data-utils.d.ts +1 -0
- package/dist/data-utils.js +2 -1
- package/package.json +4 -4
package/dist/data-scale-utils.js
CHANGED
|
@@ -300,24 +300,43 @@ function getVisualChannelScaleByZoom(_ref3) {
|
|
|
300
300
|
* Get categorical colorMap from colors and domain (unique values)
|
|
301
301
|
*/
|
|
302
302
|
function getCategoricalColorMap(colors, domain) {
|
|
303
|
-
|
|
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
|
-
}
|
|
303
|
+
var uniqueValues = (0, _dataUtils.unique)(domain).sort();
|
|
315
304
|
var colorMap = colors.map(function (color) {
|
|
316
|
-
if (color in colorToUniqueValues) {
|
|
317
|
-
return [colorToUniqueValues[color], color];
|
|
318
|
-
}
|
|
319
305
|
return [null, color];
|
|
320
306
|
});
|
|
307
|
+
if (colors.length === 0 || uniqueValues.length === 0) {
|
|
308
|
+
return colorMap;
|
|
309
|
+
}
|
|
310
|
+
var lastIndex = colors.length - 1;
|
|
311
|
+
var assignCount = Math.min(lastIndex, uniqueValues.length);
|
|
312
|
+
|
|
313
|
+
// Assign first values one-to-one up to the penultimate color (if any)
|
|
314
|
+
for (var i = 0; i < assignCount; i++) {
|
|
315
|
+
// @ts-ignore tuple
|
|
316
|
+
colorMap[i][0] = uniqueValues[i];
|
|
317
|
+
}
|
|
318
|
+
if (uniqueValues.length > colors.length) {
|
|
319
|
+
// Aggregate the rest (including the value that would have gone to last color)
|
|
320
|
+
// Build aggregated array incrementally to match legacy behavior
|
|
321
|
+
var aggregatedValues = [];
|
|
322
|
+
for (var _i = lastIndex; _i < uniqueValues.length; _i++) {
|
|
323
|
+
var value = uniqueValues[_i];
|
|
324
|
+
if (Array.isArray(value)) {
|
|
325
|
+
// Spread array elements to match legacy flattening behavior
|
|
326
|
+
aggregatedValues.push.apply(aggregatedValues, (0, _toConsumableArray2["default"])(value));
|
|
327
|
+
} else {
|
|
328
|
+
aggregatedValues.push(value);
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
// @ts-ignore tuple
|
|
332
|
+
colorMap[lastIndex][0] = aggregatedValues;
|
|
333
|
+
} else if (uniqueValues.length === colors.length) {
|
|
334
|
+
// Exactly one per color
|
|
335
|
+
// @ts-ignore tuple
|
|
336
|
+
colorMap[lastIndex][0] = uniqueValues[lastIndex];
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
// @ts-ignore tuple
|
|
321
340
|
return colorMap;
|
|
322
341
|
}
|
|
323
342
|
|
|
@@ -598,4 +617,4 @@ function initCustomPaletteByCustomScale(_ref9) {
|
|
|
598
617
|
};
|
|
599
618
|
return customPalette;
|
|
600
619
|
}
|
|
601
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_d3Array","require","_uniq","_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 => {\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]) => {\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 => {\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 || 'point-count'}`;\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":[]}
|
|
620
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_d3Array","require","_uniq","_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","uniqueValues","colorMap","color","lastIndex","assignCount","min","aggregatedValues","value","_toConsumableArray2","colorMapToCategoricalColorBreaks","_ref4","_ref5","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 => {\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  const uniqueValues = unique(domain).sort();\n  const colorMap = colors.map(color => [null, color]);\n\n  if (colors.length === 0 || uniqueValues.length === 0) {\n    return colorMap;\n  }\n\n  const lastIndex = colors.length - 1;\n  const assignCount = Math.min(lastIndex, uniqueValues.length);\n\n  // Assign first values one-to-one up to the penultimate color (if any)\n  for (let i = 0; i < assignCount; i++) {\n    // @ts-ignore tuple\n    colorMap[i][0] = uniqueValues[i];\n  }\n\n  if (uniqueValues.length > colors.length) {\n    // Aggregate the rest (including the value that would have gone to last color)\n    // Build aggregated array incrementally to match legacy behavior\n    const aggregatedValues: any[] = [];\n    for (let i = lastIndex; i < uniqueValues.length; i++) {\n      const value = uniqueValues[i];\n      if (Array.isArray(value)) {\n        // Spread array elements to match legacy flattening behavior\n        aggregatedValues.push(...(value as any[]));\n      } else {\n        aggregatedValues.push(value);\n      }\n    }\n    // @ts-ignore tuple\n    colorMap[lastIndex][0] = aggregatedValues;\n  } else if (uniqueValues.length === colors.length) {\n    // Exactly one per color\n    // @ts-ignore tuple\n    colorMap[lastIndex][0] = uniqueValues[lastIndex];\n  }\n\n  // @ts-ignore tuple\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]) => {\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 => {\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 || 'point-count'}`;\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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,IAAAA,QAAA,GAAAC,OAAA;AACA,IAAAC,KAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,OAAA,GAAAD,sBAAA,CAAAF,OAAA;AAEA,IAAAI,YAAA,GAAAJ,OAAA;AACA,IAAAK,UAAA,GAAAL,OAAA;AAiBA,IAAAM,WAAA,GAAAN,OAAA;AAEA,IAAAO,UAAA,GAAAP,OAAA;AACA,IAAAQ,YAAA,GAAAR,OAAA;AACA,IAAAS,MAAA,GAAAT,OAAA;AAAsC,SAAAU,QAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,GAAAC,MAAA,CAAAC,IAAA,CAAAJ,CAAA,OAAAG,MAAA,CAAAE,qBAAA,QAAAC,CAAA,GAAAH,MAAA,CAAAE,qBAAA,CAAAL,CAAA,GAAAC,CAAA,KAAAK,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAAN,CAAA,WAAAE,MAAA,CAAAK,wBAAA,CAAAR,CAAA,EAAAC,CAAA,EAAAQ,UAAA,OAAAP,CAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,CAAA,EAAAI,CAAA,YAAAJ,CAAA;AAAA,SAAAU,cAAAZ,CAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAY,SAAA,CAAAC,MAAA,EAAAb,CAAA,UAAAC,CAAA,WAAAW,SAAA,CAAAZ,CAAA,IAAAY,SAAA,CAAAZ,CAAA,QAAAA,CAAA,OAAAF,OAAA,CAAAI,MAAA,CAAAD,CAAA,OAAAa,OAAA,WAAAd,CAAA,QAAAe,gBAAA,aAAAhB,CAAA,EAAAC,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAE,MAAA,CAAAc,yBAAA,GAAAd,MAAA,CAAAe,gBAAA,CAAAlB,CAAA,EAAAG,MAAA,CAAAc,yBAAA,CAAAf,CAAA,KAAAH,OAAA,CAAAI,MAAA,CAAAD,CAAA,GAAAa,OAAA,WAAAd,CAAA,IAAAE,MAAA,CAAAgB,cAAA,CAAAnB,CAAA,EAAAC,CAAA,EAAAE,MAAA,CAAAK,wBAAA,CAAAN,CAAA,EAAAD,CAAA,iBAAAD,CAAA,IA7BtC;AACA;AAQA;AAmCA;;AAQA;AACA;AACA;AACO,SAASoB,iBAAiBA,CAC/BC,IAAW,EACXC,aAAiC,EACjCC,QAAe,EACL;EACV,IAAMC,MAAM,GAAG,OAAOF,aAAa,KAAK,UAAU,GAAGD,IAAI,CAACI,GAAG,CAACH,aAAa,CAAC,GAAGD,IAAI;EAEnF,OAAOG,MAAM,CAACjB,MAAM,CAACmB,+BAAkB,CAAC,CAACC,IAAI,CAACJ,QAAQ,CAAC;AACzD;;AAEA;AACA;AACA;AACO,SAASK,gBAAgBA,CAC9BC,aAAqC,EACrCP,aAAyC,EAC/B;EACV,IAAME,MAAM,GAAGK,aAAa,CAACC,QAAQ,CAACR,aAAa,CAAC;EAEpD,OAAO,IAAAS,iBAAM,EAACP,MAAM,CAAC,CAACjB,MAAM,CAACmB,+BAAkB,CAAC,CAACC,IAAI,CAAC,CAAC;AACzD;;AAEA;AACA;AACA;AACO,SAASK,eAAeA,CAC7BX,IAAc,EACdC,aAAiC,EACf;EAClB,IAAMW,KAAK,GAAG,OAAOX,aAAa,KAAK,UAAU,GAAG,IAAAY,eAAM,EAACb,IAAI,EAAEC,aAAa,CAAC,GAAG,IAAAY,eAAM,EAACb,IAAI,CAAC;EAC9F,OAAOY,KAAK,CAACR,GAAG,CAAC,UAACU,CAAqB,EAAEC,CAAS;IAAA,OAAMD,CAAC,KAAKE,SAAS,GAAGD,CAAC,GAAGD,CAAC;EAAA,CAAC,CAAC;AAInF;;AAEA;AACA;AACA;AACO,SAASG,YAAYA,CAACjB,IAAW,EAAEC,aAAgC,EAAoB;EAC5F,IAAAiB,gBAAA,GAAiBP,eAAe,CAACX,IAAI,EAAEC,aAAa,CAAC;IAAAkB,iBAAA,OAAAC,eAAA,aAAAF,gBAAA;IAA9CG,EAAE,GAAAF,iBAAA;IAAEG,EAAE,GAAAH,iBAAA;EACb,OAAO,CAACE,EAAE,KAAK,CAAC,GAAG,IAAI,GAAGA,EAAE,EAAEC,EAAE,CAAC;AACnC;AAOA;AACA;AACA;AACO,SAASC,aAAaA,CAACC,MAAe,EAAyB;EACpE,OAAO,IAAAC,oBAAa,EAACD,MAAM,CAAC,IAAIE,KAAK,CAACC,OAAO,CAACH,MAAM,CAACI,KAAK,CAAC,IAAIF,KAAK,CAACC,OAAO,CAACH,MAAM,CAACK,CAAC,CAAC;AACxF;AAOA;AACA;AACA;AACO,SAASC,gBAAgBA,CAACN,MAAW,EAA6B;EACvE,OAAO,IAAAC,oBAAa,EAACD,MAAM,CAAC,IAAIE,KAAK,CAACC,OAAO,CAACH,MAAM,CAACO,SAAS,CAAC,IAAIL,KAAK,CAACC,OAAO,CAACH,MAAM,CAACK,CAAC,CAAC;AAC5F;;AAEA;AACA;AACA;AACO,SAASG,0BAA0BA,CACxCD,SAAmB,EACnBE,OAAe,EACS;EACxB,IAAMC,UAAU,GAAG,EAAE;EACrB,IAAI,CAACC,MAAM,CAACC,QAAQ,CAACH,OAAO,CAAC,IAAIA,OAAO,GAAG,CAAC,EAAE;IAC5C,OAAO,CAACF,SAAS,CAAC,CAAC,CAAC,EAAEA,SAAS,CAACA,SAAS,CAACtC,MAAM,GAAG,CAAC,CAAC,CAAC;EACxD;EACA,KAAK,IAAIsB,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGkB,OAAO,EAAElB,CAAC,EAAE,EAAE;IAChC;IACA,IAAMsB,QAAQ,GAAGtB,CAAC,GAAGkB,OAAO;IAC5B;IACAC,UAAU,CAAC7C,IAAI,CAAC,IAAAiD,uBAAU,EAACP,SAAS,EAAEM,QAAQ,CAAC,CAAC;EAClD;EAEA,OAAOH,UAAU;AACnB;;AAEA;AACA;AACA;AACO,SAASK,oBAAoBA,CAACf,MAAa,EAAEgB,KAAe,EAAEX,CAAS,EAAO;EACnF,IAAMd,CAAC,GAAG,IAAA0B,mBAAU,EAACD,KAAK,EAAEX,CAAC,CAAC;EAE9B,IAAIW,KAAK,CAACzB,CAAC,CAAC,KAAKc,CAAC,EAAE;IAClB;IACA,OAAOL,MAAM,CAACT,CAAC,CAAC;EAClB;EACA;EACA,OAAOS,MAAM,CAACkB,IAAI,CAACC,GAAG,CAAC5B,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;AACnC;;AAEA;AACA;AACA;AACO,SAAS6B,gBAAgBA,CAC9BC,KAAa,EACbjC,KAAoC,EACpCY,MAAiE,EACjEsB,KAAe,EACE;EACjB,IAAMC,aAAa,GAAGC,qBAAU,CAACF,KAAK,GAAG,QAAQ,GAAGD,KAAK,CAAC,CAAC,CAAC,CACzDrB,MAAM,CAACA,MAAM,CAAC,CACdZ,KAAK,CAACkC,KAAK,GAAGtB,MAAM,GAAGZ,KAAK,CAAC;EAChCmC,aAAa,CAACE,SAAS,GAAGH,KAAK,GAAG,QAAQ,GAAGD,KAAK;EAClD,OAAOE,aAAa;AACtB;;AAEA;AACA;AACA;AACA,SAASG,kBAAkBA,CACzBL,KAAsB,EACtBM,WAAwB,EACI;EAC5B,IAAMC,SAAS,GAAGP,KAAK,CAACjC,KAAK,CAAC,CAAC,CAACnB,MAAM;EACtC,OAAOoD,KAAK,CAACjC,KAAK,CAAC,CAAC,CAACR,GAAG,CAAC,UAACU,CAAC,EAAEC,CAAC,EAAK;IACjC,IAAMsC,MAAM,GAAGR,KAAK,CAACS,YAAY,CAACxC,CAAC,CAAC;IACpC,IAAMyC,MAAM,GAAG,CACbxC,CAAC,KAAK,CAAC,GAAG,IAAI,GAAG,IAAAyC,8BAAmB,EAACL,WAAW,CAACE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,EAC5DtC,CAAC,KAAKqC,SAAS,GAAG,CAAC,GAAG,IAAI,GAAG,IAAAI,8BAAmB,EAACL,WAAW,CAACE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CACzE;IACD,OAAO;MACL;MACAzC,KAAK,EAAEyC,MAAM;MACb;MACAE,MAAM,EAANA,MAAM;MACNE,KAAK,EACH1C,CAAC,KAAK,CAAC,gBAAA2C,MAAA,CACUP,WAAW,CAACE,MAAM,CAAC,CAAC,CAAC,CAAC,IACnCtC,CAAC,KAAKqC,SAAS,GAAG,CAAC,MAAAM,MAAA,CAChBP,WAAW,CAACE,MAAM,CAAC,CAAC,CAAC,CAAC,mBAAAK,MAAA,CACtBP,WAAW,CAACE,MAAM,CAAC,CAAC,CAAC,CAAC,UAAAK,MAAA,CAAOP,WAAW,CAACE,MAAM,CAAC,CAAC,CAAC,CAAC;IAC9D,CAAC;EACH,CAAC,CAAC;AACJ;;AAEA;AACA;AACA;AACA,SAASM,cAAcA,CACrBd,KAAsB,EACtBM,WAAwB,EACI;EAC5B,OAAON,KAAK,CAACjC,KAAK,CAAC,CAAC,CAACR,GAAG,CAAC,UAAAU,CAAC,EAAI;IAC5B;IACA,IAAMuC,MAAM,GAAGR,KAAK,CAACS,YAAY,CAACxC,CAAC,CAAC;IACpC,IAAMyC,MAAM,GAAG,CACb,IAAAC,8BAAmB,EAACL,WAAW,CAACE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,EAC3C,IAAAG,8BAAmB,EAACL,WAAW,CAACE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAC5C;IAED,OAAO;MACLI,KAAK,KAAAC,MAAA,CAAKP,WAAW,CAACE,MAAM,CAAC,CAAC,CAAC,CAAC,UAAAK,MAAA,CAAOP,WAAW,CAACE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAE;MAC/D;MACAzC,KAAK,EAAEyC,MAAM;MACb;MACAE,MAAM,EAANA;IACF,CAAC;EACH,CAAC,CAAC;AACJ;AAEA,IAAMK,sBAAsB,GAAG,SAAzBA,sBAAsBA,CAAGC,CAAC;EAAA,OAAKA,CAAC,GAAG,IAAAC,uBAAY,EAACD,CAAC,EAAE,MAAM,CAAC,GAAG,UAAU;AAAA,CAAC;AAC9E;AACA;AACA;AACO,SAASE,eAAeA,CAAClB,KAAsB,EAAEM,WAAwB,EAAgB;EAC9F,IAAI,OAAON,KAAK,CAACS,YAAY,KAAK,UAAU,EAAE;IAC5C,OAAO,EAAE;EACX;EACA,IAAMU,oBAAoB,GAAG,SAAvBA,oBAAoBA,CAAIH,CAAC,EAAEI,IAAI;IAAA,OACnCJ,CAAC,IAAIV,WAAW,GAAGA,WAAW,CAACU,CAAC,CAAC,GAAGA,CAAC,GAAG,IAAAC,uBAAY,EAACD,CAAC,EAAEI,IAAI,CAAC,GAAG,UAAU;EAAA;EAC5E,IAAMC,MAAM,GACVrB,KAAK,CAACI,SAAS,KAAK,WAAW,GAC3BC,kBAAkB,CAACL,KAAK,EAAEmB,oBAAoB,CAAC,GAC/CnB,KAAK,CAACI,SAAS,KAAK,QAAQ,GAC5BC,kBAAkB,CAACL,KAAK,EAAEe,sBAAsB,CAAC,GACjDD,cAAc,CAACd,KAAK,EAAEM,WAAW,CAAC;EAExC,IAAMnD,IAAI,GAAG6C,KAAK,CAACjC,KAAK,CAAC,CAAC;EAE1B,OAAOsD,MAAM,CAAC9D,GAAG,CAAC,UAACqD,KAAK,EAAEU,KAAK;IAAA,OAAA5E,aAAA;MAC7BS,IAAI,EAAE0B,KAAK,CAACC,OAAO,CAAC3B,IAAI,CAACmE,KAAK,CAAC,CAAC,GAAG,IAAAC,oBAAQ,EAACpE,IAAI,CAACmE,KAAK,CAAC,CAAC,GAAGnE,IAAI,CAACmE,KAAK;IAAC,GACnEV,KAAK;EAAA,CACR,CAAC;AACL;;AAEA;AACA;AACA;AACO,SAASY,iBAAiBA,CAACxB,KAAsB,EAAuB;EAC7E,IAAMrB,MAAM,GAAGqB,KAAK,CAACrB,MAAM,CAAC,CAAC;EAC7B,IAAM0C,MAAM,GAAGrB,KAAK,CAACrB,MAAM,CAAC,CAAC;EAC7B,IAAMxB,IAAI,GAAGwB,MAAM,CAACpB,GAAG,CAACyC,KAAK,CAAC;EAE9B,OAAO7C,IAAI,CAACI,GAAG,CAAC,UAACkE,KAAK,EAAEH,KAAK;IAAA,OAAM;MACjCnE,IAAI,EAAE,IAAAuE,sBAAU,EAACD,KAAK,CAAC,GAAG,IAAAF,oBAAQ,EAACE,KAAK,CAAC,GAAGA,KAAK;MACjDb,KAAK,EAAES,MAAM,CAACC,KAAK;IACrB,CAAC;EAAA,CAAC,CAAC;AACL;AAEA,IAAMK,aAAa,GAAG,SAAhBA,aAAaA,CAAG1D,CAAC;EAAA,OAAIA,CAAC;AAAA;AAE5B,IAAM2D,kBAAkB,GAAG,SAArBA,kBAAkBA,CAAGjD,MAAM,EAAI;EACnC,IAAMkD,SAAS,GAAG,IAAAC,uCAA0B,EAACnD,MAAM,CAAC;EACpD,OAAO,UAAAoD,GAAG;IAAA,OAAIC,kBAAM,CAACC,GAAG,CAACF,GAAG,CAAC,CAACG,MAAM,CAACL,SAAS,CAAC;EAAA;AACjD,CAAC;AAEM,SAASM,mBAAmBA,CAACxD,MAAM,EAAEyD,SAAS,EAAE;EACrD;EACA,OAAOA,SAAS,KAAKC,0BAAe,CAACC,SAAS,GAC1CV,kBAAkB,CAACjD,MAAM,CAAC,GAC1B,CAACyD,SAAS,GACVT,aAAa,GACb,UAAAX,CAAC;IAAA,OAAK,IAAAuB,mBAAQ,EAACvB,CAAC,CAAC,GAAG,IAAAC,uBAAY,EAACD,CAAC,EAAEoB,SAAS,CAAC,GAAG,UAAU;EAAA,CAAC;AAClE;;AAEA;AACA;AACA;AACO,SAASI,gBAAgBA,CAAAC,IAAA,EAUO;EAAA,IATrCzC,KAAK,GAAAyC,IAAA,CAALzC,KAAK;IACLI,SAAS,GAAAqC,IAAA,CAATrC,SAAS;IACTE,WAAW,GAAAmC,IAAA,CAAXnC,WAAW;IACX8B,SAAS,GAAAK,IAAA,CAATL,SAAS;EAOT,IAAI,CAACpC,KAAK,IAAIA,KAAK,CAAC0C,MAAM,EAAE;IAC1B,OAAO,EAAE;EACX;EACA,IACEtC,SAAS,KAAKuC,sBAAW,CAACC,OAAO,IACjCxC,SAAS,KAAKuC,sBAAW,CAACE,aAAa,IACvCT,SAAS,KAAKC,0BAAe,CAACS,MAAM,EACpC;IACA,OAAOtB,iBAAiB,CAACxB,KAAK,CAAC;EACjC;EAEA,IAAM+C,WAAW,GAAGzC,WAAW,IAAI6B,mBAAmB,CAACnC,KAAK,CAACrB,MAAM,CAAC,CAAC,EAAEyD,SAAS,CAAC;EAEjF,OAAOlB,eAAe,CAAClB,KAAK,EAAE+C,WAAW,CAAC;AAC5C;;AAEA;AACA;AACA;AACO,SAASC,kBAAkBA,CAAAC,KAAA,EAWP;EAAA,IAVzBlF,KAAK,GAAAkF,KAAA,CAALlF,KAAK;IACLY,MAAM,GAAAsE,KAAA,CAANtE,MAAM;IACNyB,SAAS,GAAA6C,KAAA,CAAT7C,SAAS;IACT8C,KAAK,GAAAD,KAAA,CAALC,KAAK;EAQL,IAAInF,KAAK,IAAIY,MAAM,IAAIyB,SAAS,EAAE;IAChC,OAAO8C,KAAK,CAACC,aAAa,CAAC/C,SAAS,EAAEzB,MAAM,EAAEZ,KAAK,CAAC;EACtD;EACA,OAAO,IAAI;AACb;;AAEA;AACA;AACA;AACO,SAASqF,uBAAuBA,CAACF,KAAY,EAAEG,aAA4B,EAAY;EAC5F,IAAM1E,MAAM,GAAGuE,KAAK,CAACI,MAAM,CAACD,aAAa,CAAC1E,MAAM,CAAC;EACjD,IAAMZ,KAAK,GAAGmF,KAAK,CAACI,MAAM,CAACC,SAAS,CAACF,aAAa,CAACtF,KAAK,CAAC;EACzD,IAAMqC,SAAS,GAAG8C,KAAK,CAACI,MAAM,CAACD,aAAa,CAACrD,KAAK,CAAC;EACnD,IAAMwD,KAAK,GAAGN,KAAK,CAACI,MAAM,CAACD,aAAa,CAACG,KAAK,CAAC;EAE/C,IAAMxD,KAAK,GAAGgD,kBAAkB,CAAC;IAC/BjF,KAAK,EAALA,KAAK;IACLY,MAAM,EAANA,MAAM;IACNyB,SAAS,EAATA,SAAS;IACT8C,KAAK,EAALA;EACF,CAAC,CAAC;EAEF,IAAMO,WAAW,GAAGjB,gBAAgB,CAAC;IACnCxC,KAAK,EAAEA,KAAK,aAALA,KAAK,eAALA,KAAK,CAAE0C,MAAM,GAAG1C,KAAK,CAAC,CAAC,CAAC,GAAGA,KAAK;IACvCI,SAAS,EAATA,SAAS;IACTgC,SAAS,EAAEoB,KAAK,CAACpC;EACnB,CAAC,CAAC;EACF,OAAOsC,qBAAqB,CAACD,WAAW,CAAC;AAC3C;;AAEA;AACA;AACA;AACO,SAASE,2BAA2BA,CAAAC,KAAA,EAQhB;EAAA,IAAAC,MAAA;EAAA,IAPzB7D,KAAK,GAAA4D,KAAA,CAAL5D,KAAK;IACLkD,KAAK,GAAAU,KAAA,CAALV,KAAK;IACLY,QAAQ,GAAAF,KAAA,CAARE,QAAQ;EAMR,KAAAD,MAAA,GAAI7D,KAAK,cAAA6D,MAAA,eAALA,MAAA,CAAOnB,MAAM,EAAE;IAAA,IAAAqB,WAAA;IACjB,IAAM/E,CAAC,GAAG,CAAA+E,WAAA,GAAAb,KAAK,CAACc,IAAI,cAAAD,WAAA,eAAVA,WAAA,CAAYE,OAAO,GAAGf,KAAK,CAACc,IAAI,CAACC,OAAO,CAACH,QAAQ,CAAC,GAAGA,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEI,IAAI;IAC7ElE,KAAK,GAAGV,MAAM,CAACC,QAAQ,CAACP,CAAC,CAAC,GAAGgB,KAAK,CAAChB,CAAC,CAAC,GAAG,IAAI;EAC9C;EACA,OAAOgB,KAAK;AACd;;AAEA;AACA;AACA;AACO,SAASmE,sBAAsBA,CACpCC,MAAgB,EAChBzF,MAAwD,EACnD;EACL,IAAM0F,YAAY,GAAG,IAAAxG,iBAAM,EAACc,MAAM,CAAC,CAAClB,IAAI,CAAC,CAAC;EAC1C,IAAM6G,QAAQ,GAAGF,MAAM,CAAC7G,GAAG,CAAC,UAAAgH,KAAK;IAAA,OAAI,CAAC,IAAI,EAAEA,KAAK,CAAC;EAAA,EAAC;EAEnD,IAAIH,MAAM,CAACxH,MAAM,KAAK,CAAC,IAAIyH,YAAY,CAACzH,MAAM,KAAK,CAAC,EAAE;IACpD,OAAO0H,QAAQ;EACjB;EAEA,IAAME,SAAS,GAAGJ,MAAM,CAACxH,MAAM,GAAG,CAAC;EACnC,IAAM6H,WAAW,GAAG5E,IAAI,CAAC6E,GAAG,CAACF,SAAS,EAAEH,YAAY,CAACzH,MAAM,CAAC;;EAE5D;EACA,KAAK,IAAIsB,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGuG,WAAW,EAAEvG,CAAC,EAAE,EAAE;IACpC;IACAoG,QAAQ,CAACpG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAGmG,YAAY,CAACnG,CAAC,CAAC;EAClC;EAEA,IAAImG,YAAY,CAACzH,MAAM,GAAGwH,MAAM,CAACxH,MAAM,EAAE;IACvC;IACA;IACA,IAAM+H,gBAAuB,GAAG,EAAE;IAClC,KAAK,IAAIzG,EAAC,GAAGsG,SAAS,EAAEtG,EAAC,GAAGmG,YAAY,CAACzH,MAAM,EAAEsB,EAAC,EAAE,EAAE;MACpD,IAAM0G,KAAK,GAAGP,YAAY,CAACnG,EAAC,CAAC;MAC7B,IAAIW,KAAK,CAACC,OAAO,CAAC8F,KAAK,CAAC,EAAE;QACxB;QACAD,gBAAgB,CAACnI,IAAI,CAAAC,KAAA,CAArBkI,gBAAgB,MAAAE,mBAAA,aAAUD,KAAK,CAAU,CAAC;MAC5C,CAAC,MAAM;QACLD,gBAAgB,CAACnI,IAAI,CAACoI,KAAK,CAAC;MAC9B;IACF;IACA;IACAN,QAAQ,CAACE,SAAS,CAAC,CAAC,CAAC,CAAC,GAAGG,gBAAgB;EAC3C,CAAC,MAAM,IAAIN,YAAY,CAACzH,MAAM,KAAKwH,MAAM,CAACxH,MAAM,EAAE;IAChD;IACA;IACA0H,QAAQ,CAACE,SAAS,CAAC,CAAC,CAAC,CAAC,GAAGH,YAAY,CAACG,SAAS,CAAC;EAClD;;EAEA;EACA,OAAOF,QAAQ;AACjB;;AAEA;AACA;AACA;AACO,SAASQ,gCAAgCA,CAC9CR,QAA0B,EACE;EAC5B,IAAI,CAACA,QAAQ,EAAE;IACb,OAAO,IAAI;EACb;EACA,IAAMb,WAAW,GAAGa,QAAQ,CAAC/G,GAAG,CAAC,UAAAwH,KAAA,EAAoB;IAAA,IAAAC,KAAA,OAAAzG,eAAA,aAAAwG,KAAA;MAAlBH,KAAK,GAAAI,KAAA;MAAET,KAAK,GAAAS,KAAA;IAC7C,OAAO;MACL7H,IAAI,EAAEoH,KAAK;MACX3D,KAAK,EAAEgE;IACT,CAAC;EACH,CAAC,CAAC;EAEF,OAAOnB,WAAW;AACpB;;AAEA;AACA;AACA;AACO,SAASwB,gCAAgCA,CAACxB,WAAgC,EAAY;EAC3F;EACA,IAAMW,MAAM,GAAG,IAAAc,gBAAI,EAACzB,WAAW,CAAClG,GAAG,CAAC,UAAA4H,EAAE;IAAA,OAAIA,EAAE,CAAChI,IAAI;EAAA,EAAC,CAAC;EACnD,IAAMG,MAAM,GAAG,IAAA4H,gBAAI,EAACzB,WAAW,CAAClG,GAAG,CAAC,UAAA4H,EAAE;IAAA,OAAIA,EAAE,CAACvE,KAAK;EAAA,EAAC,CAAC;EAEpD,OAAOuD,sBAAsB,CAACC,MAAM,EAAE9G,MAAM,CAAC;AAC/C;;AAEA;AACA;AACA;AACO,SAASoG,qBAAqBA,CAACD,WAA+C,EAAY;EAC/F,IAAMa,QAAQ,GAAGb,WAAW,CAAClG,GAAG,CAAC,UAAC6H,UAAU,EAAElH,CAAC,EAAK;IAClD;IACA,OAAO,CACLkH,UAAU,CAAC1E,MAAM,GACbxC,CAAC,KAAKuF,WAAW,CAAC7G,MAAM,GAAG,CAAC,GAC1B,IAAI,CAAC;IAAA,EACLwI,UAAU,CAAC1E,MAAM,CAAC,CAAC,CAAC,GACtB0E,UAAU,CAACxE,KAAK,EACpBwE,UAAU,CAACjI,IAAI,CAChB;EACH,CAAC,CAAC;;EAEF;EACA,OAAOmH,QAAQ;AACjB;;AAEA;AACA;AACA;AACO,SAASe,qBAAqBA,CAACf,QAA0B,EAAuB;EACrF,IAAI,CAACA,QAAQ,EAAE;IACb,OAAO,IAAI;EACb;EACA,IAAMb,WAAW,GAAGa,QAAQ,CAAC/G,GAAG,CAAC,UAAA+H,KAAA,EAAiBpH,CAAC,EAAK;IAAA,IAAAqH,KAAA,OAAAhH,eAAA,aAAA+G,KAAA;MAArBV,KAAK,GAAAW,KAAA;MAAEhB,KAAK,GAAAgB,KAAA;IAC7C,IAAMxH,KAAK,GACTG,CAAC,KAAK,CAAC;IACH;IACA,CAAC,CAACsH,QAAQ,EAAEZ,KAAK,CAAC;IAClB;IACF1G,CAAC,KAAKoG,QAAQ,CAAC1H,MAAM,GAAG,CAAC,GACvB,CAAC0H,QAAQ,CAACpG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAEsH,QAAQ,CAAC;IAC9B;IACA,CAAClB,QAAQ,CAACpG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE0G,KAAK,CAAC;IACjC,OAAO;MACLzH,IAAI,EAAEoH,KAAK;MACXxG,KAAK,EAALA,KAAK;MACL2C,MAAM,EAAE3C,KAAK;MACb6C,KAAK;MACH;MACA1C,CAAC,KAAK,CAAC,gBAAA2C,MAAA,CACU+D,KAAK;MAClB;MACF1G,CAAC,KAAKoG,QAAQ,CAAC1H,MAAM,GAAG,CAAC,MAAAiE,MAAA,CACpByD,QAAQ,CAACpG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,mBAAA2C,MAAA,CAClByD,QAAQ,CAACpG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,UAAA2C,MAAA,CAAO+D,KAAK;IACzC,CAAC;EACH,CAAC,CAAC;;EAEF;EACA,OAAOnB,WAAW;AACpB;;AAEA;AACA;AACA;AACO,SAASgC,oBAAoBA,CAAChC,WAAoB,EAA+B;EACtF,OAAOiC,OAAO,CAAC7G,KAAK,CAACC,OAAO,CAAC2E,WAAW,CAAC,IAAIA,WAAW,CAAC7G,MAAM,IAAI6G,WAAW,CAAC,CAAC,CAAC,CAAC/C,MAAM,CAAC;AAC3F;;AAEA;AACO,SAASiF,kBAAkBA,CAAAC,KAAA,EAU/B;EAAA,IATDC,cAAc,GAAAD,KAAA,CAAdC,cAAc;IACdC,WAAW,GAAAF,KAAA,CAAXE,WAAW;IACXC,OAAO,GAAAH,KAAA,CAAPG,OAAO;IACPC,kBAAkB,GAAAJ,KAAA,CAAlBI,kBAAkB;EAOlB,IAAIC,SAAS,GAAG3G,MAAM,CAAC4G,iBAAiB;EACxC,IAAIC,SAAS,GAAG7G,MAAM,CAAC8G,iBAAiB;EACxC,IAAIC,MAAM,GAAG,CAAC;EACd,IAAIC,SAAS,GAAG,CAAC;EAEjB,IAAIT,cAAc,EAAE;IAClB5J,MAAM,CAACqB,MAAM,CAACuI,cAAc,CAAC,CAAChJ,OAAO,CAAC,UAAA0J,GAAG,EAAI;MAC3C,IAAMxE,GAAG,GAAGwE,GAAG,CAAC3B,KAAK;MACrB,IAAI,IAAArC,mBAAQ,EAACR,GAAG,CAAC,EAAE;QACjB,IAAIA,GAAG,GAAGkE,SAAS,EAAEA,SAAS,GAAGlE,GAAG;QACpC,IAAIA,GAAG,GAAGoE,SAAS,EAAEA,SAAS,GAAGpE,GAAG;QACpCuE,SAAS,IAAIvE,GAAG;QAChBsE,MAAM,IAAI,CAAC;MACb;IACF,CAAC,CAAC;EACJ,CAAC,MAAM;IACL,IAAIP,WAAW,IAAIA,WAAW,CAAC5G,SAAS,IAAI4G,WAAW,CAACU,IAAI,EAAE;MAC5D;MACA,OAAO,CACLV,WAAW,CAAC5G,SAAS,CAAC,CAAC,CAAC,CAAC0F,KAAK,EAC9BkB,WAAW,CAAC5G,SAAS,CAAC4G,WAAW,CAAC5G,SAAS,CAACtC,MAAM,GAAG,CAAC,CAAC,CAACgI,KAAK,EAC7DkB,WAAW,CAACU,IAAI,CACjB;IACH;IACA,IAAIT,OAAO,IAAIC,kBAAkB,EAAE;MACjCD,OAAO,CAACU,UAAU,CAAC5J,OAAO,CAAC,UAAA6J,CAAC,EAAI;QAC9B,IAAM3E,GAAG,GAAGiE,kBAAkB,CAACU,CAAC,CAAC;QACjC,IAAI,IAAAnE,mBAAQ,EAACR,GAAG,CAAC,EAAE;UACjB,IAAIA,GAAG,GAAGkE,SAAS,EAAEA,SAAS,GAAGlE,GAAG;UACpC,IAAIA,GAAG,GAAGoE,SAAS,EAAEA,SAAS,GAAGpE,GAAG;UACpCuE,SAAS,IAAIvE,GAAG;UAChBsE,MAAM,IAAI,CAAC;QACb;MACF,CAAC,CAAC;IACJ;EACF;EACA,IAAMM,aAAa,GAAGN,MAAM,GAAG,CAAC,GAAGC,SAAS,GAAGD,MAAM,GAAG,CAAC;EACzD,OAAO,CAACA,MAAM,GAAG,CAAC,GAAGJ,SAAS,GAAG,CAAC,EAAEI,MAAM,GAAG,CAAC,GAAGF,SAAS,GAAG,CAAC,EAAEQ,aAAa,CAAC;AAChF;AAEO,SAASC,+BAA+BA,CAACtC,QAAkB,EAAEhD,KAAa,EAAO;EACtF,IAAI,CAACgD,QAAQ,EAAE;IACb,OAAOA,QAAQ;EACjB;EACA,IAAMuC,WAAW,GAAGvC,QAAQ,CAAC/G,GAAG,CAAC,UAACuJ,EAAE,EAAE5I,CAAC,EAAK;IAC1C,IAAIA,CAAC,KAAKoD,KAAK,EAAE;MACf,OAAO,CAAC,IAAI,EAAEwF,EAAE,CAAC,CAAC,CAAC,CAAC;IACtB;IACA,OAAOA,EAAE;EACX,CAAC,CAAC;EACF,OAAOD,WAAW;AACpB;;AAEA;AACA;AACA;AACO,SAASE,oCAAoCA,CAClDzC,QAAyB,EACzBhD,KAAa,EACb+C,YAAkC,EACL;EAC7B,IAAI,CAACC,QAAQ,IAAI,CAACD,YAAY,EAAE;IAC9B,OAAOC,QAAQ;EACjB;;EAEA;EACA,IAAM0C,aAAa,GAAG/K,MAAM,CAACgL,WAAW,CAAC5C,YAAY,CAAC9G,GAAG,CAAC,UAAAwE,GAAG;IAAA,OAAI,CAACA,GAAG,EAAE,KAAK,CAAC;EAAA,EAAC,CAAC;EAC/EuC,QAAQ,CAACzH,OAAO,CAAC,UAAAiK,EAAE,EAAI;IACrB,IAAAI,oBAAO,EAACJ,EAAE,CAAC,CAAC,CAAC,CAAC,CAACjK,OAAO,CAAC,UAAAsK,CAAC,EAAI;MAC1B,IAAIA,CAAC,EAAEH,aAAa,CAACG,CAAC,CAAC,GAAG,IAAI;IAChC,CAAC,CAAC;EACJ,CAAC,CAAC;EACF,IAAMC,IAAI,GAAGnL,MAAM,CAACC,IAAI,CAAC8K,aAAa,CAAC,CAAC3K,MAAM,CAAC,UAAA8K,CAAC;IAAA,OAAI,CAACH,aAAa,CAACG,CAAC,CAAC;EAAA,EAAC;;EAEtE;EACA,IAAMN,WAAW,GAAGvC,QAAQ,CAAC/G,GAAG,CAAC,UAACuJ,EAAE,EAAE5I,CAAC,EAAK;IAC1C,IAAIA,CAAC,KAAKoD,KAAK,EAAE;MACf,OAAO,IAAAT,MAAA,KAAAgE,mBAAA,aAAKuC,IAAI,OAAAvC,mBAAA,aAAK,IAAAqC,oBAAO,EAACJ,EAAE,CAAC,CAAC,CAAC,CAAC,IAAGA,EAAE,CAAC,CAAC,CAAC,CAAC;IAC9C;IACA,OAAOA,EAAE;EACX,CAAC,CAAa;EAEd,OAAOD,WAAW;AACpB;;AAEA;AACA;AACA;AACO,SAASQ,kCAAkCA,CAChD/C,QAAqC,EACrCgD,IAAqB,EACrBhG,KAAa,EACgB;EAC7B,IAAI,CAACgD,QAAQ,EAAE;IACb,OAAOA,QAAQ;EACjB;EACA,IAAMuC,WAAW,GAAGvC,QAAQ,CAAC/G,GAAG,CAAC,UAACuJ,EAAE,EAAE5I,CAAC,EAAK;IAC1C,IAAIA,CAAC,KAAKoD,KAAK,EAAE;MACf,IAAI,CAACwF,EAAE,CAAC,CAAC,CAAC,EAAE;QACV,OAAO,CAAC,IAAI,EAAEA,EAAE,CAAC,CAAC,CAAC,CAAC;MACtB;MACA,IAAMS,mBAAmB,GAAG,IAAAL,oBAAO,EAACJ,EAAE,CAAC,CAAC,CAAC,CAAC;MAC1C,IAAMU,mBAAmB,GAAGD,mBAAmB,CAAClL,MAAM,CAAC,UAAA8K,CAAC;QAAA,OAAIA,CAAC,KAAKG,IAAI;MAAA,EAAC;MACvE,OAAO,CAACE,mBAAmB,EAAEV,EAAE,CAAC,CAAC,CAAC,CAAC;IACrC;IACA,OAAOA,EAAE;EACX,CAAC,CAAa;EAEd,OAAOD,WAAW;AACpB;;AAEA;AACA;AACA;AACO,SAASY,8BAA8BA,CAC5CnD,QAAkB,EAClBoD,KAA0B,EAC1BpG,KAAa,EACH;EACV,IAAI,CAACgD,QAAQ,EAAE;IACb,OAAOA,QAAQ;EACjB;EAEA,IAAMuC,WAAW,GAAGvC,QAAQ,CAAC/G,GAAG,CAAC,UAACuJ,EAAE,EAAE5I,CAAC,EAAK;IAC1C,IAAIA,CAAC,KAAKoD,KAAK,EAAE;MACf,IAAI,CAACwF,EAAE,CAAC,CAAC,CAAC,EAAE;QACV,OAAO,CAACY,KAAK,EAAEZ,EAAE,CAAC,CAAC,CAAC,CAAC;MACvB;MACA,IAAMS,oBAAmB,GAAG,IAAAL,oBAAO,EAACJ,EAAE,CAAC,CAAC,CAAC,CAAC;MAC1C,IAAMU,mBAAmB,GAAG,IAAAtC,gBAAI,EAACqC,oBAAmB,CAAC1G,MAAM,CAAC6G,KAAK,CAAC,CAAC;MACnE,OAAO,CAACF,mBAAmB,EAAEV,EAAE,CAAC,CAAC,CAAC,CAAC;IACrC;IACA;IACA,IAAMS,mBAAmB,GAAGT,EAAE,CAAC,CAAC,CAAC;IACjC,IAAIjI,KAAK,CAACC,OAAO,CAACyI,mBAAmB,CAAC,EAAE;MACtC,IAAMC,oBAAwC,GAAID,mBAAmB,CAAWlL,MAAM,CACpF,UAAA8K,CAAC;QAAA,OAAI,CAACO,KAAK,CAACC,QAAQ,CAACR,CAAC,CAAC;MAAA,CACzB,CAAC;MACD,OAAO,CAACK,oBAAmB,EAAEV,EAAE,CAAC,CAAC,CAAC,CAAC;IACrC,CAAC,MAAM,IAAIS,mBAAmB,IAAIG,KAAK,CAACC,QAAQ,CAACJ,mBAAmB,CAAC,EAAE;MACrE,OAAO,CAAC,IAAI,EAAET,EAAE,CAAC,CAAC,CAAC,CAAC;IACtB;IAEA,OAAOA,EAAE;EACX,CAAC,CAAa;EAEd,OAAOD,WAAW;AACpB;;AAEA;AACA;AACA;AACO,SAASe,wBAAwBA,CACtCC,WAAgC,EAChCC,UAAsB,EAEoC;EAAA,IAD1DC,MAAM,GAAApL,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAwB,SAAA,GAAAxB,SAAA,MAAG,IAAI;EAEb,IAAMqL,IAAI,GAAGF,UAAU,CAACxD,QAAQ,GAC5BwD,UAAU,CAACxD,QAAQ,GACnBH,sBAAsB,CAAC2D,UAAU,CAAC1D,MAAM,EAAEyD,WAAW,CAAC;EAE1D,IAAM9J,KAAiB,GAAG,EAAE;EAC5B,IAAMY,MAAgB,GAAG,EAAE;EAC3BqJ,IAAI,CAACnL,OAAO,CAAC,UAAAiK,EAAE,EAAI;IACjB,IAAIjI,KAAK,CAACC,OAAO,CAACgI,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE;MACxBA,EAAE,CAAC,CAAC,CAAC,CAACjK,OAAO,CAAC,UAAAkF,GAAG,EAAI;QACnBpD,MAAM,CAACnC,IAAI,CAACuF,GAAG,CAAC;QAChBhE,KAAK,CAACvB,IAAI,CAACuL,MAAM,GAAG,IAAAE,oBAAQ,EAACnB,EAAE,CAAC,CAAC,CAAC,CAAC,GAAGA,EAAE,CAAC,CAAC,CAAC,CAAC;MAC9C,CAAC,CAAC;IACJ,CAAC,MAAM;MACLnI,MAAM,CAACnC,IAAI,CAACsK,EAAE,CAAC,CAAC,CAAC,CAAC;MAClB/I,KAAK,CAACvB,IAAI,CAACuL,MAAM,GAAG,IAAAE,oBAAQ,EAACnB,EAAE,CAAC,CAAC,CAAC,CAAC,GAAGA,EAAE,CAAC,CAAC,CAAC,CAAC;IAC9C;EACF,CAAC,CAAC;EAEF,IAAM9G,KAAK,GAAGD,gBAAgB,CAAC4C,sBAAW,CAACE,aAAa,EAAE9E,KAAK,EAAEY,MAAM,EAAE,KAAK,CAAC;EAC/EqB,KAAK,CAACkI,OAAO,CAACC,yBAAc,CAAC;EAC7B,OAAOnI,KAAK;AACd;;AAEA;AACA;AACA;AACO,SAASoI,8BAA8BA,CAAAC,KAAA,EAYjB;EAAA,IAX3BrI,KAAK,GAAAqI,KAAA,CAALrI,KAAK;IACLwD,KAAK,GAAA6E,KAAA,CAAL7E,KAAK;IACL8E,aAAa,GAAAD,KAAA,CAAbC,aAAa;IACbvK,KAAK,GAAAsK,KAAA,CAALtK,KAAK;IACL0F,WAAW,GAAA4E,KAAA,CAAX5E,WAAW;EAQX,IAAM8E,iBAAiB,0BAAA1H,MAAA,CAA0Bb,KAAK,OAAAa,MAAA,CAAI,CAAA2C,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEgF,IAAI,KAAI,aAAa,CAAE;EACxF;EACA,IAAMC,aAAa,GAAG1K,KAAK,CAACuG,QAAQ,IAAIvG,KAAK,CAACyK,IAAI,KAAKD,iBAAiB,IAAIxK,KAAK,CAACqD,IAAI,KAAKpB,KAAK;EAChG,IAAMsE,QAAQ,GAAGmE,aAAa,GAC1B1K,KAAK,CAACuG,QAAQ,GACdtE,KAAK,KAAK2C,sBAAW,CAACE,aAAa,IAAIyF,aAAa,GACpDnE,sBAAsB,CAACpG,KAAK,CAACqG,MAAM,EAAEkE,aAAa,CAAC,GACnD7E,WAAW,IAAIgC,oBAAoB,CAAChC,WAAW,CAAC,GAChDC,qBAAqB,CAACD,WAAW,CAAC,GAClC,IAAI;EACR,IAAMW,MAAM,GAAGqE,aAAa,GAAG1K,KAAK,CAACqG,MAAM,GAAGE,QAAQ,GAAGA,QAAQ,CAAC/G,GAAG,CAAC,UAAAuJ,EAAE;IAAA,OAAIA,EAAE,CAAC,CAAC,CAAC;EAAA,EAAC,GAAG/I,KAAK,CAACqG,MAAM;;EAEjG;EACA,IAAMsE,aAAuC,GAAG;IAC9CC,QAAQ,EAAE,QAAQ;IAClBH,IAAI,EAAED,iBAAiB;IACvBnH,IAAI,EAAEpB,KAAK;IACXsE,QAAQ,EAARA,QAAQ;IACRF,MAAM,EAAEA,MAAM,IAAI;EACpB,CAAC;EAED,OAAOsE,aAAa;AACtB","ignoreList":[]}
|
package/dist/data-utils.d.ts
CHANGED
|
@@ -33,6 +33,7 @@ export declare function validateLongitude(longitude: number | undefined): number
|
|
|
33
33
|
export declare function validateCoordinate(value: number, minValue: number, maxValue: number): number;
|
|
34
34
|
/**
|
|
35
35
|
* simple getting unique values of an array
|
|
36
|
+
* Note: filters out null and undefined values
|
|
36
37
|
*
|
|
37
38
|
* @param values
|
|
38
39
|
* @returns unique values
|
package/dist/data-utils.js
CHANGED
|
@@ -103,6 +103,7 @@ function validateCoordinate(value, minValue, maxValue) {
|
|
|
103
103
|
|
|
104
104
|
/**
|
|
105
105
|
* simple getting unique values of an array
|
|
106
|
+
* Note: filters out null and undefined values
|
|
106
107
|
*
|
|
107
108
|
* @param values
|
|
108
109
|
* @returns unique values
|
|
@@ -531,4 +532,4 @@ function datetimeFormatter(timezone) {
|
|
|
531
532
|
};
|
|
532
533
|
};
|
|
533
534
|
}
|
|
534
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["arrow","_interopRequireWildcard","require","_assert","_interopRequireDefault","_d3Format","_momentTimezone","_arrow","_constants","_commonUtils","_plot","_utils","_FIELD_DISPLAY_FORMAT","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof3","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","MAX_LATITUDE","exports","MIN_LATITUDE","MAX_LONGITUDE","MIN_LONGITUDE","validateLatitude","latitude","validateCoordinate","validateLongitude","longitude","value","minValue","maxValue","unique","values","results","uniqueSet","Set","forEach","v","notNullorUndefined","push","getLatLngBounds","points","idx","limit","lats","map","d","Number","Array","isArray","filter","isFinite","sort","numberSort","length","Math","max","min","clamp","_ref","_ref2","_slicedToArray2","val","arguments","undefined","getSampleData","data","sampleSize","getValue","sampleStep","floor","output","timeToUnixMilli","format","moment","utc","valueOf","Date","isNumber","obj","prop","prototype","b","getSortingFunction","fieldType","ALL_FIELD_TYPES","real","integer","timestamp","preciseRound","num","decimals","pow","round","sign","toFixed","roundToFour","concat","getRoundingDecimalFromStep","step","isNaN","assert","stepStr","toString","splitExponential","split","coeffZero","coeffDecimal","parseInt","splitZero","normalizeSliderValue","marks","snapToMarks","roundValToStep","decimal","steps","remain","closest","rounded","defaultFormatter","String","floatFormatter","uint8ArrayToHex","from","byte","padStart","join","FIELD_DISPLAY_FORMAT","_defineProperty2","string","date","geojson","isPlainObject","JSON","stringify","geoarrow","field","Vector","_field$metadata","encoding","metadata","geometry","parseGeometryFromArrow","error","Uint8Array","object","array","h3","parseFieldValue","type","getFormatter","tooltipFormat","TOOLTIP_FORMATS","find","f","TOOLTIP_KEY","applyDefaultFormat","applyCustomFormat","getColumnFormatter","displayFormat","_typeof2","applyValueMap","TOOLTIP_FORMAT_TYPES","DECIMAL","d3Format","DATE","DATE_TIME","datetimeFormatter","PERCENTAGE","DECIMAL_DECIMAL_FIXED_2","BOOLEAN","getBooleanFormatter","formatLargeNumber","formatNumber","transformation","Y","Z","E","P","T","G","M","k","h","da","c","m","μ","p","z","y","reverseFormatNumber","str","returnValue","strNum","trim","replace","entries","includes","parseFloat","timezone","ts","tz"],"sources":["../src/data-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport * as arrow from 'apache-arrow';\nimport assert from 'assert';\nimport {format as d3Format} from 'd3-format';\nimport moment from 'moment-timezone';\n\nimport {parseGeometryFromArrow} from '@loaders.gl/arrow';\n\nimport {\n  ALL_FIELD_TYPES,\n  TOOLTIP_FORMATS,\n  TOOLTIP_FORMAT_TYPES,\n  TOOLTIP_KEY,\n  TooltipFormat\n} from '@kepler.gl/constants';\nimport {notNullorUndefined} from '@kepler.gl/common-utils';\nimport {Field, Millisecond, ProtoDatasetField} from '@kepler.gl/types';\n\nimport {snapToMarks} from './plot';\nimport {isPlainObject} from './utils';\n\nexport type FieldFormatter = (value: any, field?: ProtoDatasetField) => string;\n\n// We need threat latitude differently otherwise mercator project view throws\n// a projection matrix error\n// Uncaught Error: Pixel project matrix not invertible\n// at WebMercatorViewport16.Viewport6 (viewport.js:81:13)\nexport const MAX_LATITUDE = 89.9;\nexport const MIN_LATITUDE = -89.9;\nexport const MAX_LONGITUDE = 180;\nexport const MIN_LONGITUDE = -180;\n\n/**\n * Validates a latitude value.\n * Ensures that the latitude is within the defined minimum and maximum latitude bounds.\n * If the value is out of bounds, it returns the nearest bound value.\n * @param latitude - The latitude value to validate.\n * @returns The validated latitude value.\n */\nexport function validateLatitude(latitude: number | undefined): number {\n  return validateCoordinate(latitude ?? 0, MIN_LATITUDE, MAX_LATITUDE);\n}\n\n/**\n * Validates a longitude value.\n * Ensures that the longitude is within the defined minimum and maximum longitude bounds.\n * If the value is out of bounds, it returns the nearest bound value.\n * @param longitude - The longitude value to validate.\n * @returns The validated longitude value.\n */\nexport function validateLongitude(longitude: number | undefined): number {\n  return validateCoordinate(longitude ?? 0, MIN_LONGITUDE, MAX_LONGITUDE);\n}\n\n/**\n * Validates a coordinate value.\n * Ensures that the value is within the specified minimum and maximum bounds.\n * If the value is out of bounds, it returns the nearest bound value.\n * @param value - The coordinate value to validate.\n * @param minValue - The minimum bound for the value.\n * @param maxValue - The maximum bound for the value.\n * @returns The validated coordinate value.\n */\nexport function validateCoordinate(value: number, minValue: number, maxValue: number): number {\n  if (value <= minValue) {\n    return minValue;\n  }\n  if (value >= maxValue) {\n    return maxValue;\n  }\n\n  return value;\n}\n\n/**\n * simple getting unique values of an array\n *\n * @param values\n * @returns unique values\n */\nexport function unique<T>(values: T[]) {\n  const results: T[] = [];\n  const uniqueSet = new Set(values);\n  uniqueSet.forEach(v => {\n    if (notNullorUndefined(v)) {\n      results.push(v);\n    }\n  });\n  return results;\n}\n\nexport function getLatLngBounds(\n  points: number[][],\n  idx: number,\n  limit: [number, number]\n): [number, number] | null {\n  const lats = points\n    .map(d => Number(Array.isArray(d)) && d[idx])\n    .filter(Number.isFinite)\n    .sort(numberSort);\n\n  if (!lats.length) {\n    return null;\n  }\n\n  // clamp to limit\n  return [Math.max(lats[0], limit[0]), Math.min(lats[lats.length - 1], limit[1])];\n}\n\nexport function clamp([min, max]: [number, number], val = 0): number {\n  return val <= min ? min : val >= max ? max : val;\n}\n\nexport function getSampleData(data, sampleSize = 500, getValue = d => d) {\n  const sampleStep = Math.max(Math.floor(data.length / sampleSize), 1);\n  const output: any[] = [];\n  for (let i = 0; i < data.length; i += sampleStep) {\n    output.push(getValue(data[i]));\n  }\n\n  return output;\n}\n\n/**\n * Convert different time format to unix milliseconds\n */\nexport function timeToUnixMilli(value: string | number | Date, format: string): Millisecond | null {\n  if (notNullorUndefined(value)) {\n    if (typeof value === 'string') {\n      return moment.utc(value, format).valueOf();\n    }\n    if (typeof value === 'number') {\n      return format === 'x' ? value * 1000 : value;\n    }\n    if (value instanceof Date) {\n      return value.valueOf();\n    }\n  }\n  return null;\n}\n\n/**\n * Whether d is a number, this filtered out NaN as well\n */\nexport function isNumber(d: unknown): d is number {\n  return Number.isFinite(d);\n}\n\n/**\n * whether object has property\n * @param {string} prop\n * @returns {boolean} - yes or no\n */\nexport function hasOwnProperty<X extends object, Y extends PropertyKey>(\n  obj: X,\n  prop: Y\n): obj is X & Record<Y, unknown> {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nexport function numberSort(a: number, b: number): number {\n  return a - b;\n}\n\nexport function getSortingFunction(fieldType: string): typeof numberSort | undefined {\n  switch (fieldType) {\n    case ALL_FIELD_TYPES.real:\n    case ALL_FIELD_TYPES.integer:\n    case ALL_FIELD_TYPES.timestamp:\n      return numberSort;\n    default:\n      return undefined;\n  }\n}\n\n/**\n * round number with exact number of decimals\n * return as a string\n */\nexport function preciseRound(num: number, decimals: number): string {\n  const t = Math.pow(10, decimals);\n  return (\n    Math.round(\n      num * t + (decimals > 0 ? 1 : 0) * (Math.sign(num) * (10 / Math.pow(100, decimals)))\n    ) / t\n  ).toFixed(decimals);\n}\n\n/**\n * round a giving number at most 4 decimal places\n * e.g. 10 -> 10, 1.12345 -> 1.2345, 2.0 -> 2\n */\nexport function roundToFour(num: number): number {\n  // @ts-expect-error\n  return Number(`${Math.round(`${num}e+4`)}e-4`);\n}\n/**\n * get number of decimals to round to for slider from step\n * @param step\n * @returns- number of decimal\n */\nexport function getRoundingDecimalFromStep(step: number): number {\n  if (isNaN(step)) {\n    assert('step is not a number');\n    assert(step);\n  }\n\n  const stepStr = step.toString();\n\n  // in case the step is a very small number e.g. 1e-7, return decimal e.g. 7 directly\n  const splitExponential = stepStr.split('e-');\n  if (splitExponential.length === 2) {\n    const coeffZero = splitExponential[0].split('.');\n    const coeffDecimal = coeffZero.length === 1 ? 0 : coeffZero[1].length;\n    return parseInt(splitExponential[1], 10) + coeffDecimal;\n  }\n\n  const splitZero = stepStr.split('.');\n  if (splitZero.length === 1) {\n    return 0;\n  }\n  return splitZero[1].length;\n}\n\n/**\n * If marks is provided, snap to marks, if not normalize to step\n * @param val\n * @param minValue\n * @param step\n * @param marks\n */\nexport function normalizeSliderValue(\n  val: number,\n  minValue: number | undefined,\n  step: number,\n  marks?: number[] | null\n): number {\n  if (marks && marks.length) {\n    // Use in slider, given a number and an array of numbers, return the nears number from the array\n    return snapToMarks(val, marks);\n  }\n\n  return roundValToStep(minValue, step, val);\n}\n\n/**\n * round the value to step for the slider\n * @param minValue\n * @param step\n * @param val\n * @returns - rounded number\n */\nexport function roundValToStep(minValue: number | undefined, step: number, val: number): number {\n  if (!isNumber(step) || !isNumber(minValue)) {\n    return val;\n  }\n\n  const decimal = getRoundingDecimalFromStep(step);\n  const steps = Math.floor((val - minValue) / step);\n  let remain = val - (steps * step + minValue);\n\n  // has to round because javascript turns 0.1 into 0.9999999999999987\n  remain = Number(preciseRound(remain, 8));\n\n  let closest: number;\n  if (remain === 0) {\n    closest = val;\n  } else if (remain < step / 2) {\n    closest = steps * step + minValue;\n  } else {\n    closest = (steps + 1) * step + minValue;\n  }\n\n  // precise round return a string rounded to the defined decimal\n  const rounded = preciseRound(closest, decimal);\n\n  return Number(rounded);\n}\n\n/**\n * Get the value format based on field and format options\n * Used in render tooltip value\n */\nexport const defaultFormatter: FieldFormatter = v => (notNullorUndefined(v) ? String(v) : '');\n\nexport const floatFormatter = v => (isNumber(v) ? String(roundToFour(v)) : '');\n\n/**\n * Transforms a WKB in Uint8Array form into a hex WKB string.\n * @param uint8Array WKB in Uint8Array form.\n * @returns hex WKB string.\n */\nexport function uint8ArrayToHex(data: Uint8Array): string {\n  return Array.from(data)\n    .map(byte => (byte as any).toString(16).padStart(2, '0'))\n    .join('');\n}\n\nexport const FIELD_DISPLAY_FORMAT: {\n  [key: string]: FieldFormatter;\n} = {\n  [ALL_FIELD_TYPES.string]: defaultFormatter,\n  [ALL_FIELD_TYPES.timestamp]: defaultFormatter,\n  [ALL_FIELD_TYPES.integer]: defaultFormatter,\n  [ALL_FIELD_TYPES.real]: defaultFormatter,\n  [ALL_FIELD_TYPES.boolean]: defaultFormatter,\n  [ALL_FIELD_TYPES.date]: defaultFormatter,\n  [ALL_FIELD_TYPES.geojson]: d =>\n    typeof d === 'string'\n      ? d\n      : isPlainObject(d)\n      ? JSON.stringify(d)\n      : Array.isArray(d)\n      ? `[${String(d)}]`\n      : '',\n  [ALL_FIELD_TYPES.geoarrow]: (data, field) => {\n    if (data instanceof arrow.Vector) {\n      try {\n        const encoding = field?.metadata?.get('ARROW:extension:name');\n        if (encoding) {\n          const geometry = parseGeometryFromArrow(data, encoding);\n          return JSON.stringify(geometry);\n        }\n      } catch (error) {\n        // ignore for now\n      }\n    } else if (data instanceof Uint8Array) {\n      return uint8ArrayToHex(data);\n    }\n    return data;\n  },\n  [ALL_FIELD_TYPES.object]: (value: any) => {\n    try {\n      return JSON.stringify(value);\n    } catch (e) {\n      return String(value);\n    }\n  },\n  [ALL_FIELD_TYPES.array]: d => JSON.stringify(d),\n  [ALL_FIELD_TYPES.h3]: defaultFormatter\n};\n\n/**\n * Parse field value and type and return a string representation\n */\nexport const parseFieldValue = (value: any, type: string, field?: Field): string => {\n  if (!notNullorUndefined(value)) {\n    return '';\n  }\n  // BigInt values cannot be serialized with JSON.stringify() directly\n  // We need to explicitly convert them to strings using .toString()\n  // See: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigInt#use_within_json\n  if (typeof value === 'bigint') {\n    return value.toString();\n  }\n  return FIELD_DISPLAY_FORMAT[type] ? FIELD_DISPLAY_FORMAT[type](value, field) : String(value);\n};\n\n/**\n * Get the value format based on field and format options\n * Used in render tooltip value\n * @param format\n * @param field\n */\nexport function getFormatter(\n  format?: string | Record<string, string> | null,\n  field?: Field\n): FieldFormatter {\n  if (!format) {\n    return defaultFormatter;\n  }\n  const tooltipFormat = Object.values(TOOLTIP_FORMATS).find(f => f[TOOLTIP_KEY] === format);\n\n  if (tooltipFormat) {\n    return applyDefaultFormat(tooltipFormat as TooltipFormat);\n  } else if (typeof format === 'string' && field) {\n    return applyCustomFormat(format, field);\n  }\n\n  return defaultFormatter;\n}\n\nexport function getColumnFormatter(\n  field: Pick<Field, 'type'> & Partial<Pick<Field, 'format' | 'displayFormat'>>\n): FieldFormatter {\n  const {format, displayFormat} = field;\n\n  if (!format && !displayFormat) {\n    return FIELD_DISPLAY_FORMAT[field.type];\n  }\n  const tooltipFormat = Object.values(TOOLTIP_FORMATS).find(f => f[TOOLTIP_KEY] === displayFormat);\n\n  if (tooltipFormat) {\n    return applyDefaultFormat(tooltipFormat);\n  } else if (typeof displayFormat === 'string' && field) {\n    return applyCustomFormat(displayFormat, field);\n  } else if (typeof displayFormat === 'object') {\n    return applyValueMap(displayFormat);\n  }\n\n  return defaultFormatter;\n}\n\nexport function applyValueMap(format) {\n  return v => format[v];\n}\n\nexport function applyDefaultFormat(tooltipFormat: TooltipFormat): (v: any) => string {\n  if (!tooltipFormat || !tooltipFormat.format) {\n    return defaultFormatter;\n  }\n\n  switch (tooltipFormat.type) {\n    case TOOLTIP_FORMAT_TYPES.DECIMAL:\n      return d3Format(tooltipFormat.format);\n    case TOOLTIP_FORMAT_TYPES.DATE:\n    case TOOLTIP_FORMAT_TYPES.DATE_TIME:\n      return datetimeFormatter(null)(tooltipFormat.format);\n    case TOOLTIP_FORMAT_TYPES.PERCENTAGE:\n      return v => `${d3Format(TOOLTIP_FORMATS.DECIMAL_DECIMAL_FIXED_2.format)(v)}%`;\n    case TOOLTIP_FORMAT_TYPES.BOOLEAN:\n      return getBooleanFormatter(tooltipFormat.format);\n    default:\n      return defaultFormatter;\n  }\n}\n\nexport function getBooleanFormatter(format: string): FieldFormatter {\n  switch (format) {\n    case '01':\n      return (v: boolean) => (v ? '1' : '0');\n    case 'yn':\n      return (v: boolean) => (v ? 'yes' : 'no');\n    default:\n      return defaultFormatter;\n  }\n}\n// Allow user to specify custom tooltip format via config\nexport function applyCustomFormat(format, field: {type?: string}): FieldFormatter {\n  switch (field.type) {\n    case ALL_FIELD_TYPES.real:\n    case ALL_FIELD_TYPES.integer:\n      return d3Format(format);\n    case ALL_FIELD_TYPES.date:\n    case ALL_FIELD_TYPES.timestamp:\n      return datetimeFormatter(null)(format);\n    default:\n      return v => v;\n  }\n}\n\nfunction formatLargeNumber(n) {\n  // SI-prefix with 4 significant digits\n  return d3Format('.4~s')(n);\n}\n\nexport function formatNumber(n: number, type?: string): string {\n  switch (type) {\n    case ALL_FIELD_TYPES.integer:\n      if (n < 0) {\n        return `-${formatNumber(-n, 'integer')}`;\n      }\n      if (n < 1000) {\n        return `${Math.round(n)}`;\n      }\n      if (n < 10 * 1000) {\n        return d3Format(',')(Math.round(n));\n      }\n      return formatLargeNumber(n);\n    case ALL_FIELD_TYPES.real:\n      if (n < 0) {\n        return `-${formatNumber(-n, 'number')}`;\n      }\n      if (n < 1000) {\n        return d3Format('.4~r')(n);\n      }\n      if (n < 10 * 1000) {\n        return d3Format(',.2~f')(n);\n      }\n      return formatLargeNumber(n);\n\n    default:\n      return formatNumber(n, 'real');\n  }\n}\n\nconst transformation = {\n  Y: Math.pow(10, 24),\n  Z: Math.pow(10, 21),\n  E: Math.pow(10, 18),\n  P: Math.pow(10, 15),\n  T: Math.pow(10, 12),\n  G: Math.pow(10, 9),\n  M: Math.pow(10, 6),\n  k: Math.pow(10, 3),\n  h: Math.pow(10, 2),\n  da: Math.pow(10, 1),\n  d: Math.pow(10, -1),\n  c: Math.pow(10, -2),\n  m: Math.pow(10, -3),\n  μ: Math.pow(10, -6),\n  n: Math.pow(10, -9),\n  p: Math.pow(10, -12),\n  f: Math.pow(10, -15),\n  a: Math.pow(10, -18),\n  z: Math.pow(10, -21),\n  y: Math.pow(10, -24)\n};\n\n/**\n * Convert a formatted number from string back to number\n */\nexport function reverseFormatNumber(str: string): number {\n  let returnValue: number | null = null;\n  const strNum = str.trim().replace(/,/g, '');\n  Object.entries(transformation).forEach(d => {\n    if (strNum.includes(d[0])) {\n      returnValue = parseFloat(strNum) * d[1];\n      return true;\n    }\n    return false;\n  });\n\n  // if no transformer found, convert to nuber regardless\n  return returnValue === null ? Number(strNum) : returnValue;\n}\n\n/**\n * Format epoch milliseconds with a format string\n * @type timezone\n */\nexport function datetimeFormatter(\n  timezone?: string | null\n): (format?: string) => (ts: number) => string {\n  return timezone\n    ? format => ts => moment.utc(ts).tz(timezone).format(format)\n    : // return empty string instead of 'Invalid date' if ts is undefined/null\n      format => ts => ts ? moment.utc(ts).format(format) : '';\n}\n"],"mappings":"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","ignoreList":[]}
|
|
535
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["arrow","_interopRequireWildcard","require","_assert","_interopRequireDefault","_d3Format","_momentTimezone","_arrow","_constants","_commonUtils","_plot","_utils","_FIELD_DISPLAY_FORMAT","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof3","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","MAX_LATITUDE","exports","MIN_LATITUDE","MAX_LONGITUDE","MIN_LONGITUDE","validateLatitude","latitude","validateCoordinate","validateLongitude","longitude","value","minValue","maxValue","unique","values","results","uniqueSet","Set","forEach","v","notNullorUndefined","push","getLatLngBounds","points","idx","limit","lats","map","d","Number","Array","isArray","filter","isFinite","sort","numberSort","length","Math","max","min","clamp","_ref","_ref2","_slicedToArray2","val","arguments","undefined","getSampleData","data","sampleSize","getValue","sampleStep","floor","output","timeToUnixMilli","format","moment","utc","valueOf","Date","isNumber","obj","prop","prototype","b","getSortingFunction","fieldType","ALL_FIELD_TYPES","real","integer","timestamp","preciseRound","num","decimals","pow","round","sign","toFixed","roundToFour","concat","getRoundingDecimalFromStep","step","isNaN","assert","stepStr","toString","splitExponential","split","coeffZero","coeffDecimal","parseInt","splitZero","normalizeSliderValue","marks","snapToMarks","roundValToStep","decimal","steps","remain","closest","rounded","defaultFormatter","String","floatFormatter","uint8ArrayToHex","from","byte","padStart","join","FIELD_DISPLAY_FORMAT","_defineProperty2","string","date","geojson","isPlainObject","JSON","stringify","geoarrow","field","Vector","_field$metadata","encoding","metadata","geometry","parseGeometryFromArrow","error","Uint8Array","object","array","h3","parseFieldValue","type","getFormatter","tooltipFormat","TOOLTIP_FORMATS","find","f","TOOLTIP_KEY","applyDefaultFormat","applyCustomFormat","getColumnFormatter","displayFormat","_typeof2","applyValueMap","TOOLTIP_FORMAT_TYPES","DECIMAL","d3Format","DATE","DATE_TIME","datetimeFormatter","PERCENTAGE","DECIMAL_DECIMAL_FIXED_2","BOOLEAN","getBooleanFormatter","formatLargeNumber","formatNumber","transformation","Y","Z","E","P","T","G","M","k","h","da","c","m","μ","p","z","y","reverseFormatNumber","str","returnValue","strNum","trim","replace","entries","includes","parseFloat","timezone","ts","tz"],"sources":["../src/data-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport * as arrow from 'apache-arrow';\nimport assert from 'assert';\nimport {format as d3Format} from 'd3-format';\nimport moment from 'moment-timezone';\n\nimport {parseGeometryFromArrow} from '@loaders.gl/arrow';\n\nimport {\n  ALL_FIELD_TYPES,\n  TOOLTIP_FORMATS,\n  TOOLTIP_FORMAT_TYPES,\n  TOOLTIP_KEY,\n  TooltipFormat\n} from '@kepler.gl/constants';\nimport {notNullorUndefined} from '@kepler.gl/common-utils';\nimport {Field, Millisecond, ProtoDatasetField} from '@kepler.gl/types';\n\nimport {snapToMarks} from './plot';\nimport {isPlainObject} from './utils';\n\nexport type FieldFormatter = (value: any, field?: ProtoDatasetField) => string;\n\n// We need threat latitude differently otherwise mercator project view throws\n// a projection matrix error\n// Uncaught Error: Pixel project matrix not invertible\n// at WebMercatorViewport16.Viewport6 (viewport.js:81:13)\nexport const MAX_LATITUDE = 89.9;\nexport const MIN_LATITUDE = -89.9;\nexport const MAX_LONGITUDE = 180;\nexport const MIN_LONGITUDE = -180;\n\n/**\n * Validates a latitude value.\n * Ensures that the latitude is within the defined minimum and maximum latitude bounds.\n * If the value is out of bounds, it returns the nearest bound value.\n * @param latitude - The latitude value to validate.\n * @returns The validated latitude value.\n */\nexport function validateLatitude(latitude: number | undefined): number {\n  return validateCoordinate(latitude ?? 0, MIN_LATITUDE, MAX_LATITUDE);\n}\n\n/**\n * Validates a longitude value.\n * Ensures that the longitude is within the defined minimum and maximum longitude bounds.\n * If the value is out of bounds, it returns the nearest bound value.\n * @param longitude - The longitude value to validate.\n * @returns The validated longitude value.\n */\nexport function validateLongitude(longitude: number | undefined): number {\n  return validateCoordinate(longitude ?? 0, MIN_LONGITUDE, MAX_LONGITUDE);\n}\n\n/**\n * Validates a coordinate value.\n * Ensures that the value is within the specified minimum and maximum bounds.\n * If the value is out of bounds, it returns the nearest bound value.\n * @param value - The coordinate value to validate.\n * @param minValue - The minimum bound for the value.\n * @param maxValue - The maximum bound for the value.\n * @returns The validated coordinate value.\n */\nexport function validateCoordinate(value: number, minValue: number, maxValue: number): number {\n  if (value <= minValue) {\n    return minValue;\n  }\n  if (value >= maxValue) {\n    return maxValue;\n  }\n\n  return value;\n}\n\n/**\n * simple getting unique values of an array\n * Note: filters out null and undefined values\n *\n * @param values\n * @returns unique values\n */\nexport function unique<T>(values: T[]) {\n  const results: T[] = [];\n  const uniqueSet = new Set(values);\n  uniqueSet.forEach(v => {\n    if (notNullorUndefined(v)) {\n      results.push(v);\n    }\n  });\n  return results;\n}\n\nexport function getLatLngBounds(\n  points: number[][],\n  idx: number,\n  limit: [number, number]\n): [number, number] | null {\n  const lats = points\n    .map(d => Number(Array.isArray(d)) && d[idx])\n    .filter(Number.isFinite)\n    .sort(numberSort);\n\n  if (!lats.length) {\n    return null;\n  }\n\n  // clamp to limit\n  return [Math.max(lats[0], limit[0]), Math.min(lats[lats.length - 1], limit[1])];\n}\n\nexport function clamp([min, max]: [number, number], val = 0): number {\n  return val <= min ? min : val >= max ? max : val;\n}\n\nexport function getSampleData(data, sampleSize = 500, getValue = d => d) {\n  const sampleStep = Math.max(Math.floor(data.length / sampleSize), 1);\n  const output: any[] = [];\n  for (let i = 0; i < data.length; i += sampleStep) {\n    output.push(getValue(data[i]));\n  }\n\n  return output;\n}\n\n/**\n * Convert different time format to unix milliseconds\n */\nexport function timeToUnixMilli(value: string | number | Date, format: string): Millisecond | null {\n  if (notNullorUndefined(value)) {\n    if (typeof value === 'string') {\n      return moment.utc(value, format).valueOf();\n    }\n    if (typeof value === 'number') {\n      return format === 'x' ? value * 1000 : value;\n    }\n    if (value instanceof Date) {\n      return value.valueOf();\n    }\n  }\n  return null;\n}\n\n/**\n * Whether d is a number, this filtered out NaN as well\n */\nexport function isNumber(d: unknown): d is number {\n  return Number.isFinite(d);\n}\n\n/**\n * whether object has property\n * @param {string} prop\n * @returns {boolean} - yes or no\n */\nexport function hasOwnProperty<X extends object, Y extends PropertyKey>(\n  obj: X,\n  prop: Y\n): obj is X & Record<Y, unknown> {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nexport function numberSort(a: number, b: number): number {\n  return a - b;\n}\n\nexport function getSortingFunction(fieldType: string): typeof numberSort | undefined {\n  switch (fieldType) {\n    case ALL_FIELD_TYPES.real:\n    case ALL_FIELD_TYPES.integer:\n    case ALL_FIELD_TYPES.timestamp:\n      return numberSort;\n    default:\n      return undefined;\n  }\n}\n\n/**\n * round number with exact number of decimals\n * return as a string\n */\nexport function preciseRound(num: number, decimals: number): string {\n  const t = Math.pow(10, decimals);\n  return (\n    Math.round(\n      num * t + (decimals > 0 ? 1 : 0) * (Math.sign(num) * (10 / Math.pow(100, decimals)))\n    ) / t\n  ).toFixed(decimals);\n}\n\n/**\n * round a giving number at most 4 decimal places\n * e.g. 10 -> 10, 1.12345 -> 1.2345, 2.0 -> 2\n */\nexport function roundToFour(num: number): number {\n  // @ts-expect-error\n  return Number(`${Math.round(`${num}e+4`)}e-4`);\n}\n/**\n * get number of decimals to round to for slider from step\n * @param step\n * @returns- number of decimal\n */\nexport function getRoundingDecimalFromStep(step: number): number {\n  if (isNaN(step)) {\n    assert('step is not a number');\n    assert(step);\n  }\n\n  const stepStr = step.toString();\n\n  // in case the step is a very small number e.g. 1e-7, return decimal e.g. 7 directly\n  const splitExponential = stepStr.split('e-');\n  if (splitExponential.length === 2) {\n    const coeffZero = splitExponential[0].split('.');\n    const coeffDecimal = coeffZero.length === 1 ? 0 : coeffZero[1].length;\n    return parseInt(splitExponential[1], 10) + coeffDecimal;\n  }\n\n  const splitZero = stepStr.split('.');\n  if (splitZero.length === 1) {\n    return 0;\n  }\n  return splitZero[1].length;\n}\n\n/**\n * If marks is provided, snap to marks, if not normalize to step\n * @param val\n * @param minValue\n * @param step\n * @param marks\n */\nexport function normalizeSliderValue(\n  val: number,\n  minValue: number | undefined,\n  step: number,\n  marks?: number[] | null\n): number {\n  if (marks && marks.length) {\n    // Use in slider, given a number and an array of numbers, return the nears number from the array\n    return snapToMarks(val, marks);\n  }\n\n  return roundValToStep(minValue, step, val);\n}\n\n/**\n * round the value to step for the slider\n * @param minValue\n * @param step\n * @param val\n * @returns - rounded number\n */\nexport function roundValToStep(minValue: number | undefined, step: number, val: number): number {\n  if (!isNumber(step) || !isNumber(minValue)) {\n    return val;\n  }\n\n  const decimal = getRoundingDecimalFromStep(step);\n  const steps = Math.floor((val - minValue) / step);\n  let remain = val - (steps * step + minValue);\n\n  // has to round because javascript turns 0.1 into 0.9999999999999987\n  remain = Number(preciseRound(remain, 8));\n\n  let closest: number;\n  if (remain === 0) {\n    closest = val;\n  } else if (remain < step / 2) {\n    closest = steps * step + minValue;\n  } else {\n    closest = (steps + 1) * step + minValue;\n  }\n\n  // precise round return a string rounded to the defined decimal\n  const rounded = preciseRound(closest, decimal);\n\n  return Number(rounded);\n}\n\n/**\n * Get the value format based on field and format options\n * Used in render tooltip value\n */\nexport const defaultFormatter: FieldFormatter = v => (notNullorUndefined(v) ? String(v) : '');\n\nexport const floatFormatter = v => (isNumber(v) ? String(roundToFour(v)) : '');\n\n/**\n * Transforms a WKB in Uint8Array form into a hex WKB string.\n * @param uint8Array WKB in Uint8Array form.\n * @returns hex WKB string.\n */\nexport function uint8ArrayToHex(data: Uint8Array): string {\n  return Array.from(data)\n    .map(byte => (byte as any).toString(16).padStart(2, '0'))\n    .join('');\n}\n\nexport const FIELD_DISPLAY_FORMAT: {\n  [key: string]: FieldFormatter;\n} = {\n  [ALL_FIELD_TYPES.string]: defaultFormatter,\n  [ALL_FIELD_TYPES.timestamp]: defaultFormatter,\n  [ALL_FIELD_TYPES.integer]: defaultFormatter,\n  [ALL_FIELD_TYPES.real]: defaultFormatter,\n  [ALL_FIELD_TYPES.boolean]: defaultFormatter,\n  [ALL_FIELD_TYPES.date]: defaultFormatter,\n  [ALL_FIELD_TYPES.geojson]: d =>\n    typeof d === 'string'\n      ? d\n      : isPlainObject(d)\n      ? JSON.stringify(d)\n      : Array.isArray(d)\n      ? `[${String(d)}]`\n      : '',\n  [ALL_FIELD_TYPES.geoarrow]: (data, field) => {\n    if (data instanceof arrow.Vector) {\n      try {\n        const encoding = field?.metadata?.get('ARROW:extension:name');\n        if (encoding) {\n          const geometry = parseGeometryFromArrow(data, encoding);\n          return JSON.stringify(geometry);\n        }\n      } catch (error) {\n        // ignore for now\n      }\n    } else if (data instanceof Uint8Array) {\n      return uint8ArrayToHex(data);\n    }\n    return data;\n  },\n  [ALL_FIELD_TYPES.object]: (value: any) => {\n    try {\n      return JSON.stringify(value);\n    } catch (e) {\n      return String(value);\n    }\n  },\n  [ALL_FIELD_TYPES.array]: d => JSON.stringify(d),\n  [ALL_FIELD_TYPES.h3]: defaultFormatter\n};\n\n/**\n * Parse field value and type and return a string representation\n */\nexport const parseFieldValue = (value: any, type: string, field?: Field): string => {\n  if (!notNullorUndefined(value)) {\n    return '';\n  }\n  // BigInt values cannot be serialized with JSON.stringify() directly\n  // We need to explicitly convert them to strings using .toString()\n  // See: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigInt#use_within_json\n  if (typeof value === 'bigint') {\n    return value.toString();\n  }\n  return FIELD_DISPLAY_FORMAT[type] ? FIELD_DISPLAY_FORMAT[type](value, field) : String(value);\n};\n\n/**\n * Get the value format based on field and format options\n * Used in render tooltip value\n * @param format\n * @param field\n */\nexport function getFormatter(\n  format?: string | Record<string, string> | null,\n  field?: Field\n): FieldFormatter {\n  if (!format) {\n    return defaultFormatter;\n  }\n  const tooltipFormat = Object.values(TOOLTIP_FORMATS).find(f => f[TOOLTIP_KEY] === format);\n\n  if (tooltipFormat) {\n    return applyDefaultFormat(tooltipFormat as TooltipFormat);\n  } else if (typeof format === 'string' && field) {\n    return applyCustomFormat(format, field);\n  }\n\n  return defaultFormatter;\n}\n\nexport function getColumnFormatter(\n  field: Pick<Field, 'type'> & Partial<Pick<Field, 'format' | 'displayFormat'>>\n): FieldFormatter {\n  const {format, displayFormat} = field;\n\n  if (!format && !displayFormat) {\n    return FIELD_DISPLAY_FORMAT[field.type];\n  }\n  const tooltipFormat = Object.values(TOOLTIP_FORMATS).find(f => f[TOOLTIP_KEY] === displayFormat);\n\n  if (tooltipFormat) {\n    return applyDefaultFormat(tooltipFormat);\n  } else if (typeof displayFormat === 'string' && field) {\n    return applyCustomFormat(displayFormat, field);\n  } else if (typeof displayFormat === 'object') {\n    return applyValueMap(displayFormat);\n  }\n\n  return defaultFormatter;\n}\n\nexport function applyValueMap(format) {\n  return v => format[v];\n}\n\nexport function applyDefaultFormat(tooltipFormat: TooltipFormat): (v: any) => string {\n  if (!tooltipFormat || !tooltipFormat.format) {\n    return defaultFormatter;\n  }\n\n  switch (tooltipFormat.type) {\n    case TOOLTIP_FORMAT_TYPES.DECIMAL:\n      return d3Format(tooltipFormat.format);\n    case TOOLTIP_FORMAT_TYPES.DATE:\n    case TOOLTIP_FORMAT_TYPES.DATE_TIME:\n      return datetimeFormatter(null)(tooltipFormat.format);\n    case TOOLTIP_FORMAT_TYPES.PERCENTAGE:\n      return v => `${d3Format(TOOLTIP_FORMATS.DECIMAL_DECIMAL_FIXED_2.format)(v)}%`;\n    case TOOLTIP_FORMAT_TYPES.BOOLEAN:\n      return getBooleanFormatter(tooltipFormat.format);\n    default:\n      return defaultFormatter;\n  }\n}\n\nexport function getBooleanFormatter(format: string): FieldFormatter {\n  switch (format) {\n    case '01':\n      return (v: boolean) => (v ? '1' : '0');\n    case 'yn':\n      return (v: boolean) => (v ? 'yes' : 'no');\n    default:\n      return defaultFormatter;\n  }\n}\n// Allow user to specify custom tooltip format via config\nexport function applyCustomFormat(format, field: {type?: string}): FieldFormatter {\n  switch (field.type) {\n    case ALL_FIELD_TYPES.real:\n    case ALL_FIELD_TYPES.integer:\n      return d3Format(format);\n    case ALL_FIELD_TYPES.date:\n    case ALL_FIELD_TYPES.timestamp:\n      return datetimeFormatter(null)(format);\n    default:\n      return v => v;\n  }\n}\n\nfunction formatLargeNumber(n) {\n  // SI-prefix with 4 significant digits\n  return d3Format('.4~s')(n);\n}\n\nexport function formatNumber(n: number, type?: string): string {\n  switch (type) {\n    case ALL_FIELD_TYPES.integer:\n      if (n < 0) {\n        return `-${formatNumber(-n, 'integer')}`;\n      }\n      if (n < 1000) {\n        return `${Math.round(n)}`;\n      }\n      if (n < 10 * 1000) {\n        return d3Format(',')(Math.round(n));\n      }\n      return formatLargeNumber(n);\n    case ALL_FIELD_TYPES.real:\n      if (n < 0) {\n        return `-${formatNumber(-n, 'number')}`;\n      }\n      if (n < 1000) {\n        return d3Format('.4~r')(n);\n      }\n      if (n < 10 * 1000) {\n        return d3Format(',.2~f')(n);\n      }\n      return formatLargeNumber(n);\n\n    default:\n      return formatNumber(n, 'real');\n  }\n}\n\nconst transformation = {\n  Y: Math.pow(10, 24),\n  Z: Math.pow(10, 21),\n  E: Math.pow(10, 18),\n  P: Math.pow(10, 15),\n  T: Math.pow(10, 12),\n  G: Math.pow(10, 9),\n  M: Math.pow(10, 6),\n  k: Math.pow(10, 3),\n  h: Math.pow(10, 2),\n  da: Math.pow(10, 1),\n  d: Math.pow(10, -1),\n  c: Math.pow(10, -2),\n  m: Math.pow(10, -3),\n  μ: Math.pow(10, -6),\n  n: Math.pow(10, -9),\n  p: Math.pow(10, -12),\n  f: Math.pow(10, -15),\n  a: Math.pow(10, -18),\n  z: Math.pow(10, -21),\n  y: Math.pow(10, -24)\n};\n\n/**\n * Convert a formatted number from string back to number\n */\nexport function reverseFormatNumber(str: string): number {\n  let returnValue: number | null = null;\n  const strNum = str.trim().replace(/,/g, '');\n  Object.entries(transformation).forEach(d => {\n    if (strNum.includes(d[0])) {\n      returnValue = parseFloat(strNum) * d[1];\n      return true;\n    }\n    return false;\n  });\n\n  // if no transformer found, convert to nuber regardless\n  return returnValue === null ? Number(strNum) : returnValue;\n}\n\n/**\n * Format epoch milliseconds with a format string\n * @type timezone\n */\nexport function datetimeFormatter(\n  timezone?: string | null\n): (format?: string) => (ts: number) => string {\n  return timezone\n    ? format => ts => moment.utc(ts).tz(timezone).format(format)\n    : // return empty string instead of 'Invalid date' if ts is undefined/null\n      format => ts => ts ? moment.utc(ts).format(format) : '';\n}\n"],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kepler.gl/utils",
|
|
3
3
|
"author": "Shan He <shan@uber.com>",
|
|
4
|
-
"version": "3.1.
|
|
4
|
+
"version": "3.1.10",
|
|
5
5
|
"description": "kepler.gl constants used by kepler.gl components, actions and reducers",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"main": "dist/index.js",
|
|
@@ -31,9 +31,9 @@
|
|
|
31
31
|
],
|
|
32
32
|
"dependencies": {
|
|
33
33
|
"@deck.gl/core": "^8.9.27",
|
|
34
|
-
"@kepler.gl/common-utils": "3.1.
|
|
35
|
-
"@kepler.gl/constants": "3.1.
|
|
36
|
-
"@kepler.gl/types": "3.1.
|
|
34
|
+
"@kepler.gl/common-utils": "3.1.10",
|
|
35
|
+
"@kepler.gl/constants": "3.1.10",
|
|
36
|
+
"@kepler.gl/types": "3.1.10",
|
|
37
37
|
"@loaders.gl/arrow": "^4.3.2",
|
|
38
38
|
"@luma.gl/constants": "^8.5.20",
|
|
39
39
|
"@luma.gl/core": "^8.5.20",
|