@kepler.gl/utils 3.1.2 → 3.1.4

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.
@@ -34,6 +34,7 @@ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/de
34
34
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
35
35
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
36
36
  var _constants = require("@kepler.gl/constants");
37
+ var _commonUtils = require("@kepler.gl/common-utils");
37
38
  var _d3Color = require("d3-color");
38
39
  var _d3Interpolate = require("d3-interpolate");
39
40
  var _utils = require("./utils");
@@ -243,7 +244,7 @@ function replaceColorsInColorRange(colorRange, newColors) {
243
244
  */
244
245
  function sortCustomPaletteColor(customPalette, oldIndex, newIndex) {
245
246
  var colors = customPalette.colors;
246
- var newColors = (0, _utils.arrayMove)(colors, oldIndex, newIndex);
247
+ var newColors = (0, _commonUtils.arrayMove)(colors, oldIndex, newIndex);
247
248
  var update = replaceColorsInColorRange(customPalette, newColors);
248
249
 
249
250
  // @ts-ignore
@@ -458,4 +459,4 @@ function initializeCustomPalette(colorRange, colorMap) {
458
459
  }
459
460
  return customPalette;
460
461
  }
461
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_constants","require","_d3Color","_d3Interpolate","_utils","_console","_interopRequireDefault","_excluded","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","hexToRgb","hex","result","isHexColor","parseInt","g","b","exec","PadNum","c","toString","concat","rgbToHex","_ref","_ref2","_slicedToArray2","map","n","join","toUpperCase","hasColorMap","colorRange","Array","isArray","colorMap","Boolean","createLinearGradient","direction","colors","step","parseFloat","toFixed","bands","rgb","index","colorMaybeToRGB","color","isRgbColor","rgbObj","d3Rgb","Number","isFinite","every","normalizeColor","component","colorMaybeToHex","rgbColor","interpolateHex","hex1","hex2","interpolate","addNewCategoricalStepAtIndex","newColor","newColorMap","_ref3","_ref4","val","_toConsumableArray2","arrayInsert","addNewQuantativeColorBreakAtIndex","newColors","i","breaks","cm","slice","newValue","newBreaks","undefined","addCustomPaletteColor","customPalette","update","type","replaceColorsInColorRange","oldColors","updated","colorLegends","reduce","accu","key","colorIdx","findIndex","sortCustomPaletteColor","oldIndex","newIndex","arrayMove","removeCustomPaletteColor","oldValue","splice","colorMapIndex","updateCustomPaletteColor","reverseColorRange","reversed","reverse","paletteIsColorBlindSafe","palette","colorBlindSafe","isQuaPalette","PALETTE_TYPES","QUA","paletteIsSteps","steps","maxStep","paletteIsType","updateColorRangeByMatchingPalette","currentColorRange","config","matchingPalette","KEPLER_COLOR_PALETTES","bestMatch","find","p","name","updateColorRangeBySelectedPalette","Console","warn","updateCustomColorRangeByColorUI","oldColorRange","colorConfig","category","colorPalette","_colorPaletteToColorR","colorPaletteToColorRange","newColorRange","_objectWithoutProperties2","UberNameRegex","RegExp","ColorBrewerRegex","colorRangeBackwardCompatibility","trimName","_colorRange$name","matchName","match","trim","_colorRange$name2","replace","initializeCustomPalette","DEFAULT_CUSTOM_PALETTE","SCALE_TYPES","customOrdinal"],"sources":["../src/color-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {\n  CategoricalPalette,\n  ColorPalette,\n  DEFAULT_CUSTOM_PALETTE,\n  colorPaletteToColorRange\n} from '@kepler.gl/constants';\nimport {\n  ColorMap,\n  ColorRange,\n  ColorRangeConfig,\n  HexColor,\n  RGBAColor,\n  RGBColor\n} from '@kepler.gl/types';\nimport {rgb as d3Rgb} from 'd3-color';\nimport {interpolate} from 'd3-interpolate';\nimport {arrayInsert, arrayMove} from './utils';\nimport Console from 'global/console';\nimport {KEPLER_COLOR_PALETTES, PALETTE_TYPES, SCALE_TYPES} from '@kepler.gl/constants';\n\n/**\n * get r g b from hex code\n *\n * @param hex\n * @returns array of r g bs\n */\nexport function hexToRgb(hex: string): RGBColor {\n  const result = isHexColor(hex);\n\n  if (!result) {\n    return [0, 0, 0];\n  }\n\n  const r = parseInt(result[1], 16);\n  const g = parseInt(result[2], 16);\n  const b = parseInt(result[3], 16);\n\n  return [r, g, b];\n}\n\nexport function isHexColor(hex: string): RegExpExecArray | null {\n  const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n\n  return result;\n}\n\nfunction PadNum(c) {\n  const hex = c.toString(16);\n  return hex.length === 1 ? `0${hex}` : hex;\n}\n\n/**\n * get hex from r g b\n *\n * @param rgb\n * @returns hex string\n */\nexport function rgbToHex([r, g, b]: RGBColor | RGBAColor): HexColor {\n  return `#${[r, g, b].map(n => PadNum(n)).join('')}`.toUpperCase();\n}\n\n/**\n * Whether color range has custom color map\n */\nexport function hasColorMap(colorRange: ColorRange): boolean {\n  return Array.isArray(colorRange.colorMap) && Boolean(colorRange.colorMap.length);\n}\n\n/**\n * given a list of rgb arrays it will generate a linear gradient css rule\n * @param direction\n * @param colors\n * @return\n */\nexport function createLinearGradient(direction: string, colors: RGBColor[]): string {\n  const step = parseFloat((100.0 / colors.length).toFixed(2));\n  const bands = colors.map((rgb, index) => {\n    return `rgba(${rgb.join(',')}, 1) ${step * index}%, rgba(${rgb.join(',')}, 1) ${\n      step * (index + 1)\n    }%`;\n  });\n\n  return `linear-gradient(to ${direction}, ${bands.join(',')})`;\n}\n\n/**\n * Convert color to RGB\n */\nexport function colorMaybeToRGB(color: unknown): RGBColor | null {\n  if (isRgbColor(color)) {\n    return color as RGBColor;\n  }\n\n  if (typeof color === 'string') {\n    const rgbObj = d3Rgb(color);\n    if (Number.isFinite(rgbObj?.r) && Number.isFinite(rgbObj?.g) && Number.isFinite(rgbObj?.b)) {\n      return [rgbObj.r, rgbObj.g, rgbObj.b];\n    }\n  }\n\n  return null;\n}\n\n/**\n * Whether color is rgb\n * @returns\n */\nexport function isRgbColor(color: unknown): boolean {\n  return Boolean(\n    color &&\n      Array.isArray(color) &&\n      color.length === 3 &&\n      color.every(n => Number.isFinite(n) && n <= 255 && n >= 0)\n  );\n}\n\n/**\n * Take color values in 0-255 range and map to [0, 1]\n */\nexport function normalizeColor(color: number[]): number[] {\n  return color.map(component => component / 255.0);\n}\n\n/**\n * Convert color to Hex\n */\nexport function colorMaybeToHex(color: unknown): HexColor {\n  const rgbColor = colorMaybeToRGB(color);\n  if (rgbColor) return rgbToHex(rgbColor);\n  return '#000000';\n}\n\n/**\n * Convert color to Hex\n */\n\nexport function interpolateHex(hex1: HexColor, hex2: HexColor): HexColor {\n  return d3Rgb(interpolate(hex1, hex2)(0.5)).hex().toUpperCase();\n}\n\nfunction addNewCategoricalStepAtIndex(colorMap, index, newColor) {\n  if (!Array.isArray(colorMap) || !colorMap.length) {\n    return colorMap;\n  }\n\n  let newColorMap = colorMap.map(([val, c]) => [Array.isArray(val) ? [...val] : val, c]);\n  newColorMap = arrayInsert(newColorMap, index + 1, [null, newColor]);\n\n  return newColorMap;\n}\n\nexport function addNewQuantativeColorBreakAtIndex(colorMap, index, newColors) {\n  if (!Array.isArray(colorMap) || !colorMap.length) {\n    return colorMap;\n  }\n\n  if (colorMap.length < 2) {\n    // less then 2, add 1 at end\n    // however shouldn't allow delete when there are 2\n    return newColors.map((c, i) => (i === 0 ? colorMap[i] : [null, c]));\n  }\n\n  // breaks should be 1 less than colors\n  const breaks = colorMap.map(cm => cm[0]).slice(0, colorMap.length - 1);\n\n  // insert new break\n  const newValue =\n    index >= breaks.length - 1\n      ? breaks[breaks.length - 1] +\n        (breaks.length > 1 ? breaks[breaks.length - 1] - breaks[breaks.length - 2] : 0)\n      : (breaks[index] + breaks[index + 1]) / 2;\n\n  const newBreaks = arrayInsert(breaks, index + 1, newValue);\n\n  // asign breaks to color\n  return newColors.map((c, i) =>\n    i === newColors.length - 1 ? [null, c] : [newBreaks[i] === undefined ? null : newBreaks[i], c]\n  );\n}\n\n/**\n * Add a new color to custom palette\n */\nexport function addCustomPaletteColor(customPalette: ColorRange, index: number): ColorRange {\n  const {colors, colorMap} = customPalette;\n  const update: Partial<ColorRange> = {};\n\n  const newColor =\n    index === colors.length - 1 ? colors[index] : interpolateHex(colors[index], colors[index + 1]);\n\n  update.colors = arrayInsert(colors, index + 1, newColor);\n\n  // add color to colorMap\n  if (colorMap) {\n    update.colorMap =\n      customPalette.type === 'customOrdinal'\n        ? addNewCategoricalStepAtIndex(colorMap, index, newColor)\n        : addNewQuantativeColorBreakAtIndex(colorMap, index, update.colors);\n  }\n\n  return {\n    ...customPalette,\n    ...update\n  };\n}\n\nfunction replaceColorsInColorRange(colorRange, newColors) {\n  const oldColors = colorRange.colors;\n  const updated = {\n    ...colorRange,\n    colors: newColors\n  };\n\n  // update color map\n  // keep value, replace color\n  if (Array.isArray(updated.colorMap)) {\n    updated.colorMap = updated.colorMap.map((cm, i) => [cm[0], newColors[i]]);\n  }\n  // update colorlegends\n  // keep value, replace color\n  if (updated.colorLegends) {\n    updated.colorLegends = Object.keys(updated.colorLegends).reduce((accu, key) => {\n      const colorIdx = oldColors.findIndex(c => c === key);\n      const newColor = newColors[colorIdx];\n\n      return newColor\n        ? {\n            ...accu,\n            [newColor]: updated.colorLegends[key]\n          }\n        : accu;\n    }, {});\n  }\n\n  return updated;\n}\n\n/**\n * Sort custom palette\n */\nexport function sortCustomPaletteColor(\n  customPalette: ColorRange,\n  oldIndex: number,\n  newIndex: number\n): ColorRange {\n  const {colors} = customPalette;\n\n  const newColors = arrayMove(colors, oldIndex, newIndex);\n  const update = replaceColorsInColorRange(customPalette, newColors);\n\n  // @ts-ignore\n  return {\n    ...customPalette,\n    ...update\n  };\n}\n\n/**\n * remove a color in custom palette at index\n */\nexport function removeCustomPaletteColor(customPalette: ColorRange, index: number): ColorRange {\n  const {colors, colorMap, colorLegends} = customPalette;\n  const oldValue = colors[index];\n  const update: Partial<ColorRange> = {};\n  update.colors = [...colors];\n\n  if (update.colors.length > 1) {\n    update.colors.splice(index, 1);\n  }\n  // update color map\n  if (Array.isArray(colorMap)) {\n    // find colorMap index\n    const colorMapIndex = colorMap.findIndex(cm => cm[1] === oldValue);\n    if (colorMapIndex >= 0) {\n      update.colorMap = [...colorMap];\n      update.colorMap.splice(colorMapIndex, 1);\n    }\n  }\n  // update color legend\n  if (colorLegends?.[oldValue]) {\n    update.colorLegends = {...colorLegends};\n    delete update.colorLegends[oldValue];\n  }\n\n  return {\n    ...customPalette,\n    ...update\n  };\n}\n\n/**\n * Update a color in custom palette at index\n */\nexport function updateCustomPaletteColor(\n  customPalette: ColorRange,\n  index: number,\n  newValue: HexColor\n): ColorRange {\n  const {colors} = customPalette;\n  const hex = newValue.toUpperCase();\n  const newColors = [...colors];\n  newColors[index] = hex;\n\n  const update = replaceColorsInColorRange(customPalette, newColors);\n\n  // @ts-ignore\n  return {\n    ...customPalette,\n    ...update\n  };\n}\n\n/**\n * Get a reversed colorRange\n */\nexport function reverseColorRange(reversed: boolean, colorRange: ColorRange): ColorRange {\n  const newColors = colorRange?.colors.slice().reverse();\n  const updated = replaceColorsInColorRange(colorRange, newColors);\n  updated.reversed = reversed;\n\n  return updated;\n}\n\n/**\n * Whether palette matches current ColorBlindSafe config\n */\nexport function paletteIsColorBlindSafe(palette: ColorPalette, colorBlindSafe: boolean) {\n  return !colorBlindSafe || (colorBlindSafe && palette.colorBlindSafe);\n}\n\n/**\n * Whether palette matches current steps config\n */\nexport function isQuaPalette(palette: ColorPalette): palette is CategoricalPalette {\n  return palette.type === PALETTE_TYPES.QUA;\n}\n\n/**\n * Whether palette matches current steps config\n */\nexport function paletteIsSteps(palette: ColorPalette, steps: number): boolean {\n  return !isQuaPalette(palette) || palette.maxStep >= steps;\n}\n\n/**\n * Whether palette matches current type config\n */\nexport function paletteIsType(palette: ColorPalette, type: string): boolean {\n  return type === 'all' || type === palette.type;\n}\n/**\n * Find best match palette based on config, update color range by it\n */\nexport function updateColorRangeByMatchingPalette(\n  currentColorRange: ColorRange,\n  config: ColorRangeConfig\n): ColorRange {\n  const {steps, colorBlindSafe, type} = config;\n\n  const matchingPalette = KEPLER_COLOR_PALETTES.filter(\n    palette =>\n      // palette match type\n      paletteIsType(palette, type) &&\n      // palette has same step\n      paletteIsSteps(palette, steps) &&\n      // palette is colorBlindSafe\n      paletteIsColorBlindSafe(palette, colorBlindSafe)\n  );\n\n  const bestMatch = matchingPalette.length\n    ? matchingPalette.find(p => p.name === currentColorRange.name) || matchingPalette[0]\n    : null;\n\n  if (bestMatch) {\n    return updateColorRangeBySelectedPalette(currentColorRange, bestMatch, config);\n  }\n  // we do nothing\n  Console.warn(\n    `we cant find any preset palette matches requirments: steps=${steps} && colorBlindSafe=${colorBlindSafe}`\n  );\n\n  return currentColorRange;\n}\n\n/**\n * Update custom palette when reverse the colors in custom palette, since changing 'steps',\n * 'colorBindSafe', 'type' should fall back to predefined palette.\n */\nexport function updateCustomColorRangeByColorUI(\n  oldColorRange: ColorRange,\n  colorConfig: ColorRangeConfig\n): ColorRange {\n  const {reversed} = colorConfig;\n  const colors = oldColorRange.colors;\n  // for custom palette, one can only 'reverse' the colors in custom palette.\n  colors.reverse();\n\n  const colorRange = {\n    name: oldColorRange.name,\n    type: oldColorRange.type,\n    category: oldColorRange.category,\n    colors,\n    ...(reversed ? {reversed} : {}),\n    ...(oldColorRange.colorMap ? {colorMap: oldColorRange.colorMap} : {}),\n    ...(oldColorRange.colorLegends ? {colorLegends: oldColorRange.colorLegends} : {})\n  };\n\n  return replaceColorsInColorRange(colorRange, colorRange.colors);\n}\n\n/**\n * Update color range after selecting a palette from color range selectoer\n * Copy over colorMap and colorLegends\n */\nexport function updateColorRangeBySelectedPalette(oldColorRange, colorPalette, colorConfig) {\n  const {colors: newColors, ...newColorRange} = colorPaletteToColorRange(colorPalette, colorConfig);\n\n  const colorRange = {\n    colors: oldColorRange.colors,\n    ...newColorRange,\n    ...(oldColorRange.colorMap ? {colorMap: oldColorRange.colorMap} : {}),\n    ...(oldColorRange.colorLegends ? {colorLegends: oldColorRange.colorLegends} : {})\n  };\n\n  return replaceColorsInColorRange(colorRange, newColors);\n}\n\nconst UberNameRegex = new RegExp(/^([A-Za-z ])+/g);\nconst ColorBrewerRegex = new RegExp(/^ColorBrewer ([A-Za-z1-9])+/g);\n\n/**\n * convert saved colorRange to colorPalette objevt type/name/category/isColorBlind\n */\nexport function colorRangeBackwardCompatibility(colorRange: ColorRange): ColorRange {\n  if (!colorRange || colorRange.type === 'custom' || colorRange.colorMap) {\n    // don't do anything to custom color palette, or palette with custom breaks\n    return colorRange;\n  }\n  let trimName;\n  if (colorRange.category === 'Uber') {\n    const matchName = (colorRange.name ?? '').match(UberNameRegex);\n    trimName = matchName ? matchName[0].trim() : null;\n    // match Uber Viz Qualitative 1.4 -> Uber Viz Qualitative\n  } else if (colorRange.category === 'ColorBrewer') {\n    const matchName = (colorRange.name ?? '').match(ColorBrewerRegex);\n    trimName = matchName ? matchName[0].replace('ColorBrewer ', '').trim() : null;\n  }\n\n  if (trimName) {\n    const matchingPalette = KEPLER_COLOR_PALETTES.find(p => p.name === trimName);\n    if (matchingPalette) {\n      return {\n        ...colorRange,\n        name: trimName,\n        type: matchingPalette?.type,\n        category: matchingPalette.category\n      };\n    }\n  }\n\n  return colorRange;\n}\n\n/**\n * Initialize custom palette from current standard color range object\n */\nexport function initializeCustomPalette(colorRange: ColorRange, colorMap?: ColorMap): ColorRange {\n  // TODO: check on `isReversed` key, whether we can remove it here\n  const customPalette = {\n    ...colorRange,\n    name: DEFAULT_CUSTOM_PALETTE.name,\n    type: DEFAULT_CUSTOM_PALETTE.type,\n    category: DEFAULT_CUSTOM_PALETTE.category,\n    ...(colorMap ? {colorMap} : {})\n  };\n\n  // only customPalette.colors are needed for custom palette editor with custom ordinal scale\n  if (!colorMap && colorRange.type === SCALE_TYPES.customOrdinal) {\n    delete customPalette.colorMap;\n  }\n  return customPalette;\n}\n"],"mappings":"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","ignoreList":[]}
462
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_constants","require","_commonUtils","_d3Color","_d3Interpolate","_utils","_console","_interopRequireDefault","_excluded","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","hexToRgb","hex","result","isHexColor","parseInt","g","b","exec","PadNum","c","toString","concat","rgbToHex","_ref","_ref2","_slicedToArray2","map","n","join","toUpperCase","hasColorMap","colorRange","Array","isArray","colorMap","Boolean","createLinearGradient","direction","colors","step","parseFloat","toFixed","bands","rgb","index","colorMaybeToRGB","color","isRgbColor","rgbObj","d3Rgb","Number","isFinite","every","normalizeColor","component","colorMaybeToHex","rgbColor","interpolateHex","hex1","hex2","interpolate","addNewCategoricalStepAtIndex","newColor","newColorMap","_ref3","_ref4","val","_toConsumableArray2","arrayInsert","addNewQuantativeColorBreakAtIndex","newColors","i","breaks","cm","slice","newValue","newBreaks","undefined","addCustomPaletteColor","customPalette","update","type","replaceColorsInColorRange","oldColors","updated","colorLegends","reduce","accu","key","colorIdx","findIndex","sortCustomPaletteColor","oldIndex","newIndex","arrayMove","removeCustomPaletteColor","oldValue","splice","colorMapIndex","updateCustomPaletteColor","reverseColorRange","reversed","reverse","paletteIsColorBlindSafe","palette","colorBlindSafe","isQuaPalette","PALETTE_TYPES","QUA","paletteIsSteps","steps","maxStep","paletteIsType","updateColorRangeByMatchingPalette","currentColorRange","config","matchingPalette","KEPLER_COLOR_PALETTES","bestMatch","find","p","name","updateColorRangeBySelectedPalette","Console","warn","updateCustomColorRangeByColorUI","oldColorRange","colorConfig","category","colorPalette","_colorPaletteToColorR","colorPaletteToColorRange","newColorRange","_objectWithoutProperties2","UberNameRegex","RegExp","ColorBrewerRegex","colorRangeBackwardCompatibility","trimName","_colorRange$name","matchName","match","trim","_colorRange$name2","replace","initializeCustomPalette","DEFAULT_CUSTOM_PALETTE","SCALE_TYPES","customOrdinal"],"sources":["../src/color-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {\n  CategoricalPalette,\n  ColorPalette,\n  DEFAULT_CUSTOM_PALETTE,\n  colorPaletteToColorRange\n} from '@kepler.gl/constants';\nimport {arrayMove} from '@kepler.gl/common-utils';\nimport {\n  ColorMap,\n  ColorRange,\n  ColorRangeConfig,\n  HexColor,\n  RGBAColor,\n  RGBColor\n} from '@kepler.gl/types';\nimport {rgb as d3Rgb} from 'd3-color';\nimport {interpolate} from 'd3-interpolate';\nimport {arrayInsert} from './utils';\nimport Console from 'global/console';\nimport {KEPLER_COLOR_PALETTES, PALETTE_TYPES, SCALE_TYPES} from '@kepler.gl/constants';\n\n/**\n * get r g b from hex code\n *\n * @param hex\n * @returns array of r g bs\n */\nexport function hexToRgb(hex: string): RGBColor {\n  const result = isHexColor(hex);\n\n  if (!result) {\n    return [0, 0, 0];\n  }\n\n  const r = parseInt(result[1], 16);\n  const g = parseInt(result[2], 16);\n  const b = parseInt(result[3], 16);\n\n  return [r, g, b];\n}\n\nexport function isHexColor(hex: string): RegExpExecArray | null {\n  const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n\n  return result;\n}\n\nfunction PadNum(c) {\n  const hex = c.toString(16);\n  return hex.length === 1 ? `0${hex}` : hex;\n}\n\n/**\n * get hex from r g b\n *\n * @param rgb\n * @returns hex string\n */\nexport function rgbToHex([r, g, b]: RGBColor | RGBAColor): HexColor {\n  return `#${[r, g, b].map(n => PadNum(n)).join('')}`.toUpperCase();\n}\n\n/**\n * Whether color range has custom color map\n */\nexport function hasColorMap(colorRange: ColorRange): boolean {\n  return Array.isArray(colorRange.colorMap) && Boolean(colorRange.colorMap.length);\n}\n\n/**\n * given a list of rgb arrays it will generate a linear gradient css rule\n * @param direction\n * @param colors\n * @return\n */\nexport function createLinearGradient(direction: string, colors: RGBColor[]): string {\n  const step = parseFloat((100.0 / colors.length).toFixed(2));\n  const bands = colors.map((rgb, index) => {\n    return `rgba(${rgb.join(',')}, 1) ${step * index}%, rgba(${rgb.join(',')}, 1) ${\n      step * (index + 1)\n    }%`;\n  });\n\n  return `linear-gradient(to ${direction}, ${bands.join(',')})`;\n}\n\n/**\n * Convert color to RGB\n */\nexport function colorMaybeToRGB(color: unknown): RGBColor | null {\n  if (isRgbColor(color)) {\n    return color as RGBColor;\n  }\n\n  if (typeof color === 'string') {\n    const rgbObj = d3Rgb(color);\n    if (Number.isFinite(rgbObj?.r) && Number.isFinite(rgbObj?.g) && Number.isFinite(rgbObj?.b)) {\n      return [rgbObj.r, rgbObj.g, rgbObj.b];\n    }\n  }\n\n  return null;\n}\n\n/**\n * Whether color is rgb\n * @returns\n */\nexport function isRgbColor(color: unknown): boolean {\n  return Boolean(\n    color &&\n      Array.isArray(color) &&\n      color.length === 3 &&\n      color.every(n => Number.isFinite(n) && n <= 255 && n >= 0)\n  );\n}\n\n/**\n * Take color values in 0-255 range and map to [0, 1]\n */\nexport function normalizeColor(color: number[]): number[] {\n  return color.map(component => component / 255.0);\n}\n\n/**\n * Convert color to Hex\n */\nexport function colorMaybeToHex(color: unknown): HexColor {\n  const rgbColor = colorMaybeToRGB(color);\n  if (rgbColor) return rgbToHex(rgbColor);\n  return '#000000';\n}\n\n/**\n * Convert color to Hex\n */\n\nexport function interpolateHex(hex1: HexColor, hex2: HexColor): HexColor {\n  return d3Rgb(interpolate(hex1, hex2)(0.5)).hex().toUpperCase();\n}\n\nfunction addNewCategoricalStepAtIndex(colorMap, index, newColor) {\n  if (!Array.isArray(colorMap) || !colorMap.length) {\n    return colorMap;\n  }\n\n  let newColorMap = colorMap.map(([val, c]) => [Array.isArray(val) ? [...val] : val, c]);\n  newColorMap = arrayInsert(newColorMap, index + 1, [null, newColor]);\n\n  return newColorMap;\n}\n\nexport function addNewQuantativeColorBreakAtIndex(colorMap, index, newColors) {\n  if (!Array.isArray(colorMap) || !colorMap.length) {\n    return colorMap;\n  }\n\n  if (colorMap.length < 2) {\n    // less then 2, add 1 at end\n    // however shouldn't allow delete when there are 2\n    return newColors.map((c, i) => (i === 0 ? colorMap[i] : [null, c]));\n  }\n\n  // breaks should be 1 less than colors\n  const breaks = colorMap.map(cm => cm[0]).slice(0, colorMap.length - 1);\n\n  // insert new break\n  const newValue =\n    index >= breaks.length - 1\n      ? breaks[breaks.length - 1] +\n        (breaks.length > 1 ? breaks[breaks.length - 1] - breaks[breaks.length - 2] : 0)\n      : (breaks[index] + breaks[index + 1]) / 2;\n\n  const newBreaks = arrayInsert(breaks, index + 1, newValue);\n\n  // asign breaks to color\n  return newColors.map((c, i) =>\n    i === newColors.length - 1 ? [null, c] : [newBreaks[i] === undefined ? null : newBreaks[i], c]\n  );\n}\n\n/**\n * Add a new color to custom palette\n */\nexport function addCustomPaletteColor(customPalette: ColorRange, index: number): ColorRange {\n  const {colors, colorMap} = customPalette;\n  const update: Partial<ColorRange> = {};\n\n  const newColor =\n    index === colors.length - 1 ? colors[index] : interpolateHex(colors[index], colors[index + 1]);\n\n  update.colors = arrayInsert(colors, index + 1, newColor);\n\n  // add color to colorMap\n  if (colorMap) {\n    update.colorMap =\n      customPalette.type === 'customOrdinal'\n        ? addNewCategoricalStepAtIndex(colorMap, index, newColor)\n        : addNewQuantativeColorBreakAtIndex(colorMap, index, update.colors);\n  }\n\n  return {\n    ...customPalette,\n    ...update\n  };\n}\n\nfunction replaceColorsInColorRange(colorRange, newColors) {\n  const oldColors = colorRange.colors;\n  const updated = {\n    ...colorRange,\n    colors: newColors\n  };\n\n  // update color map\n  // keep value, replace color\n  if (Array.isArray(updated.colorMap)) {\n    updated.colorMap = updated.colorMap.map((cm, i) => [cm[0], newColors[i]]);\n  }\n  // update colorlegends\n  // keep value, replace color\n  if (updated.colorLegends) {\n    updated.colorLegends = Object.keys(updated.colorLegends).reduce((accu, key) => {\n      const colorIdx = oldColors.findIndex(c => c === key);\n      const newColor = newColors[colorIdx];\n\n      return newColor\n        ? {\n            ...accu,\n            [newColor]: updated.colorLegends[key]\n          }\n        : accu;\n    }, {});\n  }\n\n  return updated;\n}\n\n/**\n * Sort custom palette\n */\nexport function sortCustomPaletteColor(\n  customPalette: ColorRange,\n  oldIndex: number,\n  newIndex: number\n): ColorRange {\n  const {colors} = customPalette;\n\n  const newColors = arrayMove(colors, oldIndex, newIndex);\n  const update = replaceColorsInColorRange(customPalette, newColors);\n\n  // @ts-ignore\n  return {\n    ...customPalette,\n    ...update\n  };\n}\n\n/**\n * remove a color in custom palette at index\n */\nexport function removeCustomPaletteColor(customPalette: ColorRange, index: number): ColorRange {\n  const {colors, colorMap, colorLegends} = customPalette;\n  const oldValue = colors[index];\n  const update: Partial<ColorRange> = {};\n  update.colors = [...colors];\n\n  if (update.colors.length > 1) {\n    update.colors.splice(index, 1);\n  }\n  // update color map\n  if (Array.isArray(colorMap)) {\n    // find colorMap index\n    const colorMapIndex = colorMap.findIndex(cm => cm[1] === oldValue);\n    if (colorMapIndex >= 0) {\n      update.colorMap = [...colorMap];\n      update.colorMap.splice(colorMapIndex, 1);\n    }\n  }\n  // update color legend\n  if (colorLegends?.[oldValue]) {\n    update.colorLegends = {...colorLegends};\n    delete update.colorLegends[oldValue];\n  }\n\n  return {\n    ...customPalette,\n    ...update\n  };\n}\n\n/**\n * Update a color in custom palette at index\n */\nexport function updateCustomPaletteColor(\n  customPalette: ColorRange,\n  index: number,\n  newValue: HexColor\n): ColorRange {\n  const {colors} = customPalette;\n  const hex = newValue.toUpperCase();\n  const newColors = [...colors];\n  newColors[index] = hex;\n\n  const update = replaceColorsInColorRange(customPalette, newColors);\n\n  // @ts-ignore\n  return {\n    ...customPalette,\n    ...update\n  };\n}\n\n/**\n * Get a reversed colorRange\n */\nexport function reverseColorRange(reversed: boolean, colorRange: ColorRange): ColorRange {\n  const newColors = colorRange?.colors.slice().reverse();\n  const updated = replaceColorsInColorRange(colorRange, newColors);\n  updated.reversed = reversed;\n\n  return updated;\n}\n\n/**\n * Whether palette matches current ColorBlindSafe config\n */\nexport function paletteIsColorBlindSafe(palette: ColorPalette, colorBlindSafe: boolean) {\n  return !colorBlindSafe || (colorBlindSafe && palette.colorBlindSafe);\n}\n\n/**\n * Whether palette matches current steps config\n */\nexport function isQuaPalette(palette: ColorPalette): palette is CategoricalPalette {\n  return palette.type === PALETTE_TYPES.QUA;\n}\n\n/**\n * Whether palette matches current steps config\n */\nexport function paletteIsSteps(palette: ColorPalette, steps: number): boolean {\n  return !isQuaPalette(palette) || palette.maxStep >= steps;\n}\n\n/**\n * Whether palette matches current type config\n */\nexport function paletteIsType(palette: ColorPalette, type: string): boolean {\n  return type === 'all' || type === palette.type;\n}\n/**\n * Find best match palette based on config, update color range by it\n */\nexport function updateColorRangeByMatchingPalette(\n  currentColorRange: ColorRange,\n  config: ColorRangeConfig\n): ColorRange {\n  const {steps, colorBlindSafe, type} = config;\n\n  const matchingPalette = KEPLER_COLOR_PALETTES.filter(\n    palette =>\n      // palette match type\n      paletteIsType(palette, type) &&\n      // palette has same step\n      paletteIsSteps(palette, steps) &&\n      // palette is colorBlindSafe\n      paletteIsColorBlindSafe(palette, colorBlindSafe)\n  );\n\n  const bestMatch = matchingPalette.length\n    ? matchingPalette.find(p => p.name === currentColorRange.name) || matchingPalette[0]\n    : null;\n\n  if (bestMatch) {\n    return updateColorRangeBySelectedPalette(currentColorRange, bestMatch, config);\n  }\n  // we do nothing\n  Console.warn(\n    `we cant find any preset palette matches requirments: steps=${steps} && colorBlindSafe=${colorBlindSafe}`\n  );\n\n  return currentColorRange;\n}\n\n/**\n * Update custom palette when reverse the colors in custom palette, since changing 'steps',\n * 'colorBindSafe', 'type' should fall back to predefined palette.\n */\nexport function updateCustomColorRangeByColorUI(\n  oldColorRange: ColorRange,\n  colorConfig: ColorRangeConfig\n): ColorRange {\n  const {reversed} = colorConfig;\n  const colors = oldColorRange.colors;\n  // for custom palette, one can only 'reverse' the colors in custom palette.\n  colors.reverse();\n\n  const colorRange = {\n    name: oldColorRange.name,\n    type: oldColorRange.type,\n    category: oldColorRange.category,\n    colors,\n    ...(reversed ? {reversed} : {}),\n    ...(oldColorRange.colorMap ? {colorMap: oldColorRange.colorMap} : {}),\n    ...(oldColorRange.colorLegends ? {colorLegends: oldColorRange.colorLegends} : {})\n  };\n\n  return replaceColorsInColorRange(colorRange, colorRange.colors);\n}\n\n/**\n * Update color range after selecting a palette from color range selectoer\n * Copy over colorMap and colorLegends\n */\nexport function updateColorRangeBySelectedPalette(oldColorRange, colorPalette, colorConfig) {\n  const {colors: newColors, ...newColorRange} = colorPaletteToColorRange(colorPalette, colorConfig);\n\n  const colorRange = {\n    colors: oldColorRange.colors,\n    ...newColorRange,\n    ...(oldColorRange.colorMap ? {colorMap: oldColorRange.colorMap} : {}),\n    ...(oldColorRange.colorLegends ? {colorLegends: oldColorRange.colorLegends} : {})\n  };\n\n  return replaceColorsInColorRange(colorRange, newColors);\n}\n\nconst UberNameRegex = new RegExp(/^([A-Za-z ])+/g);\nconst ColorBrewerRegex = new RegExp(/^ColorBrewer ([A-Za-z1-9])+/g);\n\n/**\n * convert saved colorRange to colorPalette objevt type/name/category/isColorBlind\n */\nexport function colorRangeBackwardCompatibility(colorRange: ColorRange): ColorRange {\n  if (!colorRange || colorRange.type === 'custom' || colorRange.colorMap) {\n    // don't do anything to custom color palette, or palette with custom breaks\n    return colorRange;\n  }\n  let trimName;\n  if (colorRange.category === 'Uber') {\n    const matchName = (colorRange.name ?? '').match(UberNameRegex);\n    trimName = matchName ? matchName[0].trim() : null;\n    // match Uber Viz Qualitative 1.4 -> Uber Viz Qualitative\n  } else if (colorRange.category === 'ColorBrewer') {\n    const matchName = (colorRange.name ?? '').match(ColorBrewerRegex);\n    trimName = matchName ? matchName[0].replace('ColorBrewer ', '').trim() : null;\n  }\n\n  if (trimName) {\n    const matchingPalette = KEPLER_COLOR_PALETTES.find(p => p.name === trimName);\n    if (matchingPalette) {\n      return {\n        ...colorRange,\n        name: trimName,\n        type: matchingPalette?.type,\n        category: matchingPalette.category\n      };\n    }\n  }\n\n  return colorRange;\n}\n\n/**\n * Initialize custom palette from current standard color range object\n */\nexport function initializeCustomPalette(colorRange: ColorRange, colorMap?: ColorMap): ColorRange {\n  // TODO: check on `isReversed` key, whether we can remove it here\n  const customPalette = {\n    ...colorRange,\n    name: DEFAULT_CUSTOM_PALETTE.name,\n    type: DEFAULT_CUSTOM_PALETTE.type,\n    category: DEFAULT_CUSTOM_PALETTE.category,\n    ...(colorMap ? {colorMap} : {})\n  };\n\n  // only customPalette.colors are needed for custom palette editor with custom ordinal scale\n  if (!colorMap && colorRange.type === SCALE_TYPES.customOrdinal) {\n    delete customPalette.colorMap;\n  }\n  return customPalette;\n}\n"],"mappings":"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","ignoreList":[]}
@@ -106,8 +106,8 @@ export interface DataContainerInterface {
106
106
  * @param options Specify start and end row indices that should be mapped.
107
107
  * @returns A new array with each element being the result of the func callback.
108
108
  */
109
- mapIndex(func: ({ index: number }: {
110
- index: any;
109
+ mapIndex(func: ({ index }: {
110
+ index: number;
111
111
  }, dataContainer: DataContainerInterface) => any, options?: RangeOptions): any[];
112
112
  /**
113
113
  * Returns the value of the first row in the provided data container that satisfies the provided testing function.
@@ -3,4 +3,4 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":[],"sources":["../src/data-container-interface.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {ProtoDatasetField} from '@kepler.gl/types';\nimport {DataRow, SharedRowOptions} from './data-row';\n\n/**\n * Specifies a range of rows of a data container that should be processed.\n */\nexport type RangeOptions = {\n  start?: number;\n  end?: number;\n};\nexport interface DataContainerInterface {\n  /**\n   * Updates the data container with new data.\n   * @param updateData updated data, e.g. for arrow data container, it's an array of arrow columns; for row data container, it's an array of rows.\n   */\n  update?(updateData: any[]): void;\n\n  /**\n   * Returns the number of rows in the data container.\n   * @returns Number of rows in the data container.\n   */\n  numRows(): number;\n\n  /**\n   * Returns the number of columns in the data container.\n   * @returns Number of columns in the data container.\n   */\n  numColumns(): number;\n\n  /**\n   * Returns the value stored at the specified cell in the data container.\n   * @param rowIndex Row index.\n   * @param columnIndex Column index.\n   * @returns Value at the specified cell.\n   */\n  valueAt(rowIndex: number, columnIndex: number): any;\n\n  /**\n   * Returns the row at the specified index.\n   * @param rowIndex Row index.\n   * @param sharedRow Passed row is filled with contents from the specified index and returned without extra row allocations.\n   * @returns A row object.\n   */\n  row(rowIndex: number, sharedRow?: SharedRowOptions): DataRow;\n\n  /**\n   * Returns the specified row of the data container represented as an array.\n   * @param rowIndex Row index.\n   * @returns The specified row represented as an array.\n   */\n  rowAsArray(rowIndex: number): any[];\n\n  /**\n   * Returns an iterator to sequentially access all rows in the data container.\n   * @param sharedRow Indicates that a temporary row object should be used.\n   * If enabled, the returned row object is shared between calls\n   * and mustn't be stored without cloning.\n   * Passed row is filled with contents of the specified row and returned on each iteration.\n   * @returns An iterator to sequentially access all rows in the data container.\n   */\n  rows(sharedRow?: SharedRowOptions): Generator<DataRow, void, any>;\n\n  /**\n   * Returns an iterator to sequentially access all values in the specified column of the data container.\n   * @param columnIndex Column index.\n   * @returns An iterator to all values in the specified column of the data container.\n   */\n  column(columnIndex: number): Generator<any, void, any>;\n\n  /**\n   * Returns the column object at the specified index.\n   * @param columnIndex Column index.\n   * @returns The column object at the specified index.\n   */\n  getColumn?(columnIndex: number): unknown;\n\n  /**\n   * Returns the field object at the specified index.\n   * @param columnIndex Column index.\n   * @returns The field object at the specified index.\n   */\n  getField?(columnIndex: number): ProtoDatasetField;\n\n  /**\n   * Returns the underlying data object.\n   * @returns Returns the underlying data object.\n   */\n  getTable?(): unknown;\n\n  /**\n   * Returns contents of the data container as a two-dimensional array.\n   * @returns Data.\n   */\n  flattenData(): any[][];\n\n  /**\n   * Generates an array of indices where each index represents a row in the data container.\n   * @returns An array of indices.\n   */\n  getPlainIndex(): number[];\n\n  /**\n   * Creates a new array populated with the results of calling the provided callback\n   * on every row in the data container.\n   * @param func Callback that is called for every row of the data container.\n   * The callback is called with the following arguments:\n   * - row: The current row being processed in the data container.\n   * - index: The index of the current row being processed in the data container.\n   * @param sharedRow Truthy value indicates that a shared row object should be used.\n   * Make sure the func callback doesn't store the row object in such case,\n   * and clone the row in case you need to store it.\n   * @param options Specify start and end row indices that should be mapped.\n   * @returns A new array with each element being the result of the func callback.\n   */\n  map(\n    func: (row: DataRow, index: number) => any,\n    sharedRow?: SharedRowOptions,\n    options?: RangeOptions\n  ): any[];\n\n  /**\n   * Creates a new array populated with the results of calling the provided callback.\n   * The callback is called for every row in the dataset, but only {index} object is passed.\n   * @param func Callback that is called for every row of the data container.\n   * @param options Specify start and end row indices that should be mapped.\n   * @returns A new array with each element being the result of the func callback.\n   */\n  mapIndex(\n    func: ({index: number}, dataContainer: DataContainerInterface) => any,\n    options?: RangeOptions\n  ): any[];\n\n  /**\n   * Returns the value of the first row in the provided data container that satisfies the provided testing function.\n   * @param func Function to execute on each value in the array.\n   * The function is called with the following arguments:\n   * - row: The current row being processed in the data container.\n   * - index: The index of the current row being processed in the data container.\n   * @param sharedRow Truthy value indicates that a shared row object should be used.\n   * Make sure the func callback doesn't store the row object in such case,\n   * and clone the row in case you need to store it.\n   * @returns First matching row or undefined if no rows satisfy the testing function.\n   */\n  find(\n    func: (row: DataRow, index: number) => any,\n    sharedRow?: SharedRowOptions\n  ): DataRow | undefined;\n\n  /**\n   * Executes a reducer function on each element of the data container, resulting in single output value.\n   * @param func A function to execute on each row in the data container.\n   * The function is called with the following arguments:\n   * - acc: The accumulator accumulates func's return values.\n   * - row: The current row being processed in the data container.\n   * - index: The index of the current row being processed in the data container.\n   * @param initialValue A value to use as the first argument to the first call of the func.\n   * @param sharedRow Truthy value indicates that a shared row object should be used.\n   * Make sure the func callback doesn't store the row object in such case,\n   * and clone the row in case you need to store it.\n   * @returns The single value that results from the reduction.\n   */\n  reduce(\n    func: (acc: any, row: DataRow, index: number) => any,\n    initialValue: any,\n    sharedRow?: SharedRowOptions\n  ): any;\n}\n"],"mappings":"","ignoreList":[]}
6
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":[],"sources":["../src/data-container-interface.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {ProtoDatasetField} from '@kepler.gl/types';\nimport {DataRow, SharedRowOptions} from './data-row';\n\n/**\n * Specifies a range of rows of a data container that should be processed.\n */\nexport type RangeOptions = {\n  start?: number;\n  end?: number;\n};\nexport interface DataContainerInterface {\n  /**\n   * Updates the data container with new data.\n   * @param updateData updated data, e.g. for arrow data container, it's an array of arrow columns; for row data container, it's an array of rows.\n   */\n  update?(updateData: any[]): void;\n\n  /**\n   * Returns the number of rows in the data container.\n   * @returns Number of rows in the data container.\n   */\n  numRows(): number;\n\n  /**\n   * Returns the number of columns in the data container.\n   * @returns Number of columns in the data container.\n   */\n  numColumns(): number;\n\n  /**\n   * Returns the value stored at the specified cell in the data container.\n   * @param rowIndex Row index.\n   * @param columnIndex Column index.\n   * @returns Value at the specified cell.\n   */\n  valueAt(rowIndex: number, columnIndex: number): any;\n\n  /**\n   * Returns the row at the specified index.\n   * @param rowIndex Row index.\n   * @param sharedRow Passed row is filled with contents from the specified index and returned without extra row allocations.\n   * @returns A row object.\n   */\n  row(rowIndex: number, sharedRow?: SharedRowOptions): DataRow;\n\n  /**\n   * Returns the specified row of the data container represented as an array.\n   * @param rowIndex Row index.\n   * @returns The specified row represented as an array.\n   */\n  rowAsArray(rowIndex: number): any[];\n\n  /**\n   * Returns an iterator to sequentially access all rows in the data container.\n   * @param sharedRow Indicates that a temporary row object should be used.\n   * If enabled, the returned row object is shared between calls\n   * and mustn't be stored without cloning.\n   * Passed row is filled with contents of the specified row and returned on each iteration.\n   * @returns An iterator to sequentially access all rows in the data container.\n   */\n  rows(sharedRow?: SharedRowOptions): Generator<DataRow, void, any>;\n\n  /**\n   * Returns an iterator to sequentially access all values in the specified column of the data container.\n   * @param columnIndex Column index.\n   * @returns An iterator to all values in the specified column of the data container.\n   */\n  column(columnIndex: number): Generator<any, void, any>;\n\n  /**\n   * Returns the column object at the specified index.\n   * @param columnIndex Column index.\n   * @returns The column object at the specified index.\n   */\n  getColumn?(columnIndex: number): unknown;\n\n  /**\n   * Returns the field object at the specified index.\n   * @param columnIndex Column index.\n   * @returns The field object at the specified index.\n   */\n  getField?(columnIndex: number): ProtoDatasetField;\n\n  /**\n   * Returns the underlying data object.\n   * @returns Returns the underlying data object.\n   */\n  getTable?(): unknown;\n\n  /**\n   * Returns contents of the data container as a two-dimensional array.\n   * @returns Data.\n   */\n  flattenData(): any[][];\n\n  /**\n   * Generates an array of indices where each index represents a row in the data container.\n   * @returns An array of indices.\n   */\n  getPlainIndex(): number[];\n\n  /**\n   * Creates a new array populated with the results of calling the provided callback\n   * on every row in the data container.\n   * @param func Callback that is called for every row of the data container.\n   * The callback is called with the following arguments:\n   * - row: The current row being processed in the data container.\n   * - index: The index of the current row being processed in the data container.\n   * @param sharedRow Truthy value indicates that a shared row object should be used.\n   * Make sure the func callback doesn't store the row object in such case,\n   * and clone the row in case you need to store it.\n   * @param options Specify start and end row indices that should be mapped.\n   * @returns A new array with each element being the result of the func callback.\n   */\n  map(\n    func: (row: DataRow, index: number) => any,\n    sharedRow?: SharedRowOptions,\n    options?: RangeOptions\n  ): any[];\n\n  /**\n   * Creates a new array populated with the results of calling the provided callback.\n   * The callback is called for every row in the dataset, but only {index} object is passed.\n   * @param func Callback that is called for every row of the data container.\n   * @param options Specify start and end row indices that should be mapped.\n   * @returns A new array with each element being the result of the func callback.\n   */\n  mapIndex(\n    func: ({index}: {index: number}, dataContainer: DataContainerInterface) => any,\n    options?: RangeOptions\n  ): any[];\n\n  /**\n   * Returns the value of the first row in the provided data container that satisfies the provided testing function.\n   * @param func Function to execute on each value in the array.\n   * The function is called with the following arguments:\n   * - row: The current row being processed in the data container.\n   * - index: The index of the current row being processed in the data container.\n   * @param sharedRow Truthy value indicates that a shared row object should be used.\n   * Make sure the func callback doesn't store the row object in such case,\n   * and clone the row in case you need to store it.\n   * @returns First matching row or undefined if no rows satisfy the testing function.\n   */\n  find(\n    func: (row: DataRow, index: number) => any,\n    sharedRow?: SharedRowOptions\n  ): DataRow | undefined;\n\n  /**\n   * Executes a reducer function on each element of the data container, resulting in single output value.\n   * @param func A function to execute on each row in the data container.\n   * The function is called with the following arguments:\n   * - acc: The accumulator accumulates func's return values.\n   * - row: The current row being processed in the data container.\n   * - index: The index of the current row being processed in the data container.\n   * @param initialValue A value to use as the first argument to the first call of the func.\n   * @param sharedRow Truthy value indicates that a shared row object should be used.\n   * Make sure the func callback doesn't store the row object in such case,\n   * and clone the row in case you need to store it.\n   * @returns The single value that results from the reduction.\n   */\n  reduce(\n    func: (acc: any, row: DataRow, index: number) => any,\n    initialValue: any,\n    sharedRow?: SharedRowOptions\n  ): any;\n}\n"],"mappings":"","ignoreList":[]}
@@ -37,7 +37,7 @@ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers
37
37
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
38
38
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
39
39
  var _d3Array = require("d3-array");
40
- var _lodash = _interopRequireDefault(require("lodash.uniq"));
40
+ var _uniq = _interopRequireDefault(require("lodash/uniq"));
41
41
  var _moment = _interopRequireDefault(require("moment"));
42
42
  var _commonUtils = require("@kepler.gl/common-utils");
43
43
  var _constants = require("@kepler.gl/constants");
@@ -345,10 +345,10 @@ function colorMapToCategoricalColorBreaks(colorMap) {
345
345
  */
346
346
  function colorBreaksToCategoricalColorMap(colorBreaks) {
347
347
  // colorMap: [string | string[], hexstring]
348
- var colors = (0, _lodash["default"])(colorBreaks.map(function (cb) {
348
+ var colors = (0, _uniq["default"])(colorBreaks.map(function (cb) {
349
349
  return cb.data;
350
350
  }));
351
- var values = (0, _lodash["default"])(colorBreaks.map(function (cb) {
351
+ var values = (0, _uniq["default"])(colorBreaks.map(function (cb) {
352
352
  return cb.label;
353
353
  }));
354
354
  return getCategoricalColorMap(colors, values);
@@ -529,7 +529,7 @@ function addCategoricalValuesToColorMap(colorMap, items, index) {
529
529
  return [items, cm[1]];
530
530
  }
531
531
  var _currentUniqueValues = (0, _commonUtils.toArray)(cm[0]);
532
- var updatedUniqueValues = (0, _lodash["default"])(_currentUniqueValues.concat(items));
532
+ var updatedUniqueValues = (0, _uniq["default"])(_currentUniqueValues.concat(items));
533
533
  return [updatedUniqueValues, cm[1]];
534
534
  }
535
535
  // remove value from other colorMap
@@ -598,4 +598,4 @@ function initCustomPaletteByCustomScale(_ref9) {
598
598
  };
599
599
  return customPalette;
600
600
  }
601
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_d3Array","require","_lodash","_interopRequireDefault","_moment","_commonUtils","_constants","_colorUtils","_dataUtils","_filterUtils","_utils","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","getQuantileDomain","data","valueAccessor","sortFunc","values","map","notNullorUndefined","sort","getOrdinalDomain","dataContainer","mapIndex","unique","getLinearDomain","range","extent","d","i","undefined","getLogDomain","_getLinearDomain","_getLinearDomain2","_slicedToArray2","d0","d1","isDomainStops","domain","isPlainObject","Array","isArray","stops","z","isDomainQuantile","quantiles","getThresholdsFromQuantiles","buckets","thresholds","Number","isFinite","position","d3Quantile","getDomainStepsbyZoom","steps","bisectLeft","Math","max","getScaleFunction","scale","fixed","scaleFunction","SCALE_FUNC","scaleType","getThresholdLabels","labelFormat","genLength","invert","invertExtent","inputs","reverseFormatNumber","label","concat","getScaleLabels","customScaleLabelFormat","n","formatNumber","getQuantLegends","thresholdLabelFormat","type","labels","index","rgbToHex","getOrdinalLegends","datum","isRgbColor","defaultFormat","getTimeLabelFormat","formatter","getTimeWidgetHintFormatter","val","moment","utc","format","getQuantLabelFormat","fieldType","ALL_FIELD_TYPES","timestamp","isNumber","getLegendOfScale","_ref","byZoom","SCALE_TYPES","ordinal","customOrdinal","string","formatLabel","getLayerColorScale","_ref2","layer","getColorScale","initializeLayerColorMap","visualChannel","config","visConfig","field","colorBreaks","colorBreaksToColorMap","getVisualChannelScaleByZoom","_ref3","_scale","mapState","_layer$meta","meta","getZoom","zoom","getCategoricalColorMap","colors","colorToUniqueValues","uniqueValues","lastColor","_toConsumableArray2","colorMap","color","colorMapToCategoricalColorBreaks","_ref4","_ref5","value","colorBreaksToCategoricalColorMap","uniq","cb","colorBreak","colorMapToColorBreaks","_ref6","_ref7","Infinity","isNumericColorBreaks","Boolean","getHistogramDomain","_ref8","aggregatedBins","columnStats","dataset","fieldValueAccessor","domainMin","POSITIVE_INFINITY","domainMax","NEGATIVE_INFINITY","nValid","domainSum","bin","mean","allIndexes","x","histogramMean","resetCategoricalColorMapByIndex","newColorMap","cm","selectRestCategoricalColorMapByIndex","uniqValueDict","fromEntries","toArray","v","rest","removeCategoricalValueFromColorMap","item","currentUniqueValues","updatedUniqueValues","addCategoricalValuesToColorMap","items","includes","getCategoricalColorScale","colorDomain","colorRange","useRgb","cMap","hexToRgb","unknown","NO_VALUE_COLOR","initCustomPaletteByCustomScale","_ref9","ordinalDomain","customPaletteName","name","reuseColorMap","customPalette","category"],"sources":["../src/data-scale-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {bisectLeft, quantileSorted as d3Quantile, extent} from 'd3-array';\nimport uniq from 'lodash.uniq';\nimport moment from 'moment';\n\nimport {notNullorUndefined, toArray} from '@kepler.gl/common-utils';\nimport {ALL_FIELD_TYPES, SCALE_FUNC, SCALE_TYPES, NO_VALUE_COLOR} from '@kepler.gl/constants';\n// import {FilterProps, KeplerTable} from '@kepler.gl/layers';\nimport {\n  AggregatedBin,\n  ColorMap,\n  ColorRange,\n  HexColor,\n  KeplerLayer as Layer,\n  MapState,\n  VisualChannel,\n  VisualChannelDomain,\n  RGBColor,\n  RGBAColor,\n  ColorUI,\n  Field\n} from '@kepler.gl/types';\n\nimport {isRgbColor, rgbToHex, hexToRgb} from './color-utils';\nimport {DataContainerInterface} from './data-container-interface';\nimport {formatNumber, isNumber, reverseFormatNumber, unique} from './data-utils';\nimport {getTimeWidgetHintFormatter} from './filter-utils';\nimport {isPlainObject} from './utils';\n\nexport type ColorBreak = {\n  data: HexColor;\n  label: string;\n  range: number[];\n  inputs: number[];\n};\nexport type ColorBreakOrdinal = {\n  data: HexColor;\n  label: string | number | string[] | number[] | null;\n};\n\nexport type D3ScaleFunction = Record<string, any> & ((x: any) => any);\n\n// TODO isolate types - depends on @kepler.gl/layers\ntype FilterProps = any;\ntype KeplerTable = any;\n\nexport type LabelFormat = (n: number, type?: string) => string;\ntype dataValueAccessor = <T>(param: T) => T;\ntype dataContainerValueAccessor = (d: {index: number}, dc: DataContainerInterface) => any;\ntype sort = (a: any, b: any) => any;\n/**\n * return quantile domain for an array of data\n */\nexport function getQuantileDomain(\n  data: any[],\n  valueAccessor?: dataValueAccessor,\n  sortFunc?: sort\n): number[] {\n  const values = typeof valueAccessor === 'function' ? data.map(valueAccessor) : data;\n\n  return values.filter(notNullorUndefined).sort(sortFunc);\n}\n\n/**\n * return ordinal domain for a data container\n */\nexport function getOrdinalDomain(\n  dataContainer: DataContainerInterface,\n  valueAccessor: dataContainerValueAccessor\n): string[] {\n  const values = dataContainer.mapIndex(valueAccessor);\n\n  return unique(values).filter(notNullorUndefined).sort();\n}\n\n/**\n * return linear domain for an array of data\n */\nexport function getLinearDomain(\n  data: number[],\n  valueAccessor?: dataValueAccessor\n): [number, number] {\n  const range = typeof valueAccessor === 'function' ? extent(data, valueAccessor) : extent(data);\n  return range.map((d: undefined | number, i: number) => (d === undefined ? i : d)) as [\n    number,\n    number\n  ];\n}\n\n/**\n * return linear domain for an array of data. A log scale domain cannot contain 0\n */\nexport function getLogDomain(data: any[], valueAccessor: dataValueAccessor): [number, number] {\n  const [d0, d1] = getLinearDomain(data, valueAccessor);\n  return [d0 === 0 ? 1e-5 : d0, d1];\n}\n\nexport type DomainStops = {\n  stops: number[];\n  z: number[];\n};\n\n/**\n * whether field domain is stops\n */\nexport function isDomainStops(domain: unknown): domain is DomainStops {\n  return isPlainObject(domain) && Array.isArray(domain.stops) && Array.isArray(domain.z);\n}\n\nexport type DomainQuantiles = {\n  quantiles: number[];\n  z: number[];\n};\n\n/**\n * whether field domain is quantiles\n */\nexport function isDomainQuantile(domain: any): domain is DomainQuantiles {\n  return isPlainObject(domain) && Array.isArray(domain.quantiles) && Array.isArray(domain.z);\n}\n\n/**\n * get the domain at zoom\n */\nexport function getThresholdsFromQuantiles(\n  quantiles: number[],\n  buckets: number\n): (number | undefined)[] {\n  const thresholds = [];\n  if (!Number.isFinite(buckets) || buckets < 1) {\n    return [quantiles[0], quantiles[quantiles.length - 1]];\n  }\n  for (let i = 1; i < buckets; i++) {\n    // position in sorted array\n    const position = i / buckets;\n    // @ts-ignore\n    thresholds.push(d3Quantile(quantiles, position));\n  }\n\n  return thresholds;\n}\n\n/**\n * get the domain at zoom\n */\nexport function getDomainStepsbyZoom(domain: any[], steps: number[], z: number): any {\n  const i = bisectLeft(steps, z);\n\n  if (steps[i] === z) {\n    // If z is an integer value exactly matching a step, return the corresponding domain\n    return domain[i];\n  }\n  // Otherwise, return the next coarsest domain\n  return domain[Math.max(i - 1, 0)];\n}\n\n/**\n * Get d3 scale function\n */\nexport function getScaleFunction(\n  scale: string,\n  range: any[] | IterableIterator<any>,\n  domain: (number | undefined)[] | string[] | IterableIterator<any>,\n  fixed?: boolean\n): D3ScaleFunction {\n  const scaleFunction = SCALE_FUNC[fixed ? 'linear' : scale]()\n    .domain(domain)\n    .range(fixed ? domain : range);\n  scaleFunction.scaleType = fixed ? 'linear' : scale;\n  return scaleFunction;\n}\n\n/**\n * Get threshold scale color labels\n */\nfunction getThresholdLabels(\n  scale: D3ScaleFunction,\n  labelFormat: LabelFormat\n): Omit<ColorBreak, 'data'>[] {\n  const genLength = scale.range().length;\n  return scale.range().map((d, i) => {\n    const invert = scale.invertExtent(d);\n    const inputs = [\n      i === 0 ? null : reverseFormatNumber(labelFormat(invert[0])),\n      i === genLength - 1 ? null : reverseFormatNumber(labelFormat(invert[1]))\n    ];\n    return {\n      // raw value\n      range: invert,\n      // formatted value\n      inputs,\n      label:\n        i === 0\n          ? `Less than ${labelFormat(invert[1])}`\n          : i === genLength - 1\n          ? `${labelFormat(invert[0])} or more`\n          : `${labelFormat(invert[0])} to ${labelFormat(invert[1])}`\n    };\n  });\n}\n\n/**\n * Get linear / quant scale color labels\n */\nfunction getScaleLabels(\n  scale: D3ScaleFunction,\n  labelFormat: LabelFormat\n): Omit<ColorBreak, 'data'>[] {\n  return scale.range().map(d => {\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}`;\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":[]}
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}`;\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":[]}