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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/dist/aggregate-utils.js +2 -2
  2. package/dist/color-utils.d.ts +4 -0
  3. package/dist/color-utils.js +28 -3
  4. package/dist/data-container-interface.js +1 -1
  5. package/dist/data-container-utils.js +2 -2
  6. package/dist/data-row.js +2 -2
  7. package/dist/data-scale-utils.js +4 -4
  8. package/dist/data-utils.d.ts +10 -12
  9. package/dist/data-utils.js +120 -44
  10. package/dist/dataset-utils.d.ts +12 -1
  11. package/dist/dataset-utils.js +74 -9
  12. package/dist/dom-to-image.d.ts +14 -14
  13. package/dist/dom-to-image.js +23 -69
  14. package/dist/dom-utils.d.ts +3 -0
  15. package/dist/dom-utils.js +29 -3
  16. package/dist/effect-utils.d.ts +13 -0
  17. package/dist/effect-utils.js +129 -0
  18. package/dist/export-map-html.js +2 -2
  19. package/dist/export-utils.js +13 -4
  20. package/dist/filter-utils.d.ts +11 -9
  21. package/dist/filter-utils.js +66 -36
  22. package/dist/format.d.ts +1 -0
  23. package/dist/format.js +33 -0
  24. package/dist/gl-utils.js +2 -2
  25. package/dist/h3-utils.d.ts +2 -1
  26. package/dist/h3-utils.js +5 -4
  27. package/dist/index.d.ts +14 -9
  28. package/dist/index.js +230 -555
  29. package/dist/indexed-data-container.js +2 -2
  30. package/dist/locale-utils.js +2 -2
  31. package/dist/map-info-utils.js +2 -2
  32. package/dist/map-style-utils/mapbox-gl-style-editor.d.ts +2 -1
  33. package/dist/map-style-utils/mapbox-gl-style-editor.js +9 -3
  34. package/dist/map-style-utils/mapbox-utils.js +2 -2
  35. package/dist/map-utils.d.ts +8 -2
  36. package/dist/map-utils.js +24 -7
  37. package/dist/mapbox-utils.js +2 -2
  38. package/dist/noop.d.ts +1 -0
  39. package/dist/noop.js +29 -0
  40. package/dist/notifications-utils.d.ts +14 -26
  41. package/dist/notifications-utils.js +9 -11
  42. package/dist/observe-dimensions.js +10 -6
  43. package/dist/plot.d.ts +6 -0
  44. package/dist/plot.js +46 -0
  45. package/dist/projection-utils.d.ts +9 -0
  46. package/dist/projection-utils.js +36 -2
  47. package/dist/row-data-container.js +2 -2
  48. package/dist/searcher-utils.js +2 -2
  49. package/dist/split-map-utils.d.ts +4 -1
  50. package/dist/split-map-utils.js +10 -4
  51. package/dist/time.d.ts +16 -0
  52. package/dist/time.js +105 -0
  53. package/dist/utils.d.ts +36 -10
  54. package/dist/utils.js +38 -6
  55. package/package.json +11 -11
@@ -1,4 +1,4 @@
1
- // Copyright (c) 2022 Uber Technologies, Inc.
1
+ // Copyright (c) 2023 Uber Technologies, Inc.
2
2
  //
3
3
  // Permission is hereby granted, free of charge, to any person obtaining a copy
4
4
  // of this software and associated documentation files (the "Software"), to deal
@@ -62,6 +62,7 @@ exports.getFilterPlot = getFilterPlot;
62
62
  exports.getIntervalBins = getIntervalBins;
63
63
  exports.isValidTimeDomain = isValidTimeDomain;
64
64
  exports.getTimeWidgetHintFormatter = getTimeWidgetHintFormatter;
65
+ exports.isSideFilter = isSideFilter;
65
66
  exports.getFilterIdInFeature = exports.featureToFilterValue = exports.getPolygonFilterFunctor = exports.LAYER_FILTERS = exports.FILTER_ID_LENGTH = exports.DEFAULT_FILTER_STRUCTURE = exports.FILTER_COMPONENTS = exports.LIMITED_FILTER_EFFECT_PROPS = exports.FILTER_UPDATER_PROPS = exports.enlargedHistogramBins = exports.histogramBins = exports.TimestampStepMap = exports.durationYear = exports.durationWeek = exports.durationDay = exports.durationHour = exports.durationMinute = exports.durationSecond = void 0;
66
67
 
67
68
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
@@ -167,9 +168,10 @@ var DEFAULT_FILTER_STRUCTURE = {
167
168
  // [string]
168
169
  freeze: false,
169
170
  id: null,
171
+ enabled: true,
170
172
  // time range filter specific
171
173
  fixedDomain: false,
172
- enlarged: false,
174
+ view: _constants.FILTER_VIEW_TYPES.side,
173
175
  isAnimating: false,
174
176
  animationWindow: _constants.ANIMATION_WINDOW.free,
175
177
  speed: 1,
@@ -198,11 +200,15 @@ var LAYER_FILTERS = [_constants.FILTER_TYPES.polygon];
198
200
 
199
201
  exports.LAYER_FILTERS = LAYER_FILTERS;
200
202
 
201
- function getDefaultFilter(dataId) {
203
+ function getDefaultFilter() {
204
+ var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
205
+ dataId = _ref.dataId,
206
+ id = _ref.id;
207
+
202
208
  return _objectSpread(_objectSpread({}, DEFAULT_FILTER_STRUCTURE), {}, {
203
209
  // store it as dataId and it could be one or many
204
- dataId: (0, _utils.toArray)(dataId),
205
- id: (0, _utils.generateHashId)(FILTER_ID_LENGTH)
210
+ dataId: dataId ? (0, _utils.toArray)(dataId) : [],
211
+ id: id || (0, _utils.generateHashId)(FILTER_ID_LENGTH)
206
212
  });
207
213
  }
208
214
  /**
@@ -275,6 +281,8 @@ var filterValidators = (0, _defineProperty2["default"])({}, _constants.FILTER_TY
275
281
  */
276
282
 
277
283
  function validateFilter(dataset, filter) {
284
+ var _filter$view;
285
+
278
286
  // match filter.dataId
279
287
  var failed = {
280
288
  dataset: dataset,
@@ -288,7 +296,9 @@ function validateFilter(dataset, filter) {
288
296
  return failed;
289
297
  }
290
298
 
291
- var initializeFilter = _objectSpread(_objectSpread(_objectSpread({}, getDefaultFilter(filter.dataId)), filter), {}, {
299
+ var initializeFilter = _objectSpread(_objectSpread(_objectSpread({}, getDefaultFilter({
300
+ dataId: filter.dataId
301
+ })), filter), {}, {
292
302
  dataId: filterDataId,
293
303
  name: (0, _utils.toArray)(filter.name)
294
304
  });
@@ -306,7 +316,7 @@ function validateFilter(dataset, filter) {
306
316
  }
307
317
 
308
318
  updatedFilter.value = adjustValueToFilterDomain(filter.value, updatedFilter);
309
- updatedFilter.enlarged = typeof filter.enlarged === 'boolean' ? filter.enlarged : updatedFilter.enlarged;
319
+ updatedFilter.view = (_filter$view = filter.view) !== null && _filter$view !== void 0 ? _filter$view : updatedFilter.view;
310
320
 
311
321
  if (updatedFilter.value === null) {
312
322
  // cannot adjust saved value to filter
@@ -347,9 +357,9 @@ function validateFilterYAxis(filter, dataset) {
347
357
  yAxis = _filter.yAxis; // TODO: validate yAxis against other datasets
348
358
 
349
359
  if (yAxis) {
350
- var matchedAxis = fields.find(function (_ref) {
351
- var name = _ref.name,
352
- type = _ref.type;
360
+ var matchedAxis = fields.find(function (_ref2) {
361
+ var name = _ref2.name,
362
+ type = _ref2.type;
353
363
  return name === yAxis.name && type === yAxis.type;
354
364
  });
355
365
  filter = matchedAxis ? _objectSpread(_objectSpread({}, filter), {}, {
@@ -372,7 +382,8 @@ function validateFilterYAxis(filter, dataset) {
372
382
 
373
383
  function getFilterProps(field, fieldDomain) {
374
384
  var filterProps = _objectSpread(_objectSpread({}, fieldDomain), {}, {
375
- fieldType: field.type
385
+ fieldType: field.type,
386
+ view: _constants.FILTER_VIEW_TYPES.side
376
387
  });
377
388
 
378
389
  switch (field.type) {
@@ -407,7 +418,7 @@ function getFilterProps(field, fieldDomain) {
407
418
  // @ts-expect-error
408
419
  return _objectSpread(_objectSpread({}, filterProps), {}, {
409
420
  type: _constants.FILTER_TYPES.timeRange,
410
- enlarged: true,
421
+ view: _constants.FILTER_VIEW_TYPES.enlarged,
411
422
  fixedDomain: true,
412
423
  value: filterProps.domain,
413
424
  gpu: true
@@ -496,6 +507,10 @@ function getFilterFunction(field, dataId, filter, layers, dataContainer) {
496
507
  return true;
497
508
  };
498
509
 
510
+ if (filter.enabled === false) {
511
+ return defaultFunc;
512
+ }
513
+
499
514
  switch (filter.type) {
500
515
  case _constants.FILTER_TYPES.range:
501
516
  return function (data) {
@@ -553,13 +568,15 @@ function getFilterFunction(field, dataId, filter, layers, dataContainer) {
553
568
  }
554
569
 
555
570
  function updateFilterDataId(dataId) {
556
- return getDefaultFilter(dataId);
571
+ return getDefaultFilter({
572
+ dataId: dataId
573
+ });
557
574
  }
558
575
 
559
- function filterDataByFilterTypes(_ref2, dataContainer) {
560
- var dynamicDomainFilters = _ref2.dynamicDomainFilters,
561
- cpuFilters = _ref2.cpuFilters,
562
- filterFuncs = _ref2.filterFuncs;
576
+ function filterDataByFilterTypes(_ref3, dataContainer) {
577
+ var dynamicDomainFilters = _ref3.dynamicDomainFilters,
578
+ cpuFilters = _ref3.cpuFilters,
579
+ filterFuncs = _ref3.filterFuncs;
563
580
  var filteredIndexForDomain = [];
564
581
  var filteredIndex = [];
565
582
  var filterContext = {
@@ -623,10 +640,10 @@ function getFilterRecord(dataId, filters) {
623
640
  function diffFilters(filterRecord) {
624
641
  var oldFilterRecord = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
625
642
  var filterChanged = {};
626
- Object.entries(filterRecord).forEach(function (_ref3) {
627
- var _ref4 = (0, _slicedToArray2["default"])(_ref3, 2),
628
- record = _ref4[0],
629
- items = _ref4[1];
643
+ Object.entries(filterRecord).forEach(function (_ref4) {
644
+ var _ref5 = (0, _slicedToArray2["default"])(_ref4, 2),
645
+ record = _ref5[0],
646
+ items = _ref5[1];
630
647
 
631
648
  items.forEach(function (filter) {
632
649
  var oldFilter = (oldFilterRecord[record] || []).find(function (f) {
@@ -671,9 +688,9 @@ function diffFilters(filterRecord) {
671
688
  // eslint-disable-next-line complexity
672
689
 
673
690
 
674
- function adjustValueToFilterDomain(value, _ref5) {
675
- var domain = _ref5.domain,
676
- type = _ref5.type;
691
+ function adjustValueToFilterDomain(value, _ref6) {
692
+ var domain = _ref6.domain,
693
+ type = _ref6.type;
677
694
 
678
695
  if (!type) {
679
696
  return false;
@@ -795,7 +812,12 @@ function getTimestampFieldDomain(dataContainer, valueAccessor) {
795
812
  var domain = ScaleUtils.getLinearDomain(mappedValue);
796
813
  var defaultTimeFormat = getTimeWidgetTitleFormatter(domain);
797
814
  var step = 0.01;
798
- var diff = domain[1] - domain[0];
815
+ var diff = domain[1] - domain[0]; // in case equal timestamp add 1 second padding to prevent break
816
+
817
+ if (!diff) {
818
+ domain[1] = domain[0] + 1000;
819
+ }
820
+
799
821
  var entry = TimestampStepMap.find(function (f) {
800
822
  return f.max >= diff;
801
823
  });
@@ -896,7 +918,7 @@ function getTimeWidgetTitleFormatter(domain) {
896
918
 
897
919
 
898
920
  function isFilterValidToSave(filter) {
899
- return (filter === null || filter === void 0 ? void 0 : filter.type) && Array.isArray(filter === null || filter === void 0 ? void 0 : filter.name) && ((filter === null || filter === void 0 ? void 0 : filter.name.length) || (filter === null || filter === void 0 ? void 0 : filter.layerId.length)) && isValidFilterValue(filter === null || filter === void 0 ? void 0 : filter.type, filter === null || filter === void 0 ? void 0 : filter.value);
921
+ return (filter === null || filter === void 0 ? void 0 : filter.type) && Array.isArray(filter === null || filter === void 0 ? void 0 : filter.name) && ((filter === null || filter === void 0 ? void 0 : filter.name.length) || (filter === null || filter === void 0 ? void 0 : filter.layerId.length));
900
922
  }
901
923
  /**
902
924
  * Sanity check on filters to prepare for save
@@ -962,9 +984,9 @@ function getColumnFilterProps(filter, dataset) {
962
984
  x: mappedValue[rowIndex],
963
985
  y: row.valueAt(fieldIdx)
964
986
  };
965
- }, true).filter(function (_ref6) {
966
- var x = _ref6.x,
967
- y = _ref6.y;
987
+ }, true).filter(function (_ref7) {
988
+ var x = _ref7.x,
989
+ y = _ref7.y;
968
990
  return Number.isFinite(x) && Number.isFinite(y);
969
991
  }).sort(function (a, b) {
970
992
  return (0, _d3Array.ascending)(a.x, b.x);
@@ -1144,7 +1166,9 @@ function generatePolygonFilter(layers, feature) {
1144
1166
  var name = layers.map(function (l) {
1145
1167
  return l.config.label;
1146
1168
  });
1147
- var filter = getDefaultFilter(dataId);
1169
+ var filter = getDefaultFilter({
1170
+ dataId: dataId
1171
+ });
1148
1172
  return _objectSpread(_objectSpread({}, filter), {}, {
1149
1173
  fixedDomain: true,
1150
1174
  type: _constants.FILTER_TYPES.polygon,
@@ -1191,7 +1215,7 @@ function validateFiltersUpdateDatasets(state) {
1191
1215
  var datasetIds = (0, _utils.toArray)(filter.dataId); // we can merge a filter only if all datasets in filter.dataId are loaded
1192
1216
 
1193
1217
  if (datasetIds.every(function (d) {
1194
- return datasets[d];
1218
+ return datasets[d] && !state.isMergingDatasets[d];
1195
1219
  })) {
1196
1220
  // all datasetIds in filter must be present the state datasets
1197
1221
  var _datasetIds$reduce = datasetIds.reduce(function (acc, datasetId) {
@@ -1207,7 +1231,7 @@ function validateFiltersUpdateDatasets(state) {
1207
1231
  if (updatedFilter) {
1208
1232
  return _objectSpread(_objectSpread({}, acc), {}, {
1209
1233
  // merge filter props
1210
- filter: acc.filter ? _objectSpread(_objectSpread({}, acc.filter), mergeFilterDomainStep(acc, updatedFilter)) : updatedFilter,
1234
+ filter: acc.filter ? _objectSpread(_objectSpread({}, acc.filter), mergeFilterDomainStep(acc.filter, updatedFilter)) : updatedFilter,
1211
1235
  applyToDatasets: [].concat((0, _toConsumableArray2["default"])(acc.applyToDatasets), [datasetId]),
1212
1236
  augmentedDatasets: _objectSpread(_objectSpread({}, acc.augmentedDatasets), {}, (0, _defineProperty2["default"])({}, datasetId, updatedDataset))
1213
1237
  });
@@ -1226,6 +1250,8 @@ function validateFiltersUpdateDatasets(state) {
1226
1250
  if (validatedFilter && (0, _lodash2["default"])(datasetIds, applyToDatasets)) {
1227
1251
  validated.push(validatedFilter);
1228
1252
  updatedDatasets = _objectSpread(_objectSpread({}, updatedDatasets), augmentedDatasets);
1253
+ } else {
1254
+ failed.push(filter);
1229
1255
  }
1230
1256
  } else {
1231
1257
  failed.push(filter);
@@ -1264,9 +1290,9 @@ function getFilterPlot(filter, dataset) {
1264
1290
  x: mappedValue[rowIndex],
1265
1291
  y: row.valueAt(fieldIdx)
1266
1292
  };
1267
- }, true).filter(function (_ref7) {
1268
- var x = _ref7.x,
1269
- y = _ref7.y;
1293
+ }, true).filter(function (_ref8) {
1294
+ var x = _ref8.x,
1295
+ y = _ref8.y;
1270
1296
  return Number.isFinite(x) && Number.isFinite(y);
1271
1297
  }).sort(function (a, b) {
1272
1298
  return (0, _d3Array.ascending)(a.x, b.x);
@@ -1315,4 +1341,8 @@ function getTimeWidgetHintFormatter(domain) {
1315
1341
  var diff = domain[1] - domain[0];
1316
1342
  return diff > durationWeek ? 'L' : diff > durationDay ? 'L LT' : diff > durationHour ? 'LT' : 'LTS';
1317
1343
  }
1318
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/filter-utils.ts"],"names":["durationSecond","durationMinute","durationHour","durationDay","durationWeek","durationYear","TimestampStepMap","max","step","Number","POSITIVE_INFINITY","histogramBins","enlargedHistogramBins","FILTER_UPDATER_PROPS","dataId","name","layerId","LIMITED_FILTER_EFFECT_PROPS","SupportedPlotType","FILTER_TYPES","timeRange","ALL_FIELD_TYPES","integer","real","range","FILTER_COMPONENTS","select","multiSelect","polygon","DEFAULT_FILTER_STRUCTURE","freeze","id","fixedDomain","enlarged","isAnimating","animationWindow","ANIMATION_WINDOW","free","speed","type","fieldIdx","domain","value","plotType","PLOT_TYPES","histogram","yAxis","interval","gpu","FILTER_ID_LENGTH","LAYER_FILTERS","getDefaultFilter","shouldApplyFilter","filter","datasetId","dataIds","includes","validatePolygonFilter","dataset","layers","failed","isValidFilterValue","isValidDataset","layer","find","l","filterValidators","validateFilter","filterDataId","filterDatasetIndex","indexOf","initializeFilter","fieldName","applyFilterFieldName","mergeDomain","updatedFilter","updatedDataset","adjustValueToFilterDomain","validateFilterYAxis","validateFilterWithData","hasOwnProperty","fields","matchedAxis","getFilterPlot","getFilterProps","field","fieldDomain","filterProps","fieldType","typeOptions","string","date","timestamp","getPolygonFilterFunctor","dataContainer","getPosition","getPositionAccessor","LAYER_TYPES","point","icon","data","pos","every","isFinite","isInPolygon","arc","line","hexagonId","dataToFeature","centroids","centroid","index","getFilterFunction","valueAccessor","defaultFunc","d","isInRange","mappedValue","accessor","Array","isArray","format","length","layerFilterFunctions","map","config","filterFunc","updateFilterDataId","filterDataByFilterTypes","dynamicDomainFilters","cpuFilters","filterFuncs","filteredIndexForDomain","filteredIndex","filterContext","filterFuncCaller","numRows","i","matchForDomain","push","matchForRender","getFilterRecord","filters","opt","filterRecord","dynamicDomain","cpu","forEach","f","ignoreDomain","cpuOnly","diffFilters","oldFilterRecord","filterChanged","Object","entries","record","items","oldFilter","prop","filteredValue","getNumericFieldDomain","mapIndex","ScaleUtils","getLinearDomain","diff","getNumericStepSize","formatNumberByStep","getHistogram","enlargedHistogram","Math","abs","x","exponentialForm","toExponential","exponent","parseFloat","split","Decimal","pow","toNumber","getTimestampFieldDomain","defaultTimeFormat","getTimeWidgetTitleFormatter","entry","histogramConstruct","bins","thresholds","bin","count","x0","x1","val","bound","floor","ceil","isValidTimeDomain","isFilterValidToSave","v","isNaN","Boolean","input","coordinates","getColumnFilterProps","getColumnFieldIdx","Console","warn","lineChart","series","row","rowIndex","y","valueAt","sort","a","b","yDomain","xDomain","getDefaultFilterPlotType","filterPlotTypes","applyFiltersToDatasets","datasetIds","datasets","reduce","acc","layersToFilter","appliedFilters","table","filterTable","option","fieldIndex","newFilter","mergeFilterDomainStep","assign","combinedDomain","featureToFilterValue","feature","filterId","properties","getFilterIdInFeature","generatePolygonFilter","notNullorUndefined","label","isVisible","filterDatasetCPU","state","datasetFilters","cpuFilteredDataset","filterTableCPU","validateFiltersUpdateDatasets","filtersToValidate","validated","updatedDatasets","augmentedDatasets","applyToDatasets","validatedFilter","getIntervalBins","keys","values","getTimeWidgetHintFormatter","undefined"],"mappings":"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","sourcesContent":["// Copyright (c) 2022 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport {ascending, extent, histogram as d3Histogram, ticks} from 'd3-array';\nimport keyMirror from 'keymirror';\nimport Console from 'global/console';\nimport get from 'lodash.get';\nimport isEqual from 'lodash.isequal';\n\nimport booleanWithin from '@turf/boolean-within';\nimport {point as turfPoint} from '@turf/helpers';\nimport {Decimal} from 'decimal.js';\nimport {\n  ALL_FIELD_TYPES,\n  FILTER_TYPES,\n  ANIMATION_WINDOW,\n  PLOT_TYPES,\n  LAYER_TYPES\n} from '@kepler.gl/constants';\nimport * as ScaleUtils from './data-scale-utils';\nimport {h3IsValid} from 'h3-js';\n\nimport {\n  Millisecond,\n  Entries,\n  Field,\n  ParsedFilter,\n  Filter,\n  FilterBase,\n  PolygonFilter,\n  FieldDomain,\n  TimeRangeFieldDomain,\n  HistogramBin,\n  Feature,\n  FeatureValue,\n  LineChart,\n  TimeRangeFilter,\n  RangeFieldDomain,\n  FilterDatasetOpt,\n  FilterRecord\n} from '@kepler.gl/types';\n\nimport {DataContainerInterface} from './data-container-interface';\nimport {generateHashId, set, toArray} from './utils';\nimport {notNullorUndefined, timeToUnixMilli, unique} from './data-utils';\nimport {getCentroid} from './h3-utils';\n\nexport const durationSecond = 1000;\nexport const durationMinute = durationSecond * 60;\nexport const durationHour = durationMinute * 60;\nexport const durationDay = durationHour * 24;\nexport const durationWeek = durationDay * 7;\nexport const durationYear = durationDay * 365;\n\nexport type FilterResult = {\n  filteredIndexForDomain?: number[];\n  filteredIndex?: number[];\n};\n\nexport type FilterChanged = {\n  // eslint-disable-next-line no-unused-vars\n  [key in keyof FilterRecord]: {\n    [key: string]: 'added' | 'deleted' | 'name_changed' | 'value_changed' | 'dataId_changed';\n  } | null;\n};\n\nexport type dataValueAccessor = (data: {index: number}) => number | null;\n\nexport const TimestampStepMap = [\n  {max: 1, step: 0.05},\n  {max: 10, step: 0.1},\n  {max: 100, step: 1},\n  {max: 500, step: 5},\n  {max: 1000, step: 10},\n  {max: 5000, step: 50},\n  {max: Number.POSITIVE_INFINITY, step: 1000}\n];\n\nexport const histogramBins = 30;\nexport const enlargedHistogramBins = 100;\n\nexport const FILTER_UPDATER_PROPS = keyMirror({\n  dataId: null,\n  name: null,\n  layerId: null\n});\n\nexport const LIMITED_FILTER_EFFECT_PROPS = keyMirror({\n  [FILTER_UPDATER_PROPS.name]: null\n});\n/**\n * Max number of filter value buffers that deck.gl provides\n */\n\nconst SupportedPlotType = {\n  [FILTER_TYPES.timeRange]: {\n    default: 'histogram',\n    [ALL_FIELD_TYPES.integer]: 'lineChart',\n    [ALL_FIELD_TYPES.real]: 'lineChart'\n  },\n  [FILTER_TYPES.range]: {\n    default: 'histogram',\n    [ALL_FIELD_TYPES.integer]: 'lineChart',\n    [ALL_FIELD_TYPES.real]: 'lineChart'\n  }\n};\n\nexport const FILTER_COMPONENTS = {\n  [FILTER_TYPES.select]: 'SingleSelectFilter',\n  [FILTER_TYPES.multiSelect]: 'MultiSelectFilter',\n  [FILTER_TYPES.timeRange]: 'TimeRangeFilter',\n  [FILTER_TYPES.range]: 'RangeFilter',\n  [FILTER_TYPES.polygon]: 'PolygonFilter'\n};\n\nexport const DEFAULT_FILTER_STRUCTURE = {\n  dataId: [], // [string]\n  freeze: false,\n  id: null,\n\n  // time range filter specific\n  fixedDomain: false,\n  enlarged: false,\n  isAnimating: false,\n  animationWindow: ANIMATION_WINDOW.free,\n  speed: 1,\n\n  // field specific\n  name: [], // string\n  type: null,\n  fieldIdx: [], // [integer]\n  domain: null,\n  value: null,\n\n  // plot\n  plotType: PLOT_TYPES.histogram,\n  yAxis: null,\n  interval: null,\n\n  // mode\n  gpu: false\n};\n\nexport const FILTER_ID_LENGTH = 4;\n\nexport const LAYER_FILTERS = [FILTER_TYPES.polygon];\n\n/**\n * Generates a filter with a dataset id as dataId\n */\nexport function getDefaultFilter(dataId: string | null | string[]): FilterBase<LineChart> {\n  return {\n    ...DEFAULT_FILTER_STRUCTURE,\n    // store it as dataId and it could be one or many\n    dataId: toArray(dataId),\n    id: generateHashId(FILTER_ID_LENGTH)\n  };\n}\n\n/**\n * Check if a filter is valid based on the given dataId\n * @param  filter to validate\n * @param  datasetId id to validate filter against\n * @return true if a filter is valid, false otherwise\n */\nexport function shouldApplyFilter(filter: Filter, datasetId: string): boolean {\n  const dataIds = toArray(filter.dataId);\n  return dataIds.includes(datasetId) && filter.value !== null;\n}\n\ninterface KeplerTableModel<K, L> {\n  id: string;\n  getColumnFieldIdx(columnName: string): number;\n  filterTable(filters: Filter[], layers: L[], opt?: FilterDatasetOpt): K;\n  getColumnFilterProps(columnName: string): Field['filterProps'] | null | undefined;\n  dataContainer: DataContainerInterface;\n  filterTableCPU(filters: Filter[], layers: L[]): K;\n}\n\n/**\n * Validates and modifies polygon filter structure\n * @param dataset\n * @param filter\n * @param layers\n * @return - {filter, dataset}\n */\nexport function validatePolygonFilter<K extends KeplerTableModel<K, L>, L extends {id: string}>(\n  dataset: K,\n  filter: PolygonFilter,\n  layers: L[]\n): {filter: PolygonFilter | null; dataset: K} {\n  const failed = {dataset, filter: null};\n  const {value, layerId, type, dataId} = filter;\n\n  if (!layerId || !isValidFilterValue(type, value)) {\n    return failed;\n  }\n\n  const isValidDataset = dataId.includes(dataset.id);\n\n  if (!isValidDataset) {\n    return failed;\n  }\n\n  const layer = layers.find(l => layerId.includes(l.id));\n\n  if (!layer) {\n    return failed;\n  }\n\n  return {\n    filter: {\n      ...filter,\n      freeze: true,\n      fieldIdx: []\n    },\n    dataset\n  };\n}\n\n/**\n * Custom filter validators\n */\nconst filterValidators = {\n  [FILTER_TYPES.polygon]: validatePolygonFilter\n};\n\n/**\n * Default validate filter function\n * @param dataset\n * @param filter\n * @return - {filter, dataset}\n */\nexport function validateFilter<K extends KeplerTableModel<K, L>, L>(\n  dataset: K,\n  filter: ParsedFilter\n): {filter: Filter | null; dataset: K} {\n  // match filter.dataId\n  const failed = {dataset, filter: null};\n  const filterDataId = toArray(filter.dataId);\n\n  const filterDatasetIndex = filterDataId.indexOf(dataset.id);\n  if (filterDatasetIndex < 0 || !toArray(filter.name)[filterDatasetIndex]) {\n    // the current filter is not mapped against the current dataset\n    return failed;\n  }\n\n  const initializeFilter: Filter = {\n    // @ts-expect-error\n    ...getDefaultFilter(filter.dataId),\n    ...filter,\n    dataId: filterDataId,\n    name: toArray(filter.name)\n  };\n\n  const fieldName = initializeFilter.name[filterDatasetIndex];\n  const {filter: updatedFilter, dataset: updatedDataset} = applyFilterFieldName(\n    initializeFilter,\n    dataset,\n    fieldName,\n    filterDatasetIndex,\n    {mergeDomain: true}\n  );\n\n  if (!updatedFilter) {\n    return failed;\n  }\n\n  updatedFilter.value = adjustValueToFilterDomain(filter.value, updatedFilter);\n  updatedFilter.enlarged =\n    typeof filter.enlarged === 'boolean' ? filter.enlarged : updatedFilter.enlarged;\n\n  if (updatedFilter.value === null) {\n    // cannot adjust saved value to filter\n    return failed;\n  }\n\n  return {\n    filter: validateFilterYAxis(updatedFilter, updatedDataset),\n    dataset: updatedDataset\n  };\n}\n\n/**\n * Validate saved filter config with new data,\n * calculate domain and fieldIdx based new fields and data\n *\n * @param dataset\n * @param filter - filter to be validate\n * @param layers - layers\n * @return validated filter\n */\nexport function validateFilterWithData<K extends KeplerTableModel<K, L>, L>(\n  dataset: K,\n  filter: ParsedFilter,\n  layers: L[]\n): {filter: Filter; dataset: K} {\n  return filter.type && filterValidators.hasOwnProperty(filter.type)\n    ? filterValidators[filter.type](dataset, filter, layers)\n    : validateFilter(dataset, filter);\n}\n\n/**\n * Validate YAxis\n * @param filter\n * @param dataset\n * @return {*}\n */\nfunction validateFilterYAxis(filter, dataset) {\n  // TODO: validate yAxis against other datasets\n\n  const {fields} = dataset;\n  const {yAxis} = filter;\n  // TODO: validate yAxis against other datasets\n  if (yAxis) {\n    const matchedAxis = fields.find(({name, type}) => name === yAxis.name && type === yAxis.type);\n\n    filter = matchedAxis\n      ? {\n          ...filter,\n          yAxis: matchedAxis,\n          ...getFilterPlot({...filter, yAxis: matchedAxis}, dataset)\n        }\n      : filter;\n  }\n\n  return filter;\n}\n\n/**\n * Get default filter prop based on field type\n *\n * @param field\n * @param fieldDomain\n * @returns default filter\n */\nexport function getFilterProps(\n  field: Field,\n  fieldDomain: FieldDomain\n): Partial<Filter> & {fieldType: string} {\n  const filterProps = {\n    ...fieldDomain,\n    fieldType: field.type\n  };\n\n  switch (field.type) {\n    case ALL_FIELD_TYPES.real:\n    case ALL_FIELD_TYPES.integer:\n      return {\n        ...filterProps,\n        value: fieldDomain.domain,\n        type: FILTER_TYPES.range,\n        // @ts-expect-error\n        typeOptions: [FILTER_TYPES.range],\n        gpu: true\n      };\n\n    case ALL_FIELD_TYPES.boolean:\n      // @ts-expect-error\n      return {\n        ...filterProps,\n        type: FILTER_TYPES.select,\n        value: true,\n        gpu: false\n      };\n\n    case ALL_FIELD_TYPES.string:\n    case ALL_FIELD_TYPES.date:\n      // @ts-expect-error\n      return {\n        ...filterProps,\n        type: FILTER_TYPES.multiSelect,\n        value: [],\n        gpu: false\n      };\n\n    case ALL_FIELD_TYPES.timestamp:\n      // @ts-expect-error\n      return {\n        ...filterProps,\n        type: FILTER_TYPES.timeRange,\n        enlarged: true,\n        fixedDomain: true,\n        value: filterProps.domain,\n        gpu: true\n      };\n\n    default:\n      // @ts-expect-error\n      return {};\n  }\n}\n\nexport const getPolygonFilterFunctor = (layer, filter, dataContainer) => {\n  const getPosition = layer.getPositionAccessor(dataContainer);\n\n  switch (layer.type) {\n    case LAYER_TYPES.point:\n    case LAYER_TYPES.icon:\n      return data => {\n        const pos = getPosition(data);\n        return pos.every(Number.isFinite) && isInPolygon(pos, filter.value);\n      };\n    case LAYER_TYPES.arc:\n    case LAYER_TYPES.line:\n      return data => {\n        const pos = getPosition(data);\n        return (\n          pos.every(Number.isFinite) &&\n          [\n            [pos[0], pos[1]],\n            [pos[3], pos[4]]\n          ].every(point => isInPolygon(point, filter.value))\n        );\n      };\n    case LAYER_TYPES.hexagonId:\n      if (layer.dataToFeature && layer.dataToFeature.centroids) {\n        return data => {\n          // null or getCentroid({id})\n          const centroid = layer.dataToFeature.centroids[data.index];\n          return centroid && isInPolygon(centroid, filter.value);\n        };\n      }\n      return data => {\n        const id = getPosition(data);\n        if (!h3IsValid(id)) {\n          return false;\n        }\n        const pos = getCentroid({id});\n        return pos.every(Number.isFinite) && isInPolygon(pos, filter.value);\n      };\n    default:\n      return () => true;\n  }\n};\n\n/**\n * @param param An object that represents a row record.\n * @param param.index Index of the row in data container.\n * @returns Returns true to keep the element, or false otherwise.\n */\ntype filterFunction = (data: {index: number}) => boolean;\n/**\n * @param field dataset Field\n * @param dataId Dataset id\n * @param filter Filter object\n * @param layers list of layers to filter upon\n * @param dataContainer Data container\n * @return filterFunction\n */\n/* eslint-disable complexity */\nexport function getFilterFunction<L extends {config: {dataId: string | null}; id: string}>(\n  field: Field | null,\n  dataId: string,\n  filter: Filter,\n  layers: L[],\n  dataContainer: DataContainerInterface\n): filterFunction {\n  // field could be null in polygon filter\n  const valueAccessor = field ? field.valueAccessor : data => null;\n  const defaultFunc = d => true;\n\n  switch (filter.type) {\n    case FILTER_TYPES.range:\n      return data => isInRange(valueAccessor(data), filter.value);\n    case FILTER_TYPES.multiSelect:\n      return data => filter.value.includes(valueAccessor(data));\n    case FILTER_TYPES.select:\n      return data => valueAccessor(data) === filter.value;\n    case FILTER_TYPES.timeRange:\n      if (!field) {\n        return defaultFunc;\n      }\n      const mappedValue = get(field, ['filterProps', 'mappedValue']);\n      const accessor = Array.isArray(mappedValue)\n        ? data => mappedValue[data.index]\n        : data => timeToUnixMilli(valueAccessor(data), field.format);\n      return data => isInRange(accessor(data), filter.value);\n    case FILTER_TYPES.polygon:\n      if (!layers || !layers.length || !filter.layerId) {\n        return defaultFunc;\n      }\n      const layerFilterFunctions = filter.layerId\n        .map(id => layers.find(l => l.id === id))\n        .filter(l => l && l.config.dataId === dataId)\n        .map(layer => getPolygonFilterFunctor(layer, filter, dataContainer));\n\n      return data => layerFilterFunctions.every(filterFunc => filterFunc(data));\n    default:\n      return defaultFunc;\n  }\n}\n\nexport function updateFilterDataId(dataId: string): FilterBase<LineChart> {\n  return getDefaultFilter(dataId);\n}\n\nexport function filterDataByFilterTypes(\n  {\n    dynamicDomainFilters,\n    cpuFilters,\n    filterFuncs\n  }: {\n    dynamicDomainFilters: Filter[] | null;\n    cpuFilters: Filter[] | null;\n    filterFuncs: {\n      [key: string]: filterFunction;\n    };\n  },\n  dataContainer: DataContainerInterface\n): FilterResult {\n  const filteredIndexForDomain: number[] = [];\n  const filteredIndex: number[] = [];\n\n  const filterContext = {index: -1, dataContainer};\n  const filterFuncCaller = (filter: Filter) => filterFuncs[filter.id](filterContext);\n\n  const numRows = dataContainer.numRows();\n  for (let i = 0; i < numRows; ++i) {\n    filterContext.index = i;\n\n    const matchForDomain = dynamicDomainFilters && dynamicDomainFilters.every(filterFuncCaller);\n    if (matchForDomain) {\n      filteredIndexForDomain.push(filterContext.index);\n    }\n\n    const matchForRender = cpuFilters && cpuFilters.every(filterFuncCaller);\n    if (matchForRender) {\n      filteredIndex.push(filterContext.index);\n    }\n  }\n\n  return {\n    ...(dynamicDomainFilters ? {filteredIndexForDomain} : {}),\n    ...(cpuFilters ? {filteredIndex} : {})\n  };\n}\n\n/**\n * Get a record of filters based on domain type and gpu / cpu\n */\nexport function getFilterRecord(\n  dataId: string,\n  filters: Filter[],\n  opt: FilterDatasetOpt = {}\n): FilterRecord {\n  const filterRecord: FilterRecord = {\n    dynamicDomain: [],\n    fixedDomain: [],\n    cpu: [],\n    gpu: []\n  };\n\n  filters.forEach(f => {\n    if (isValidFilterValue(f.type, f.value) && toArray(f.dataId).includes(dataId)) {\n      (f.fixedDomain || opt.ignoreDomain\n        ? filterRecord.fixedDomain\n        : filterRecord.dynamicDomain\n      ).push(f);\n\n      (f.gpu && !opt.cpuOnly ? filterRecord.gpu : filterRecord.cpu).push(f);\n    }\n  });\n\n  return filterRecord;\n}\n\n/**\n * Compare filter records to get what has changed\n */\nexport function diffFilters(\n  filterRecord: FilterRecord,\n  oldFilterRecord: FilterRecord | {} = {}\n): FilterChanged {\n  let filterChanged: Partial<FilterChanged> = {};\n\n  (Object.entries(filterRecord) as Entries<FilterRecord>).forEach(([record, items]) => {\n    items.forEach(filter => {\n      const oldFilter: Filter = (oldFilterRecord[record] || []).find(\n        (f: Filter) => f.id === filter.id\n      );\n\n      if (!oldFilter) {\n        // added\n        filterChanged = set([record, filter.id], 'added', filterChanged);\n      } else {\n        // check  what has changed\n        ['name', 'value', 'dataId'].forEach(prop => {\n          if (filter[prop] !== oldFilter[prop]) {\n            filterChanged = set([record, filter.id], `${prop}_changed`, filterChanged);\n          }\n        });\n      }\n    });\n\n    (oldFilterRecord[record] || []).forEach((oldFilter: Filter) => {\n      // deleted\n      if (!items.find(f => f.id === oldFilter.id)) {\n        filterChanged = set([record, oldFilter.id], 'deleted', filterChanged);\n      }\n    });\n  });\n\n  return {...{dynamicDomain: null, fixedDomain: null, cpu: null, gpu: null}, ...filterChanged};\n}\n/**\n * Call by parsing filters from URL\n * Check if value of filter within filter domain, if not adjust it to match\n * filter domain\n *\n * @returns value - adjusted value to match filter or null to remove filter\n */\n// eslint-disable-next-line complexity\nexport function adjustValueToFilterDomain(value: Filter['value'], {domain, type}) {\n  if (!type) {\n    return false;\n  }\n  // if the current filter is a polygon it will not have any domain\n  // all other filter types require domain\n  if (type !== FILTER_TYPES.polygon && !domain) {\n    return false;\n  }\n\n  switch (type) {\n    case FILTER_TYPES.range:\n    case FILTER_TYPES.timeRange:\n      if (!Array.isArray(value) || value.length !== 2) {\n        return domain.map(d => d);\n      }\n\n      return value.map((d, i) => (notNullorUndefined(d) && isInRange(d, domain) ? d : domain[i]));\n\n    case FILTER_TYPES.multiSelect:\n      if (!Array.isArray(value)) {\n        return [];\n      }\n      const filteredValue = value.filter(d => domain.includes(d));\n      return filteredValue.length ? filteredValue : [];\n\n    case FILTER_TYPES.select:\n      return domain.includes(value) ? value : true;\n    case FILTER_TYPES.polygon:\n      return value;\n\n    default:\n      return null;\n  }\n}\n/* eslint-enable complexity */\n\n/**\n * Calculate numeric domain and suitable step\n */\nexport function getNumericFieldDomain(\n  dataContainer: DataContainerInterface,\n  valueAccessor: dataValueAccessor\n): RangeFieldDomain {\n  let domain: [number, number] = [0, 1];\n  let step = 0.1;\n\n  const mappedValue = dataContainer.mapIndex(valueAccessor);\n\n  if (dataContainer.numRows() > 1) {\n    domain = ScaleUtils.getLinearDomain(mappedValue);\n    const diff = domain[1] - domain[0];\n\n    // in case equal domain, [96, 96], which will break quantize scale\n    if (!diff) {\n      domain[1] = domain[0] + 1;\n    }\n\n    step = getNumericStepSize(diff) || step;\n    domain[0] = formatNumberByStep(domain[0], step, 'floor');\n    domain[1] = formatNumberByStep(domain[1], step, 'ceil');\n  }\n\n  const {histogram, enlargedHistogram} = getHistogram(domain, mappedValue);\n\n  return {domain, step, histogram, enlargedHistogram};\n}\n\n/**\n * Calculate step size for range and timerange filter\n */\nexport function getNumericStepSize(diff: number): number {\n  diff = Math.abs(diff);\n\n  if (diff > 100) {\n    return 1;\n  } else if (diff > 3) {\n    return 0.01;\n  } else if (diff > 1) {\n    return 0.001;\n  }\n  // Try to get at least 1000 steps - and keep the step size below that of\n  // the (diff > 1) case.\n  const x = diff / 1000;\n  // Find the exponent and truncate to 10 to the power of that exponent\n\n  const exponentialForm = x.toExponential();\n  const exponent = parseFloat(exponentialForm.split('e')[1]);\n\n  // Getting ready for node 12\n  // this is why we need decimal.js\n  // Math.pow(10, -5) = 0.000009999999999999999\n  // the above result shows in browser and node 10\n  // node 12 behaves correctly\n  return new Decimal(10).pow(exponent).toNumber();\n}\n\n/**\n * Calculate timestamp domain and suitable step\n */\nexport function getTimestampFieldDomain(\n  dataContainer: DataContainerInterface,\n  valueAccessor: dataValueAccessor\n): TimeRangeFieldDomain {\n  // to avoid converting string format time to epoch\n  // every time we compare we store a value mapped to int in filter domain\n\n  const mappedValue = dataContainer.mapIndex(valueAccessor);\n  const domain = ScaleUtils.getLinearDomain(mappedValue);\n  const defaultTimeFormat = getTimeWidgetTitleFormatter(domain);\n\n  let step = 0.01;\n\n  const diff = domain[1] - domain[0];\n  const entry = TimestampStepMap.find(f => f.max >= diff);\n  if (entry) {\n    step = entry.step;\n  }\n\n  const {histogram, enlargedHistogram} = getHistogram(domain, mappedValue);\n\n  return {\n    domain,\n    step,\n    mappedValue,\n    histogram,\n    enlargedHistogram,\n    defaultTimeFormat\n  };\n}\n\nexport function histogramConstruct(\n  domain: [number, number],\n  mappedValue: (Millisecond | number)[],\n  bins: number\n): HistogramBin[] {\n  return d3Histogram()\n    .thresholds(ticks(domain[0], domain[1], bins))\n    .domain(domain)(mappedValue)\n    .map(bin => ({\n      count: bin.length,\n      bin,\n      x0: bin.x0,\n      x1: bin.x1\n    }));\n}\n/**\n * Calculate histogram from domain and array of values\n */\nexport function getHistogram(\n  domain: [number, number],\n  mappedValue: (Millisecond | number)[]\n): {histogram: HistogramBin[]; enlargedHistogram: HistogramBin[]} {\n  const histogram = histogramConstruct(domain, mappedValue, histogramBins);\n  const enlargedHistogram = histogramConstruct(domain, mappedValue, enlargedHistogramBins);\n\n  return {histogram, enlargedHistogram};\n}\n\n/**\n * round number based on step\n *\n * @param {Number} val\n * @param {Number} step\n * @param {string} bound\n * @returns {Number} rounded number\n */\nexport function formatNumberByStep(val: number, step: number, bound: 'floor' | 'ceil'): number {\n  if (bound === 'floor') {\n    return Math.floor(val * (1 / step)) / (1 / step);\n  }\n\n  return Math.ceil(val * (1 / step)) / (1 / step);\n}\n\nexport function isInRange(val: any, domain: number[]): boolean {\n  if (!Array.isArray(domain)) {\n    return false;\n  }\n\n  return val >= domain[0] && val <= domain[1];\n}\n\n/**\n * Determines whether a point is within the provided polygon\n *\n * @param point as input search [lat, lng]\n * @param polygon Points must be within these (Multi)Polygon(s)\n * @return {boolean}\n */\nexport function isInPolygon(point: number[], polygon: any): boolean {\n  return booleanWithin(turfPoint(point), polygon);\n}\nexport function getTimeWidgetTitleFormatter(domain: [number, number]): string | null {\n  if (!isValidTimeDomain(domain)) {\n    return null;\n  }\n\n  const diff = domain[1] - domain[0];\n\n  // Local aware formats\n  // https://momentjs.com/docs/#/parsing/string-format\n  return diff > durationYear ? 'L' : diff > durationDay ? 'L LT' : 'L LTS';\n}\n\n/**\n * Sanity check on filters to prepare for save\n * @type {typeof import('./filter-utils').isFilterValidToSave}\n */\nexport function isFilterValidToSave(filter: any): boolean {\n  return (\n    filter?.type &&\n    Array.isArray(filter?.name) &&\n    (filter?.name.length || filter?.layerId.length) &&\n    isValidFilterValue(filter?.type, filter?.value)\n  );\n}\n\n/**\n * Sanity check on filters to prepare for save\n * @type {typeof import('./filter-utils').isValidFilterValue}\n */\n/* eslint-disable complexity */\nexport function isValidFilterValue(type: string | null, value: any): boolean {\n  if (!type) {\n    return false;\n  }\n  switch (type) {\n    case FILTER_TYPES.select:\n      return value === true || value === false;\n\n    case FILTER_TYPES.range:\n    case FILTER_TYPES.timeRange:\n      return Array.isArray(value) && value.every(v => v !== null && !isNaN(v));\n\n    case FILTER_TYPES.multiSelect:\n      return Array.isArray(value) && Boolean(value.length);\n\n    case FILTER_TYPES.input:\n      return Boolean(value.length);\n\n    case FILTER_TYPES.polygon:\n      const coordinates = get(value, ['geometry', 'coordinates']);\n      return Boolean(value && value.id && coordinates);\n\n    default:\n      return true;\n  }\n}\n\nexport function getColumnFilterProps<K extends KeplerTableModel<K, L>, L>(\n  filter: Filter,\n  dataset: K\n): {lineChart: LineChart; yAxs: Field} | {} {\n  if (filter.plotType === PLOT_TYPES.histogram || !filter.yAxis) {\n    // histogram should be calculated when create filter\n    return {};\n  }\n\n  const {mappedValue = []} = filter;\n  const {yAxis} = filter;\n  const fieldIdx = dataset.getColumnFieldIdx(yAxis.name);\n  if (fieldIdx < 0) {\n    Console.warn(`yAxis ${yAxis.name} does not exist in dataset`);\n    return {lineChart: {}, yAxis};\n  }\n\n  // return lineChart\n  const series = dataset.dataContainer\n    .map(\n      (row, rowIndex) => ({\n        x: mappedValue[rowIndex],\n        y: row.valueAt(fieldIdx)\n      }),\n      true\n    )\n    .filter(({x, y}) => Number.isFinite(x) && Number.isFinite(y))\n    .sort((a, b) => ascending(a.x, b.x));\n\n  const yDomain = extent(series, d => d.y);\n  const xDomain = [series[0].x, series[series.length - 1].x];\n\n  return {lineChart: {series, yDomain, xDomain}, yAxis};\n}\n\nexport function getDefaultFilterPlotType(filter: Filter): string | null {\n  const filterPlotTypes: typeof SupportedPlotType[keyof typeof SupportedPlotType] | null =\n    filter.type && SupportedPlotType[filter.type];\n  if (!filterPlotTypes) {\n    return null;\n  }\n\n  if (!filter.yAxis) {\n    return filterPlotTypes.default;\n  }\n\n  return filterPlotTypes[filter.yAxis.type] || null;\n}\n\n/**\n *\n * @param datasetIds list of dataset ids to be filtered\n * @param datasets all datasets\n * @param filters all filters to be applied to datasets\n * @return datasets - new updated datasets\n */\nexport function applyFiltersToDatasets<\n  K extends KeplerTableModel<K, L>,\n  L extends {config: {dataId: string | null}}\n>(\n  datasetIds: string[],\n  datasets: {[id: string]: K},\n  filters: Filter[],\n  layers?: L[]\n): {[id: string]: K} {\n  const dataIds = toArray(datasetIds);\n  return dataIds.reduce((acc, dataId) => {\n    const layersToFilter = (layers || []).filter(l => l.config.dataId === dataId);\n    const appliedFilters = filters.filter(d => shouldApplyFilter(d, dataId));\n    const table = datasets[dataId];\n\n    return {\n      ...acc,\n      [dataId]: table.filterTable(appliedFilters, layersToFilter, {})\n    };\n  }, datasets);\n}\n\n/**\n * Applies a new field name value to fielter and update both filter and dataset\n * @param filter - to be applied the new field name on\n * @param dataset - dataset the field belongs to\n * @param fieldName - field.name\n * @param filterDatasetIndex - field.name\n * @param option\n * @return - {filter, datasets}\n */\nexport function applyFilterFieldName<K extends KeplerTableModel<K, L>, L>(\n  filter: Filter,\n  dataset: K,\n  fieldName: string,\n  filterDatasetIndex = 0,\n  option?: {mergeDomain: boolean}\n): {\n  filter: Filter | null;\n  dataset: K;\n} {\n  // using filterDatasetIndex we can filter only the specified dataset\n  const mergeDomain = option && option.hasOwnProperty('mergeDomain') ? option.mergeDomain : false;\n\n  const fieldIndex = dataset.getColumnFieldIdx(fieldName);\n  // if no field with same name is found, move to the next datasets\n  if (fieldIndex === -1) {\n    // throw new Error(`fieldIndex not found. Dataset must contain a property with name: ${fieldName}`);\n    return {filter: null, dataset};\n  }\n\n  // TODO: validate field type\n  const filterProps = dataset.getColumnFilterProps(fieldName);\n\n  const newFilter = {\n    ...(mergeDomain ? mergeFilterDomainStep(filter, filterProps) : {...filter, ...filterProps}),\n    name: Object.assign([...toArray(filter.name)], {[filterDatasetIndex]: fieldName}),\n    fieldIdx: Object.assign([...toArray(filter.fieldIdx)], {\n      [filterDatasetIndex]: fieldIndex\n    }),\n    // TODO, since we allow to add multiple fields to a filter we can no longer freeze the filter\n    freeze: true\n  };\n\n  return {\n    filter: newFilter,\n    dataset\n  };\n}\n\n/**\n * Merge one filter with other filter prop domain\n */\n/* eslint-disable complexity */\nexport function mergeFilterDomainStep(\n  filter: Filter,\n  filterProps?: Partial<Filter>\n): (Filter & {step?: number}) | null {\n  if (!filter) {\n    return null;\n  }\n\n  if (!filterProps) {\n    return filter;\n  }\n\n  if ((filter.fieldType && filter.fieldType !== filterProps.fieldType) || !filterProps.domain) {\n    return filter;\n  }\n\n  const combinedDomain = !filter.domain\n    ? filterProps.domain\n    : [...(filter.domain || []), ...(filterProps.domain || [])].sort((a, b) => a - b);\n\n  const newFilter = {\n    ...filter,\n    ...filterProps,\n    domain: [combinedDomain[0], combinedDomain[combinedDomain.length - 1]]\n  };\n\n  switch (filterProps.fieldType) {\n    case ALL_FIELD_TYPES.string:\n    case ALL_FIELD_TYPES.date:\n      return {\n        ...newFilter,\n        domain: unique(combinedDomain).sort()\n      };\n\n    case ALL_FIELD_TYPES.timestamp:\n      const step =\n        (filter as TimeRangeFilter).step < (filterProps as TimeRangeFieldDomain).step\n          ? (filter as TimeRangeFilter).step\n          : (filterProps as TimeRangeFieldDomain).step;\n\n      return {\n        ...newFilter,\n        step\n      };\n    case ALL_FIELD_TYPES.real:\n    case ALL_FIELD_TYPES.integer:\n    default:\n      return newFilter;\n  }\n}\n/* eslint-enable complexity */\n\n/**\n * Generates polygon filter\n */\nexport const featureToFilterValue = (\n  feature: Feature,\n  filterId: string,\n  properties?: {}\n): FeatureValue => ({\n  ...feature,\n  id: feature.id,\n  properties: {\n    ...feature.properties,\n    ...properties,\n    filterId\n  }\n});\n\nexport const getFilterIdInFeature = (f: FeatureValue): string => get(f, ['properties', 'filterId']);\n\n/**\n * Generates polygon filter\n */\nexport function generatePolygonFilter<\n  L extends {config: {dataId: string | null; label: string}; id: string}\n>(layers: L[], feature: Feature): PolygonFilter {\n  const dataId = layers.map(l => l.config.dataId).filter(notNullorUndefined);\n  const layerId = layers.map(l => l.id);\n  const name = layers.map(l => l.config.label);\n  const filter = getDefaultFilter(dataId);\n  return {\n    ...filter,\n    fixedDomain: true,\n    type: FILTER_TYPES.polygon,\n    name,\n    layerId,\n    value: featureToFilterValue(feature, filter.id, {isVisible: true})\n  };\n}\n\n/**\n * Run filter entirely on CPU\n */\ninterface StateType<K extends KeplerTableModel<K, L>, L> {\n  layers: L[];\n  filters: Filter[];\n  datasets: {[id: string]: K};\n}\n\nexport function filterDatasetCPU<T extends StateType<K, L>, K extends KeplerTableModel<K, L>, L>(\n  state: T,\n  dataId: string\n): T {\n  const datasetFilters = state.filters.filter(f => f.dataId.includes(dataId));\n  const dataset = state.datasets[dataId];\n\n  if (!dataset) {\n    return state;\n  }\n\n  const cpuFilteredDataset = dataset.filterTableCPU(datasetFilters, state.layers);\n\n  return set(['datasets', dataId], cpuFilteredDataset, state);\n}\n\n/**\n * Validate parsed filters with datasets and add filterProps to field\n */\nexport function validateFiltersUpdateDatasets<\n  S extends {datasets: {[id: string]: K}; layers: L[]},\n  K extends KeplerTableModel<K, L>,\n  L extends {config: {dataId: string | null; label: string}; id: string}\n>(\n  state: S,\n  filtersToValidate: ParsedFilter[] = []\n): {\n  validated: Filter[];\n  failed: Filter[];\n  updatedDatasets: S['datasets'];\n} {\n  // TODO Better Typings here\n  const validated: any[] = [];\n  const failed: any[] = [];\n  const {datasets} = state;\n  let updatedDatasets = datasets;\n\n  // merge filters\n  filtersToValidate.forEach(filter => {\n    // we can only look for datasets define in the filter dataId\n    const datasetIds = toArray(filter.dataId);\n\n    // we can merge a filter only if all datasets in filter.dataId are loaded\n    if (datasetIds.every(d => datasets[d])) {\n      // all datasetIds in filter must be present the state datasets\n      const {filter: validatedFilter, applyToDatasets, augmentedDatasets} = datasetIds.reduce(\n        (acc, datasetId) => {\n          const dataset = updatedDatasets[datasetId];\n          const layers = state.layers.filter(l => l.config.dataId === dataset.id);\n          const {filter: updatedFilter, dataset: updatedDataset} = validateFilterWithData(\n            acc.augmentedDatasets[datasetId] || dataset,\n            filter,\n            layers\n          );\n\n          if (updatedFilter) {\n            return {\n              ...acc,\n              // merge filter props\n              filter: acc.filter\n                ? {\n                    ...acc.filter,\n                    ...mergeFilterDomainStep(acc, updatedFilter)\n                  }\n                : updatedFilter,\n\n              applyToDatasets: [...acc.applyToDatasets, datasetId],\n\n              augmentedDatasets: {\n                ...acc.augmentedDatasets,\n                [datasetId]: updatedDataset\n              }\n            };\n          }\n\n          return acc;\n        },\n        {\n          filter: null,\n          applyToDatasets: [],\n          augmentedDatasets: {}\n        }\n      );\n\n      if (validatedFilter && isEqual(datasetIds, applyToDatasets)) {\n        validated.push(validatedFilter);\n        updatedDatasets = {\n          ...updatedDatasets,\n          ...augmentedDatasets\n        };\n      }\n    } else {\n      failed.push(filter);\n    }\n  });\n\n  return {validated, failed, updatedDatasets};\n}\n\nexport function getFilterPlot<K extends KeplerTableModel<K, L>, L>(\n  filter: Filter,\n  dataset: K\n): {lineChart: LineChart; yAxs: Field} | {} {\n  if (filter.plotType === PLOT_TYPES.histogram || !filter.yAxis) {\n    // histogram should be calculated when create filter\n    return {};\n  }\n\n  const {mappedValue = []} = filter;\n  const {yAxis} = filter;\n  const fieldIdx = dataset.getColumnFieldIdx(yAxis.name);\n  if (fieldIdx < 0) {\n    Console.warn(`yAxis ${yAxis.name} does not exist in dataset`);\n    return {lineChart: {}, yAxis};\n  }\n\n  // return lineChart\n  const series = dataset.dataContainer\n    .map(\n      (row, rowIndex) => ({\n        x: mappedValue[rowIndex],\n        y: row.valueAt(fieldIdx)\n      }),\n      true\n    )\n    .filter(({x, y}) => Number.isFinite(x) && Number.isFinite(y))\n    .sort((a, b) => ascending(a.x, b.x));\n\n  const yDomain = extent(series, d => d.y);\n  const xDomain = [series[0].x, series[series.length - 1].x];\n\n  return {lineChart: {series, yDomain, xDomain}, yAxis};\n}\n\n/**\n * Retrieve interval bins for time filter\n */\nexport function getIntervalBins(filter: TimeRangeFilter) {\n  const {bins} = filter;\n  const interval = filter.plotType?.interval;\n  if (!interval || !bins || Object.keys(bins).length === 0) {\n    return null;\n  }\n  const values = Object.values(bins);\n  return values[0] ? values[0][interval] : null;\n}\n\nexport function isValidTimeDomain(domain) {\n  return Array.isArray(domain) && domain.every(Number.isFinite);\n}\n\nexport function getTimeWidgetHintFormatter(domain: [number, number]): string | undefined {\n  if (!isValidTimeDomain(domain)) {\n    return undefined;\n  }\n\n  const diff = domain[1] - domain[0];\n  return diff > durationWeek\n    ? 'L'\n    : diff > durationDay\n    ? 'L LT'\n    : diff > durationHour\n    ? 'LT'\n    : 'LTS';\n}\n"]}
1344
+
1345
+ function isSideFilter(filter) {
1346
+ return filter.view === _constants.FILTER_VIEW_TYPES.side;
1347
+ }
1348
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/filter-utils.ts"],"names":["durationSecond","durationMinute","durationHour","durationDay","durationWeek","durationYear","TimestampStepMap","max","step","Number","POSITIVE_INFINITY","histogramBins","enlargedHistogramBins","FILTER_UPDATER_PROPS","dataId","name","layerId","LIMITED_FILTER_EFFECT_PROPS","SupportedPlotType","FILTER_TYPES","timeRange","ALL_FIELD_TYPES","integer","real","range","FILTER_COMPONENTS","select","multiSelect","polygon","DEFAULT_FILTER_STRUCTURE","freeze","id","enabled","fixedDomain","view","FILTER_VIEW_TYPES","side","isAnimating","animationWindow","ANIMATION_WINDOW","free","speed","type","fieldIdx","domain","value","plotType","PLOT_TYPES","histogram","yAxis","interval","gpu","FILTER_ID_LENGTH","LAYER_FILTERS","getDefaultFilter","shouldApplyFilter","filter","datasetId","dataIds","includes","validatePolygonFilter","dataset","layers","failed","isValidFilterValue","isValidDataset","layer","find","l","filterValidators","validateFilter","filterDataId","filterDatasetIndex","indexOf","initializeFilter","fieldName","applyFilterFieldName","mergeDomain","updatedFilter","updatedDataset","adjustValueToFilterDomain","validateFilterYAxis","validateFilterWithData","hasOwnProperty","fields","matchedAxis","getFilterPlot","getFilterProps","field","fieldDomain","filterProps","fieldType","typeOptions","string","date","timestamp","enlarged","getPolygonFilterFunctor","dataContainer","getPosition","getPositionAccessor","LAYER_TYPES","point","icon","data","pos","every","isFinite","isInPolygon","arc","line","hexagonId","dataToFeature","centroids","centroid","index","getFilterFunction","valueAccessor","defaultFunc","d","isInRange","mappedValue","accessor","Array","isArray","format","length","layerFilterFunctions","map","config","filterFunc","updateFilterDataId","filterDataByFilterTypes","dynamicDomainFilters","cpuFilters","filterFuncs","filteredIndexForDomain","filteredIndex","filterContext","filterFuncCaller","numRows","i","matchForDomain","push","matchForRender","getFilterRecord","filters","opt","filterRecord","dynamicDomain","cpu","forEach","f","ignoreDomain","cpuOnly","diffFilters","oldFilterRecord","filterChanged","Object","entries","record","items","oldFilter","prop","filteredValue","getNumericFieldDomain","mapIndex","ScaleUtils","getLinearDomain","diff","getNumericStepSize","formatNumberByStep","getHistogram","enlargedHistogram","Math","abs","x","exponentialForm","toExponential","exponent","parseFloat","split","Decimal","pow","toNumber","getTimestampFieldDomain","defaultTimeFormat","getTimeWidgetTitleFormatter","entry","histogramConstruct","bins","thresholds","bin","count","x0","x1","val","bound","floor","ceil","isValidTimeDomain","isFilterValidToSave","v","isNaN","Boolean","input","coordinates","getColumnFilterProps","getColumnFieldIdx","Console","warn","lineChart","series","row","rowIndex","y","valueAt","sort","a","b","yDomain","xDomain","getDefaultFilterPlotType","filterPlotTypes","applyFiltersToDatasets","datasetIds","datasets","reduce","acc","layersToFilter","appliedFilters","table","filterTable","option","fieldIndex","newFilter","mergeFilterDomainStep","assign","combinedDomain","featureToFilterValue","feature","filterId","properties","getFilterIdInFeature","generatePolygonFilter","notNullorUndefined","label","isVisible","filterDatasetCPU","state","datasetFilters","cpuFilteredDataset","filterTableCPU","validateFiltersUpdateDatasets","filtersToValidate","validated","updatedDatasets","isMergingDatasets","augmentedDatasets","applyToDatasets","validatedFilter","getIntervalBins","keys","values","getTimeWidgetHintFormatter","undefined","isSideFilter"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport {ascending, extent, histogram as d3Histogram, ticks} from 'd3-array';\nimport keyMirror from 'keymirror';\nimport Console from 'global/console';\nimport get from 'lodash.get';\nimport isEqual from 'lodash.isequal';\n\nimport booleanWithin from '@turf/boolean-within';\nimport {point as turfPoint} from '@turf/helpers';\nimport {Decimal} from 'decimal.js';\nimport {\n  ALL_FIELD_TYPES,\n  FILTER_TYPES,\n  ANIMATION_WINDOW,\n  PLOT_TYPES,\n  LAYER_TYPES,\n  FILTER_VIEW_TYPES\n} from '@kepler.gl/constants';\nimport {VisState} from '@kepler.gl/schemas';\nimport * as ScaleUtils from './data-scale-utils';\nimport {h3IsValid} from 'h3-js';\n\nimport {\n  Millisecond,\n  Entries,\n  Field,\n  ParsedFilter,\n  Filter,\n  FilterBase,\n  PolygonFilter,\n  FieldDomain,\n  TimeRangeFieldDomain,\n  HistogramBin,\n  Feature,\n  FeatureValue,\n  LineChart,\n  TimeRangeFilter,\n  RangeFieldDomain,\n  FilterDatasetOpt,\n  FilterRecord\n} from '@kepler.gl/types';\n\nimport {DataContainerInterface} from './data-container-interface';\nimport {generateHashId, set, toArray} from './utils';\nimport {notNullorUndefined, timeToUnixMilli, unique} from './data-utils';\nimport {getCentroid} from './h3-utils';\n\nexport const durationSecond = 1000;\nexport const durationMinute = durationSecond * 60;\nexport const durationHour = durationMinute * 60;\nexport const durationDay = durationHour * 24;\nexport const durationWeek = durationDay * 7;\nexport const durationYear = durationDay * 365;\n\nexport type FilterResult = {\n  filteredIndexForDomain?: number[];\n  filteredIndex?: number[];\n};\n\nexport type FilterChanged = {\n  // eslint-disable-next-line no-unused-vars\n  [key in keyof FilterRecord]: {\n    [key: string]: 'added' | 'deleted' | 'name_changed' | 'value_changed' | 'dataId_changed';\n  } | null;\n};\n\nexport type dataValueAccessor = (data: {index: number}) => number | null;\n\nexport const TimestampStepMap = [\n  {max: 1, step: 0.05},\n  {max: 10, step: 0.1},\n  {max: 100, step: 1},\n  {max: 500, step: 5},\n  {max: 1000, step: 10},\n  {max: 5000, step: 50},\n  {max: Number.POSITIVE_INFINITY, step: 1000}\n];\n\nexport const histogramBins = 30;\nexport const enlargedHistogramBins = 100;\n\nexport const FILTER_UPDATER_PROPS = keyMirror({\n  dataId: null,\n  name: null,\n  layerId: null\n});\n\nexport const LIMITED_FILTER_EFFECT_PROPS = keyMirror({\n  [FILTER_UPDATER_PROPS.name]: null\n});\n/**\n * Max number of filter value buffers that deck.gl provides\n */\n\nconst SupportedPlotType = {\n  [FILTER_TYPES.timeRange]: {\n    default: 'histogram',\n    [ALL_FIELD_TYPES.integer]: 'lineChart',\n    [ALL_FIELD_TYPES.real]: 'lineChart'\n  },\n  [FILTER_TYPES.range]: {\n    default: 'histogram',\n    [ALL_FIELD_TYPES.integer]: 'lineChart',\n    [ALL_FIELD_TYPES.real]: 'lineChart'\n  }\n};\n\nexport const FILTER_COMPONENTS = {\n  [FILTER_TYPES.select]: 'SingleSelectFilter',\n  [FILTER_TYPES.multiSelect]: 'MultiSelectFilter',\n  [FILTER_TYPES.timeRange]: 'TimeRangeFilter',\n  [FILTER_TYPES.range]: 'RangeFilter',\n  [FILTER_TYPES.polygon]: 'PolygonFilter'\n};\n\nexport const DEFAULT_FILTER_STRUCTURE = {\n  dataId: [], // [string]\n  freeze: false,\n  id: null,\n  enabled: true,\n\n  // time range filter specific\n  fixedDomain: false,\n  view: FILTER_VIEW_TYPES.side,\n  isAnimating: false,\n  animationWindow: ANIMATION_WINDOW.free,\n  speed: 1,\n\n  // field specific\n  name: [], // string\n  type: null,\n  fieldIdx: [], // [integer]\n  domain: null,\n  value: null,\n\n  // plot\n  plotType: PLOT_TYPES.histogram,\n  yAxis: null,\n  interval: null,\n\n  // mode\n  gpu: false\n};\n\nexport const FILTER_ID_LENGTH = 4;\n\nexport const LAYER_FILTERS = [FILTER_TYPES.polygon];\n\n/**\n * Generates a filter with a dataset id as dataId\n */\nexport function getDefaultFilter({\n  dataId,\n  id\n}: {\n  dataId?: string | null | string[];\n  id?: string;\n} = {}): FilterBase<LineChart> {\n  return {\n    ...DEFAULT_FILTER_STRUCTURE,\n    // store it as dataId and it could be one or many\n    dataId: dataId ? toArray(dataId) : [],\n    id: id || generateHashId(FILTER_ID_LENGTH)\n  };\n}\n\n/**\n * Check if a filter is valid based on the given dataId\n * @param  filter to validate\n * @param  datasetId id to validate filter against\n * @return true if a filter is valid, false otherwise\n */\nexport function shouldApplyFilter(filter: Filter, datasetId: string): boolean {\n  const dataIds = toArray(filter.dataId);\n  return dataIds.includes(datasetId) && filter.value !== null;\n}\n\ninterface KeplerTableModel<K, L> {\n  id: string;\n  getColumnFieldIdx(columnName: string): number;\n  filterTable(filters: Filter[], layers: L[], opt?: FilterDatasetOpt): K;\n  getColumnFilterProps(columnName: string): Field['filterProps'] | null | undefined;\n  dataContainer: DataContainerInterface;\n  filterTableCPU(filters: Filter[], layers: L[]): K;\n}\n\n/**\n * Validates and modifies polygon filter structure\n * @param dataset\n * @param filter\n * @param layers\n * @return - {filter, dataset}\n */\nexport function validatePolygonFilter<K extends KeplerTableModel<K, L>, L extends {id: string}>(\n  dataset: K,\n  filter: PolygonFilter,\n  layers: L[]\n): {filter: PolygonFilter | null; dataset: K} {\n  const failed = {dataset, filter: null};\n  const {value, layerId, type, dataId} = filter;\n\n  if (!layerId || !isValidFilterValue(type, value)) {\n    return failed;\n  }\n\n  const isValidDataset = dataId.includes(dataset.id);\n\n  if (!isValidDataset) {\n    return failed;\n  }\n\n  const layer = layers.find(l => layerId.includes(l.id));\n\n  if (!layer) {\n    return failed;\n  }\n\n  return {\n    filter: {\n      ...filter,\n      freeze: true,\n      fieldIdx: []\n    },\n    dataset\n  };\n}\n\n/**\n * Custom filter validators\n */\nconst filterValidators = {\n  [FILTER_TYPES.polygon]: validatePolygonFilter\n};\n\n/**\n * Default validate filter function\n * @param dataset\n * @param filter\n * @return - {filter, dataset}\n */\nexport function validateFilter<K extends KeplerTableModel<K, L>, L>(\n  dataset: K,\n  filter: ParsedFilter\n): {filter: Filter | null; dataset: K} {\n  // match filter.dataId\n  const failed = {dataset, filter: null};\n  const filterDataId = toArray(filter.dataId);\n\n  const filterDatasetIndex = filterDataId.indexOf(dataset.id);\n  if (filterDatasetIndex < 0 || !toArray(filter.name)[filterDatasetIndex]) {\n    // the current filter is not mapped against the current dataset\n    return failed;\n  }\n\n  const initializeFilter: Filter = {\n    ...getDefaultFilter({dataId: filter.dataId}),\n    ...filter,\n    dataId: filterDataId,\n    name: toArray(filter.name)\n  };\n\n  const fieldName = initializeFilter.name[filterDatasetIndex];\n  const {filter: updatedFilter, dataset: updatedDataset} = applyFilterFieldName(\n    initializeFilter,\n    dataset,\n    fieldName,\n    filterDatasetIndex,\n    {mergeDomain: true}\n  );\n\n  if (!updatedFilter) {\n    return failed;\n  }\n\n  updatedFilter.value = adjustValueToFilterDomain(filter.value, updatedFilter);\n  updatedFilter.view = filter.view ?? updatedFilter.view;\n\n  if (updatedFilter.value === null) {\n    // cannot adjust saved value to filter\n    return failed;\n  }\n\n  return {\n    filter: validateFilterYAxis(updatedFilter, updatedDataset),\n    dataset: updatedDataset\n  };\n}\n\n/**\n * Validate saved filter config with new data,\n * calculate domain and fieldIdx based new fields and data\n *\n * @param dataset\n * @param filter - filter to be validate\n * @param layers - layers\n * @return validated filter\n */\nexport function validateFilterWithData<K extends KeplerTableModel<K, L>, L>(\n  dataset: K,\n  filter: ParsedFilter,\n  layers: L[]\n): {filter: Filter; dataset: K} {\n  return filter.type && filterValidators.hasOwnProperty(filter.type)\n    ? filterValidators[filter.type](dataset, filter, layers)\n    : validateFilter(dataset, filter);\n}\n\n/**\n * Validate YAxis\n * @param filter\n * @param dataset\n * @return {*}\n */\nfunction validateFilterYAxis(filter, dataset) {\n  // TODO: validate yAxis against other datasets\n\n  const {fields} = dataset;\n  const {yAxis} = filter;\n  // TODO: validate yAxis against other datasets\n  if (yAxis) {\n    const matchedAxis = fields.find(({name, type}) => name === yAxis.name && type === yAxis.type);\n\n    filter = matchedAxis\n      ? {\n          ...filter,\n          yAxis: matchedAxis,\n          ...getFilterPlot({...filter, yAxis: matchedAxis}, dataset)\n        }\n      : filter;\n  }\n\n  return filter;\n}\n\n/**\n * Get default filter prop based on field type\n *\n * @param field\n * @param fieldDomain\n * @returns default filter\n */\nexport function getFilterProps(\n  field: Field,\n  fieldDomain: FieldDomain\n): Partial<Filter> & {fieldType: string} {\n  const filterProps = {\n    ...fieldDomain,\n    fieldType: field.type,\n    view: FILTER_VIEW_TYPES.side\n  };\n\n  switch (field.type) {\n    case ALL_FIELD_TYPES.real:\n    case ALL_FIELD_TYPES.integer:\n      return {\n        ...filterProps,\n        value: fieldDomain.domain,\n        type: FILTER_TYPES.range,\n        // @ts-expect-error\n        typeOptions: [FILTER_TYPES.range],\n        gpu: true\n      };\n\n    case ALL_FIELD_TYPES.boolean:\n      // @ts-expect-error\n      return {\n        ...filterProps,\n        type: FILTER_TYPES.select,\n        value: true,\n        gpu: false\n      };\n\n    case ALL_FIELD_TYPES.string:\n    case ALL_FIELD_TYPES.date:\n      // @ts-expect-error\n      return {\n        ...filterProps,\n        type: FILTER_TYPES.multiSelect,\n        value: [],\n        gpu: false\n      };\n\n    case ALL_FIELD_TYPES.timestamp:\n      // @ts-expect-error\n      return {\n        ...filterProps,\n        type: FILTER_TYPES.timeRange,\n        view: FILTER_VIEW_TYPES.enlarged,\n        fixedDomain: true,\n        value: filterProps.domain,\n        gpu: true\n      };\n\n    default:\n      // @ts-expect-error\n      return {};\n  }\n}\n\nexport const getPolygonFilterFunctor = (layer, filter, dataContainer) => {\n  const getPosition = layer.getPositionAccessor(dataContainer);\n\n  switch (layer.type) {\n    case LAYER_TYPES.point:\n    case LAYER_TYPES.icon:\n      return data => {\n        const pos = getPosition(data);\n        return pos.every(Number.isFinite) && isInPolygon(pos, filter.value);\n      };\n    case LAYER_TYPES.arc:\n    case LAYER_TYPES.line:\n      return data => {\n        const pos = getPosition(data);\n        return (\n          pos.every(Number.isFinite) &&\n          [\n            [pos[0], pos[1]],\n            [pos[3], pos[4]]\n          ].every(point => isInPolygon(point, filter.value))\n        );\n      };\n    case LAYER_TYPES.hexagonId:\n      if (layer.dataToFeature && layer.dataToFeature.centroids) {\n        return data => {\n          // null or getCentroid({id})\n          const centroid = layer.dataToFeature.centroids[data.index];\n          return centroid && isInPolygon(centroid, filter.value);\n        };\n      }\n      return data => {\n        const id = getPosition(data);\n        if (!h3IsValid(id)) {\n          return false;\n        }\n        const pos = getCentroid({id});\n        return pos.every(Number.isFinite) && isInPolygon(pos, filter.value);\n      };\n    default:\n      return () => true;\n  }\n};\n\n/**\n * @param param An object that represents a row record.\n * @param param.index Index of the row in data container.\n * @returns Returns true to keep the element, or false otherwise.\n */\ntype filterFunction = (data: {index: number}) => boolean;\n/**\n * @param field dataset Field\n * @param dataId Dataset id\n * @param filter Filter object\n * @param layers list of layers to filter upon\n * @param dataContainer Data container\n * @return filterFunction\n */\n/* eslint-disable complexity */\nexport function getFilterFunction<L extends {config: {dataId: string | null}; id: string}>(\n  field: Field | null,\n  dataId: string,\n  filter: Filter,\n  layers: L[],\n  dataContainer: DataContainerInterface\n): filterFunction {\n  // field could be null in polygon filter\n  const valueAccessor = field ? field.valueAccessor : data => null;\n  const defaultFunc = d => true;\n\n  if (filter.enabled === false) {\n    return defaultFunc;\n  }\n\n  switch (filter.type) {\n    case FILTER_TYPES.range:\n      return data => isInRange(valueAccessor(data), filter.value);\n    case FILTER_TYPES.multiSelect:\n      return data => filter.value.includes(valueAccessor(data));\n    case FILTER_TYPES.select:\n      return data => valueAccessor(data) === filter.value;\n    case FILTER_TYPES.timeRange:\n      if (!field) {\n        return defaultFunc;\n      }\n      const mappedValue = get(field, ['filterProps', 'mappedValue']);\n      const accessor = Array.isArray(mappedValue)\n        ? data => mappedValue[data.index]\n        : data => timeToUnixMilli(valueAccessor(data), field.format);\n      return data => isInRange(accessor(data), filter.value);\n    case FILTER_TYPES.polygon:\n      if (!layers || !layers.length || !filter.layerId) {\n        return defaultFunc;\n      }\n      const layerFilterFunctions = filter.layerId\n        .map(id => layers.find(l => l.id === id))\n        .filter(l => l && l.config.dataId === dataId)\n        .map(layer => getPolygonFilterFunctor(layer, filter, dataContainer));\n\n      return data => layerFilterFunctions.every(filterFunc => filterFunc(data));\n    default:\n      return defaultFunc;\n  }\n}\n\nexport function updateFilterDataId(dataId: string | string[]): FilterBase<LineChart> {\n  return getDefaultFilter({dataId});\n}\n\nexport function filterDataByFilterTypes(\n  {\n    dynamicDomainFilters,\n    cpuFilters,\n    filterFuncs\n  }: {\n    dynamicDomainFilters: Filter[] | null;\n    cpuFilters: Filter[] | null;\n    filterFuncs: {\n      [key: string]: filterFunction;\n    };\n  },\n  dataContainer: DataContainerInterface\n): FilterResult {\n  const filteredIndexForDomain: number[] = [];\n  const filteredIndex: number[] = [];\n\n  const filterContext = {index: -1, dataContainer};\n  const filterFuncCaller = (filter: Filter) => filterFuncs[filter.id](filterContext);\n\n  const numRows = dataContainer.numRows();\n  for (let i = 0; i < numRows; ++i) {\n    filterContext.index = i;\n\n    const matchForDomain = dynamicDomainFilters && dynamicDomainFilters.every(filterFuncCaller);\n    if (matchForDomain) {\n      filteredIndexForDomain.push(filterContext.index);\n    }\n\n    const matchForRender = cpuFilters && cpuFilters.every(filterFuncCaller);\n    if (matchForRender) {\n      filteredIndex.push(filterContext.index);\n    }\n  }\n\n  return {\n    ...(dynamicDomainFilters ? {filteredIndexForDomain} : {}),\n    ...(cpuFilters ? {filteredIndex} : {})\n  };\n}\n\n/**\n * Get a record of filters based on domain type and gpu / cpu\n */\nexport function getFilterRecord(\n  dataId: string,\n  filters: Filter[],\n  opt: FilterDatasetOpt = {}\n): FilterRecord {\n  const filterRecord: FilterRecord = {\n    dynamicDomain: [],\n    fixedDomain: [],\n    cpu: [],\n    gpu: []\n  };\n\n  filters.forEach(f => {\n    if (isValidFilterValue(f.type, f.value) && toArray(f.dataId).includes(dataId)) {\n      (f.fixedDomain || opt.ignoreDomain\n        ? filterRecord.fixedDomain\n        : filterRecord.dynamicDomain\n      ).push(f);\n\n      (f.gpu && !opt.cpuOnly ? filterRecord.gpu : filterRecord.cpu).push(f);\n    }\n  });\n\n  return filterRecord;\n}\n\n/**\n * Compare filter records to get what has changed\n */\nexport function diffFilters(\n  filterRecord: FilterRecord,\n  oldFilterRecord: FilterRecord | {} = {}\n): FilterChanged {\n  let filterChanged: Partial<FilterChanged> = {};\n\n  (Object.entries(filterRecord) as Entries<FilterRecord>).forEach(([record, items]) => {\n    items.forEach(filter => {\n      const oldFilter: Filter = (oldFilterRecord[record] || []).find(\n        (f: Filter) => f.id === filter.id\n      );\n\n      if (!oldFilter) {\n        // added\n        filterChanged = set([record, filter.id], 'added', filterChanged);\n      } else {\n        // check  what has changed\n        ['name', 'value', 'dataId'].forEach(prop => {\n          if (filter[prop] !== oldFilter[prop]) {\n            filterChanged = set([record, filter.id], `${prop}_changed`, filterChanged);\n          }\n        });\n      }\n    });\n\n    (oldFilterRecord[record] || []).forEach((oldFilter: Filter) => {\n      // deleted\n      if (!items.find(f => f.id === oldFilter.id)) {\n        filterChanged = set([record, oldFilter.id], 'deleted', filterChanged);\n      }\n    });\n  });\n\n  return {...{dynamicDomain: null, fixedDomain: null, cpu: null, gpu: null}, ...filterChanged};\n}\n/**\n * Call by parsing filters from URL\n * Check if value of filter within filter domain, if not adjust it to match\n * filter domain\n *\n * @returns value - adjusted value to match filter or null to remove filter\n */\n// eslint-disable-next-line complexity\nexport function adjustValueToFilterDomain(value: Filter['value'], {domain, type}) {\n  if (!type) {\n    return false;\n  }\n  // if the current filter is a polygon it will not have any domain\n  // all other filter types require domain\n  if (type !== FILTER_TYPES.polygon && !domain) {\n    return false;\n  }\n\n  switch (type) {\n    case FILTER_TYPES.range:\n    case FILTER_TYPES.timeRange:\n      if (!Array.isArray(value) || value.length !== 2) {\n        return domain.map(d => d);\n      }\n\n      return value.map((d, i) => (notNullorUndefined(d) && isInRange(d, domain) ? d : domain[i]));\n\n    case FILTER_TYPES.multiSelect:\n      if (!Array.isArray(value)) {\n        return [];\n      }\n      const filteredValue = value.filter(d => domain.includes(d));\n      return filteredValue.length ? filteredValue : [];\n\n    case FILTER_TYPES.select:\n      return domain.includes(value) ? value : true;\n    case FILTER_TYPES.polygon:\n      return value;\n\n    default:\n      return null;\n  }\n}\n/* eslint-enable complexity */\n\n/**\n * Calculate numeric domain and suitable step\n */\nexport function getNumericFieldDomain(\n  dataContainer: DataContainerInterface,\n  valueAccessor: dataValueAccessor\n): RangeFieldDomain {\n  let domain: [number, number] = [0, 1];\n  let step = 0.1;\n\n  const mappedValue = dataContainer.mapIndex(valueAccessor);\n\n  if (dataContainer.numRows() > 1) {\n    domain = ScaleUtils.getLinearDomain(mappedValue);\n    const diff = domain[1] - domain[0];\n\n    // in case equal domain, [96, 96], which will break quantize scale\n    if (!diff) {\n      domain[1] = domain[0] + 1;\n    }\n\n    step = getNumericStepSize(diff) || step;\n    domain[0] = formatNumberByStep(domain[0], step, 'floor');\n    domain[1] = formatNumberByStep(domain[1], step, 'ceil');\n  }\n\n  const {histogram, enlargedHistogram} = getHistogram(domain, mappedValue);\n\n  return {domain, step, histogram, enlargedHistogram};\n}\n\n/**\n * Calculate step size for range and timerange filter\n */\nexport function getNumericStepSize(diff: number): number {\n  diff = Math.abs(diff);\n\n  if (diff > 100) {\n    return 1;\n  } else if (diff > 3) {\n    return 0.01;\n  } else if (diff > 1) {\n    return 0.001;\n  }\n  // Try to get at least 1000 steps - and keep the step size below that of\n  // the (diff > 1) case.\n  const x = diff / 1000;\n  // Find the exponent and truncate to 10 to the power of that exponent\n\n  const exponentialForm = x.toExponential();\n  const exponent = parseFloat(exponentialForm.split('e')[1]);\n\n  // Getting ready for node 12\n  // this is why we need decimal.js\n  // Math.pow(10, -5) = 0.000009999999999999999\n  // the above result shows in browser and node 10\n  // node 12 behaves correctly\n  return new Decimal(10).pow(exponent).toNumber();\n}\n\n/**\n * Calculate timestamp domain and suitable step\n */\nexport function getTimestampFieldDomain(\n  dataContainer: DataContainerInterface,\n  valueAccessor: dataValueAccessor\n): TimeRangeFieldDomain {\n  // to avoid converting string format time to epoch\n  // every time we compare we store a value mapped to int in filter domain\n\n  const mappedValue = dataContainer.mapIndex(valueAccessor);\n  const domain = ScaleUtils.getLinearDomain(mappedValue);\n  const defaultTimeFormat = getTimeWidgetTitleFormatter(domain);\n\n  let step = 0.01;\n\n  const diff = domain[1] - domain[0];\n  // in case equal timestamp add 1 second padding to prevent break\n  if (!diff) {\n    domain[1] = domain[0] + 1000;\n  }\n  const entry = TimestampStepMap.find(f => f.max >= diff);\n  if (entry) {\n    step = entry.step;\n  }\n\n  const {histogram, enlargedHistogram} = getHistogram(domain, mappedValue);\n\n  return {\n    domain,\n    step,\n    mappedValue,\n    histogram,\n    enlargedHistogram,\n    defaultTimeFormat\n  };\n}\n\nexport function histogramConstruct(\n  domain: [number, number],\n  mappedValue: (Millisecond | number)[],\n  bins: number\n): HistogramBin[] {\n  return d3Histogram()\n    .thresholds(ticks(domain[0], domain[1], bins))\n    .domain(domain)(mappedValue)\n    .map(bin => ({\n      count: bin.length,\n      bin,\n      x0: bin.x0,\n      x1: bin.x1\n    }));\n}\n/**\n * Calculate histogram from domain and array of values\n */\nexport function getHistogram(\n  domain: [number, number],\n  mappedValue: (Millisecond | number)[]\n): {histogram: HistogramBin[]; enlargedHistogram: HistogramBin[]} {\n  const histogram = histogramConstruct(domain, mappedValue, histogramBins);\n  const enlargedHistogram = histogramConstruct(domain, mappedValue, enlargedHistogramBins);\n\n  return {histogram, enlargedHistogram};\n}\n\n/**\n * round number based on step\n *\n * @param {Number} val\n * @param {Number} step\n * @param {string} bound\n * @returns {Number} rounded number\n */\nexport function formatNumberByStep(val: number, step: number, bound: 'floor' | 'ceil'): number {\n  if (bound === 'floor') {\n    return Math.floor(val * (1 / step)) / (1 / step);\n  }\n\n  return Math.ceil(val * (1 / step)) / (1 / step);\n}\n\nexport function isInRange(val: any, domain: number[]): boolean {\n  if (!Array.isArray(domain)) {\n    return false;\n  }\n\n  return val >= domain[0] && val <= domain[1];\n}\n\n/**\n * Determines whether a point is within the provided polygon\n *\n * @param point as input search [lat, lng]\n * @param polygon Points must be within these (Multi)Polygon(s)\n * @return {boolean}\n */\nexport function isInPolygon(point: number[], polygon: any): boolean {\n  return booleanWithin(turfPoint(point), polygon);\n}\nexport function getTimeWidgetTitleFormatter(domain: [number, number]): string | null {\n  if (!isValidTimeDomain(domain)) {\n    return null;\n  }\n\n  const diff = domain[1] - domain[0];\n\n  // Local aware formats\n  // https://momentjs.com/docs/#/parsing/string-format\n  return diff > durationYear ? 'L' : diff > durationDay ? 'L LT' : 'L LTS';\n}\n\n/**\n * Sanity check on filters to prepare for save\n * @type {typeof import('./filter-utils').isFilterValidToSave}\n */\nexport function isFilterValidToSave(filter: any): boolean {\n  return (\n    filter?.type && Array.isArray(filter?.name) && (filter?.name.length || filter?.layerId.length)\n  );\n}\n\n/**\n * Sanity check on filters to prepare for save\n * @type {typeof import('./filter-utils').isValidFilterValue}\n */\n/* eslint-disable complexity */\nexport function isValidFilterValue(type: string | null, value: any): boolean {\n  if (!type) {\n    return false;\n  }\n  switch (type) {\n    case FILTER_TYPES.select:\n      return value === true || value === false;\n\n    case FILTER_TYPES.range:\n    case FILTER_TYPES.timeRange:\n      return Array.isArray(value) && value.every(v => v !== null && !isNaN(v));\n\n    case FILTER_TYPES.multiSelect:\n      return Array.isArray(value) && Boolean(value.length);\n\n    case FILTER_TYPES.input:\n      return Boolean(value.length);\n\n    case FILTER_TYPES.polygon:\n      const coordinates = get(value, ['geometry', 'coordinates']);\n      return Boolean(value && value.id && coordinates);\n\n    default:\n      return true;\n  }\n}\n\nexport function getColumnFilterProps<K extends KeplerTableModel<K, L>, L>(\n  filter: Filter,\n  dataset: K\n): {lineChart: LineChart; yAxs: Field} | {} {\n  if (filter.plotType === PLOT_TYPES.histogram || !filter.yAxis) {\n    // histogram should be calculated when create filter\n    return {};\n  }\n\n  const {mappedValue = []} = filter;\n  const {yAxis} = filter;\n  const fieldIdx = dataset.getColumnFieldIdx(yAxis.name);\n  if (fieldIdx < 0) {\n    Console.warn(`yAxis ${yAxis.name} does not exist in dataset`);\n    return {lineChart: {}, yAxis};\n  }\n\n  // return lineChart\n  const series = dataset.dataContainer\n    .map(\n      (row, rowIndex) => ({\n        x: mappedValue[rowIndex],\n        y: row.valueAt(fieldIdx)\n      }),\n      true\n    )\n    .filter(({x, y}) => Number.isFinite(x) && Number.isFinite(y))\n    .sort((a, b) => ascending(a.x, b.x));\n\n  const yDomain = extent(series, d => d.y);\n  const xDomain = [series[0].x, series[series.length - 1].x];\n\n  return {lineChart: {series, yDomain, xDomain}, yAxis};\n}\n\nexport function getDefaultFilterPlotType(filter: Filter): string | null {\n  const filterPlotTypes: typeof SupportedPlotType[keyof typeof SupportedPlotType] | null =\n    filter.type && SupportedPlotType[filter.type];\n  if (!filterPlotTypes) {\n    return null;\n  }\n\n  if (!filter.yAxis) {\n    return filterPlotTypes.default;\n  }\n\n  return filterPlotTypes[filter.yAxis.type] || null;\n}\n\n/**\n *\n * @param datasetIds list of dataset ids to be filtered\n * @param datasets all datasets\n * @param filters all filters to be applied to datasets\n * @return datasets - new updated datasets\n */\nexport function applyFiltersToDatasets<\n  K extends KeplerTableModel<K, L>,\n  L extends {config: {dataId: string | null}}\n>(\n  datasetIds: string[],\n  datasets: {[id: string]: K},\n  filters: Filter[],\n  layers?: L[]\n): {[id: string]: K} {\n  const dataIds = toArray(datasetIds);\n  return dataIds.reduce((acc, dataId) => {\n    const layersToFilter = (layers || []).filter(l => l.config.dataId === dataId);\n    const appliedFilters = filters.filter(d => shouldApplyFilter(d, dataId));\n    const table = datasets[dataId];\n\n    return {\n      ...acc,\n      [dataId]: table.filterTable(appliedFilters, layersToFilter, {})\n    };\n  }, datasets);\n}\n\n/**\n * Applies a new field name value to fielter and update both filter and dataset\n * @param filter - to be applied the new field name on\n * @param dataset - dataset the field belongs to\n * @param fieldName - field.name\n * @param filterDatasetIndex - field.name\n * @param option\n * @return - {filter, datasets}\n */\nexport function applyFilterFieldName<K extends KeplerTableModel<K, L>, L>(\n  filter: Filter,\n  dataset: K,\n  fieldName: string,\n  filterDatasetIndex = 0,\n  option?: {mergeDomain: boolean}\n): {\n  filter: Filter | null;\n  dataset: K;\n} {\n  // using filterDatasetIndex we can filter only the specified dataset\n  const mergeDomain = option && option.hasOwnProperty('mergeDomain') ? option.mergeDomain : false;\n\n  const fieldIndex = dataset.getColumnFieldIdx(fieldName);\n  // if no field with same name is found, move to the next datasets\n  if (fieldIndex === -1) {\n    // throw new Error(`fieldIndex not found. Dataset must contain a property with name: ${fieldName}`);\n    return {filter: null, dataset};\n  }\n\n  // TODO: validate field type\n  const filterProps = dataset.getColumnFilterProps(fieldName);\n\n  const newFilter = {\n    ...(mergeDomain ? mergeFilterDomainStep(filter, filterProps) : {...filter, ...filterProps}),\n    name: Object.assign([...toArray(filter.name)], {[filterDatasetIndex]: fieldName}),\n    fieldIdx: Object.assign([...toArray(filter.fieldIdx)], {\n      [filterDatasetIndex]: fieldIndex\n    }),\n    // TODO, since we allow to add multiple fields to a filter we can no longer freeze the filter\n    freeze: true\n  };\n\n  return {\n    filter: newFilter,\n    dataset\n  };\n}\n\n/**\n * Merge one filter with other filter prop domain\n */\n/* eslint-disable complexity */\nexport function mergeFilterDomainStep(\n  filter: Filter,\n  filterProps?: Partial<Filter>\n): (Filter & {step?: number}) | null {\n  if (!filter) {\n    return null;\n  }\n\n  if (!filterProps) {\n    return filter;\n  }\n\n  if ((filter.fieldType && filter.fieldType !== filterProps.fieldType) || !filterProps.domain) {\n    return filter;\n  }\n\n  const combinedDomain = !filter.domain\n    ? filterProps.domain\n    : [...(filter.domain || []), ...(filterProps.domain || [])].sort((a, b) => a - b);\n\n  const newFilter = {\n    ...filter,\n    ...filterProps,\n    domain: [combinedDomain[0], combinedDomain[combinedDomain.length - 1]]\n  };\n\n  switch (filterProps.fieldType) {\n    case ALL_FIELD_TYPES.string:\n    case ALL_FIELD_TYPES.date:\n      return {\n        ...newFilter,\n        domain: unique(combinedDomain).sort()\n      };\n\n    case ALL_FIELD_TYPES.timestamp:\n      const step =\n        (filter as TimeRangeFilter).step < (filterProps as TimeRangeFieldDomain).step\n          ? (filter as TimeRangeFilter).step\n          : (filterProps as TimeRangeFieldDomain).step;\n\n      return {\n        ...newFilter,\n        step\n      };\n    case ALL_FIELD_TYPES.real:\n    case ALL_FIELD_TYPES.integer:\n    default:\n      return newFilter;\n  }\n}\n/* eslint-enable complexity */\n\n/**\n * Generates polygon filter\n */\nexport const featureToFilterValue = (\n  feature: Feature,\n  filterId: string,\n  properties?: {}\n): FeatureValue => ({\n  ...feature,\n  id: feature.id,\n  properties: {\n    ...feature.properties,\n    ...properties,\n    filterId\n  }\n});\n\nexport const getFilterIdInFeature = (f: FeatureValue): string => get(f, ['properties', 'filterId']);\n\n/**\n * Generates polygon filter\n */\nexport function generatePolygonFilter<\n  L extends {config: {dataId: string | null; label: string}; id: string}\n>(layers: L[], feature: Feature): PolygonFilter {\n  const dataId = layers.map(l => l.config.dataId).filter(notNullorUndefined);\n  const layerId = layers.map(l => l.id);\n  const name = layers.map(l => l.config.label);\n  const filter = getDefaultFilter({dataId});\n  return {\n    ...filter,\n    fixedDomain: true,\n    type: FILTER_TYPES.polygon,\n    name,\n    layerId,\n    value: featureToFilterValue(feature, filter.id, {isVisible: true})\n  };\n}\n\n/**\n * Run filter entirely on CPU\n */\ninterface StateType<K extends KeplerTableModel<K, L>, L> {\n  layers: L[];\n  filters: Filter[];\n  datasets: {[id: string]: K};\n}\n\nexport function filterDatasetCPU<T extends StateType<K, L>, K extends KeplerTableModel<K, L>, L>(\n  state: T,\n  dataId: string\n): T {\n  const datasetFilters = state.filters.filter(f => f.dataId.includes(dataId));\n  const dataset = state.datasets[dataId];\n\n  if (!dataset) {\n    return state;\n  }\n\n  const cpuFilteredDataset = dataset.filterTableCPU(datasetFilters, state.layers);\n\n  return set(['datasets', dataId], cpuFilteredDataset, state);\n}\n\n/**\n * Validate parsed filters with datasets and add filterProps to field\n */\ntype MinVisStateForFilter = Pick<VisState, 'layers' | 'datasets' | 'isMergingDatasets'>;\nexport function validateFiltersUpdateDatasets<\n  S extends MinVisStateForFilter,\n  K extends KeplerTableModel<K, L>,\n  L extends {config: {dataId: string | null; label: string}; id: string}\n>(\n  state: S,\n  filtersToValidate: ParsedFilter[] = []\n): {\n  validated: Filter[];\n  failed: Filter[];\n  updatedDatasets: S['datasets'];\n} {\n  // TODO Better Typings here\n  const validated: any[] = [];\n  const failed: any[] = [];\n  const {datasets} = state;\n  let updatedDatasets = datasets;\n\n  // merge filters\n  filtersToValidate.forEach(filter => {\n    // we can only look for datasets define in the filter dataId\n    const datasetIds = toArray(filter.dataId);\n\n    // we can merge a filter only if all datasets in filter.dataId are loaded\n    if (datasetIds.every(d => datasets[d] && !state.isMergingDatasets[d])) {\n      // all datasetIds in filter must be present the state datasets\n      const {filter: validatedFilter, applyToDatasets, augmentedDatasets} = datasetIds.reduce<{\n        filter: Filter | null;\n        applyToDatasets: string[];\n        augmentedDatasets: {[datasetId: string]: any};\n      }>(\n        (acc, datasetId) => {\n          const dataset = updatedDatasets[datasetId];\n          const layers = state.layers.filter(l => l.config.dataId === dataset.id);\n          const {filter: updatedFilter, dataset: updatedDataset} = validateFilterWithData(\n            acc.augmentedDatasets[datasetId] || dataset,\n            filter,\n            layers\n          );\n\n          if (updatedFilter) {\n            return {\n              ...acc,\n              // merge filter props\n              filter: acc.filter\n                ? {\n                    ...acc.filter,\n                    // TODO check: changed from acc to acc.filter to fix types\n                    ...mergeFilterDomainStep(acc.filter, updatedFilter)\n                  }\n                : updatedFilter,\n\n              applyToDatasets: [...acc.applyToDatasets, datasetId],\n\n              augmentedDatasets: {\n                ...acc.augmentedDatasets,\n                [datasetId]: updatedDataset\n              }\n            };\n          }\n\n          return acc;\n        },\n        {\n          filter: null,\n          applyToDatasets: [],\n          augmentedDatasets: {}\n        }\n      );\n\n      if (validatedFilter && isEqual(datasetIds, applyToDatasets)) {\n        validated.push(validatedFilter);\n        updatedDatasets = {\n          ...updatedDatasets,\n          ...augmentedDatasets\n        };\n      } else {\n        failed.push(filter);\n      }\n    } else {\n      failed.push(filter);\n    }\n  });\n\n  return {validated, failed, updatedDatasets};\n}\n\nexport function getFilterPlot<K extends KeplerTableModel<K, L>, L>(\n  filter: Filter,\n  dataset: K\n): {lineChart: LineChart; yAxs: Field} | {} {\n  if (filter.plotType === PLOT_TYPES.histogram || !filter.yAxis) {\n    // histogram should be calculated when create filter\n    return {};\n  }\n\n  const {mappedValue = []} = filter;\n  const {yAxis} = filter;\n  const fieldIdx = dataset.getColumnFieldIdx(yAxis.name);\n  if (fieldIdx < 0) {\n    Console.warn(`yAxis ${yAxis.name} does not exist in dataset`);\n    return {lineChart: {}, yAxis};\n  }\n\n  // return lineChart\n  const series = dataset.dataContainer\n    .map(\n      (row, rowIndex) => ({\n        x: mappedValue[rowIndex],\n        y: row.valueAt(fieldIdx)\n      }),\n      true\n    )\n    .filter(({x, y}) => Number.isFinite(x) && Number.isFinite(y))\n    .sort((a, b) => ascending(a.x, b.x));\n\n  const yDomain = extent(series, d => d.y);\n  const xDomain = [series[0].x, series[series.length - 1].x];\n\n  return {lineChart: {series, yDomain, xDomain}, yAxis};\n}\n\n/**\n * Retrieve interval bins for time filter\n */\nexport function getIntervalBins(filter: TimeRangeFilter) {\n  const {bins} = filter;\n  const interval = filter.plotType?.interval;\n  if (!interval || !bins || Object.keys(bins).length === 0) {\n    return null;\n  }\n  const values = Object.values(bins);\n  return values[0] ? values[0][interval] : null;\n}\n\nexport function isValidTimeDomain(domain) {\n  return Array.isArray(domain) && domain.every(Number.isFinite);\n}\n\nexport function getTimeWidgetHintFormatter(domain: [number, number]): string | undefined {\n  if (!isValidTimeDomain(domain)) {\n    return undefined;\n  }\n\n  const diff = domain[1] - domain[0];\n  return diff > durationWeek\n    ? 'L'\n    : diff > durationDay\n    ? 'L LT'\n    : diff > durationHour\n    ? 'LT'\n    : 'LTS';\n}\n\nexport function isSideFilter(filter: Filter): boolean {\n  return filter.view === FILTER_VIEW_TYPES.side;\n}\n"]}