@kepler.gl/utils 3.0.0-alpha.2 → 3.1.0-alpha.0

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 (73) hide show
  1. package/package.json +14 -10
  2. package/dist/aggregate-utils.d.ts +0 -3
  3. package/dist/aggregate-utils.js +0 -75
  4. package/dist/arrow-data-container.d.ts +0 -54
  5. package/dist/arrow-data-container.js +0 -360
  6. package/dist/color-utils.d.ts +0 -51
  7. package/dist/color-utils.js +0 -161
  8. package/dist/data-container-interface.d.ts +0 -133
  9. package/dist/data-container-interface.js +0 -6
  10. package/dist/data-container-utils.d.ts +0 -30
  11. package/dist/data-container-utils.js +0 -88
  12. package/dist/data-row.d.ts +0 -59
  13. package/dist/data-row.js +0 -126
  14. package/dist/data-scale-utils.d.ts +0 -23
  15. package/dist/data-scale-utils.js +0 -62
  16. package/dist/data-utils.d.ts +0 -103
  17. package/dist/data-utils.js +0 -502
  18. package/dist/dataset-utils.d.ts +0 -116
  19. package/dist/dataset-utils.js +0 -614
  20. package/dist/dom-to-image.d.ts +0 -73
  21. package/dist/dom-to-image.js +0 -489
  22. package/dist/dom-utils.d.ts +0 -23
  23. package/dist/dom-utils.js +0 -434
  24. package/dist/effect-utils.d.ts +0 -23
  25. package/dist/effect-utils.js +0 -196
  26. package/dist/export-map-html.d.ts +0 -9
  27. package/dist/export-map-html.js +0 -28
  28. package/dist/export-utils.d.ts +0 -53
  29. package/dist/export-utils.js +0 -262
  30. package/dist/filter-utils.d.ts +0 -326
  31. package/dist/filter-utils.js +0 -1333
  32. package/dist/format.d.ts +0 -1
  33. package/dist/format.js +0 -17
  34. package/dist/gl-utils.d.ts +0 -1
  35. package/dist/gl-utils.js +0 -35
  36. package/dist/h3-utils.d.ts +0 -21
  37. package/dist/h3-utils.js +0 -81
  38. package/dist/index.d.ts +0 -36
  39. package/dist/index.js +0 -772
  40. package/dist/indexed-data-container.d.ts +0 -34
  41. package/dist/indexed-data-container.js +0 -254
  42. package/dist/locale-utils.d.ts +0 -2
  43. package/dist/locale-utils.js +0 -54
  44. package/dist/map-info-utils.d.ts +0 -1
  45. package/dist/map-info-utils.js +0 -15
  46. package/dist/map-style-utils/mapbox-gl-style-editor.d.ts +0 -65
  47. package/dist/map-style-utils/mapbox-gl-style-editor.js +0 -218
  48. package/dist/map-style-utils/mapbox-utils.d.ts +0 -9
  49. package/dist/map-style-utils/mapbox-utils.js +0 -48
  50. package/dist/map-utils.d.ts +0 -9
  51. package/dist/map-utils.js +0 -65
  52. package/dist/mapbox-utils.d.ts +0 -7
  53. package/dist/mapbox-utils.js +0 -22
  54. package/dist/noop.d.ts +0 -1
  55. package/dist/noop.js +0 -11
  56. package/dist/notifications-utils.d.ts +0 -42
  57. package/dist/notifications-utils.js +0 -85
  58. package/dist/observe-dimensions.d.ts +0 -15
  59. package/dist/observe-dimensions.js +0 -151
  60. package/dist/plot.d.ts +0 -6
  61. package/dist/plot.js +0 -31
  62. package/dist/projection-utils.d.ts +0 -21
  63. package/dist/projection-utils.js +0 -100
  64. package/dist/row-data-container.d.ts +0 -31
  65. package/dist/row-data-container.js +0 -252
  66. package/dist/searcher-utils.d.ts +0 -1
  67. package/dist/searcher-utils.js +0 -28
  68. package/dist/split-map-utils.d.ts +0 -32
  69. package/dist/split-map-utils.js +0 -114
  70. package/dist/time.d.ts +0 -16
  71. package/dist/time.js +0 -89
  72. package/dist/utils.d.ts +0 -116
  73. package/dist/utils.js +0 -305
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@kepler.gl/utils",
3
3
  "author": "Shan He <shan@uber.com>",
4
- "version": "3.0.0-alpha.2",
4
+ "version": "3.1.0-alpha.0",
5
5
  "description": "kepler.gl constants used by kepler.gl components, actions and reducers",
6
6
  "license": "MIT",
7
7
  "main": "dist/index.js",
@@ -30,23 +30,25 @@
30
30
  "umd"
31
31
  ],
32
32
  "dependencies": {
33
- "apache-arrow": "^13.0.0",
34
- "@kepler.gl/constants": "3.0.0-alpha.2",
35
- "@kepler.gl/types": "3.0.0-alpha.2",
33
+ "@kepler.gl/common-utils": "3.1.0-alpha.0",
34
+ "@kepler.gl/constants": "3.1.0-alpha.0",
35
+ "@kepler.gl/types": "3.1.0-alpha.0",
36
36
  "@luma.gl/constants": "^8.5.20",
37
37
  "@luma.gl/core": "^8.5.20",
38
38
  "@mapbox/geo-viewport": "^0.4.1",
39
39
  "@turf/boolean-within": "^6.0.1",
40
40
  "@turf/helpers": "^6.1.4",
41
- "@types/d3-array": "^2.0.0",
41
+ "@types/d3-array": "^2.8.0",
42
42
  "@types/keymirror": "^0.1.1",
43
43
  "@types/lodash.clonedeep": "^4.5.7",
44
44
  "@types/lodash.get": "^4.4.6",
45
45
  "@types/lodash.isequal": "^4.5.5",
46
46
  "@types/lodash.memoize": "^4.1.7",
47
47
  "@types/lodash.throttle": "^4.1.7",
48
+ "apache-arrow": ">=15.0.0",
48
49
  "d3-array": "^2.8.0",
49
50
  "d3-format": "^2.0.0",
51
+ "d3-interpolate": "^2.0.1",
50
52
  "decimal.js": "^10.2.0",
51
53
  "global": "^4.3.0",
52
54
  "h3-js": "^3.1.0",
@@ -59,6 +61,7 @@
59
61
  "mini-svg-data-uri": "^1.0.3",
60
62
  "moment-timezone": "^0.5.35",
61
63
  "react": "^18.2.0",
64
+ "react-map-gl": "^7.1.6",
62
65
  "resize-observer-polyfill": "^1.5.1",
63
66
  "type-analyzer": "0.4.0"
64
67
  },
@@ -66,15 +69,16 @@
66
69
  "sourceMap": false,
67
70
  "instrument": false
68
71
  },
69
- "engines": {
70
- "node": ">=18.18.2"
71
- },
72
72
  "maintainers": [
73
73
  "Shan He <heshan0131@gmail.com>",
74
74
  "Giuseppe Macri <gmacri@uber.com>"
75
75
  ],
76
+ "engines": {
77
+ "node": ">=18"
78
+ },
76
79
  "volta": {
77
80
  "node": "18.18.2",
78
- "yarn": "1.22.17"
79
- }
81
+ "yarn": "4.4.0"
82
+ },
83
+ "packageManager": "yarn@4.4.0"
80
84
  }
@@ -1,3 +0,0 @@
1
- export declare const getFrequency: (data: any) => any;
2
- export declare const getMode: (data: any) => string;
3
- export declare function aggregate(data: any, technique: any): any;
@@ -1,75 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.aggregate = aggregate;
9
- exports.getMode = exports.getFrequency = void 0;
10
-
11
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
-
13
- var _d3Array = require("d3-array");
14
-
15
- var _constants = require("@kepler.gl/constants");
16
-
17
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
18
-
19
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
20
-
21
- var getFrequency = function getFrequency(data) {
22
- return data.reduce(function (uniques, val) {
23
- return _objectSpread(_objectSpread({}, uniques), {}, (0, _defineProperty2["default"])({}, val, (uniques[val] || 0) + 1));
24
- }, {});
25
- };
26
-
27
- exports.getFrequency = getFrequency;
28
-
29
- var getMode = function getMode(data) {
30
- var occur = getFrequency(data);
31
- return Object.keys(occur).reduce(function (prev, key) {
32
- return occur[prev] >= occur[key] ? prev : key;
33
- }, Object.keys(occur)[0]);
34
- };
35
-
36
- exports.getMode = getMode;
37
-
38
- function aggregate(data, technique) {
39
- switch (technique) {
40
- case _constants.AGGREGATION_TYPES.average:
41
- return (0, _d3Array.mean)(data);
42
-
43
- case _constants.AGGREGATION_TYPES.countUnique:
44
- return Object.keys(data.reduce(function (uniques, val) {
45
- uniques[val] = uniques[val] || 0;
46
- uniques[val] += 1;
47
- return uniques;
48
- }, {})).length;
49
-
50
- case _constants.AGGREGATION_TYPES.mode:
51
- return getMode(data);
52
-
53
- case _constants.AGGREGATION_TYPES.maximum:
54
- return (0, _d3Array.max)(data);
55
-
56
- case _constants.AGGREGATION_TYPES.minimum:
57
- return (0, _d3Array.min)(data);
58
-
59
- case _constants.AGGREGATION_TYPES.median:
60
- return (0, _d3Array.median)(data);
61
-
62
- case _constants.AGGREGATION_TYPES.stdev:
63
- return (0, _d3Array.deviation)(data);
64
-
65
- case _constants.AGGREGATION_TYPES.sum:
66
- return (0, _d3Array.sum)(data);
67
-
68
- case _constants.AGGREGATION_TYPES.variance:
69
- return (0, _d3Array.variance)(data);
70
-
71
- default:
72
- return data.length;
73
- }
74
- }
75
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9hZ2dyZWdhdGUtdXRpbHMudHMiXSwibmFtZXMiOlsiZ2V0RnJlcXVlbmN5IiwiZGF0YSIsInJlZHVjZSIsInVuaXF1ZXMiLCJ2YWwiLCJnZXRNb2RlIiwib2NjdXIiLCJPYmplY3QiLCJrZXlzIiwicHJldiIsImtleSIsImFnZ3JlZ2F0ZSIsInRlY2huaXF1ZSIsIkFHR1JFR0FUSU9OX1RZUEVTIiwiYXZlcmFnZSIsImNvdW50VW5pcXVlIiwibGVuZ3RoIiwibW9kZSIsIm1heGltdW0iLCJtaW5pbXVtIiwibWVkaWFuIiwic3RkZXYiLCJzdW0iLCJ2YXJpYW5jZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBR0E7O0FBQ0E7Ozs7OztBQUVPLElBQU1BLFlBQVksR0FBRyxTQUFmQSxZQUFlLENBQUFDLElBQUk7QUFBQSxTQUM5QkEsSUFBSSxDQUFDQyxNQUFMLENBQ0UsVUFBQ0MsT0FBRCxFQUFVQyxHQUFWO0FBQUEsMkNBQ0tELE9BREwsNENBRUdDLEdBRkgsRUFFUyxDQUFDRCxPQUFPLENBQUNDLEdBQUQsQ0FBUCxJQUFnQixDQUFqQixJQUFzQixDQUYvQjtBQUFBLEdBREYsRUFLRSxFQUxGLENBRDhCO0FBQUEsQ0FBekI7Ozs7QUFTQSxJQUFNQyxPQUFPLEdBQUcsU0FBVkEsT0FBVSxDQUFBSixJQUFJLEVBQUk7QUFDN0IsTUFBTUssS0FBSyxHQUFHTixZQUFZLENBQUNDLElBQUQsQ0FBMUI7QUFDQSxTQUFPTSxNQUFNLENBQUNDLElBQVAsQ0FBWUYsS0FBWixFQUFtQkosTUFBbkIsQ0FDTCxVQUFDTyxJQUFELEVBQU9DLEdBQVA7QUFBQSxXQUFnQkosS0FBSyxDQUFDRyxJQUFELENBQUwsSUFBZUgsS0FBSyxDQUFDSSxHQUFELENBQXBCLEdBQTRCRCxJQUE1QixHQUFtQ0MsR0FBbkQ7QUFBQSxHQURLLEVBRUxILE1BQU0sQ0FBQ0MsSUFBUCxDQUFZRixLQUFaLEVBQW1CLENBQW5CLENBRkssQ0FBUDtBQUlELENBTk07Ozs7QUFRQSxTQUFTSyxTQUFULENBQW1CVixJQUFuQixFQUF5QlcsU0FBekIsRUFBb0M7QUFDekMsVUFBUUEsU0FBUjtBQUNFLFNBQUtDLDZCQUFrQkMsT0FBdkI7QUFDRSxhQUFPLG1CQUFLYixJQUFMLENBQVA7O0FBQ0YsU0FBS1ksNkJBQWtCRSxXQUF2QjtBQUNFLGFBQU9SLE1BQU0sQ0FBQ0MsSUFBUCxDQUNMUCxJQUFJLENBQUNDLE1BQUwsQ0FBWSxVQUFDQyxPQUFELEVBQVVDLEdBQVYsRUFBa0I7QUFDNUJELFFBQUFBLE9BQU8sQ0FBQ0MsR0FBRCxDQUFQLEdBQWVELE9BQU8sQ0FBQ0MsR0FBRCxDQUFQLElBQWdCLENBQS9CO0FBQ0FELFFBQUFBLE9BQU8sQ0FBQ0MsR0FBRCxDQUFQLElBQWdCLENBQWhCO0FBQ0EsZUFBT0QsT0FBUDtBQUNELE9BSkQsRUFJRyxFQUpILENBREssRUFNTGEsTUFORjs7QUFPRixTQUFLSCw2QkFBa0JJLElBQXZCO0FBQ0UsYUFBT1osT0FBTyxDQUFDSixJQUFELENBQWQ7O0FBRUYsU0FBS1ksNkJBQWtCSyxPQUF2QjtBQUNFLGFBQU8sa0JBQUlqQixJQUFKLENBQVA7O0FBQ0YsU0FBS1ksNkJBQWtCTSxPQUF2QjtBQUNFLGFBQU8sa0JBQUlsQixJQUFKLENBQVA7O0FBQ0YsU0FBS1ksNkJBQWtCTyxNQUF2QjtBQUNFLGFBQU8scUJBQU9uQixJQUFQLENBQVA7O0FBQ0YsU0FBS1ksNkJBQWtCUSxLQUF2QjtBQUNFLGFBQU8sd0JBQVVwQixJQUFWLENBQVA7O0FBQ0YsU0FBS1ksNkJBQWtCUyxHQUF2QjtBQUNFLGFBQU8sa0JBQUlyQixJQUFKLENBQVA7O0FBQ0YsU0FBS1ksNkJBQWtCVSxRQUF2QjtBQUNFLGFBQU8sdUJBQVN0QixJQUFULENBQVA7O0FBQ0Y7QUFDRSxhQUFPQSxJQUFJLENBQUNlLE1BQVo7QUEzQko7QUE2QkQiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogTUlUXG4vLyBDb3B5cmlnaHQgY29udHJpYnV0b3JzIHRvIHRoZSBrZXBsZXIuZ2wgcHJvamVjdFxuXG5pbXBvcnQge2RldmlhdGlvbiwgbWluLCBtYXgsIG1lYW4sIG1lZGlhbiwgc3VtLCB2YXJpYW5jZX0gZnJvbSAnZDMtYXJyYXknO1xuaW1wb3J0IHtBR0dSRUdBVElPTl9UWVBFU30gZnJvbSAnQGtlcGxlci5nbC9jb25zdGFudHMnO1xuXG5leHBvcnQgY29uc3QgZ2V0RnJlcXVlbmN5ID0gZGF0YSA9PlxuICBkYXRhLnJlZHVjZShcbiAgICAodW5pcXVlcywgdmFsKSA9PiAoe1xuICAgICAgLi4udW5pcXVlcyxcbiAgICAgIFt2YWxdOiAodW5pcXVlc1t2YWxdIHx8IDApICsgMVxuICAgIH0pLFxuICAgIHt9XG4gICk7XG5cbmV4cG9ydCBjb25zdCBnZXRNb2RlID0gZGF0YSA9PiB7XG4gIGNvbnN0IG9jY3VyID0gZ2V0RnJlcXVlbmN5KGRhdGEpO1xuICByZXR1cm4gT2JqZWN0LmtleXMob2NjdXIpLnJlZHVjZShcbiAgICAocHJldiwga2V5KSA9PiAob2NjdXJbcHJldl0gPj0gb2NjdXJba2V5XSA/IHByZXYgOiBrZXkpLFxuICAgIE9iamVjdC5rZXlzKG9jY3VyKVswXVxuICApO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIGFnZ3JlZ2F0ZShkYXRhLCB0ZWNobmlxdWUpIHtcbiAgc3dpdGNoICh0ZWNobmlxdWUpIHtcbiAgICBjYXNlIEFHR1JFR0FUSU9OX1RZUEVTLmF2ZXJhZ2U6XG4gICAgICByZXR1cm4gbWVhbihkYXRhKTtcbiAgICBjYXNlIEFHR1JFR0FUSU9OX1RZUEVTLmNvdW50VW5pcXVlOlxuICAgICAgcmV0dXJuIE9iamVjdC5rZXlzKFxuICAgICAgICBkYXRhLnJlZHVjZSgodW5pcXVlcywgdmFsKSA9PiB7XG4gICAgICAgICAgdW5pcXVlc1t2YWxdID0gdW5pcXVlc1t2YWxdIHx8IDA7XG4gICAgICAgICAgdW5pcXVlc1t2YWxdICs9IDE7XG4gICAgICAgICAgcmV0dXJuIHVuaXF1ZXM7XG4gICAgICAgIH0sIHt9KVxuICAgICAgKS5sZW5ndGg7XG4gICAgY2FzZSBBR0dSRUdBVElPTl9UWVBFUy5tb2RlOlxuICAgICAgcmV0dXJuIGdldE1vZGUoZGF0YSk7XG5cbiAgICBjYXNlIEFHR1JFR0FUSU9OX1RZUEVTLm1heGltdW06XG4gICAgICByZXR1cm4gbWF4KGRhdGEpO1xuICAgIGNhc2UgQUdHUkVHQVRJT05fVFlQRVMubWluaW11bTpcbiAgICAgIHJldHVybiBtaW4oZGF0YSk7XG4gICAgY2FzZSBBR0dSRUdBVElPTl9UWVBFUy5tZWRpYW46XG4gICAgICByZXR1cm4gbWVkaWFuKGRhdGEpO1xuICAgIGNhc2UgQUdHUkVHQVRJT05fVFlQRVMuc3RkZXY6XG4gICAgICByZXR1cm4gZGV2aWF0aW9uKGRhdGEpO1xuICAgIGNhc2UgQUdHUkVHQVRJT05fVFlQRVMuc3VtOlxuICAgICAgcmV0dXJuIHN1bShkYXRhKTtcbiAgICBjYXNlIEFHR1JFR0FUSU9OX1RZUEVTLnZhcmlhbmNlOlxuICAgICAgcmV0dXJuIHZhcmlhbmNlKGRhdGEpO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gZGF0YS5sZW5ndGg7XG4gIH1cbn1cbiJdfQ==
@@ -1,54 +0,0 @@
1
- import * as arrow from 'apache-arrow';
2
- import { DATA_TYPES as AnalyzerDATA_TYPES } from 'type-analyzer';
3
- import { Field } from '@kepler.gl/types';
4
- import { DataRow, SharedRowOptions } from './data-row';
5
- import { DataContainerInterface, RangeOptions } from './data-container-interface';
6
- declare type ArrowDataContainerInput = {
7
- cols: arrow.Vector[];
8
- fields?: Field[];
9
- };
10
- /**
11
- * A data container where all data is stored in raw Arrow table
12
- */
13
- export declare class ArrowDataContainer implements DataContainerInterface {
14
- _cols: arrow.Vector[];
15
- _numColumns: number;
16
- _numRows: number;
17
- _fields: Field[];
18
- _numChunks: number;
19
- constructor(data: ArrowDataContainerInput);
20
- update(updateData: arrow.Vector<any>[]): void;
21
- numChunks(): number;
22
- numRows(): number;
23
- numColumns(): number;
24
- valueAt(rowIndex: number, columnIndex: number): any;
25
- row(rowIndex: number, sharedRow?: SharedRowOptions): DataRow;
26
- rowAsArray(rowIndex: number): any[];
27
- rows(sharedRow: SharedRowOptions): any;
28
- column(columnIndex: number): Generator<any, void, unknown>;
29
- getColumn(columnIndex: number): arrow.Vector;
30
- getField(columnIndex: number): Field;
31
- flattenData(): any[][];
32
- getPlainIndex(): number[];
33
- map<T>(func: (row: DataRow, index: number) => T, sharedRow?: SharedRowOptions, options?: RangeOptions): T[];
34
- mapIndex<T>(func: ({ index }: {
35
- index: any;
36
- }, dc: DataContainerInterface) => T, options?: RangeOptions): T[];
37
- find(func: (row: DataRow, index: number) => boolean, sharedRow?: SharedRowOptions): DataRow | undefined;
38
- reduce<T>(func: (acc: T, row: DataRow, index: number) => T, initialValue: T, sharedRow?: SharedRowOptions): T;
39
- }
40
- /**
41
- * Convert arrow data type to kepler.gl field types
42
- *
43
- * @param arrowType the arrow data type
44
- * @returns corresponding type in `ALL_FIELD_TYPES`
45
- */
46
- export declare function arrowDataTypeToFieldType(arrowType: arrow.DataType): string;
47
- /**
48
- * Convert arrow data type to analyzer type
49
- *
50
- * @param arrowType the arrow data type
51
- * @returns corresponding type in `AnalyzerDATA_TYPES`
52
- */
53
- export declare function arrowDataTypeToAnalyzerDataType(arrowType: arrow.DataType): typeof AnalyzerDATA_TYPES;
54
- export {};
@@ -1,360 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
-
7
- Object.defineProperty(exports, "__esModule", {
8
- value: true
9
- });
10
- exports.arrowDataTypeToFieldType = arrowDataTypeToFieldType;
11
- exports.arrowDataTypeToAnalyzerDataType = arrowDataTypeToAnalyzerDataType;
12
- exports.ArrowDataContainer = void 0;
13
-
14
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
15
-
16
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
17
-
18
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
19
-
20
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
21
-
22
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
23
-
24
- var arrow = _interopRequireWildcard(require("apache-arrow"));
25
-
26
- var _window = require("global/window");
27
-
28
- var _typeAnalyzer = require("type-analyzer");
29
-
30
- var _constants = require("@kepler.gl/constants");
31
-
32
- var _dataRow = require("./data-row");
33
-
34
- var _marked = /*#__PURE__*/_regenerator["default"].mark(rowsIterator),
35
- _marked2 = /*#__PURE__*/_regenerator["default"].mark(columnIterator);
36
-
37
- /**
38
- * @param dataContainer
39
- * @param sharedRow
40
- */
41
- function rowsIterator(dataContainer, sharedRow) {
42
- var numRows, rowIndex;
43
- return _regenerator["default"].wrap(function rowsIterator$(_context) {
44
- while (1) {
45
- switch (_context.prev = _context.next) {
46
- case 0:
47
- numRows = dataContainer.numRows();
48
- rowIndex = 0;
49
-
50
- case 2:
51
- if (!(rowIndex < numRows)) {
52
- _context.next = 8;
53
- break;
54
- }
55
-
56
- _context.next = 5;
57
- return dataContainer.row(rowIndex, sharedRow);
58
-
59
- case 5:
60
- ++rowIndex;
61
- _context.next = 2;
62
- break;
63
-
64
- case 8:
65
- case "end":
66
- return _context.stop();
67
- }
68
- }
69
- }, _marked);
70
- }
71
- /**
72
- * @param dataContainer
73
- * @param columnIndex
74
- */
75
-
76
-
77
- function columnIterator(dataContainer, columnIndex) {
78
- var numRows, rowIndex;
79
- return _regenerator["default"].wrap(function columnIterator$(_context2) {
80
- while (1) {
81
- switch (_context2.prev = _context2.next) {
82
- case 0:
83
- numRows = dataContainer.numRows();
84
- rowIndex = 0;
85
-
86
- case 2:
87
- if (!(rowIndex < numRows)) {
88
- _context2.next = 8;
89
- break;
90
- }
91
-
92
- _context2.next = 5;
93
- return dataContainer.valueAt(rowIndex, columnIndex);
94
-
95
- case 5:
96
- ++rowIndex;
97
- _context2.next = 2;
98
- break;
99
-
100
- case 8:
101
- case "end":
102
- return _context2.stop();
103
- }
104
- }
105
- }, _marked2);
106
- }
107
- /**
108
- * A data container where all data is stored in raw Arrow table
109
- */
110
-
111
-
112
- var ArrowDataContainer = /*#__PURE__*/function () {
113
- // cache column data to make valueAt() faster
114
- // _colData: any[][];
115
- function ArrowDataContainer(data) {
116
- (0, _classCallCheck2["default"])(this, ArrowDataContainer);
117
- (0, _defineProperty2["default"])(this, "_cols", void 0);
118
- (0, _defineProperty2["default"])(this, "_numColumns", void 0);
119
- (0, _defineProperty2["default"])(this, "_numRows", void 0);
120
- (0, _defineProperty2["default"])(this, "_fields", void 0);
121
- (0, _defineProperty2["default"])(this, "_numChunks", void 0);
122
-
123
- if (!data.cols) {
124
- throw Error('ArrowDataContainer: no columns provided');
125
- }
126
-
127
- if (!Array.isArray(data.cols)) {
128
- throw Error("ArrowDataContainer: columns object isn't an array");
129
- }
130
-
131
- this._cols = data.cols;
132
- this._numColumns = data.cols.length;
133
- this._numRows = data.cols[0].length;
134
- this._fields = data.fields || [];
135
- this._numChunks = data.cols[0].data.length; // this._colData = data.cols.map(c => c.toArray());
136
- }
137
-
138
- (0, _createClass2["default"])(ArrowDataContainer, [{
139
- key: "update",
140
- value: function update(updateData) {
141
- this._cols = updateData;
142
- this._numColumns = this._cols.length;
143
- this._numRows = this._cols[0].length;
144
- this._numChunks = this._cols[0].data.length; // cache column data to make valueAt() faster
145
- // this._colData = this._cols.map(c => c.toArray());
146
- }
147
- }, {
148
- key: "numChunks",
149
- value: function numChunks() {
150
- return this._numChunks;
151
- }
152
- }, {
153
- key: "numRows",
154
- value: function numRows() {
155
- return this._numRows;
156
- }
157
- }, {
158
- key: "numColumns",
159
- value: function numColumns() {
160
- return this._numColumns;
161
- }
162
- }, {
163
- key: "valueAt",
164
- value: function valueAt(rowIndex, columnIndex) {
165
- // return this._colData[columnIndex][rowIndex];
166
- return this._cols[columnIndex].get(rowIndex);
167
- }
168
- }, {
169
- key: "row",
170
- value: function row(rowIndex, sharedRow) {
171
- var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow);
172
-
173
- if (tSharedRow) {
174
- tSharedRow.setSource(this, rowIndex);
175
- return tSharedRow;
176
- }
177
-
178
- return new _dataRow.DataRow(this, rowIndex);
179
- }
180
- }, {
181
- key: "rowAsArray",
182
- value: function rowAsArray(rowIndex) {
183
- // return this._colData.map(col => col[rowIndex]);
184
- return this._cols.map(function (col) {
185
- return col.get(rowIndex);
186
- });
187
- }
188
- }, {
189
- key: "rows",
190
- value: function rows(sharedRow) {
191
- var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow);
192
-
193
- return rowsIterator(this, tSharedRow);
194
- }
195
- }, {
196
- key: "column",
197
- value: function column(columnIndex) {
198
- return columnIterator(this, columnIndex);
199
- }
200
- }, {
201
- key: "getColumn",
202
- value: function getColumn(columnIndex) {
203
- return this._cols[columnIndex];
204
- }
205
- }, {
206
- key: "getField",
207
- value: function getField(columnIndex) {
208
- return this._fields[columnIndex];
209
- }
210
- }, {
211
- key: "flattenData",
212
- value: function flattenData() {
213
- var data = [];
214
-
215
- for (var i = 0; i < this._numRows; ++i) {
216
- data.push(this.rowAsArray(i));
217
- }
218
-
219
- return data;
220
- }
221
- }, {
222
- key: "getPlainIndex",
223
- value: function getPlainIndex() {
224
- return (0, _toConsumableArray2["default"])(Array(this._numRows).keys());
225
- }
226
- }, {
227
- key: "map",
228
- value: function map(func, sharedRow) {
229
- var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
230
-
231
- var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow);
232
-
233
- var _options$start = options.start,
234
- start = _options$start === void 0 ? 0 : _options$start,
235
- _options$end = options.end,
236
- end = _options$end === void 0 ? this.numRows() : _options$end;
237
- var endRow = Math.min(this.numRows(), end);
238
- var out = [];
239
-
240
- for (var rowIndex = start; rowIndex < endRow; ++rowIndex) {
241
- var _row = this.row(rowIndex, tSharedRow);
242
-
243
- out.push(func(_row, rowIndex));
244
- }
245
-
246
- return out;
247
- }
248
- }, {
249
- key: "mapIndex",
250
- value: function mapIndex(func) {
251
- var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
252
- var _options$start2 = options.start,
253
- start = _options$start2 === void 0 ? 0 : _options$start2,
254
- _options$end2 = options.end,
255
- end = _options$end2 === void 0 ? this.numRows() : _options$end2;
256
- var endRow = Math.min(this.numRows(), end);
257
- var out = [];
258
-
259
- for (var rowIndex = start; rowIndex < endRow; ++rowIndex) {
260
- out.push(func({
261
- index: rowIndex
262
- }, this));
263
- }
264
-
265
- return out;
266
- }
267
- }, {
268
- key: "find",
269
- value: function find(func, sharedRow) {
270
- var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow);
271
-
272
- for (var rowIndex = 0; rowIndex < this._numRows; ++rowIndex) {
273
- var _row2 = this.row(rowIndex, tSharedRow);
274
-
275
- if (func(_row2, rowIndex)) {
276
- return _row2;
277
- }
278
- }
279
-
280
- return undefined;
281
- }
282
- }, {
283
- key: "reduce",
284
- value: function reduce(func, initialValue, sharedRow) {
285
- var tSharedRow = _dataRow.DataRow.createSharedRow(sharedRow);
286
-
287
- for (var rowIndex = 0; rowIndex < this._numRows; ++rowIndex) {
288
- var _row3 = this.row(rowIndex, tSharedRow);
289
-
290
- initialValue = func(initialValue, _row3, rowIndex);
291
- }
292
-
293
- return initialValue;
294
- }
295
- }]);
296
- return ArrowDataContainer;
297
- }();
298
- /**
299
- * Convert arrow data type to kepler.gl field types
300
- *
301
- * @param arrowType the arrow data type
302
- * @returns corresponding type in `ALL_FIELD_TYPES`
303
- */
304
-
305
-
306
- exports.ArrowDataContainer = ArrowDataContainer;
307
-
308
- function arrowDataTypeToFieldType(arrowType) {
309
- // Note: this function doesn't return ALL_FIELD_TYPES.geojson or ALL_FIELD_TYPES.array, which
310
- // should be further detected by caller
311
- if (arrow.DataType.isDate(arrowType)) {
312
- return _constants.ALL_FIELD_TYPES.date;
313
- } else if (arrow.DataType.isTimestamp(arrowType) || arrow.DataType.isTime(arrowType)) {
314
- return _constants.ALL_FIELD_TYPES.timestamp;
315
- } else if (arrow.DataType.isFloat(arrowType)) {
316
- return _constants.ALL_FIELD_TYPES.real;
317
- } else if (arrow.DataType.isInt(arrowType)) {
318
- return _constants.ALL_FIELD_TYPES.integer;
319
- } else if (arrow.DataType.isBool(arrowType)) {
320
- return _constants.ALL_FIELD_TYPES["boolean"];
321
- } else if (arrow.DataType.isUtf8(arrowType) || arrow.DataType.isNull(arrowType)) {
322
- return _constants.ALL_FIELD_TYPES.string;
323
- } else if (arrow.DataType.isBinary(arrowType) || arrow.DataType.isDictionary(arrowType) || arrow.DataType.isFixedSizeBinary(arrowType) || arrow.DataType.isFixedSizeList(arrowType) || arrow.DataType.isList(arrowType) || arrow.DataType.isMap(arrowType) || arrow.DataType.isStruct(arrowType)) {
324
- return _constants.ALL_FIELD_TYPES.object;
325
- } else {
326
- _window.console.warn("Unsupported arrow type: ".concat(arrowType));
327
-
328
- return _constants.ALL_FIELD_TYPES.string;
329
- }
330
- }
331
- /**
332
- * Convert arrow data type to analyzer type
333
- *
334
- * @param arrowType the arrow data type
335
- * @returns corresponding type in `AnalyzerDATA_TYPES`
336
- */
337
-
338
-
339
- function arrowDataTypeToAnalyzerDataType(arrowType) {
340
- if (arrow.DataType.isDate(arrowType)) {
341
- return _typeAnalyzer.DATA_TYPES.DATE;
342
- } else if (arrow.DataType.isTimestamp(arrowType) || arrow.DataType.isTime(arrowType)) {
343
- return _typeAnalyzer.DATA_TYPES.DATETIME;
344
- } else if (arrow.DataType.isFloat(arrowType)) {
345
- return _typeAnalyzer.DATA_TYPES.FLOAT;
346
- } else if (arrow.DataType.isInt(arrowType)) {
347
- return _typeAnalyzer.DATA_TYPES.INT;
348
- } else if (arrow.DataType.isBool(arrowType)) {
349
- return _typeAnalyzer.DATA_TYPES.BOOLEAN;
350
- } else if (arrow.DataType.isUtf8(arrowType) || arrow.DataType.isNull(arrowType)) {
351
- return _typeAnalyzer.DATA_TYPES.STRING;
352
- } else if (arrow.DataType.isBinary(arrowType) || arrow.DataType.isDictionary(arrowType) || arrow.DataType.isFixedSizeBinary(arrowType) || arrow.DataType.isFixedSizeList(arrowType) || arrow.DataType.isList(arrowType) || arrow.DataType.isMap(arrowType) || arrow.DataType.isStruct(arrowType)) {
353
- return _typeAnalyzer.DATA_TYPES.OBJECT;
354
- } else {
355
- _window.console.warn("Unsupported arrow type: ".concat(arrowType));
356
-
357
- return _typeAnalyzer.DATA_TYPES.STRING;
358
- }
359
- }
360
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/arrow-data-container.ts"],"names":["rowsIterator","columnIterator","dataContainer","sharedRow","numRows","rowIndex","row","columnIndex","valueAt","ArrowDataContainer","data","cols","Error","Array","isArray","_cols","_numColumns","length","_numRows","_fields","fields","_numChunks","updateData","get","tSharedRow","DataRow","createSharedRow","setSource","map","col","i","push","rowAsArray","keys","func","options","start","end","endRow","Math","min","out","index","undefined","initialValue","arrowDataTypeToFieldType","arrowType","arrow","DataType","isDate","ALL_FIELD_TYPES","date","isTimestamp","isTime","timestamp","isFloat","real","isInt","integer","isBool","isUtf8","isNull","string","isBinary","isDictionary","isFixedSizeBinary","isFixedSizeList","isList","isMap","isStruct","object","globalConsole","warn","arrowDataTypeToAnalyzerDataType","AnalyzerDATA_TYPES","DATE","DATETIME","FLOAT","INT","BOOLEAN","STRING","OBJECT"],"mappings":"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","sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport * as arrow from 'apache-arrow';\nimport {console as globalConsole} from 'global/window';\nimport {DATA_TYPES as AnalyzerDATA_TYPES} from 'type-analyzer';\nimport {Field} from '@kepler.gl/types';\nimport {ALL_FIELD_TYPES} from '@kepler.gl/constants';\n\nimport {DataRow, SharedRowOptions} from './data-row';\nimport {DataContainerInterface, RangeOptions} from './data-container-interface';\n\ntype ArrowDataContainerInput = {\n  cols: arrow.Vector[];\n  fields?: Field[];\n};\n\n/**\n * @param dataContainer\n * @param sharedRow\n */\nfunction* rowsIterator(dataContainer: DataContainerInterface, sharedRow: SharedRowOptions) {\n  const numRows = dataContainer.numRows();\n  for (let rowIndex = 0; rowIndex < numRows; ++rowIndex) {\n    yield dataContainer.row(rowIndex, sharedRow);\n  }\n}\n\n/**\n * @param dataContainer\n * @param columnIndex\n */\nfunction* columnIterator(dataContainer: DataContainerInterface, columnIndex: number) {\n  const numRows = dataContainer.numRows();\n  for (let rowIndex = 0; rowIndex < numRows; ++rowIndex) {\n    yield dataContainer.valueAt(rowIndex, columnIndex);\n  }\n}\n\n/**\n * A data container where all data is stored in raw Arrow table\n */\nexport class ArrowDataContainer implements DataContainerInterface {\n  _cols: arrow.Vector[];\n  _numColumns: number;\n  _numRows: number;\n  _fields: Field[];\n  _numChunks: number;\n  // cache column data to make valueAt() faster\n  // _colData: any[][];\n\n  constructor(data: ArrowDataContainerInput) {\n    if (!data.cols) {\n      throw Error('ArrowDataContainer: no columns provided');\n    }\n\n    if (!Array.isArray(data.cols)) {\n      throw Error(\"ArrowDataContainer: columns object isn't an array\");\n    }\n\n    this._cols = data.cols;\n    this._numColumns = data.cols.length;\n    this._numRows = data.cols[0].length;\n    this._fields = data.fields || [];\n    this._numChunks = data.cols[0].data.length;\n    // this._colData = data.cols.map(c => c.toArray());\n  }\n\n  update(updateData: arrow.Vector<any>[]) {\n    this._cols = updateData;\n    this._numColumns = this._cols.length;\n    this._numRows = this._cols[0].length;\n    this._numChunks = this._cols[0].data.length;\n    // cache column data to make valueAt() faster\n    // this._colData = this._cols.map(c => c.toArray());\n  }\n\n  numChunks(): number {\n    return this._numChunks;\n  }\n\n  numRows(): number {\n    return this._numRows;\n  }\n\n  numColumns(): number {\n    return this._numColumns;\n  }\n\n  valueAt(rowIndex: number, columnIndex: number): any {\n    // return this._colData[columnIndex][rowIndex];\n    return this._cols[columnIndex].get(rowIndex);\n  }\n\n  row(rowIndex: number, sharedRow?: SharedRowOptions): DataRow {\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\n    if (tSharedRow) {\n      tSharedRow.setSource(this, rowIndex);\n      return tSharedRow;\n    }\n\n    return new DataRow(this, rowIndex);\n  }\n\n  rowAsArray(rowIndex: number): any[] {\n    // return this._colData.map(col => col[rowIndex]);\n    return this._cols.map(col => col.get(rowIndex));\n  }\n\n  rows(sharedRow: SharedRowOptions) {\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\n    return rowsIterator(this, tSharedRow);\n  }\n\n  column(columnIndex: number) {\n    return columnIterator(this, columnIndex);\n  }\n\n  getColumn(columnIndex: number): arrow.Vector {\n    return this._cols[columnIndex];\n  }\n\n  getField(columnIndex: number): Field {\n    return this._fields[columnIndex];\n  }\n\n  flattenData(): any[][] {\n    const data: any[][] = [];\n    for (let i = 0; i < this._numRows; ++i) {\n      data.push(this.rowAsArray(i));\n    }\n    return data;\n  }\n\n  getPlainIndex(): number[] {\n    return [...Array(this._numRows).keys()];\n  }\n\n  map<T>(\n    func: (row: DataRow, index: number) => T,\n    sharedRow?: SharedRowOptions,\n    options: RangeOptions = {}\n  ): T[] {\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\n\n    const {start = 0, end = this.numRows()} = options;\n    const endRow = Math.min(this.numRows(), end);\n\n    const out: T[] = [];\n    for (let rowIndex = start; rowIndex < endRow; ++rowIndex) {\n      const row = this.row(rowIndex, tSharedRow);\n      out.push(func(row, rowIndex));\n    }\n    return out;\n  }\n\n  mapIndex<T>(func: ({index}, dc: DataContainerInterface) => T, options: RangeOptions = {}): T[] {\n    const {start = 0, end = this.numRows()} = options;\n    const endRow = Math.min(this.numRows(), end);\n\n    const out: T[] = [];\n    for (let rowIndex = start; rowIndex < endRow; ++rowIndex) {\n      out.push(func({index: rowIndex}, this));\n    }\n    return out;\n  }\n\n  find(\n    func: (row: DataRow, index: number) => boolean,\n    sharedRow?: SharedRowOptions\n  ): DataRow | undefined {\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\n\n    for (let rowIndex = 0; rowIndex < this._numRows; ++rowIndex) {\n      const row = this.row(rowIndex, tSharedRow);\n      if (func(row, rowIndex)) {\n        return row;\n      }\n    }\n    return undefined;\n  }\n\n  reduce<T>(\n    func: (acc: T, row: DataRow, index: number) => T,\n    initialValue: T,\n    sharedRow?: SharedRowOptions\n  ): T {\n    const tSharedRow = DataRow.createSharedRow(sharedRow);\n\n    for (let rowIndex = 0; rowIndex < this._numRows; ++rowIndex) {\n      const row = this.row(rowIndex, tSharedRow);\n      initialValue = func(initialValue, row, rowIndex);\n    }\n    return initialValue;\n  }\n}\n\n/**\n * Convert arrow data type to kepler.gl field types\n *\n * @param arrowType the arrow data type\n * @returns corresponding type in `ALL_FIELD_TYPES`\n */\nexport function arrowDataTypeToFieldType(arrowType: arrow.DataType): string {\n  // Note: this function doesn't return ALL_FIELD_TYPES.geojson or ALL_FIELD_TYPES.array, which\n  // should be further detected by caller\n  if (arrow.DataType.isDate(arrowType)) {\n    return ALL_FIELD_TYPES.date;\n  } else if (arrow.DataType.isTimestamp(arrowType) || arrow.DataType.isTime(arrowType)) {\n    return ALL_FIELD_TYPES.timestamp;\n  } else if (arrow.DataType.isFloat(arrowType)) {\n    return ALL_FIELD_TYPES.real;\n  } else if (arrow.DataType.isInt(arrowType)) {\n    return ALL_FIELD_TYPES.integer;\n  } else if (arrow.DataType.isBool(arrowType)) {\n    return ALL_FIELD_TYPES.boolean;\n  } else if (arrow.DataType.isUtf8(arrowType) || arrow.DataType.isNull(arrowType)) {\n    return ALL_FIELD_TYPES.string;\n  } else if (\n    arrow.DataType.isBinary(arrowType) ||\n    arrow.DataType.isDictionary(arrowType) ||\n    arrow.DataType.isFixedSizeBinary(arrowType) ||\n    arrow.DataType.isFixedSizeList(arrowType) ||\n    arrow.DataType.isList(arrowType) ||\n    arrow.DataType.isMap(arrowType) ||\n    arrow.DataType.isStruct(arrowType)\n  ) {\n    return ALL_FIELD_TYPES.object;\n  } else {\n    globalConsole.warn(`Unsupported arrow type: ${arrowType}`);\n    return ALL_FIELD_TYPES.string;\n  }\n}\n\n/**\n * Convert arrow data type to analyzer type\n *\n * @param arrowType the arrow data type\n * @returns corresponding type in `AnalyzerDATA_TYPES`\n */\nexport function arrowDataTypeToAnalyzerDataType(\n  arrowType: arrow.DataType\n): typeof AnalyzerDATA_TYPES {\n  if (arrow.DataType.isDate(arrowType)) {\n    return AnalyzerDATA_TYPES.DATE;\n  } else if (arrow.DataType.isTimestamp(arrowType) || arrow.DataType.isTime(arrowType)) {\n    return AnalyzerDATA_TYPES.DATETIME;\n  } else if (arrow.DataType.isFloat(arrowType)) {\n    return AnalyzerDATA_TYPES.FLOAT;\n  } else if (arrow.DataType.isInt(arrowType)) {\n    return AnalyzerDATA_TYPES.INT;\n  } else if (arrow.DataType.isBool(arrowType)) {\n    return AnalyzerDATA_TYPES.BOOLEAN;\n  } else if (arrow.DataType.isUtf8(arrowType) || arrow.DataType.isNull(arrowType)) {\n    return AnalyzerDATA_TYPES.STRING;\n  } else if (\n    arrow.DataType.isBinary(arrowType) ||\n    arrow.DataType.isDictionary(arrowType) ||\n    arrow.DataType.isFixedSizeBinary(arrowType) ||\n    arrow.DataType.isFixedSizeList(arrowType) ||\n    arrow.DataType.isList(arrowType) ||\n    arrow.DataType.isMap(arrowType) ||\n    arrow.DataType.isStruct(arrowType)\n  ) {\n    return AnalyzerDATA_TYPES.OBJECT;\n  } else {\n    globalConsole.warn(`Unsupported arrow type: ${arrowType}`);\n    return AnalyzerDATA_TYPES.STRING;\n  }\n}\n"]}
@@ -1,51 +0,0 @@
1
- import { ColorRange } from '@kepler.gl/constants';
2
- import { HexColor, RGBColor } from '@kepler.gl/types';
3
- /**
4
- * get r g b from hex code
5
- *
6
- * @param hex
7
- * @returns array of r g bs
8
- */
9
- export declare function hexToRgb(hex: string): RGBColor;
10
- export declare function isHexColor(hex: string): RegExpExecArray | null;
11
- /**
12
- * get hex from r g b
13
- *
14
- * @param rgb
15
- * @returns hex string
16
- */
17
- export declare function rgbToHex([r, g, b]: RGBColor): HexColor;
18
- /**
19
- * Get color group name by parsing name, discard step in the name
20
- * e.g. Global Warming 6 -> Global Warming
21
- *
22
- * @param {Object} colorRange
23
- * @return {string | null}
24
- */
25
- export declare function getColorGroupByName(colorRange: ColorRange): string | null;
26
- /**
27
- * Get a reversed colorRange
28
- * @param reversed
29
- * @param colorRange
30
- */
31
- export declare function reverseColorRange(reversed: boolean, colorRange: ColorRange): ColorRange | null;
32
- /**
33
- * given a list of rgb arrays it will generate a linear gradient css rule
34
- * @param direction
35
- * @param colors
36
- * @return
37
- */
38
- export declare function createLinearGradient(direction: string, colors: RGBColor[]): string;
39
- /**
40
- * Convert color to RGB
41
- */
42
- export declare function colorMaybeToRGB(color: unknown): RGBColor | null;
43
- /**
44
- * Whether color is rgb
45
- * @returns
46
- */
47
- export declare function isRgbColor(color: unknown): boolean;
48
- /**
49
- * Take color values in 0-255 range and map to [0, 1]
50
- */
51
- export declare function normalizeColor(color: number[]): number[];