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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/plot.js CHANGED
@@ -17,6 +17,7 @@ exports.getRangeFilterBins = getRangeFilterBins;
17
17
  exports.getTimeBins = getTimeBins;
18
18
  exports.getValueAggrFunc = void 0;
19
19
  exports.histogramFromDomain = histogramFromDomain;
20
+ exports.histogramFromOrdinal = histogramFromOrdinal;
20
21
  exports.histogramFromThreshold = histogramFromThreshold;
21
22
  exports.histogramFromValues = histogramFromValues;
22
23
  exports.isPercentField = isPercentField;
@@ -111,6 +112,27 @@ function histogramFromValues(values, numBins, valueAccessor) {
111
112
  return (0, _dataUtils.isNumber)(x0) && (0, _dataUtils.isNumber)(x1);
112
113
  });
113
114
  }
115
+ function histogramFromOrdinal(domain, values, valueAccessor) {
116
+ // @ts-expect-error to typed to expect strings
117
+ var getBins = (0, _d3Array.histogram)().thresholds(domain);
118
+ if (valueAccessor) {
119
+ // @ts-expect-error to typed to expect strings
120
+ getBins.value(valueAccessor);
121
+ }
122
+
123
+ // @ts-expect-error null values aren't expected
124
+ var bins = getBins(values);
125
+
126
+ // @ts-ignore d3-array types doesn't match
127
+ return bins.map(function (bin) {
128
+ return {
129
+ count: bin.length,
130
+ indexes: bin,
131
+ x0: bin.x0,
132
+ x1: bin.x0
133
+ };
134
+ });
135
+ }
114
136
 
115
137
  /**
116
138
  *
@@ -612,4 +634,4 @@ function getDefaultPlotType(filter, datasets) {
612
634
  aggregation: _constants.AGGREGATION_TYPES.sum
613
635
  };
614
636
  }
615
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_d3Array","require","_lodash","_interopRequireDefault","_time","_moment","_commonUtils","_constants","_dataUtils","_aggregation","_strings","_format","_colorUtils","_createForOfIteratorHelper","r","e","t","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","_n","F","s","n","done","value","f","TypeError","o","a","u","call","next","_arrayLikeToArray","toString","slice","constructor","name","from","test","ownKeys","Object","keys","getOwnPropertySymbols","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","histogramFromThreshold","thresholds","values","valueAccessor","filterEmptyBins","undefined","getBins","d3Histogram","domain","bins","map","bin","count","indexes","x0","x1","b","histogramFromValues","numBins","isNumber","histogramFromDomain","ticks","getTimeBins","datasets","interval","timeBins","dataId","dataIdIdx","dataset","runGpuFilterForPlot","binByTime","mappedValue","getFilterMappedValue","intervalBins","getBinThresholds","idx","timeInterval","intervalToFunction","_domain","_slicedToArray2","t0","t1","floor","getTime","ceiling","ceil","durationDay","binThresholds","range","moment","utc","valueOf","lastStep","offset","skipIndexes","getSkipIndexes","_dataset$gpuFilter","gpuFilter","filterValueUpdateTriggers","filterRange","filterValueAccessor","filteredIndex","getFilterValue","dataContainer","allChannels","_","i","skipAll","includes","filterData","getFilterDataFunc","gpuFilters","valueIndex","findIndex","id","filterColumn","reduce","accu","item","skips","index","every","val","validBin","snapToMarks","marks","bisectLeft","normalizeValue","minValue","step","roundValToStep","isPercentField","field","metadata","numerator","denominator","updateAggregationByField","aggregation","AGGREGATION_TYPES","average","getAgregationType","getAggregationAccessor","fields","numeratorIdx","denominatorIdx","getNumerator","valueAt","getDenominator","getValueAggrFunc","exports","datasetField","find","aggregate","getAggregationOptiosnBasedOnField","TIME_AGGREGATION","_ref","sum","getDelta","y","lastBin","delta","pct","getPctChange","y0","Number","isFinite","getLineChart","_timeBins","yAxis","plotType","lineChart","seriesDataId","isEqual","getYValue","init","series","x","yDomain","extent","d","xDomain","split","splitSeries","aggrName","AGGREGATION_NAME","title","concat","fieldType","type","allTime","lines","temp","notNullorUndefined","markers","adjustValueToAnimationWindow","state","_filter$value","value0","value1","animationWindow","getInitialInterval","datasetBins","val0","val1","ANIMATION_WINDOW","indexOf","NaN","updatedFilter","getFilterPlotColorsByDataId","oldColorsByDataId","colorsByDataId","_iterator","_step","rgbToHex","color","err","updateTimeFilterPlotType","nextFilter","nextPlotType","_typeof2","getDefaultPlotType","PLOT_TYPES","histogram","getRangeFilterBins","acc","datasetIdx","_filter$bins","fieldName","getColumnField","updateRangeFilterPlotType","BINS","getChartTitle","yAxisName","displayName","capitalizeFirstLetter","defaultTimeFormat","getDefaultTimeFormat"],"sources":["../src/plot.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {bisectLeft, extent, histogram as d3Histogram, ticks} from 'd3-array';\nimport isEqual from 'lodash.isequal';\nimport {getFilterMappedValue, getInitialInterval, intervalToFunction} from './time';\nimport moment from 'moment';\nimport {\n  Bin,\n  TimeBins,\n  Millisecond,\n  TimeRangeFilter,\n  RangeFilter,\n  PlotType,\n  Filter,\n  LineChart,\n  Field,\n  ValueOf,\n  LineDatum\n} from '@kepler.gl/types';\nimport {notNullorUndefined} from '@kepler.gl/common-utils';\nimport {\n  ANIMATION_WINDOW,\n  BINS,\n  durationDay,\n  TIME_AGGREGATION,\n  AGGREGATION_TYPES,\n  PLOT_TYPES,\n  AggregationTypes\n} from '@kepler.gl/constants';\n\nimport {isNumber, roundValToStep} from './data-utils';\nimport {aggregate, AGGREGATION_NAME} from './aggregation';\nimport {capitalizeFirstLetter} from './strings';\nimport {getDefaultTimeFormat} from './format';\nimport {rgbToHex} from './color-utils';\nimport {DataContainerInterface} from '.';\nimport {KeplerTableModel} from './types';\n\n// TODO kepler-table module isn't accessible from utils. Add compatible interface to types\ntype Datasets = any;\n\n/**\n *\n * @param thresholds\n * @param values\n * @param indexes\n */\nexport function histogramFromThreshold(\n  thresholds: number[],\n  values: number[],\n  valueAccessor?: (d: unknown) => number,\n  filterEmptyBins = true\n): Bin[] {\n  const getBins = d3Histogram()\n    .domain([thresholds[0], thresholds[thresholds.length - 1]])\n    .thresholds(thresholds);\n\n  if (valueAccessor) {\n    getBins.value(valueAccessor);\n  }\n\n  // @ts-ignore\n  const bins = getBins(values).map(bin => ({\n    count: bin.length,\n    indexes: bin,\n    x0: bin.x0,\n    x1: bin.x1\n  }));\n\n  // d3-histogram ignores threshold values outside the domain\n  // The first bin.x0 is always equal to the minimum domain value, and the last bin.x1 is always equal to the maximum domain value.\n\n  // bins[0].x0 = thresholds[0];\n  // bins[bins.length - 1].x1 = thresholds[thresholds.length - 1];\n\n  // @ts-ignore\n  return filterEmptyBins ? bins.filter(b => b.count > 0) : bins;\n}\n\n/**\n *\n * @param values\n * @param numBins\n * @param valueAccessor\n */\nexport function histogramFromValues(\n  values: (Millisecond | null | number)[],\n  numBins: number,\n  valueAccessor?: (d: unknown) => number\n) {\n  const getBins = d3Histogram().thresholds(numBins);\n\n  if (valueAccessor) {\n    getBins.value(valueAccessor);\n  }\n\n  // @ts-ignore d3-array types doesn't match\n  return getBins(values)\n    .map(bin => ({\n      count: bin.length,\n      indexes: bin,\n      x0: bin.x0,\n      x1: bin.x1\n    }))\n    .filter(b => {\n      const {x0, x1} = b;\n      return isNumber(x0) && isNumber(x1);\n    });\n}\n\n/**\n *\n * @param domain\n * @param values\n * @param numBins\n * @param valueAccessor\n */\nexport function histogramFromDomain(\n  domain: [number, number],\n  values: (Millisecond | null | number)[],\n  numBins: number,\n  valueAccessor?: (d: unknown) => number\n): Bin[] {\n  const getBins = d3Histogram().thresholds(ticks(domain[0], domain[1], numBins)).domain(domain);\n  if (valueAccessor) {\n    getBins.value(valueAccessor);\n  }\n\n  // @ts-ignore d3-array types doesn't match\n  return getBins(values).map(bin => ({\n    count: bin.length,\n    indexes: bin,\n    x0: bin.x0,\n    x1: bin.x1\n  }));\n}\n\n/**\n * @param filter\n * @param datasets\n * @param interval\n */\nexport function getTimeBins(\n  filter: TimeRangeFilter,\n  datasets: Datasets,\n  interval: PlotType['interval']\n): TimeBins {\n  let bins = filter.timeBins || {};\n\n  filter.dataId.forEach((dataId, dataIdIdx) => {\n    // reuse bins if filterData did not change\n    if (bins[dataId] && bins[dataId][interval]) {\n      return;\n    }\n    const dataset = datasets[dataId];\n\n    // do not apply current filter\n    const indexes = runGpuFilterForPlot(dataset, filter);\n\n    bins = {\n      ...bins,\n      [dataId]: {\n        ...bins[dataId],\n        [interval]: binByTime(indexes, dataset, interval, filter)\n      }\n    };\n  });\n\n  return bins;\n}\n\nexport function binByTime(indexes, dataset, interval, filter) {\n  // gpuFilters need to be apply to filteredIndex\n  const mappedValue = getFilterMappedValue(dataset, filter);\n  if (!mappedValue) {\n    return null;\n  }\n  const intervalBins = getBinThresholds(interval, filter.domain);\n  const valueAccessor = idx => mappedValue[idx];\n  const bins = histogramFromThreshold(intervalBins, indexes, valueAccessor);\n\n  return bins;\n}\n\nexport function getBinThresholds(interval: string, domain: number[]): number[] {\n  const timeInterval = intervalToFunction(interval);\n  const [t0, t1] = domain;\n  const floor = timeInterval.floor(t0).getTime();\n  const ceiling = timeInterval.ceil(t1).getTime();\n\n  if (!timeInterval) {\n    // if time interval is not defined\n    // this should not happen\n    return [t0, t0 + durationDay];\n  }\n  const binThresholds = timeInterval.range(floor, ceiling + 1).map(t => moment.utc(t).valueOf());\n  const lastStep = binThresholds[binThresholds.length - 1];\n  if (lastStep === t1) {\n    // when last step equal to domain max, add one more step\n    binThresholds.push(moment.utc(timeInterval.offset(lastStep)).valueOf());\n  }\n\n  return binThresholds;\n}\n\n/**\n * Run GPU filter on current filter result to generate indexes for ploting chart\n * Skip ruuning for the same field\n * @param dataset\n * @param filter\n */\nexport function runGpuFilterForPlot<K extends KeplerTableModel<K, L>, L>(\n  dataset: K,\n  filter?: Filter\n): number[] {\n  const skipIndexes = getSkipIndexes(dataset, filter);\n\n  const {\n    gpuFilter: {filterValueUpdateTriggers, filterRange, filterValueAccessor},\n    filteredIndex\n  } = dataset;\n  const getFilterValue = filterValueAccessor(dataset.dataContainer)();\n\n  const allChannels = Object.keys(filterValueUpdateTriggers)\n    .map((_, i) => i)\n    .filter(i => Object.values(filterValueUpdateTriggers)[i]);\n  const skipAll = !allChannels.filter(i => !skipIndexes.includes(i)).length;\n  if (skipAll) {\n    return filteredIndex;\n  }\n\n  const filterData = getFilterDataFunc(\n    filterRange,\n    getFilterValue,\n    dataset.dataContainer,\n    skipIndexes\n  );\n\n  return filteredIndex.filter(filterData);\n}\n\nfunction getSkipIndexes(dataset, filter) {\n  // array of gpu filter names\n  if (!filter) {\n    return [];\n  }\n  const gpuFilters = Object.values(dataset.gpuFilter.filterValueUpdateTriggers) as ({\n    name: string;\n  } | null)[];\n  const valueIndex = filter.dataId.findIndex(id => id === dataset.id);\n  const filterColumn = filter.name[valueIndex];\n\n  return gpuFilters.reduce((accu, item, idx) => {\n    if (item && filterColumn === item.name) {\n      accu.push(idx);\n    }\n    return accu;\n  }, [] as number[]);\n}\n\nexport function getFilterDataFunc(\n  filterRange,\n  getFilterValue,\n  dataContainer: DataContainerInterface,\n  skips\n) {\n  return index =>\n    getFilterValue({index}).every(\n      (val, i) => skips.includes(i) || (val >= filterRange[i][0] && val <= filterRange[i][1])\n    );\n}\n\nexport function validBin(b) {\n  return b.x0 !== undefined && b.x1 !== undefined;\n}\n\n/**\n * Use in slider, given a number and an array of numbers, return the nears number from the array.\n * Takes a value, timesteps and return the actual step.\n * @param value\n * @param marks\n */\nexport function snapToMarks(value: number, marks: number[]): number {\n  // always use bin x0\n  if (!marks.length) {\n    // @ts-expect-error looking at the usage null return value isn't expected and requires extra handling in a lot of places\n    return null;\n  }\n  const i = bisectLeft(marks, value);\n  if (i === 0) {\n    return marks[i];\n  } else if (i === marks.length) {\n    return marks[i - 1];\n  }\n  const idx = marks[i] - value < value - marks[i - 1] ? i : i - 1;\n  return marks[idx];\n}\n\nexport function normalizeValue(val, minValue, step, marks) {\n  if (marks && marks.length) {\n    return snapToMarks(val, marks);\n  }\n\n  return roundValToStep(minValue, step, val);\n}\n\nexport function isPercentField(field) {\n  return field.metadata && field.metadata.numerator && field.metadata.denominator;\n}\n\nexport function updateAggregationByField(field: Field, aggregation: ValueOf<AggregationTypes>) {\n  // shouldn't apply sum to percent fiele type\n  // default aggregation is average\n  return field && isPercentField(field)\n    ? AGGREGATION_TYPES.average\n    : aggregation || AGGREGATION_TYPES.average;\n}\n\nconst getAgregationType = (field, aggregation) => {\n  if (isPercentField(field)) {\n    return 'mean_of_percent';\n  }\n  return aggregation;\n};\n\nconst getAggregationAccessor = (field, dataContainer: DataContainerInterface, fields) => {\n  if (isPercentField(field)) {\n    const numeratorIdx = fields.findIndex(f => f.name === field.metadata.numerator);\n    const denominatorIdx = fields.findIndex(f => f.name === field.metadata.denominator);\n\n    return {\n      getNumerator: i => dataContainer.valueAt(i, numeratorIdx),\n      getDenominator: i => dataContainer.valueAt(i, denominatorIdx)\n    };\n  }\n\n  return i => field.valueAccessor({index: i});\n};\n\nexport const getValueAggrFunc = (\n  field: Field | string | null,\n  aggregation: string,\n  dataset: KeplerTableModel<any, any>\n): ((bin: Bin) => number) => {\n  const {dataContainer, fields} = dataset;\n\n  // The passed-in field might not have all the fields set (e.g. valueAccessor)\n  const datasetField = fields.find(\n    f => field && (f.name === field || f.name === (field as Field).name)\n  );\n\n  return datasetField && aggregation\n    ? bin =>\n        aggregate(\n          bin.indexes,\n          getAgregationType(datasetField, aggregation),\n          // @ts-expect-error can return {getNumerator, getDenominator}\n          getAggregationAccessor(datasetField, dataContainer, fields)\n        )\n    : bin => bin.count;\n};\n\nexport const getAggregationOptiosnBasedOnField = field => {\n  if (isPercentField(field)) {\n    // don't show sum\n    return TIME_AGGREGATION.filter(({id}) => id !== AGGREGATION_TYPES.sum);\n  }\n  return TIME_AGGREGATION;\n};\n\nfunction getDelta(\n  bins: LineDatum[],\n  y: number,\n  interval: PlotType['interval']\n): Partial<LineDatum> & {delta: 'last'; pct: number | null} {\n  // if (WOW[interval]) return getWow(bins, y, interval);\n  const lastBin = bins[bins.length - 1];\n\n  return {\n    delta: 'last',\n    pct: lastBin ? getPctChange(y, lastBin.y) : null\n  };\n}\n\nexport function getPctChange(y: unknown, y0: unknown): number | null {\n  if (Number.isFinite(y) && Number.isFinite(y0) && y0 !== 0) {\n    return ((y as number) - (y0 as number)) / (y0 as number);\n  }\n  return null;\n}\n\n/**\n *\n * @param datasets\n * @param filter\n */\nexport function getLineChart(datasets: Datasets, filter: Filter): LineChart {\n  const {dataId, yAxis, plotType, lineChart} = filter;\n  const {aggregation, interval} = plotType;\n  const seriesDataId = dataId[0];\n  const bins = (filter as TimeRangeFilter).timeBins?.[seriesDataId]?.[interval];\n\n  if (\n    lineChart &&\n    lineChart.aggregation === aggregation &&\n    lineChart.interval === interval &&\n    lineChart.yAxis === yAxis?.name &&\n    // we need to make sure we validate bins because of cross filter data changes\n    isEqual(bins, lineChart?.bins)\n  ) {\n    // don't update lineChart if plotType hasn't change\n    return lineChart;\n  }\n\n  const dataset = datasets[seriesDataId];\n  const getYValue = getValueAggrFunc(yAxis, aggregation, dataset);\n\n  const init: LineDatum[] = [];\n  const series = (bins || []).reduce((accu, bin, i) => {\n    const y = getYValue(bin);\n    const delta = getDelta(accu, y, interval);\n    accu.push({\n      x: bin.x0,\n      y,\n      ...delta\n    });\n    return accu;\n  }, init);\n\n  const yDomain = extent<{y: any}>(series, d => d.y);\n  const xDomain = bins ? [bins[0].x0, bins[bins.length - 1].x1] : [];\n\n  // treat missing data as another series\n  const split = splitSeries(series);\n  const aggrName = AGGREGATION_NAME[aggregation];\n\n  return {\n    // @ts-ignore\n    yDomain,\n    // @ts-ignore\n    xDomain,\n    interval,\n    aggregation,\n    // @ts-ignore\n    series: split,\n    title: `${aggrName}${' of '}${yAxis ? yAxis.name : 'Count'}`,\n    fieldType: yAxis ? yAxis.type : 'integer',\n    yAxis: yAxis ? yAxis.name : null,\n    allTime: {\n      title: `All Time Average`,\n      value: aggregate(series, AGGREGATION_TYPES.average, d => d.y)\n    },\n    // @ts-expect-error bins is Bins[], not a Bins map. Refactor to use correct types.\n    bins\n  };\n}\n\n// split into multiple series when see missing data\nexport function splitSeries(series) {\n  const lines: any[] = [];\n  let temp: any[] = [];\n  for (let i = 0; i < series.length; i++) {\n    const d = series[i];\n    if (!notNullorUndefined(d.y) && temp.length) {\n      // ends temp\n      lines.push(temp);\n      temp = [];\n    } else if (notNullorUndefined(d.y)) {\n      temp.push(d);\n    }\n\n    if (i === series.length - 1 && temp.length) {\n      lines.push(temp);\n    }\n  }\n\n  const markers = lines.length > 1 ? series.filter(d => notNullorUndefined(d.y)) : [];\n\n  return {lines, markers};\n}\n\ntype MinVisStateForAnimationWindow = {\n  datasets: Datasets;\n};\n\nexport function adjustValueToAnimationWindow<S extends MinVisStateForAnimationWindow>(\n  state: S,\n  filter: TimeRangeFilter\n) {\n  const {\n    plotType,\n    value: [value0, value1],\n    animationWindow\n  } = filter;\n\n  const interval = plotType.interval || getInitialInterval(filter, state.datasets);\n  const bins = getTimeBins(filter, state.datasets, interval);\n  const datasetBins = bins && Object.keys(bins).length && Object.values(bins)[0][interval];\n  const thresholds = (datasetBins || []).map(b => b.x0);\n\n  let val0 = value0;\n  let val1 = value1;\n  let idx;\n  if (animationWindow === ANIMATION_WINDOW.interval) {\n    val0 = snapToMarks(value1, thresholds);\n    idx = thresholds.indexOf(val0);\n    val1 = idx > -1 ? datasetBins[idx].x1 : NaN;\n  } else {\n    // fit current value to window\n    val0 = snapToMarks(value0, thresholds);\n    val1 = snapToMarks(value1, thresholds);\n\n    if (val0 === val1) {\n      idx = thresholds.indexOf(val0);\n      if (idx === thresholds.length - 1) {\n        val0 = thresholds[idx - 1];\n      } else {\n        val1 = thresholds[idx + 1];\n      }\n    }\n  }\n\n  const updatedFilter = {\n    ...filter,\n    plotType: {\n      ...filter.plotType,\n      interval\n    },\n    timeBins: bins,\n    value: [val0, val1]\n  };\n\n  return updatedFilter;\n}\n\n/**\n * Create or update colors for a filter plot\n * @param filter\n * @param datasets\n * @param oldColorsByDataId\n */\nfunction getFilterPlotColorsByDataId(filter, datasets, oldColorsByDataId) {\n  let colorsByDataId = oldColorsByDataId || {};\n  for (const dataId of filter.dataId) {\n    if (!colorsByDataId[dataId] && datasets[dataId]) {\n      colorsByDataId = {\n        ...colorsByDataId,\n        [dataId]: rgbToHex(datasets[dataId].color)\n      };\n    }\n  }\n  return colorsByDataId;\n}\n\n/**\n *\n * @param filter\n * @param plotType\n * @param datasets\n * @param dataId\n */\nexport function updateTimeFilterPlotType(\n  filter: TimeRangeFilter,\n  plotType: TimeRangeFilter['plotType'],\n  datasets: Datasets,\n  dataId?: string\n): TimeRangeFilter {\n  let nextFilter = filter;\n  let nextPlotType = plotType;\n  if (typeof nextPlotType !== 'object' || !nextPlotType.aggregation || !nextPlotType.interval) {\n    nextPlotType = getDefaultPlotType(filter, datasets);\n  }\n\n  if (filter.dataId.length > 1) {\n    nextPlotType = {\n      ...nextPlotType,\n      colorsByDataId: getFilterPlotColorsByDataId(filter, datasets, nextPlotType.colorsByDataId)\n    };\n  }\n  nextFilter = {\n    ...nextFilter,\n    plotType: nextPlotType\n  };\n\n  const bins = getTimeBins(nextFilter, datasets, nextPlotType.interval);\n\n  nextFilter = {\n    ...nextFilter,\n    timeBins: bins\n  };\n\n  if (plotType.type === PLOT_TYPES.histogram) {\n    // Histogram is calculated and memoized in the chart itself\n  } else if (plotType.type === PLOT_TYPES.lineChart) {\n    // we should be able to move this into its own component so react will do the shallow comparison for us.\n    nextFilter = {\n      ...nextFilter,\n      lineChart: getLineChart(datasets, nextFilter)\n    };\n  }\n\n  return nextFilter;\n}\n\nexport function getRangeFilterBins(filter, datasets, numBins) {\n  const {domain} = filter;\n  if (!filter.dataId) return null;\n\n  return filter.dataId.reduce((acc, dataId, datasetIdx) => {\n    if (filter.bins?.[dataId]) {\n      // don't recalculate bins\n      acc[dataId] = filter.bins[dataId];\n      return acc;\n    }\n    const fieldName = filter.name[datasetIdx];\n    if (dataId && fieldName) {\n      const dataset = datasets[dataId];\n      const field = dataset?.getColumnField(fieldName);\n      if (dataset && field) {\n        const indexes = runGpuFilterForPlot(dataset, filter);\n        const valueAccessor = index => field.valueAccessor({index});\n        acc[dataId] = histogramFromDomain(domain, indexes, numBins, valueAccessor);\n      }\n    }\n    return acc;\n  }, {});\n}\n\nexport function updateRangeFilterPlotType(\n  filter: RangeFilter,\n  plotType: RangeFilter['plotType'],\n  datasets: Datasets,\n  dataId?: string\n): RangeFilter {\n  const nextFilter = {\n    ...filter,\n    plotType\n  };\n\n  // if (dataId) {\n  //   // clear bins\n  //   nextFilter = {\n  //     ...nextFilter,\n  //     bins: {\n  //       ...nextFilter.bins,\n  //       [dataId]: null\n  //     }\n  //   };\n  // }\n\n  return {\n    ...filter,\n    plotType,\n    bins: getRangeFilterBins(nextFilter, datasets, BINS)\n  };\n}\n\nexport function getChartTitle(\n  yAxis: {displayName?: string},\n  plotType: {aggregation: string}\n): string {\n  const yAxisName = yAxis?.displayName;\n  const {aggregation} = plotType;\n\n  if (yAxisName) {\n    return capitalizeFirstLetter(`${aggregation} ${yAxisName} over Time`);\n  }\n\n  return `Count of Rows over Time`;\n}\n\nexport function getDefaultPlotType(filter, datasets) {\n  const interval = getInitialInterval(filter, datasets);\n  const defaultTimeFormat = getDefaultTimeFormat(interval);\n  return {\n    interval,\n    defaultTimeFormat,\n    type: PLOT_TYPES.histogram,\n    aggregation: AGGREGATION_TYPES.sum\n  };\n}\n"],"mappings":"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","ignoreList":[]}
637
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_d3Array","require","_lodash","_interopRequireDefault","_time","_moment","_commonUtils","_constants","_dataUtils","_aggregation","_strings","_format","_colorUtils","_createForOfIteratorHelper","r","e","t","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","_n","F","s","n","done","value","f","TypeError","o","a","u","call","next","_arrayLikeToArray","toString","slice","constructor","name","from","test","ownKeys","Object","keys","getOwnPropertySymbols","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","histogramFromThreshold","thresholds","values","valueAccessor","filterEmptyBins","undefined","getBins","d3Histogram","domain","bins","map","bin","count","indexes","x0","x1","b","histogramFromValues","numBins","isNumber","histogramFromOrdinal","histogramFromDomain","ticks","getTimeBins","datasets","interval","timeBins","dataId","dataIdIdx","dataset","runGpuFilterForPlot","binByTime","mappedValue","getFilterMappedValue","intervalBins","getBinThresholds","idx","timeInterval","intervalToFunction","_domain","_slicedToArray2","t0","t1","floor","getTime","ceiling","ceil","durationDay","binThresholds","range","moment","utc","valueOf","lastStep","offset","skipIndexes","getSkipIndexes","_dataset$gpuFilter","gpuFilter","filterValueUpdateTriggers","filterRange","filterValueAccessor","filteredIndex","getFilterValue","dataContainer","allChannels","_","i","skipAll","includes","filterData","getFilterDataFunc","gpuFilters","valueIndex","findIndex","id","filterColumn","reduce","accu","item","skips","index","every","val","validBin","snapToMarks","marks","bisectLeft","normalizeValue","minValue","step","roundValToStep","isPercentField","field","metadata","numerator","denominator","updateAggregationByField","aggregation","AGGREGATION_TYPES","average","getAgregationType","getAggregationAccessor","fields","numeratorIdx","denominatorIdx","getNumerator","valueAt","getDenominator","getValueAggrFunc","exports","datasetField","find","aggregate","getAggregationOptiosnBasedOnField","TIME_AGGREGATION","_ref","sum","getDelta","y","lastBin","delta","pct","getPctChange","y0","Number","isFinite","getLineChart","_timeBins","yAxis","plotType","lineChart","seriesDataId","isEqual","getYValue","init","series","x","yDomain","extent","d","xDomain","split","splitSeries","aggrName","AGGREGATION_NAME","title","concat","fieldType","type","allTime","lines","temp","notNullorUndefined","markers","adjustValueToAnimationWindow","state","_filter$value","value0","value1","animationWindow","getInitialInterval","datasetBins","val0","val1","ANIMATION_WINDOW","indexOf","NaN","updatedFilter","getFilterPlotColorsByDataId","oldColorsByDataId","colorsByDataId","_iterator","_step","rgbToHex","color","err","updateTimeFilterPlotType","nextFilter","nextPlotType","_typeof2","getDefaultPlotType","PLOT_TYPES","histogram","getRangeFilterBins","acc","datasetIdx","_filter$bins","fieldName","getColumnField","updateRangeFilterPlotType","BINS","getChartTitle","yAxisName","displayName","capitalizeFirstLetter","defaultTimeFormat","getDefaultTimeFormat"],"sources":["../src/plot.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {bisectLeft, extent, histogram as d3Histogram, ticks} from 'd3-array';\nimport isEqual from 'lodash.isequal';\nimport {getFilterMappedValue, getInitialInterval, intervalToFunction} from './time';\nimport moment from 'moment';\nimport {\n  Bin,\n  TimeBins,\n  Millisecond,\n  TimeRangeFilter,\n  RangeFilter,\n  PlotType,\n  Filter,\n  LineChart,\n  Field,\n  ValueOf,\n  LineDatum\n} from '@kepler.gl/types';\nimport {notNullorUndefined} from '@kepler.gl/common-utils';\nimport {\n  ANIMATION_WINDOW,\n  BINS,\n  durationDay,\n  TIME_AGGREGATION,\n  AGGREGATION_TYPES,\n  PLOT_TYPES,\n  AggregationTypes\n} from '@kepler.gl/constants';\n\nimport {isNumber, roundValToStep} from './data-utils';\nimport {aggregate, AGGREGATION_NAME} from './aggregation';\nimport {capitalizeFirstLetter} from './strings';\nimport {getDefaultTimeFormat} from './format';\nimport {rgbToHex} from './color-utils';\nimport {DataContainerInterface} from '.';\nimport {KeplerTableModel} from './types';\n\n// TODO kepler-table module isn't accessible from utils. Add compatible interface to types\ntype Datasets = any;\n\n/**\n *\n * @param thresholds\n * @param values\n * @param indexes\n */\nexport function histogramFromThreshold(\n  thresholds: number[],\n  values: number[],\n  valueAccessor?: (d: unknown) => number,\n  filterEmptyBins = true\n): Bin[] {\n  const getBins = d3Histogram()\n    .domain([thresholds[0], thresholds[thresholds.length - 1]])\n    .thresholds(thresholds);\n\n  if (valueAccessor) {\n    getBins.value(valueAccessor);\n  }\n\n  // @ts-ignore\n  const bins = getBins(values).map(bin => ({\n    count: bin.length,\n    indexes: bin,\n    x0: bin.x0,\n    x1: bin.x1\n  }));\n\n  // d3-histogram ignores threshold values outside the domain\n  // The first bin.x0 is always equal to the minimum domain value, and the last bin.x1 is always equal to the maximum domain value.\n\n  // bins[0].x0 = thresholds[0];\n  // bins[bins.length - 1].x1 = thresholds[thresholds.length - 1];\n\n  // @ts-ignore\n  return filterEmptyBins ? bins.filter(b => b.count > 0) : bins;\n}\n\n/**\n *\n * @param values\n * @param numBins\n * @param valueAccessor\n */\nexport function histogramFromValues(\n  values: (Millisecond | null | number)[],\n  numBins: number,\n  valueAccessor?: (d: number) => number\n) {\n  const getBins = d3Histogram().thresholds(numBins);\n\n  if (valueAccessor) {\n    getBins.value(valueAccessor);\n  }\n\n  // @ts-ignore d3-array types doesn't match\n  return getBins(values)\n    .map(bin => ({\n      count: bin.length,\n      indexes: bin,\n      x0: bin.x0,\n      x1: bin.x1\n    }))\n    .filter(b => {\n      const {x0, x1} = b;\n      return isNumber(x0) && isNumber(x1);\n    });\n}\n\nexport function histogramFromOrdinal(\n  domain: [string],\n  values: (Millisecond | null | number)[],\n  valueAccessor?: (d: unknown) => string\n): Bin[] {\n  // @ts-expect-error to typed to expect strings\n  const getBins = d3Histogram().thresholds(domain);\n  if (valueAccessor) {\n    // @ts-expect-error to typed to expect strings\n    getBins.value(valueAccessor);\n  }\n\n  // @ts-expect-error null values aren't expected\n  const bins = getBins(values);\n\n  // @ts-ignore d3-array types doesn't match\n  return bins.map(bin => ({\n    count: bin.length,\n    indexes: bin,\n    x0: bin.x0,\n    x1: bin.x0\n  }));\n}\n\n/**\n *\n * @param domain\n * @param values\n * @param numBins\n * @param valueAccessor\n */\nexport function histogramFromDomain(\n  domain: [number, number],\n  values: (Millisecond | null | number)[],\n  numBins: number,\n  valueAccessor?: (d: unknown) => number\n): Bin[] {\n  const getBins = d3Histogram().thresholds(ticks(domain[0], domain[1], numBins)).domain(domain);\n  if (valueAccessor) {\n    getBins.value(valueAccessor);\n  }\n\n  // @ts-ignore d3-array types doesn't match\n  return getBins(values).map(bin => ({\n    count: bin.length,\n    indexes: bin,\n    x0: bin.x0,\n    x1: bin.x1\n  }));\n}\n\n/**\n * @param filter\n * @param datasets\n * @param interval\n */\nexport function getTimeBins(\n  filter: TimeRangeFilter,\n  datasets: Datasets,\n  interval: PlotType['interval']\n): TimeBins {\n  let bins = filter.timeBins || {};\n\n  filter.dataId.forEach((dataId, dataIdIdx) => {\n    // reuse bins if filterData did not change\n    if (bins[dataId] && bins[dataId][interval]) {\n      return;\n    }\n    const dataset = datasets[dataId];\n\n    // do not apply current filter\n    const indexes = runGpuFilterForPlot(dataset, filter);\n\n    bins = {\n      ...bins,\n      [dataId]: {\n        ...bins[dataId],\n        [interval]: binByTime(indexes, dataset, interval, filter)\n      }\n    };\n  });\n\n  return bins;\n}\n\nexport function binByTime(indexes, dataset, interval, filter) {\n  // gpuFilters need to be apply to filteredIndex\n  const mappedValue = getFilterMappedValue(dataset, filter);\n  if (!mappedValue) {\n    return null;\n  }\n  const intervalBins = getBinThresholds(interval, filter.domain);\n  const valueAccessor = idx => mappedValue[idx];\n  const bins = histogramFromThreshold(intervalBins, indexes, valueAccessor);\n\n  return bins;\n}\n\nexport function getBinThresholds(interval: string, domain: number[]): number[] {\n  const timeInterval = intervalToFunction(interval);\n  const [t0, t1] = domain;\n  const floor = timeInterval.floor(t0).getTime();\n  const ceiling = timeInterval.ceil(t1).getTime();\n\n  if (!timeInterval) {\n    // if time interval is not defined\n    // this should not happen\n    return [t0, t0 + durationDay];\n  }\n  const binThresholds = timeInterval.range(floor, ceiling + 1).map(t => moment.utc(t).valueOf());\n  const lastStep = binThresholds[binThresholds.length - 1];\n  if (lastStep === t1) {\n    // when last step equal to domain max, add one more step\n    binThresholds.push(moment.utc(timeInterval.offset(lastStep)).valueOf());\n  }\n\n  return binThresholds;\n}\n\n/**\n * Run GPU filter on current filter result to generate indexes for ploting chart\n * Skip ruuning for the same field\n * @param dataset\n * @param filter\n */\nexport function runGpuFilterForPlot<K extends KeplerTableModel<K, L>, L>(\n  dataset: K,\n  filter?: Filter\n): number[] {\n  const skipIndexes = getSkipIndexes(dataset, filter);\n\n  const {\n    gpuFilter: {filterValueUpdateTriggers, filterRange, filterValueAccessor},\n    filteredIndex\n  } = dataset;\n  const getFilterValue = filterValueAccessor(dataset.dataContainer)();\n\n  const allChannels = Object.keys(filterValueUpdateTriggers)\n    .map((_, i) => i)\n    .filter(i => Object.values(filterValueUpdateTriggers)[i]);\n  const skipAll = !allChannels.filter(i => !skipIndexes.includes(i)).length;\n  if (skipAll) {\n    return filteredIndex;\n  }\n\n  const filterData = getFilterDataFunc(\n    filterRange,\n    getFilterValue,\n    dataset.dataContainer,\n    skipIndexes\n  );\n\n  return filteredIndex.filter(filterData);\n}\n\nfunction getSkipIndexes(dataset, filter) {\n  // array of gpu filter names\n  if (!filter) {\n    return [];\n  }\n  const gpuFilters = Object.values(dataset.gpuFilter.filterValueUpdateTriggers) as ({\n    name: string;\n  } | null)[];\n  const valueIndex = filter.dataId.findIndex(id => id === dataset.id);\n  const filterColumn = filter.name[valueIndex];\n\n  return gpuFilters.reduce((accu, item, idx) => {\n    if (item && filterColumn === item.name) {\n      accu.push(idx);\n    }\n    return accu;\n  }, [] as number[]);\n}\n\nexport function getFilterDataFunc(\n  filterRange,\n  getFilterValue,\n  dataContainer: DataContainerInterface,\n  skips\n) {\n  return index =>\n    getFilterValue({index}).every(\n      (val, i) => skips.includes(i) || (val >= filterRange[i][0] && val <= filterRange[i][1])\n    );\n}\n\nexport function validBin(b) {\n  return b.x0 !== undefined && b.x1 !== undefined;\n}\n\n/**\n * Use in slider, given a number and an array of numbers, return the nears number from the array.\n * Takes a value, timesteps and return the actual step.\n * @param value\n * @param marks\n */\nexport function snapToMarks(value: number, marks: number[]): number {\n  // always use bin x0\n  if (!marks.length) {\n    // @ts-expect-error looking at the usage null return value isn't expected and requires extra handling in a lot of places\n    return null;\n  }\n  const i = bisectLeft(marks, value);\n  if (i === 0) {\n    return marks[i];\n  } else if (i === marks.length) {\n    return marks[i - 1];\n  }\n  const idx = marks[i] - value < value - marks[i - 1] ? i : i - 1;\n  return marks[idx];\n}\n\nexport function normalizeValue(val, minValue, step, marks) {\n  if (marks && marks.length) {\n    return snapToMarks(val, marks);\n  }\n\n  return roundValToStep(minValue, step, val);\n}\n\nexport function isPercentField(field) {\n  return field.metadata && field.metadata.numerator && field.metadata.denominator;\n}\n\nexport function updateAggregationByField(field: Field, aggregation: ValueOf<AggregationTypes>) {\n  // shouldn't apply sum to percent fiele type\n  // default aggregation is average\n  return field && isPercentField(field)\n    ? AGGREGATION_TYPES.average\n    : aggregation || AGGREGATION_TYPES.average;\n}\n\nconst getAgregationType = (field, aggregation) => {\n  if (isPercentField(field)) {\n    return 'mean_of_percent';\n  }\n  return aggregation;\n};\n\nconst getAggregationAccessor = (field, dataContainer: DataContainerInterface, fields) => {\n  if (isPercentField(field)) {\n    const numeratorIdx = fields.findIndex(f => f.name === field.metadata.numerator);\n    const denominatorIdx = fields.findIndex(f => f.name === field.metadata.denominator);\n\n    return {\n      getNumerator: i => dataContainer.valueAt(i, numeratorIdx),\n      getDenominator: i => dataContainer.valueAt(i, denominatorIdx)\n    };\n  }\n\n  return i => field.valueAccessor({index: i});\n};\n\nexport const getValueAggrFunc = (\n  field: Field | string | null,\n  aggregation: string,\n  dataset: KeplerTableModel<any, any>\n): ((bin: Bin) => number) => {\n  const {dataContainer, fields} = dataset;\n\n  // The passed-in field might not have all the fields set (e.g. valueAccessor)\n  const datasetField = fields.find(\n    f => field && (f.name === field || f.name === (field as Field).name)\n  );\n\n  return datasetField && aggregation\n    ? bin =>\n        aggregate(\n          bin.indexes,\n          getAgregationType(datasetField, aggregation),\n          // @ts-expect-error can return {getNumerator, getDenominator}\n          getAggregationAccessor(datasetField, dataContainer, fields)\n        )\n    : bin => bin.count;\n};\n\nexport const getAggregationOptiosnBasedOnField = field => {\n  if (isPercentField(field)) {\n    // don't show sum\n    return TIME_AGGREGATION.filter(({id}) => id !== AGGREGATION_TYPES.sum);\n  }\n  return TIME_AGGREGATION;\n};\n\nfunction getDelta(\n  bins: LineDatum[],\n  y: number,\n  interval: PlotType['interval']\n): Partial<LineDatum> & {delta: 'last'; pct: number | null} {\n  // if (WOW[interval]) return getWow(bins, y, interval);\n  const lastBin = bins[bins.length - 1];\n\n  return {\n    delta: 'last',\n    pct: lastBin ? getPctChange(y, lastBin.y) : null\n  };\n}\n\nexport function getPctChange(y: unknown, y0: unknown): number | null {\n  if (Number.isFinite(y) && Number.isFinite(y0) && y0 !== 0) {\n    return ((y as number) - (y0 as number)) / (y0 as number);\n  }\n  return null;\n}\n\n/**\n *\n * @param datasets\n * @param filter\n */\nexport function getLineChart(datasets: Datasets, filter: Filter): LineChart {\n  const {dataId, yAxis, plotType, lineChart} = filter;\n  const {aggregation, interval} = plotType;\n  const seriesDataId = dataId[0];\n  const bins = (filter as TimeRangeFilter).timeBins?.[seriesDataId]?.[interval];\n\n  if (\n    lineChart &&\n    lineChart.aggregation === aggregation &&\n    lineChart.interval === interval &&\n    lineChart.yAxis === yAxis?.name &&\n    // we need to make sure we validate bins because of cross filter data changes\n    isEqual(bins, lineChart?.bins)\n  ) {\n    // don't update lineChart if plotType hasn't change\n    return lineChart;\n  }\n\n  const dataset = datasets[seriesDataId];\n  const getYValue = getValueAggrFunc(yAxis, aggregation, dataset);\n\n  const init: LineDatum[] = [];\n  const series = (bins || []).reduce((accu, bin, i) => {\n    const y = getYValue(bin);\n    const delta = getDelta(accu, y, interval);\n    accu.push({\n      x: bin.x0,\n      y,\n      ...delta\n    });\n    return accu;\n  }, init);\n\n  const yDomain = extent<{y: any}>(series, d => d.y);\n  const xDomain = bins ? [bins[0].x0, bins[bins.length - 1].x1] : [];\n\n  // treat missing data as another series\n  const split = splitSeries(series);\n  const aggrName = AGGREGATION_NAME[aggregation];\n\n  return {\n    // @ts-ignore\n    yDomain,\n    // @ts-ignore\n    xDomain,\n    interval,\n    aggregation,\n    // @ts-ignore\n    series: split,\n    title: `${aggrName}${' of '}${yAxis ? yAxis.name : 'Count'}`,\n    fieldType: yAxis ? yAxis.type : 'integer',\n    yAxis: yAxis ? yAxis.name : null,\n    allTime: {\n      title: `All Time Average`,\n      value: aggregate(series, AGGREGATION_TYPES.average, d => d.y)\n    },\n    // @ts-expect-error bins is Bins[], not a Bins map. Refactor to use correct types.\n    bins\n  };\n}\n\n// split into multiple series when see missing data\nexport function splitSeries(series) {\n  const lines: any[] = [];\n  let temp: any[] = [];\n  for (let i = 0; i < series.length; i++) {\n    const d = series[i];\n    if (!notNullorUndefined(d.y) && temp.length) {\n      // ends temp\n      lines.push(temp);\n      temp = [];\n    } else if (notNullorUndefined(d.y)) {\n      temp.push(d);\n    }\n\n    if (i === series.length - 1 && temp.length) {\n      lines.push(temp);\n    }\n  }\n\n  const markers = lines.length > 1 ? series.filter(d => notNullorUndefined(d.y)) : [];\n\n  return {lines, markers};\n}\n\ntype MinVisStateForAnimationWindow = {\n  datasets: Datasets;\n};\n\nexport function adjustValueToAnimationWindow<S extends MinVisStateForAnimationWindow>(\n  state: S,\n  filter: TimeRangeFilter\n) {\n  const {\n    plotType,\n    value: [value0, value1],\n    animationWindow\n  } = filter;\n\n  const interval = plotType.interval || getInitialInterval(filter, state.datasets);\n  const bins = getTimeBins(filter, state.datasets, interval);\n  const datasetBins = bins && Object.keys(bins).length && Object.values(bins)[0][interval];\n  const thresholds = (datasetBins || []).map(b => b.x0);\n\n  let val0 = value0;\n  let val1 = value1;\n  let idx;\n  if (animationWindow === ANIMATION_WINDOW.interval) {\n    val0 = snapToMarks(value1, thresholds);\n    idx = thresholds.indexOf(val0);\n    val1 = idx > -1 ? datasetBins[idx].x1 : NaN;\n  } else {\n    // fit current value to window\n    val0 = snapToMarks(value0, thresholds);\n    val1 = snapToMarks(value1, thresholds);\n\n    if (val0 === val1) {\n      idx = thresholds.indexOf(val0);\n      if (idx === thresholds.length - 1) {\n        val0 = thresholds[idx - 1];\n      } else {\n        val1 = thresholds[idx + 1];\n      }\n    }\n  }\n\n  const updatedFilter = {\n    ...filter,\n    plotType: {\n      ...filter.plotType,\n      interval\n    },\n    timeBins: bins,\n    value: [val0, val1]\n  };\n\n  return updatedFilter;\n}\n\n/**\n * Create or update colors for a filter plot\n * @param filter\n * @param datasets\n * @param oldColorsByDataId\n */\nfunction getFilterPlotColorsByDataId(filter, datasets, oldColorsByDataId) {\n  let colorsByDataId = oldColorsByDataId || {};\n  for (const dataId of filter.dataId) {\n    if (!colorsByDataId[dataId] && datasets[dataId]) {\n      colorsByDataId = {\n        ...colorsByDataId,\n        [dataId]: rgbToHex(datasets[dataId].color)\n      };\n    }\n  }\n  return colorsByDataId;\n}\n\n/**\n *\n * @param filter\n * @param plotType\n * @param datasets\n * @param dataId\n */\nexport function updateTimeFilterPlotType(\n  filter: TimeRangeFilter,\n  plotType: TimeRangeFilter['plotType'],\n  datasets: Datasets,\n  dataId?: string\n): TimeRangeFilter {\n  let nextFilter = filter;\n  let nextPlotType = plotType;\n  if (typeof nextPlotType !== 'object' || !nextPlotType.aggregation || !nextPlotType.interval) {\n    nextPlotType = getDefaultPlotType(filter, datasets);\n  }\n\n  if (filter.dataId.length > 1) {\n    nextPlotType = {\n      ...nextPlotType,\n      colorsByDataId: getFilterPlotColorsByDataId(filter, datasets, nextPlotType.colorsByDataId)\n    };\n  }\n  nextFilter = {\n    ...nextFilter,\n    plotType: nextPlotType\n  };\n\n  const bins = getTimeBins(nextFilter, datasets, nextPlotType.interval);\n\n  nextFilter = {\n    ...nextFilter,\n    timeBins: bins\n  };\n\n  if (plotType.type === PLOT_TYPES.histogram) {\n    // Histogram is calculated and memoized in the chart itself\n  } else if (plotType.type === PLOT_TYPES.lineChart) {\n    // we should be able to move this into its own component so react will do the shallow comparison for us.\n    nextFilter = {\n      ...nextFilter,\n      lineChart: getLineChart(datasets, nextFilter)\n    };\n  }\n\n  return nextFilter;\n}\n\nexport function getRangeFilterBins(filter, datasets, numBins) {\n  const {domain} = filter;\n  if (!filter.dataId) return null;\n\n  return filter.dataId.reduce((acc, dataId, datasetIdx) => {\n    if (filter.bins?.[dataId]) {\n      // don't recalculate bins\n      acc[dataId] = filter.bins[dataId];\n      return acc;\n    }\n    const fieldName = filter.name[datasetIdx];\n    if (dataId && fieldName) {\n      const dataset = datasets[dataId];\n      const field = dataset?.getColumnField(fieldName);\n      if (dataset && field) {\n        const indexes = runGpuFilterForPlot(dataset, filter);\n        const valueAccessor = index => field.valueAccessor({index});\n        acc[dataId] = histogramFromDomain(domain, indexes, numBins, valueAccessor);\n      }\n    }\n    return acc;\n  }, {});\n}\n\nexport function updateRangeFilterPlotType(\n  filter: RangeFilter,\n  plotType: RangeFilter['plotType'],\n  datasets: Datasets,\n  dataId?: string\n): RangeFilter {\n  const nextFilter = {\n    ...filter,\n    plotType\n  };\n\n  // if (dataId) {\n  //   // clear bins\n  //   nextFilter = {\n  //     ...nextFilter,\n  //     bins: {\n  //       ...nextFilter.bins,\n  //       [dataId]: null\n  //     }\n  //   };\n  // }\n\n  return {\n    ...filter,\n    plotType,\n    bins: getRangeFilterBins(nextFilter, datasets, BINS)\n  };\n}\n\nexport function getChartTitle(yAxis: Field, plotType: PlotType): string {\n  const yAxisName = yAxis?.displayName;\n  const {aggregation} = plotType;\n\n  if (yAxisName) {\n    return capitalizeFirstLetter(`${aggregation} ${yAxisName} over Time`);\n  }\n\n  return `Count of Rows over Time`;\n}\n\nexport function getDefaultPlotType(filter, datasets) {\n  const interval = getInitialInterval(filter, datasets);\n  const defaultTimeFormat = getDefaultTimeFormat(interval);\n  return {\n    interval,\n    defaultTimeFormat,\n    type: PLOT_TYPES.histogram,\n    aggregation: AGGREGATION_TYPES.sum\n  };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,IAAAA,QAAA,GAAAC,OAAA;AACA,IAAAC,OAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,KAAA,GAAAH,OAAA;AACA,IAAAI,OAAA,GAAAF,sBAAA,CAAAF,OAAA;AAcA,IAAAK,YAAA,GAAAL,OAAA;AACA,IAAAM,UAAA,GAAAN,OAAA;AAUA,IAAAO,UAAA,GAAAP,OAAA;AACA,IAAAQ,YAAA,GAAAR,OAAA;AACA,IAAAS,QAAA,GAAAT,OAAA;AACA,IAAAU,OAAA,GAAAV,OAAA;AACA,IAAAW,WAAA,GAAAX,OAAA;AAAuC,SAAAY,2BAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,yBAAAC,MAAA,IAAAH,CAAA,CAAAG,MAAA,CAAAC,QAAA,KAAAJ,CAAA,qBAAAE,CAAA,QAAAG,KAAA,CAAAC,OAAA,CAAAN,CAAA,MAAAE,CAAA,GAAAK,2BAAA,CAAAP,CAAA,MAAAC,CAAA,IAAAD,CAAA,uBAAAA,CAAA,CAAAQ,MAAA,IAAAN,CAAA,KAAAF,CAAA,GAAAE,CAAA,OAAAO,EAAA,MAAAC,CAAA,YAAAA,EAAA,eAAAC,CAAA,EAAAD,CAAA,EAAAE,CAAA,WAAAA,EAAA,WAAAH,EAAA,IAAAT,CAAA,CAAAQ,MAAA,KAAAK,IAAA,WAAAA,IAAA,MAAAC,KAAA,EAAAd,CAAA,CAAAS,EAAA,UAAAR,CAAA,WAAAA,EAAAD,CAAA,UAAAA,CAAA,KAAAe,CAAA,EAAAL,CAAA,gBAAAM,SAAA,iJAAAC,CAAA,EAAAC,CAAA,OAAAC,CAAA,gBAAAR,CAAA,WAAAA,EAAA,IAAAT,CAAA,GAAAA,CAAA,CAAAkB,IAAA,CAAApB,CAAA,MAAAY,CAAA,WAAAA,EAAA,QAAAZ,CAAA,GAAAE,CAAA,CAAAmB,IAAA,WAAAH,CAAA,GAAAlB,CAAA,CAAAa,IAAA,EAAAb,CAAA,KAAAC,CAAA,WAAAA,EAAAD,CAAA,IAAAmB,CAAA,OAAAF,CAAA,GAAAjB,CAAA,KAAAe,CAAA,WAAAA,EAAA,UAAAG,CAAA,YAAAhB,CAAA,cAAAA,CAAA,8BAAAiB,CAAA,QAAAF,CAAA;AAAA,SAAAV,4BAAAP,CAAA,EAAAkB,CAAA,QAAAlB,CAAA,2BAAAA,CAAA,SAAAsB,iBAAA,CAAAtB,CAAA,EAAAkB,CAAA,OAAAhB,CAAA,MAAAqB,QAAA,CAAAH,IAAA,CAAApB,CAAA,EAAAwB,KAAA,6BAAAtB,CAAA,IAAAF,CAAA,CAAAyB,WAAA,KAAAvB,CAAA,GAAAF,CAAA,CAAAyB,WAAA,CAAAC,IAAA,aAAAxB,CAAA,cAAAA,CAAA,GAAAG,KAAA,CAAAsB,IAAA,CAAA3B,CAAA,oBAAAE,CAAA,+CAAA0B,IAAA,CAAA1B,CAAA,IAAAoB,iBAAA,CAAAtB,CAAA,EAAAkB,CAAA;AAAA,SAAAI,kBAAAtB,CAAA,EAAAkB,CAAA,aAAAA,CAAA,IAAAA,CAAA,GAAAlB,CAAA,CAAAQ,MAAA,MAAAU,CAAA,GAAAlB,CAAA,CAAAQ,MAAA,YAAAP,CAAA,MAAAW,CAAA,GAAAP,KAAA,CAAAa,CAAA,GAAAjB,CAAA,GAAAiB,CAAA,EAAAjB,CAAA,IAAAW,CAAA,CAAAX,CAAA,IAAAD,CAAA,CAAAC,CAAA,UAAAW,CAAA;AAAA,SAAAiB,QAAA5B,CAAA,EAAAD,CAAA,QAAAE,CAAA,GAAA4B,MAAA,CAAAC,IAAA,CAAA9B,CAAA,OAAA6B,MAAA,CAAAE,qBAAA,QAAAf,CAAA,GAAAa,MAAA,CAAAE,qBAAA,CAAA/B,CAAA,GAAAD,CAAA,KAAAiB,CAAA,GAAAA,CAAA,CAAAgB,MAAA,WAAAjC,CAAA,WAAA8B,MAAA,CAAAI,wBAAA,CAAAjC,CAAA,EAAAD,CAAA,EAAAmC,UAAA,OAAAjC,CAAA,CAAAkC,IAAA,CAAAC,KAAA,CAAAnC,CAAA,EAAAe,CAAA,YAAAf,CAAA;AAAA,SAAAoC,cAAArC,CAAA,aAAAD,CAAA,MAAAA,CAAA,GAAAuC,SAAA,CAAA/B,MAAA,EAAAR,CAAA,UAAAE,CAAA,WAAAqC,SAAA,CAAAvC,CAAA,IAAAuC,SAAA,CAAAvC,CAAA,QAAAA,CAAA,OAAA6B,OAAA,CAAAC,MAAA,CAAA5B,CAAA,OAAAsC,OAAA,WAAAxC,CAAA,QAAAyC,gBAAA,aAAAxC,CAAA,EAAAD,CAAA,EAAAE,CAAA,CAAAF,CAAA,SAAA8B,MAAA,CAAAY,yBAAA,GAAAZ,MAAA,CAAAa,gBAAA,CAAA1C,CAAA,EAAA6B,MAAA,CAAAY,yBAAA,CAAAxC,CAAA,KAAA2B,OAAA,CAAAC,MAAA,CAAA5B,CAAA,GAAAsC,OAAA,WAAAxC,CAAA,IAAA8B,MAAA,CAAAc,cAAA,CAAA3C,CAAA,EAAAD,CAAA,EAAA8B,MAAA,CAAAI,wBAAA,CAAAhC,CAAA,EAAAF,CAAA,iBAAAC,CAAA,IAnCvC;AACA;AAsCA;;AAGA;AACA;AACA;AACA;AACA;AACA;AACO,SAAS4C,sBAAsBA,CACpCC,UAAoB,EACpBC,MAAgB,EAChBC,aAAsC,EAE/B;EAAA,IADPC,eAAe,GAAAV,SAAA,CAAA/B,MAAA,QAAA+B,SAAA,QAAAW,SAAA,GAAAX,SAAA,MAAG,IAAI;EAEtB,IAAMY,OAAO,GAAG,IAAAC,kBAAW,EAAC,CAAC,CAC1BC,MAAM,CAAC,CAACP,UAAU,CAAC,CAAC,CAAC,EAAEA,UAAU,CAACA,UAAU,CAACtC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAC1DsC,UAAU,CAACA,UAAU,CAAC;EAEzB,IAAIE,aAAa,EAAE;IACjBG,OAAO,CAACrC,KAAK,CAACkC,aAAa,CAAC;EAC9B;;EAEA;EACA,IAAMM,IAAI,GAAGH,OAAO,CAACJ,MAAM,CAAC,CAACQ,GAAG,CAAC,UAAAC,GAAG;IAAA,OAAK;MACvCC,KAAK,EAAED,GAAG,CAAChD,MAAM;MACjBkD,OAAO,EAAEF,GAAG;MACZG,EAAE,EAAEH,GAAG,CAACG,EAAE;MACVC,EAAE,EAAEJ,GAAG,CAACI;IACV,CAAC;EAAA,CAAC,CAAC;;EAEH;EACA;;EAEA;EACA;;EAEA;EACA,OAAOX,eAAe,GAAGK,IAAI,CAACrB,MAAM,CAAC,UAAA4B,CAAC;IAAA,OAAIA,CAAC,CAACJ,KAAK,GAAG,CAAC;EAAA,EAAC,GAAGH,IAAI;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACO,SAASQ,mBAAmBA,CACjCf,MAAuC,EACvCgB,OAAe,EACff,aAAqC,EACrC;EACA,IAAMG,OAAO,GAAG,IAAAC,kBAAW,EAAC,CAAC,CAACN,UAAU,CAACiB,OAAO,CAAC;EAEjD,IAAIf,aAAa,EAAE;IACjBG,OAAO,CAACrC,KAAK,CAACkC,aAAa,CAAC;EAC9B;;EAEA;EACA,OAAOG,OAAO,CAACJ,MAAM,CAAC,CACnBQ,GAAG,CAAC,UAAAC,GAAG;IAAA,OAAK;MACXC,KAAK,EAAED,GAAG,CAAChD,MAAM;MACjBkD,OAAO,EAAEF,GAAG;MACZG,EAAE,EAAEH,GAAG,CAACG,EAAE;MACVC,EAAE,EAAEJ,GAAG,CAACI;IACV,CAAC;EAAA,CAAC,CAAC,CACF3B,MAAM,CAAC,UAAA4B,CAAC,EAAI;IACX,IAAOF,EAAE,GAAQE,CAAC,CAAXF,EAAE;MAAEC,EAAE,GAAIC,CAAC,CAAPD,EAAE;IACb,OAAO,IAAAI,mBAAQ,EAACL,EAAE,CAAC,IAAI,IAAAK,mBAAQ,EAACJ,EAAE,CAAC;EACrC,CAAC,CAAC;AACN;AAEO,SAASK,oBAAoBA,CAClCZ,MAAgB,EAChBN,MAAuC,EACvCC,aAAsC,EAC/B;EACP;EACA,IAAMG,OAAO,GAAG,IAAAC,kBAAW,EAAC,CAAC,CAACN,UAAU,CAACO,MAAM,CAAC;EAChD,IAAIL,aAAa,EAAE;IACjB;IACAG,OAAO,CAACrC,KAAK,CAACkC,aAAa,CAAC;EAC9B;;EAEA;EACA,IAAMM,IAAI,GAAGH,OAAO,CAACJ,MAAM,CAAC;;EAE5B;EACA,OAAOO,IAAI,CAACC,GAAG,CAAC,UAAAC,GAAG;IAAA,OAAK;MACtBC,KAAK,EAAED,GAAG,CAAChD,MAAM;MACjBkD,OAAO,EAAEF,GAAG;MACZG,EAAE,EAAEH,GAAG,CAACG,EAAE;MACVC,EAAE,EAAEJ,GAAG,CAACG;IACV,CAAC;EAAA,CAAC,CAAC;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASO,mBAAmBA,CACjCb,MAAwB,EACxBN,MAAuC,EACvCgB,OAAe,EACff,aAAsC,EAC/B;EACP,IAAMG,OAAO,GAAG,IAAAC,kBAAW,EAAC,CAAC,CAACN,UAAU,CAAC,IAAAqB,cAAK,EAACd,MAAM,CAAC,CAAC,CAAC,EAAEA,MAAM,CAAC,CAAC,CAAC,EAAEU,OAAO,CAAC,CAAC,CAACV,MAAM,CAACA,MAAM,CAAC;EAC7F,IAAIL,aAAa,EAAE;IACjBG,OAAO,CAACrC,KAAK,CAACkC,aAAa,CAAC;EAC9B;;EAEA;EACA,OAAOG,OAAO,CAACJ,MAAM,CAAC,CAACQ,GAAG,CAAC,UAAAC,GAAG;IAAA,OAAK;MACjCC,KAAK,EAAED,GAAG,CAAChD,MAAM;MACjBkD,OAAO,EAAEF,GAAG;MACZG,EAAE,EAAEH,GAAG,CAACG,EAAE;MACVC,EAAE,EAAEJ,GAAG,CAACI;IACV,CAAC;EAAA,CAAC,CAAC;AACL;;AAEA;AACA;AACA;AACA;AACA;AACO,SAASQ,WAAWA,CACzBnC,MAAuB,EACvBoC,QAAkB,EAClBC,QAA8B,EACpB;EACV,IAAIhB,IAAI,GAAGrB,MAAM,CAACsC,QAAQ,IAAI,CAAC,CAAC;EAEhCtC,MAAM,CAACuC,MAAM,CAAChC,OAAO,CAAC,UAACgC,MAAM,EAAEC,SAAS,EAAK;IAC3C;IACA,IAAInB,IAAI,CAACkB,MAAM,CAAC,IAAIlB,IAAI,CAACkB,MAAM,CAAC,CAACF,QAAQ,CAAC,EAAE;MAC1C;IACF;IACA,IAAMI,OAAO,GAAGL,QAAQ,CAACG,MAAM,CAAC;;IAEhC;IACA,IAAMd,OAAO,GAAGiB,mBAAmB,CAACD,OAAO,EAAEzC,MAAM,CAAC;IAEpDqB,IAAI,GAAAhB,aAAA,CAAAA,aAAA,KACCgB,IAAI,WAAAb,gBAAA,iBACN+B,MAAM,EAAAlC,aAAA,CAAAA,aAAA,KACFgB,IAAI,CAACkB,MAAM,CAAC,WAAA/B,gBAAA,iBACd6B,QAAQ,EAAGM,SAAS,CAAClB,OAAO,EAAEgB,OAAO,EAAEJ,QAAQ,EAAErC,MAAM,CAAC,IAE5D;EACH,CAAC,CAAC;EAEF,OAAOqB,IAAI;AACb;AAEO,SAASsB,SAASA,CAAClB,OAAO,EAAEgB,OAAO,EAAEJ,QAAQ,EAAErC,MAAM,EAAE;EAC5D;EACA,IAAM4C,WAAW,GAAG,IAAAC,0BAAoB,EAACJ,OAAO,EAAEzC,MAAM,CAAC;EACzD,IAAI,CAAC4C,WAAW,EAAE;IAChB,OAAO,IAAI;EACb;EACA,IAAME,YAAY,GAAGC,gBAAgB,CAACV,QAAQ,EAAErC,MAAM,CAACoB,MAAM,CAAC;EAC9D,IAAML,aAAa,GAAG,SAAhBA,aAAaA,CAAGiC,GAAG;IAAA,OAAIJ,WAAW,CAACI,GAAG,CAAC;EAAA;EAC7C,IAAM3B,IAAI,GAAGT,sBAAsB,CAACkC,YAAY,EAAErB,OAAO,EAAEV,aAAa,CAAC;EAEzE,OAAOM,IAAI;AACb;AAEO,SAAS0B,gBAAgBA,CAACV,QAAgB,EAAEjB,MAAgB,EAAY;EAC7E,IAAM6B,YAAY,GAAG,IAAAC,wBAAkB,EAACb,QAAQ,CAAC;EACjD,IAAAc,OAAA,OAAAC,eAAA,aAAiBhC,MAAM;IAAhBiC,EAAE,GAAAF,OAAA;IAAEG,EAAE,GAAAH,OAAA;EACb,IAAMI,KAAK,GAAGN,YAAY,CAACM,KAAK,CAACF,EAAE,CAAC,CAACG,OAAO,CAAC,CAAC;EAC9C,IAAMC,OAAO,GAAGR,YAAY,CAACS,IAAI,CAACJ,EAAE,CAAC,CAACE,OAAO,CAAC,CAAC;EAE/C,IAAI,CAACP,YAAY,EAAE;IACjB;IACA;IACA,OAAO,CAACI,EAAE,EAAEA,EAAE,GAAGM,sBAAW,CAAC;EAC/B;EACA,IAAMC,aAAa,GAAGX,YAAY,CAACY,KAAK,CAACN,KAAK,EAAEE,OAAO,GAAG,CAAC,CAAC,CAACnC,GAAG,CAAC,UAAArD,CAAC;IAAA,OAAI6F,kBAAM,CAACC,GAAG,CAAC9F,CAAC,CAAC,CAAC+F,OAAO,CAAC,CAAC;EAAA,EAAC;EAC9F,IAAMC,QAAQ,GAAGL,aAAa,CAACA,aAAa,CAACrF,MAAM,GAAG,CAAC,CAAC;EACxD,IAAI0F,QAAQ,KAAKX,EAAE,EAAE;IACnB;IACAM,aAAa,CAACzD,IAAI,CAAC2D,kBAAM,CAACC,GAAG,CAACd,YAAY,CAACiB,MAAM,CAACD,QAAQ,CAAC,CAAC,CAACD,OAAO,CAAC,CAAC,CAAC;EACzE;EAEA,OAAOJ,aAAa;AACtB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACO,SAASlB,mBAAmBA,CACjCD,OAAU,EACVzC,MAAe,EACL;EACV,IAAMmE,WAAW,GAAGC,cAAc,CAAC3B,OAAO,EAAEzC,MAAM,CAAC;EAEnD,IAAAqE,kBAAA,GAGI5B,OAAO,CAFT6B,SAAS;IAAGC,yBAAyB,GAAAF,kBAAA,CAAzBE,yBAAyB;IAAEC,WAAW,GAAAH,kBAAA,CAAXG,WAAW;IAAEC,mBAAmB,GAAAJ,kBAAA,CAAnBI,mBAAmB;IACvEC,aAAa,GACXjC,OAAO,CADTiC,aAAa;EAEf,IAAMC,cAAc,GAAGF,mBAAmB,CAAChC,OAAO,CAACmC,aAAa,CAAC,CAAC,CAAC;EAEnE,IAAMC,WAAW,GAAGhF,MAAM,CAACC,IAAI,CAACyE,yBAAyB,CAAC,CACvDjD,GAAG,CAAC,UAACwD,CAAC,EAAEC,CAAC;IAAA,OAAKA,CAAC;EAAA,EAAC,CAChB/E,MAAM,CAAC,UAAA+E,CAAC;IAAA,OAAIlF,MAAM,CAACiB,MAAM,CAACyD,yBAAyB,CAAC,CAACQ,CAAC,CAAC;EAAA,EAAC;EAC3D,IAAMC,OAAO,GAAG,CAACH,WAAW,CAAC7E,MAAM,CAAC,UAAA+E,CAAC;IAAA,OAAI,CAACZ,WAAW,CAACc,QAAQ,CAACF,CAAC,CAAC;EAAA,EAAC,CAACxG,MAAM;EACzE,IAAIyG,OAAO,EAAE;IACX,OAAON,aAAa;EACtB;EAEA,IAAMQ,UAAU,GAAGC,iBAAiB,CAClCX,WAAW,EACXG,cAAc,EACdlC,OAAO,CAACmC,aAAa,EACrBT,WACF,CAAC;EAED,OAAOO,aAAa,CAAC1E,MAAM,CAACkF,UAAU,CAAC;AACzC;AAEA,SAASd,cAAcA,CAAC3B,OAAO,EAAEzC,MAAM,EAAE;EACvC;EACA,IAAI,CAACA,MAAM,EAAE;IACX,OAAO,EAAE;EACX;EACA,IAAMoF,UAAU,GAAGvF,MAAM,CAACiB,MAAM,CAAC2B,OAAO,CAAC6B,SAAS,CAACC,yBAAyB,CAEjE;EACX,IAAMc,UAAU,GAAGrF,MAAM,CAACuC,MAAM,CAAC+C,SAAS,CAAC,UAAAC,EAAE;IAAA,OAAIA,EAAE,KAAK9C,OAAO,CAAC8C,EAAE;EAAA,EAAC;EACnE,IAAMC,YAAY,GAAGxF,MAAM,CAACP,IAAI,CAAC4F,UAAU,CAAC;EAE5C,OAAOD,UAAU,CAACK,MAAM,CAAC,UAACC,IAAI,EAAEC,IAAI,EAAE3C,GAAG,EAAK;IAC5C,IAAI2C,IAAI,IAAIH,YAAY,KAAKG,IAAI,CAAClG,IAAI,EAAE;MACtCiG,IAAI,CAACvF,IAAI,CAAC6C,GAAG,CAAC;IAChB;IACA,OAAO0C,IAAI;EACb,CAAC,EAAE,EAAc,CAAC;AACpB;AAEO,SAASP,iBAAiBA,CAC/BX,WAAW,EACXG,cAAc,EACdC,aAAqC,EACrCgB,KAAK,EACL;EACA,OAAO,UAAAC,KAAK;IAAA,OACVlB,cAAc,CAAC;MAACkB,KAAK,EAALA;IAAK,CAAC,CAAC,CAACC,KAAK,CAC3B,UAACC,GAAG,EAAEhB,CAAC;MAAA,OAAKa,KAAK,CAACX,QAAQ,CAACF,CAAC,CAAC,IAAKgB,GAAG,IAAIvB,WAAW,CAACO,CAAC,CAAC,CAAC,CAAC,CAAC,IAAIgB,GAAG,IAAIvB,WAAW,CAACO,CAAC,CAAC,CAAC,CAAC,CAAE;IAAA,CACzF,CAAC;EAAA;AACL;AAEO,SAASiB,QAAQA,CAACpE,CAAC,EAAE;EAC1B,OAAOA,CAAC,CAACF,EAAE,KAAKT,SAAS,IAAIW,CAAC,CAACD,EAAE,KAAKV,SAAS;AACjD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACO,SAASgF,WAAWA,CAACpH,KAAa,EAAEqH,KAAe,EAAU;EAClE;EACA,IAAI,CAACA,KAAK,CAAC3H,MAAM,EAAE;IACjB;IACA,OAAO,IAAI;EACb;EACA,IAAMwG,CAAC,GAAG,IAAAoB,mBAAU,EAACD,KAAK,EAAErH,KAAK,CAAC;EAClC,IAAIkG,CAAC,KAAK,CAAC,EAAE;IACX,OAAOmB,KAAK,CAACnB,CAAC,CAAC;EACjB,CAAC,MAAM,IAAIA,CAAC,KAAKmB,KAAK,CAAC3H,MAAM,EAAE;IAC7B,OAAO2H,KAAK,CAACnB,CAAC,GAAG,CAAC,CAAC;EACrB;EACA,IAAM/B,GAAG,GAAGkD,KAAK,CAACnB,CAAC,CAAC,GAAGlG,KAAK,GAAGA,KAAK,GAAGqH,KAAK,CAACnB,CAAC,GAAG,CAAC,CAAC,GAAGA,CAAC,GAAGA,CAAC,GAAG,CAAC;EAC/D,OAAOmB,KAAK,CAAClD,GAAG,CAAC;AACnB;AAEO,SAASoD,cAAcA,CAACL,GAAG,EAAEM,QAAQ,EAAEC,IAAI,EAAEJ,KAAK,EAAE;EACzD,IAAIA,KAAK,IAAIA,KAAK,CAAC3H,MAAM,EAAE;IACzB,OAAO0H,WAAW,CAACF,GAAG,EAAEG,KAAK,CAAC;EAChC;EAEA,OAAO,IAAAK,yBAAc,EAACF,QAAQ,EAAEC,IAAI,EAAEP,GAAG,CAAC;AAC5C;AAEO,SAASS,cAAcA,CAACC,KAAK,EAAE;EACpC,OAAOA,KAAK,CAACC,QAAQ,IAAID,KAAK,CAACC,QAAQ,CAACC,SAAS,IAAIF,KAAK,CAACC,QAAQ,CAACE,WAAW;AACjF;AAEO,SAASC,wBAAwBA,CAACJ,KAAY,EAAEK,WAAsC,EAAE;EAC7F;EACA;EACA,OAAOL,KAAK,IAAID,cAAc,CAACC,KAAK,CAAC,GACjCM,4BAAiB,CAACC,OAAO,GACzBF,WAAW,IAAIC,4BAAiB,CAACC,OAAO;AAC9C;AAEA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAIR,KAAK,EAAEK,WAAW,EAAK;EAChD,IAAIN,cAAc,CAACC,KAAK,CAAC,EAAE;IACzB,OAAO,iBAAiB;EAC1B;EACA,OAAOK,WAAW;AACpB,CAAC;AAED,IAAMI,sBAAsB,GAAG,SAAzBA,sBAAsBA,CAAIT,KAAK,EAAE7B,aAAqC,EAAEuC,MAAM,EAAK;EACvF,IAAIX,cAAc,CAACC,KAAK,CAAC,EAAE;IACzB,IAAMW,YAAY,GAAGD,MAAM,CAAC7B,SAAS,CAAC,UAAAxG,CAAC;MAAA,OAAIA,CAAC,CAACW,IAAI,KAAKgH,KAAK,CAACC,QAAQ,CAACC,SAAS;IAAA,EAAC;IAC/E,IAAMU,cAAc,GAAGF,MAAM,CAAC7B,SAAS,CAAC,UAAAxG,CAAC;MAAA,OAAIA,CAAC,CAACW,IAAI,KAAKgH,KAAK,CAACC,QAAQ,CAACE,WAAW;IAAA,EAAC;IAEnF,OAAO;MACLU,YAAY,EAAE,SAAdA,YAAYA,CAAEvC,CAAC;QAAA,OAAIH,aAAa,CAAC2C,OAAO,CAACxC,CAAC,EAAEqC,YAAY,CAAC;MAAA;MACzDI,cAAc,EAAE,SAAhBA,cAAcA,CAAEzC,CAAC;QAAA,OAAIH,aAAa,CAAC2C,OAAO,CAACxC,CAAC,EAAEsC,cAAc,CAAC;MAAA;IAC/D,CAAC;EACH;EAEA,OAAO,UAAAtC,CAAC;IAAA,OAAI0B,KAAK,CAAC1F,aAAa,CAAC;MAAC8E,KAAK,EAAEd;IAAC,CAAC,CAAC;EAAA;AAC7C,CAAC;AAEM,IAAM0C,gBAAgB,GAAAC,OAAA,CAAAD,gBAAA,GAAG,SAAnBA,gBAAgBA,CAC3BhB,KAA4B,EAC5BK,WAAmB,EACnBrE,OAAmC,EACR;EAC3B,IAAOmC,aAAa,GAAYnC,OAAO,CAAhCmC,aAAa;IAAEuC,MAAM,GAAI1E,OAAO,CAAjB0E,MAAM;;EAE5B;EACA,IAAMQ,YAAY,GAAGR,MAAM,CAACS,IAAI,CAC9B,UAAA9I,CAAC;IAAA,OAAI2H,KAAK,KAAK3H,CAAC,CAACW,IAAI,KAAKgH,KAAK,IAAI3H,CAAC,CAACW,IAAI,KAAMgH,KAAK,CAAWhH,IAAI,CAAC;EAAA,CACtE,CAAC;EAED,OAAOkI,YAAY,IAAIb,WAAW,GAC9B,UAAAvF,GAAG;IAAA,OACD,IAAAsG,sBAAS,EACPtG,GAAG,CAACE,OAAO,EACXwF,iBAAiB,CAACU,YAAY,EAAEb,WAAW,CAAC;IAC5C;IACAI,sBAAsB,CAACS,YAAY,EAAE/C,aAAa,EAAEuC,MAAM,CAC5D,CAAC;EAAA,IACH,UAAA5F,GAAG;IAAA,OAAIA,GAAG,CAACC,KAAK;EAAA;AACtB,CAAC;AAEM,IAAMsG,iCAAiC,GAAAJ,OAAA,CAAAI,iCAAA,GAAG,SAApCA,iCAAiCA,CAAGrB,KAAK,EAAI;EACxD,IAAID,cAAc,CAACC,KAAK,CAAC,EAAE;IACzB;IACA,OAAOsB,2BAAgB,CAAC/H,MAAM,CAAC,UAAAgI,IAAA;MAAA,IAAEzC,EAAE,GAAAyC,IAAA,CAAFzC,EAAE;MAAA,OAAMA,EAAE,KAAKwB,4BAAiB,CAACkB,GAAG;IAAA,EAAC;EACxE;EACA,OAAOF,2BAAgB;AACzB,CAAC;AAED,SAASG,QAAQA,CACf7G,IAAiB,EACjB8G,CAAS,EACT9F,QAA8B,EAC4B;EAC1D;EACA,IAAM+F,OAAO,GAAG/G,IAAI,CAACA,IAAI,CAAC9C,MAAM,GAAG,CAAC,CAAC;EAErC,OAAO;IACL8J,KAAK,EAAE,MAAM;IACbC,GAAG,EAAEF,OAAO,GAAGG,YAAY,CAACJ,CAAC,EAAEC,OAAO,CAACD,CAAC,CAAC,GAAG;EAC9C,CAAC;AACH;AAEO,SAASI,YAAYA,CAACJ,CAAU,EAAEK,EAAW,EAAiB;EACnE,IAAIC,MAAM,CAACC,QAAQ,CAACP,CAAC,CAAC,IAAIM,MAAM,CAACC,QAAQ,CAACF,EAAE,CAAC,IAAIA,EAAE,KAAK,CAAC,EAAE;IACzD,OAAO,CAAEL,CAAC,GAAeK,EAAa,IAAKA,EAAa;EAC1D;EACA,OAAO,IAAI;AACb;;AAEA;AACA;AACA;AACA;AACA;AACO,SAASG,YAAYA,CAACvG,QAAkB,EAAEpC,MAAc,EAAa;EAAA,IAAA4I,SAAA;EAC1E,IAAOrG,MAAM,GAAgCvC,MAAM,CAA5CuC,MAAM;IAAEsG,KAAK,GAAyB7I,MAAM,CAApC6I,KAAK;IAAEC,QAAQ,GAAe9I,MAAM,CAA7B8I,QAAQ;IAAEC,SAAS,GAAI/I,MAAM,CAAnB+I,SAAS;EACzC,IAAOjC,WAAW,GAAcgC,QAAQ,CAAjChC,WAAW;IAAEzE,QAAQ,GAAIyG,QAAQ,CAApBzG,QAAQ;EAC5B,IAAM2G,YAAY,GAAGzG,MAAM,CAAC,CAAC,CAAC;EAC9B,IAAMlB,IAAI,IAAAuH,SAAA,GAAI5I,MAAM,CAAqBsC,QAAQ,cAAAsG,SAAA,gBAAAA,SAAA,GAApCA,SAAA,CAAuCI,YAAY,CAAC,cAAAJ,SAAA,uBAApDA,SAAA,CAAuDvG,QAAQ,CAAC;EAE7E,IACE0G,SAAS,IACTA,SAAS,CAACjC,WAAW,KAAKA,WAAW,IACrCiC,SAAS,CAAC1G,QAAQ,KAAKA,QAAQ,IAC/B0G,SAAS,CAACF,KAAK,MAAKA,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEpJ,IAAI;EAC/B;EACA,IAAAwJ,kBAAO,EAAC5H,IAAI,EAAE0H,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAE1H,IAAI,CAAC,EAC9B;IACA;IACA,OAAO0H,SAAS;EAClB;EAEA,IAAMtG,OAAO,GAAGL,QAAQ,CAAC4G,YAAY,CAAC;EACtC,IAAME,SAAS,GAAGzB,gBAAgB,CAACoB,KAAK,EAAE/B,WAAW,EAAErE,OAAO,CAAC;EAE/D,IAAM0G,IAAiB,GAAG,EAAE;EAC5B,IAAMC,MAAM,GAAG,CAAC/H,IAAI,IAAI,EAAE,EAAEoE,MAAM,CAAC,UAACC,IAAI,EAAEnE,GAAG,EAAEwD,CAAC,EAAK;IACnD,IAAMoD,CAAC,GAAGe,SAAS,CAAC3H,GAAG,CAAC;IACxB,IAAM8G,KAAK,GAAGH,QAAQ,CAACxC,IAAI,EAAEyC,CAAC,EAAE9F,QAAQ,CAAC;IACzCqD,IAAI,CAACvF,IAAI,CAAAE,aAAA;MACPgJ,CAAC,EAAE9H,GAAG,CAACG,EAAE;MACTyG,CAAC,EAADA;IAAC,GACEE,KAAK,CACT,CAAC;IACF,OAAO3C,IAAI;EACb,CAAC,EAAEyD,IAAI,CAAC;EAER,IAAMG,OAAO,GAAG,IAAAC,eAAM,EAAWH,MAAM,EAAE,UAAAI,CAAC;IAAA,OAAIA,CAAC,CAACrB,CAAC;EAAA,EAAC;EAClD,IAAMsB,OAAO,GAAGpI,IAAI,GAAG,CAACA,IAAI,CAAC,CAAC,CAAC,CAACK,EAAE,EAAEL,IAAI,CAACA,IAAI,CAAC9C,MAAM,GAAG,CAAC,CAAC,CAACoD,EAAE,CAAC,GAAG,EAAE;;EAElE;EACA,IAAM+H,KAAK,GAAGC,WAAW,CAACP,MAAM,CAAC;EACjC,IAAMQ,QAAQ,GAAGC,6BAAgB,CAAC/C,WAAW,CAAC;EAE9C,OAAO;IACL;IACAwC,OAAO,EAAPA,OAAO;IACP;IACAG,OAAO,EAAPA,OAAO;IACPpH,QAAQ,EAARA,QAAQ;IACRyE,WAAW,EAAXA,WAAW;IACX;IACAsC,MAAM,EAAEM,KAAK;IACbI,KAAK,KAAAC,MAAA,CAAKH,QAAQ,EAAG,MAAM,EAAAG,MAAA,CAAGlB,KAAK,GAAGA,KAAK,CAACpJ,IAAI,GAAG,OAAO,CAAE;IAC5DuK,SAAS,EAAEnB,KAAK,GAAGA,KAAK,CAACoB,IAAI,GAAG,SAAS;IACzCpB,KAAK,EAAEA,KAAK,GAAGA,KAAK,CAACpJ,IAAI,GAAG,IAAI;IAChCyK,OAAO,EAAE;MACPJ,KAAK,oBAAoB;MACzBjL,KAAK,EAAE,IAAAgJ,sBAAS,EAACuB,MAAM,EAAErC,4BAAiB,CAACC,OAAO,EAAE,UAAAwC,CAAC;QAAA,OAAIA,CAAC,CAACrB,CAAC;MAAA;IAC9D,CAAC;IACD;IACA9G,IAAI,EAAJA;EACF,CAAC;AACH;;AAEA;AACO,SAASsI,WAAWA,CAACP,MAAM,EAAE;EAClC,IAAMe,KAAY,GAAG,EAAE;EACvB,IAAIC,IAAW,GAAG,EAAE;EACpB,KAAK,IAAIrF,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGqE,MAAM,CAAC7K,MAAM,EAAEwG,CAAC,EAAE,EAAE;IACtC,IAAMyE,CAAC,GAAGJ,MAAM,CAACrE,CAAC,CAAC;IACnB,IAAI,CAAC,IAAAsF,+BAAkB,EAACb,CAAC,CAACrB,CAAC,CAAC,IAAIiC,IAAI,CAAC7L,MAAM,EAAE;MAC3C;MACA4L,KAAK,CAAChK,IAAI,CAACiK,IAAI,CAAC;MAChBA,IAAI,GAAG,EAAE;IACX,CAAC,MAAM,IAAI,IAAAC,+BAAkB,EAACb,CAAC,CAACrB,CAAC,CAAC,EAAE;MAClCiC,IAAI,CAACjK,IAAI,CAACqJ,CAAC,CAAC;IACd;IAEA,IAAIzE,CAAC,KAAKqE,MAAM,CAAC7K,MAAM,GAAG,CAAC,IAAI6L,IAAI,CAAC7L,MAAM,EAAE;MAC1C4L,KAAK,CAAChK,IAAI,CAACiK,IAAI,CAAC;IAClB;EACF;EAEA,IAAME,OAAO,GAAGH,KAAK,CAAC5L,MAAM,GAAG,CAAC,GAAG6K,MAAM,CAACpJ,MAAM,CAAC,UAAAwJ,CAAC;IAAA,OAAI,IAAAa,+BAAkB,EAACb,CAAC,CAACrB,CAAC,CAAC;EAAA,EAAC,GAAG,EAAE;EAEnF,OAAO;IAACgC,KAAK,EAALA,KAAK;IAAEG,OAAO,EAAPA;EAAO,CAAC;AACzB;AAMO,SAASC,4BAA4BA,CAC1CC,KAAQ,EACRxK,MAAuB,EACvB;EACA,IACE8I,QAAQ,GAGN9I,MAAM,CAHR8I,QAAQ;IAAA2B,aAAA,OAAArH,eAAA,aAGNpD,MAAM,CAFRnB,KAAK;IAAG6L,MAAM,GAAAD,aAAA;IAAEE,MAAM,GAAAF,aAAA;IACtBG,eAAe,GACb5K,MAAM,CADR4K,eAAe;EAGjB,IAAMvI,QAAQ,GAAGyG,QAAQ,CAACzG,QAAQ,IAAI,IAAAwI,wBAAkB,EAAC7K,MAAM,EAAEwK,KAAK,CAACpI,QAAQ,CAAC;EAChF,IAAMf,IAAI,GAAGc,WAAW,CAACnC,MAAM,EAAEwK,KAAK,CAACpI,QAAQ,EAAEC,QAAQ,CAAC;EAC1D,IAAMyI,WAAW,GAAGzJ,IAAI,IAAIxB,MAAM,CAACC,IAAI,CAACuB,IAAI,CAAC,CAAC9C,MAAM,IAAIsB,MAAM,CAACiB,MAAM,CAACO,IAAI,CAAC,CAAC,CAAC,CAAC,CAACgB,QAAQ,CAAC;EACxF,IAAMxB,UAAU,GAAG,CAACiK,WAAW,IAAI,EAAE,EAAExJ,GAAG,CAAC,UAAAM,CAAC;IAAA,OAAIA,CAAC,CAACF,EAAE;EAAA,EAAC;EAErD,IAAIqJ,IAAI,GAAGL,MAAM;EACjB,IAAIM,IAAI,GAAGL,MAAM;EACjB,IAAI3H,GAAG;EACP,IAAI4H,eAAe,KAAKK,2BAAgB,CAAC5I,QAAQ,EAAE;IACjD0I,IAAI,GAAG9E,WAAW,CAAC0E,MAAM,EAAE9J,UAAU,CAAC;IACtCmC,GAAG,GAAGnC,UAAU,CAACqK,OAAO,CAACH,IAAI,CAAC;IAC9BC,IAAI,GAAGhI,GAAG,GAAG,CAAC,CAAC,GAAG8H,WAAW,CAAC9H,GAAG,CAAC,CAACrB,EAAE,GAAGwJ,GAAG;EAC7C,CAAC,MAAM;IACL;IACAJ,IAAI,GAAG9E,WAAW,CAACyE,MAAM,EAAE7J,UAAU,CAAC;IACtCmK,IAAI,GAAG/E,WAAW,CAAC0E,MAAM,EAAE9J,UAAU,CAAC;IAEtC,IAAIkK,IAAI,KAAKC,IAAI,EAAE;MACjBhI,GAAG,GAAGnC,UAAU,CAACqK,OAAO,CAACH,IAAI,CAAC;MAC9B,IAAI/H,GAAG,KAAKnC,UAAU,CAACtC,MAAM,GAAG,CAAC,EAAE;QACjCwM,IAAI,GAAGlK,UAAU,CAACmC,GAAG,GAAG,CAAC,CAAC;MAC5B,CAAC,MAAM;QACLgI,IAAI,GAAGnK,UAAU,CAACmC,GAAG,GAAG,CAAC,CAAC;MAC5B;IACF;EACF;EAEA,IAAMoI,aAAa,GAAA/K,aAAA,CAAAA,aAAA,KACdL,MAAM;IACT8I,QAAQ,EAAAzI,aAAA,CAAAA,aAAA,KACHL,MAAM,CAAC8I,QAAQ;MAClBzG,QAAQ,EAARA;IAAQ,EACT;IACDC,QAAQ,EAAEjB,IAAI;IACdxC,KAAK,EAAE,CAACkM,IAAI,EAAEC,IAAI;EAAC,EACpB;EAED,OAAOI,aAAa;AACtB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAASC,2BAA2BA,CAACrL,MAAM,EAAEoC,QAAQ,EAAEkJ,iBAAiB,EAAE;EACxE,IAAIC,cAAc,GAAGD,iBAAiB,IAAI,CAAC,CAAC;EAAC,IAAAE,SAAA,GAAA1N,0BAAA,CACxBkC,MAAM,CAACuC,MAAM;IAAAkJ,KAAA;EAAA;IAAlC,KAAAD,SAAA,CAAA9M,CAAA,MAAA+M,KAAA,GAAAD,SAAA,CAAA7M,CAAA,IAAAC,IAAA,GAAoC;MAAA,IAAzB2D,MAAM,GAAAkJ,KAAA,CAAA5M,KAAA;MACf,IAAI,CAAC0M,cAAc,CAAChJ,MAAM,CAAC,IAAIH,QAAQ,CAACG,MAAM,CAAC,EAAE;QAC/CgJ,cAAc,GAAAlL,aAAA,CAAAA,aAAA,KACTkL,cAAc,WAAA/K,gBAAA,iBAChB+B,MAAM,EAAG,IAAAmJ,oBAAQ,EAACtJ,QAAQ,CAACG,MAAM,CAAC,CAACoJ,KAAK,CAAC,EAC3C;MACH;IACF;EAAC,SAAAC,GAAA;IAAAJ,SAAA,CAAAxN,CAAA,CAAA4N,GAAA;EAAA;IAAAJ,SAAA,CAAA1M,CAAA;EAAA;EACD,OAAOyM,cAAc;AACvB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO,SAASM,wBAAwBA,CACtC7L,MAAuB,EACvB8I,QAAqC,EACrC1G,QAAkB,EAClBG,MAAe,EACE;EACjB,IAAIuJ,UAAU,GAAG9L,MAAM;EACvB,IAAI+L,YAAY,GAAGjD,QAAQ;EAC3B,IAAI,IAAAkD,QAAA,aAAOD,YAAY,MAAK,QAAQ,IAAI,CAACA,YAAY,CAACjF,WAAW,IAAI,CAACiF,YAAY,CAAC1J,QAAQ,EAAE;IAC3F0J,YAAY,GAAGE,kBAAkB,CAACjM,MAAM,EAAEoC,QAAQ,CAAC;EACrD;EAEA,IAAIpC,MAAM,CAACuC,MAAM,CAAChE,MAAM,GAAG,CAAC,EAAE;IAC5BwN,YAAY,GAAA1L,aAAA,CAAAA,aAAA,KACP0L,YAAY;MACfR,cAAc,EAAEF,2BAA2B,CAACrL,MAAM,EAAEoC,QAAQ,EAAE2J,YAAY,CAACR,cAAc;IAAC,EAC3F;EACH;EACAO,UAAU,GAAAzL,aAAA,CAAAA,aAAA,KACLyL,UAAU;IACbhD,QAAQ,EAAEiD;EAAY,EACvB;EAED,IAAM1K,IAAI,GAAGc,WAAW,CAAC2J,UAAU,EAAE1J,QAAQ,EAAE2J,YAAY,CAAC1J,QAAQ,CAAC;EAErEyJ,UAAU,GAAAzL,aAAA,CAAAA,aAAA,KACLyL,UAAU;IACbxJ,QAAQ,EAAEjB;EAAI,EACf;EAED,IAAIyH,QAAQ,CAACmB,IAAI,KAAKiC,qBAAU,CAACC,SAAS,EAAE;IAC1C;EAAA,CACD,MAAM,IAAIrD,QAAQ,CAACmB,IAAI,KAAKiC,qBAAU,CAACnD,SAAS,EAAE;IACjD;IACA+C,UAAU,GAAAzL,aAAA,CAAAA,aAAA,KACLyL,UAAU;MACb/C,SAAS,EAAEJ,YAAY,CAACvG,QAAQ,EAAE0J,UAAU;IAAC,EAC9C;EACH;EAEA,OAAOA,UAAU;AACnB;AAEO,SAASM,kBAAkBA,CAACpM,MAAM,EAAEoC,QAAQ,EAAEN,OAAO,EAAE;EAC5D,IAAOV,MAAM,GAAIpB,MAAM,CAAhBoB,MAAM;EACb,IAAI,CAACpB,MAAM,CAACuC,MAAM,EAAE,OAAO,IAAI;EAE/B,OAAOvC,MAAM,CAACuC,MAAM,CAACkD,MAAM,CAAC,UAAC4G,GAAG,EAAE9J,MAAM,EAAE+J,UAAU,EAAK;IAAA,IAAAC,YAAA;IACvD,KAAAA,YAAA,GAAIvM,MAAM,CAACqB,IAAI,cAAAkL,YAAA,eAAXA,YAAA,CAAchK,MAAM,CAAC,EAAE;MACzB;MACA8J,GAAG,CAAC9J,MAAM,CAAC,GAAGvC,MAAM,CAACqB,IAAI,CAACkB,MAAM,CAAC;MACjC,OAAO8J,GAAG;IACZ;IACA,IAAMG,SAAS,GAAGxM,MAAM,CAACP,IAAI,CAAC6M,UAAU,CAAC;IACzC,IAAI/J,MAAM,IAAIiK,SAAS,EAAE;MACvB,IAAM/J,OAAO,GAAGL,QAAQ,CAACG,MAAM,CAAC;MAChC,IAAMkE,KAAK,GAAGhE,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEgK,cAAc,CAACD,SAAS,CAAC;MAChD,IAAI/J,OAAO,IAAIgE,KAAK,EAAE;QACpB,IAAMhF,OAAO,GAAGiB,mBAAmB,CAACD,OAAO,EAAEzC,MAAM,CAAC;QACpD,IAAMe,aAAa,GAAG,SAAhBA,aAAaA,CAAG8E,KAAK;UAAA,OAAIY,KAAK,CAAC1F,aAAa,CAAC;YAAC8E,KAAK,EAALA;UAAK,CAAC,CAAC;QAAA;QAC3DwG,GAAG,CAAC9J,MAAM,CAAC,GAAGN,mBAAmB,CAACb,MAAM,EAAEK,OAAO,EAAEK,OAAO,EAAEf,aAAa,CAAC;MAC5E;IACF;IACA,OAAOsL,GAAG;EACZ,CAAC,EAAE,CAAC,CAAC,CAAC;AACR;AAEO,SAASK,yBAAyBA,CACvC1M,MAAmB,EACnB8I,QAAiC,EACjC1G,QAAkB,EAClBG,MAAe,EACF;EACb,IAAMuJ,UAAU,GAAAzL,aAAA,CAAAA,aAAA,KACXL,MAAM;IACT8I,QAAQ,EAARA;EAAQ,EACT;;EAED;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;EAEA,OAAAzI,aAAA,CAAAA,aAAA,KACKL,MAAM;IACT8I,QAAQ,EAARA,QAAQ;IACRzH,IAAI,EAAE+K,kBAAkB,CAACN,UAAU,EAAE1J,QAAQ,EAAEuK,eAAI;EAAC;AAExD;AAEO,SAASC,aAAaA,CAAC/D,KAAY,EAAEC,QAAkB,EAAU;EACtE,IAAM+D,SAAS,GAAGhE,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEiE,WAAW;EACpC,IAAOhG,WAAW,GAAIgC,QAAQ,CAAvBhC,WAAW;EAElB,IAAI+F,SAAS,EAAE;IACb,OAAO,IAAAE,8BAAqB,KAAAhD,MAAA,CAAIjD,WAAW,OAAAiD,MAAA,CAAI8C,SAAS,eAAY,CAAC;EACvE;EAEA;AACF;AAEO,SAASZ,kBAAkBA,CAACjM,MAAM,EAAEoC,QAAQ,EAAE;EACnD,IAAMC,QAAQ,GAAG,IAAAwI,wBAAkB,EAAC7K,MAAM,EAAEoC,QAAQ,CAAC;EACrD,IAAM4K,iBAAiB,GAAG,IAAAC,4BAAoB,EAAC5K,QAAQ,CAAC;EACxD,OAAO;IACLA,QAAQ,EAARA,QAAQ;IACR2K,iBAAiB,EAAjBA,iBAAiB;IACjB/C,IAAI,EAAEiC,qBAAU,CAACC,SAAS;IAC1BrF,WAAW,EAAEC,4BAAiB,CAACkB;EACjC,CAAC;AACH","ignoreList":[]}
package/dist/utils.js CHANGED
@@ -199,8 +199,8 @@ function hasPortableWidth(breakPointValues) {
199
199
  return mobileWidth.matches;
200
200
  }
201
201
  function isTest() {
202
- var _process;
203
- return typeof process !== 'undefined' && ((_process = process) === null || _process === void 0 || (_process = _process.env) === null || _process === void 0 ? void 0 : _process.NODE_ENV) === 'test';
202
+ var _globalThis$process;
203
+ return ((_globalThis$process = globalThis.process) === null || _globalThis$process === void 0 || (_globalThis$process = _globalThis$process.env) === null || _globalThis$process === void 0 ? void 0 : _globalThis$process.NODE_ENV) === 'test';
204
204
  }
205
205
 
206
206
  /**
@@ -238,4 +238,4 @@ function arrayDifference(source) {
238
238
  }, initial);
239
239
  };
240
240
  }
241
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_window","_interopRequireDefault","require","_strings","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","generateHashIdFromString","str","hash","i","chr","len","toString","charCodeAt","isChrome","window","chrome","webstore","camelToTitle","breakWord","replace","capitalizeFirstLetter","camelize","exports","match","index","Number","toLowerCase","toUpperCase","insertValue","obj","key","value","Array","isArray","concat","_toConsumableArray2","slice","isObject","_typeof2","isPlainObject","setPath","_ref","_ref2","_toArray2","next","prototype","hasOwnProperty","call","set","path","DEFAULT_ERROR_MESSAGE","getError","err","defaultMessage","undefined","Error","message","error","JSON","stringify","arrayInsert","arr","val","arrayMoveMutate","array","from","to","splice","arrayMove","hasMobileWidth","breakPointValues","mobileWidth","matchMedia","palm","matches","hasPortableWidth","desk","isTest","_process","process","env","NODE_ENV","filterObjectByPredicate","predicate","entries","reduce","acc","entry","isFunction","func","findById","id","find","a","arrayDifference","source","initial","compare","element","foundElement"],"sources":["../src/utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport window from 'global/window';\nimport {capitalizeFirstLetter} from './strings';\n\n/**\n * Generate a hash string based on string\n * @param str\n * @returns\n */\nexport function generateHashIdFromString(str: string): string {\n  // generate hash string based on string\n  let hash = 0;\n  let i;\n  let chr;\n  let len;\n  if (str.length === 0) return hash.toString();\n  for (i = 0, len = str.length; i < len; i++) {\n    chr = str.charCodeAt(i);\n    // eslint-disable-next-line no-bitwise\n    hash = (hash << 5) - hash + chr;\n    // eslint-disable-next-line no-bitwise\n    hash |= 0; // Convert to 32bit integer\n  }\n  return hash.toString(36);\n}\n\n/**\n * Detect chrome\n * @returns {boolean} - yes or no\n */\nexport function isChrome(): boolean {\n  // Chrome 1+\n  return window.chrome && window.chrome.webstore;\n}\n\n/**\n * Convert camel style names to title\n * strokeColor -> Stroke Color\n * @param {string} str\n * @returns {string}\n */\nexport function camelToTitle(str: string): string {\n  const breakWord = str.replace(/([A-Z])/g, ' $1');\n  return capitalizeFirstLetter(breakWord);\n}\n\n/**\n * Convert names to camel style\n * Stroke Color -> strokeColor\n * @param {string} str\n * @returns {string}\n */\nexport const camelize = (str: string): string => {\n  return str.replace(/(?:^\\w|[A-Z]|\\b\\w|\\s+)/g, (match, index) => {\n    if (Number(match) === 0) return ''; // or if (/\\s+/.test(match)) for white spaces\n    return index === 0 ? match.toLowerCase() : match.toUpperCase();\n  });\n};\n\n/**\n * immutably insert value to an Array or Object\n * @param {Array|Object} obj\n * @param {Number|String} key\n * @param {*} value\n * @returns {Array|Object}\n */\nexport const insertValue = <T extends any[] | object>(\n  obj: T,\n  key: number | string,\n  value: any\n): T => {\n  if (Array.isArray(obj) && typeof key === 'number') {\n    return [...obj.slice(0, key), value, ...obj.slice(key + 1, obj.length)] as T;\n  }\n\n  return {...obj, [key]: value};\n};\n\n/**\n * check if value is a loose object including a plain object, array, function\n * @param {*} value\n */\nexport function isObject(value): boolean {\n  return value !== null && (typeof value === 'object' || typeof value === 'function');\n}\n\n/**\n * whether is an object\n * @returns {boolean} - yes or no\n */\nexport function isPlainObject(obj: unknown): obj is Record<string, unknown> {\n  return obj === Object(obj) && typeof obj !== 'function' && !Array.isArray(obj);\n}\n\nconst setPath = <T extends any[] | object>(\n  [key, ...next]: (string | number)[],\n  value: any,\n  obj: object | any[]\n): T => {\n  // is Object allows js object, array and function\n  if (!isObject(obj)) {\n    return obj as T;\n  }\n\n  if (next.length === 0) {\n    return insertValue(obj, key, value) as T;\n  }\n\n  // @ts-ignore\n  return insertValue(\n    obj,\n    key,\n    setPath(next, value, Object.prototype.hasOwnProperty.call(obj, key) ? obj[key] : {})\n  );\n};\n\n/**\n * Immutable version of _.set\n * @param {Array<String|Number>} path\n * @param {*} value\n * @param {Object} obj\n * @returns {Object}\n */\n// @ts-ignore\nexport const set = <T extends any[] | object>(path: (string | number)[], value: any, obj: T): T =>\n  obj === null ? obj : setPath(path, value, obj);\n\ntype ErrorObject = {\n  error?: any;\n  err?: any;\n  message?: any;\n};\n\nexport const DEFAULT_ERROR_MESSAGE = 'Something went wrong';\n\n/**\n * Get error information of unknown type\n * Extracts as much human readable information as possible\n * Ensure result is an Error object suitable for throw or promise rejection\n *\n * @private\n * @param {*}  err - Unknown error\n * @return {string} - human readable error msg\n */\nexport function getError(\n  err?: Error | ErrorObject | string,\n  defaultMessage: string = DEFAULT_ERROR_MESSAGE\n): string {\n  if (!err) {\n    return defaultMessage;\n  }\n\n  if (typeof err === 'string') {\n    return err;\n  } else if (err instanceof Error) {\n    return err.message;\n  } else if (typeof err === 'object') {\n    return Object.prototype.hasOwnProperty.call(err, 'message')\n      ? getError(err.message)\n      : Object.prototype.hasOwnProperty.call(err, 'error')\n      ? getError(err.error)\n      : Object.prototype.hasOwnProperty.call(err, 'err')\n      ? getError(err.err)\n      : JSON.stringify(err);\n  }\n\n  return defaultMessage;\n}\n\nexport function arrayInsert<T>(arr: T[], index: number, val: T): T[] {\n  if (!Array.isArray(arr)) {\n    return arr;\n  }\n\n  return [...arr.slice(0, index), val, ...arr.slice(index)];\n}\n\nconst arrayMoveMutate = (array, from, to) => {\n  array.splice(to < 0 ? array.length + to : to, 0, array.splice(from, 1)[0]);\n};\n\n/**\n *\n * @param {any[]} array\n * @param {number} from\n * @param {number} to\n * @returns {any[]}\n */\nexport const arrayMove = <T>(array: T[], from: number, to: number): T[] => {\n  array = array.slice();\n  arrayMoveMutate(array, from, to);\n  return array;\n};\n\nexport function hasMobileWidth(breakPointValues: {palm: number; desk: number}): boolean {\n  const mobileWidth = window.matchMedia(`(max-width: ${breakPointValues.palm}px)`);\n  return mobileWidth.matches;\n}\n\nexport function hasPortableWidth(breakPointValues: {palm: number; desk: number}): boolean {\n  const mobileWidth = window.matchMedia(`(max-width: ${breakPointValues.desk}px)`);\n  return mobileWidth.matches;\n}\n\nexport function isTest(): boolean {\n  return typeof process !== 'undefined' && process?.env?.NODE_ENV === 'test';\n}\n\n/**\n * Filters an object by an arbitrary predicate\n * Returns a new object containing all elements that match the predicate\n * @param {Object} obj Object to be filtered\n * @param {Function} predicate Predicate by which the object will be filtered\n * @returns {Object}\n */\nexport function filterObjectByPredicate(obj, predicate) {\n  return Object.entries(obj).reduce(\n    (acc, entry) => (predicate(entry[0], entry[1]) ? {...acc, [entry[0]]: entry[1]} : acc),\n    {}\n  );\n}\n\nexport function isFunction(func: unknown): boolean {\n  return typeof func === 'function';\n}\n\nexport function findById(id: string): <X extends {id: string}>(arr: X[]) => X | undefined {\n  return arr => arr.find(a => a.id === id);\n}\n\n/**\n * Returns array difference from\n */\nexport function arrayDifference<X extends {id: string}>(source: X[]): (compare: X[]) => X[] {\n  const initial: X[] = [];\n  return compare =>\n    source.reduce((acc, element) => {\n      const foundElement = findById(element.id)(compare);\n      return foundElement ? [...acc, foundElement] : acc;\n    }, initial);\n}\n"],"mappings":"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","ignoreList":[]}
241
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_window","_interopRequireDefault","require","_strings","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","generateHashIdFromString","str","hash","i","chr","len","toString","charCodeAt","isChrome","window","chrome","webstore","camelToTitle","breakWord","replace","capitalizeFirstLetter","camelize","exports","match","index","Number","toLowerCase","toUpperCase","insertValue","obj","key","value","Array","isArray","concat","_toConsumableArray2","slice","isObject","_typeof2","isPlainObject","setPath","_ref","_ref2","_toArray2","next","prototype","hasOwnProperty","call","set","path","DEFAULT_ERROR_MESSAGE","getError","err","defaultMessage","undefined","Error","message","error","JSON","stringify","arrayInsert","arr","val","arrayMoveMutate","array","from","to","splice","arrayMove","hasMobileWidth","breakPointValues","mobileWidth","matchMedia","palm","matches","hasPortableWidth","desk","isTest","_globalThis$process","globalThis","process","env","NODE_ENV","filterObjectByPredicate","predicate","entries","reduce","acc","entry","isFunction","func","findById","id","find","a","arrayDifference","source","initial","compare","element","foundElement"],"sources":["../src/utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport window from 'global/window';\nimport {capitalizeFirstLetter} from './strings';\n\n/**\n * Generate a hash string based on string\n * @param str\n * @returns\n */\nexport function generateHashIdFromString(str: string): string {\n  // generate hash string based on string\n  let hash = 0;\n  let i;\n  let chr;\n  let len;\n  if (str.length === 0) return hash.toString();\n  for (i = 0, len = str.length; i < len; i++) {\n    chr = str.charCodeAt(i);\n    // eslint-disable-next-line no-bitwise\n    hash = (hash << 5) - hash + chr;\n    // eslint-disable-next-line no-bitwise\n    hash |= 0; // Convert to 32bit integer\n  }\n  return hash.toString(36);\n}\n\n/**\n * Detect chrome\n * @returns {boolean} - yes or no\n */\nexport function isChrome(): boolean {\n  // Chrome 1+\n  return window.chrome && window.chrome.webstore;\n}\n\n/**\n * Convert camel style names to title\n * strokeColor -> Stroke Color\n * @param {string} str\n * @returns {string}\n */\nexport function camelToTitle(str: string): string {\n  const breakWord = str.replace(/([A-Z])/g, ' $1');\n  return capitalizeFirstLetter(breakWord);\n}\n\n/**\n * Convert names to camel style\n * Stroke Color -> strokeColor\n * @param {string} str\n * @returns {string}\n */\nexport const camelize = (str: string): string => {\n  return str.replace(/(?:^\\w|[A-Z]|\\b\\w|\\s+)/g, (match, index) => {\n    if (Number(match) === 0) return ''; // or if (/\\s+/.test(match)) for white spaces\n    return index === 0 ? match.toLowerCase() : match.toUpperCase();\n  });\n};\n\n/**\n * immutably insert value to an Array or Object\n * @param {Array|Object} obj\n * @param {Number|String} key\n * @param {*} value\n * @returns {Array|Object}\n */\nexport const insertValue = <T extends any[] | object>(\n  obj: T,\n  key: number | string,\n  value: any\n): T => {\n  if (Array.isArray(obj) && typeof key === 'number') {\n    return [...obj.slice(0, key), value, ...obj.slice(key + 1, obj.length)] as T;\n  }\n\n  return {...obj, [key]: value};\n};\n\n/**\n * check if value is a loose object including a plain object, array, function\n * @param {*} value\n */\nexport function isObject(value): boolean {\n  return value !== null && (typeof value === 'object' || typeof value === 'function');\n}\n\n/**\n * whether is an object\n * @returns {boolean} - yes or no\n */\nexport function isPlainObject(obj: unknown): obj is Record<string, unknown> {\n  return obj === Object(obj) && typeof obj !== 'function' && !Array.isArray(obj);\n}\n\nconst setPath = <T extends any[] | object>(\n  [key, ...next]: (string | number)[],\n  value: any,\n  obj: object | any[]\n): T => {\n  // is Object allows js object, array and function\n  if (!isObject(obj)) {\n    return obj as T;\n  }\n\n  if (next.length === 0) {\n    return insertValue(obj, key, value) as T;\n  }\n\n  // @ts-ignore\n  return insertValue(\n    obj,\n    key,\n    setPath(next, value, Object.prototype.hasOwnProperty.call(obj, key) ? obj[key] : {})\n  );\n};\n\n/**\n * Immutable version of _.set\n * @param {Array<String|Number>} path\n * @param {*} value\n * @param {Object} obj\n * @returns {Object}\n */\n// @ts-ignore\nexport const set = <T extends any[] | object>(path: (string | number)[], value: any, obj: T): T =>\n  obj === null ? obj : setPath(path, value, obj);\n\ntype ErrorObject = {\n  error?: any;\n  err?: any;\n  message?: any;\n};\n\nexport const DEFAULT_ERROR_MESSAGE = 'Something went wrong';\n\n/**\n * Get error information of unknown type\n * Extracts as much human readable information as possible\n * Ensure result is an Error object suitable for throw or promise rejection\n *\n * @private\n * @param {*}  err - Unknown error\n * @return {string} - human readable error msg\n */\nexport function getError(\n  err?: Error | ErrorObject | string,\n  defaultMessage: string = DEFAULT_ERROR_MESSAGE\n): string {\n  if (!err) {\n    return defaultMessage;\n  }\n\n  if (typeof err === 'string') {\n    return err;\n  } else if (err instanceof Error) {\n    return err.message;\n  } else if (typeof err === 'object') {\n    return Object.prototype.hasOwnProperty.call(err, 'message')\n      ? getError(err.message)\n      : Object.prototype.hasOwnProperty.call(err, 'error')\n      ? getError(err.error)\n      : Object.prototype.hasOwnProperty.call(err, 'err')\n      ? getError(err.err)\n      : JSON.stringify(err);\n  }\n\n  return defaultMessage;\n}\n\nexport function arrayInsert<T>(arr: T[], index: number, val: T): T[] {\n  if (!Array.isArray(arr)) {\n    return arr;\n  }\n\n  return [...arr.slice(0, index), val, ...arr.slice(index)];\n}\n\nconst arrayMoveMutate = (array, from, to) => {\n  array.splice(to < 0 ? array.length + to : to, 0, array.splice(from, 1)[0]);\n};\n\n/**\n *\n * @param {any[]} array\n * @param {number} from\n * @param {number} to\n * @returns {any[]}\n */\nexport const arrayMove = <T>(array: T[], from: number, to: number): T[] => {\n  array = array.slice();\n  arrayMoveMutate(array, from, to);\n  return array;\n};\n\nexport function hasMobileWidth(breakPointValues: {palm: number; desk: number}): boolean {\n  const mobileWidth = window.matchMedia(`(max-width: ${breakPointValues.palm}px)`);\n  return mobileWidth.matches;\n}\n\nexport function hasPortableWidth(breakPointValues: {palm: number; desk: number}): boolean {\n  const mobileWidth = window.matchMedia(`(max-width: ${breakPointValues.desk}px)`);\n  return mobileWidth.matches;\n}\n\nexport function isTest(): boolean {\n  return globalThis.process?.env?.NODE_ENV === 'test';\n}\n\n/**\n * Filters an object by an arbitrary predicate\n * Returns a new object containing all elements that match the predicate\n * @param {Object} obj Object to be filtered\n * @param {Function} predicate Predicate by which the object will be filtered\n * @returns {Object}\n */\nexport function filterObjectByPredicate(obj, predicate) {\n  return Object.entries(obj).reduce(\n    (acc, entry) => (predicate(entry[0], entry[1]) ? {...acc, [entry[0]]: entry[1]} : acc),\n    {}\n  );\n}\n\nexport function isFunction(func: unknown): boolean {\n  return typeof func === 'function';\n}\n\nexport function findById(id: string): <X extends {id: string}>(arr: X[]) => X | undefined {\n  return arr => arr.find(a => a.id === id);\n}\n\n/**\n * Returns array difference from\n */\nexport function arrayDifference<X extends {id: string}>(source: X[]): (compare: X[]) => X[] {\n  const initial: X[] = [];\n  return compare =>\n    source.reduce((acc, element) => {\n      const foundElement = findById(element.id)(compare);\n      return foundElement ? [...acc, foundElement] : acc;\n    }, initial);\n}\n"],"mappings":"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","ignoreList":[]}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@kepler.gl/utils",
3
3
  "author": "Shan He <shan@uber.com>",
4
- "version": "3.1.0-alpha.3",
4
+ "version": "3.1.0-alpha.5",
5
5
  "description": "kepler.gl constants used by kepler.gl components, actions and reducers",
6
6
  "license": "MIT",
7
7
  "main": "dist/index.js",
@@ -31,10 +31,10 @@
31
31
  ],
32
32
  "dependencies": {
33
33
  "@deck.gl/core": "^8.9.27",
34
- "@dnd-kit/sortable": "^7.0.2",
35
- "@kepler.gl/common-utils": "3.1.0-alpha.3",
36
- "@kepler.gl/constants": "3.1.0-alpha.3",
37
- "@kepler.gl/types": "3.1.0-alpha.3",
34
+ "@dnd-kit/sortable": "^8.0.0",
35
+ "@kepler.gl/common-utils": "3.1.0-alpha.5",
36
+ "@kepler.gl/constants": "3.1.0-alpha.5",
37
+ "@kepler.gl/types": "3.1.0-alpha.5",
38
38
  "@luma.gl/constants": "^8.5.20",
39
39
  "@luma.gl/core": "^8.5.20",
40
40
  "@mapbox/geo-viewport": "^0.4.1",