@lowentry/utils 1.25.3 → 2.0.3

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 (184) hide show
  1. package/LICENSE +23 -0
  2. package/README.md +0 -2
  3. package/dist/src/LeTypes.d.ts +73 -0
  4. package/dist/src/LeTypes.d.ts.map +1 -0
  5. package/dist/src/LeTypes.js +235 -0
  6. package/dist/src/LeTypes.js.map +1 -0
  7. package/dist/src/LeUtils.d.ts +745 -0
  8. package/dist/src/LeUtils.d.ts.map +1 -0
  9. package/dist/src/LeUtils.js +3168 -0
  10. package/dist/src/LeUtils.js.map +1 -0
  11. package/dist/src/classes/EventEmitter.d.ts +51 -0
  12. package/dist/src/classes/EventEmitter.d.ts.map +1 -0
  13. package/dist/src/classes/EventEmitter.js +94 -0
  14. package/dist/src/classes/EventEmitter.js.map +1 -0
  15. package/dist/src/classes/LinkedList.d.ts +35 -0
  16. package/dist/src/classes/LinkedList.d.ts.map +1 -0
  17. package/dist/src/classes/LinkedList.js +99 -0
  18. package/dist/src/classes/LinkedList.js.map +1 -0
  19. package/dist/src/classes/SerializableMap.d.ts +14 -0
  20. package/dist/src/classes/SerializableMap.d.ts.map +1 -0
  21. package/dist/src/classes/SerializableMap.js +27 -0
  22. package/dist/src/classes/SerializableMap.js.map +1 -0
  23. package/dist/src/classes/TreeSet.d.ts +123 -0
  24. package/dist/src/classes/TreeSet.d.ts.map +1 -0
  25. package/dist/src/classes/TreeSet.js +210 -0
  26. package/dist/src/classes/TreeSet.js.map +1 -0
  27. package/dist/src/index.d.ts +148 -0
  28. package/dist/src/index.d.ts.map +1 -0
  29. package/dist/src/index.js +13 -0
  30. package/dist/src/index.js.map +1 -0
  31. package/dist/tests/CustomClasses.test.d.ts +2 -0
  32. package/dist/tests/CustomClasses.test.d.ts.map +1 -0
  33. package/dist/tests/CustomClasses.test.js +138 -0
  34. package/dist/tests/CustomClasses.test.js.map +1 -0
  35. package/dist/tests/LeClasses.EventEmitter.test.d.ts +2 -0
  36. package/dist/tests/LeClasses.EventEmitter.test.d.ts.map +1 -0
  37. package/dist/tests/LeClasses.EventEmitter.test.js +39 -0
  38. package/dist/tests/LeClasses.EventEmitter.test.js.map +1 -0
  39. package/dist/tests/LeClasses.LinkedList.test.d.ts +2 -0
  40. package/dist/tests/LeClasses.LinkedList.test.d.ts.map +1 -0
  41. package/dist/tests/LeClasses.LinkedList.test.js +36 -0
  42. package/dist/tests/LeClasses.LinkedList.test.js.map +1 -0
  43. package/dist/tests/LeClasses.SerializableMap.test.d.ts +2 -0
  44. package/dist/tests/LeClasses.SerializableMap.test.d.ts.map +1 -0
  45. package/dist/tests/LeClasses.SerializableMap.test.js +25 -0
  46. package/dist/tests/LeClasses.SerializableMap.test.js.map +1 -0
  47. package/dist/tests/LeClasses.TreeSet.test.d.ts +2 -0
  48. package/dist/tests/LeClasses.TreeSet.test.d.ts.map +1 -0
  49. package/dist/tests/LeClasses.TreeSet.test.js +28 -0
  50. package/dist/tests/LeClasses.TreeSet.test.js.map +1 -0
  51. package/dist/tests/LeTypes.ARRAY.test.d.ts +2 -0
  52. package/dist/tests/LeTypes.ARRAY.test.d.ts.map +1 -0
  53. package/dist/tests/LeTypes.ARRAY.test.js +103 -0
  54. package/dist/tests/LeTypes.ARRAY.test.js.map +1 -0
  55. package/dist/tests/LeTypes.BOOL.test.d.ts +2 -0
  56. package/dist/tests/LeTypes.BOOL.test.d.ts.map +1 -0
  57. package/dist/tests/LeTypes.BOOL.test.js +138 -0
  58. package/dist/tests/LeTypes.BOOL.test.js.map +1 -0
  59. package/dist/tests/LeTypes.FLOAT.test.d.ts +2 -0
  60. package/dist/tests/LeTypes.FLOAT.test.d.ts.map +1 -0
  61. package/dist/tests/LeTypes.FLOAT.test.js +120 -0
  62. package/dist/tests/LeTypes.FLOAT.test.js.map +1 -0
  63. package/dist/tests/LeTypes.FLOAT_ANY.test.d.ts +2 -0
  64. package/dist/tests/LeTypes.FLOAT_ANY.test.d.ts.map +1 -0
  65. package/dist/tests/LeTypes.FLOAT_ANY.test.js +47 -0
  66. package/dist/tests/LeTypes.FLOAT_ANY.test.js.map +1 -0
  67. package/dist/tests/LeTypes.INT.test.d.ts +2 -0
  68. package/dist/tests/LeTypes.INT.test.d.ts.map +1 -0
  69. package/dist/tests/LeTypes.INT.test.js +80 -0
  70. package/dist/tests/LeTypes.INT.test.js.map +1 -0
  71. package/dist/tests/LeTypes.INT_ANY.test.d.ts +2 -0
  72. package/dist/tests/LeTypes.INT_ANY.test.d.ts.map +1 -0
  73. package/dist/tests/LeTypes.INT_ANY.test.js +37 -0
  74. package/dist/tests/LeTypes.INT_ANY.test.js.map +1 -0
  75. package/dist/tests/LeTypes.ISSET.test.d.ts +2 -0
  76. package/dist/tests/LeTypes.ISSET.test.d.ts.map +1 -0
  77. package/dist/tests/LeTypes.ISSET.test.js +113 -0
  78. package/dist/tests/LeTypes.ISSET.test.js.map +1 -0
  79. package/dist/tests/LeTypes.IS_ARRAY.test.d.ts +2 -0
  80. package/dist/tests/LeTypes.IS_ARRAY.test.d.ts.map +1 -0
  81. package/dist/tests/LeTypes.IS_ARRAY.test.js +81 -0
  82. package/dist/tests/LeTypes.IS_ARRAY.test.js.map +1 -0
  83. package/dist/tests/LeTypes.IS_OBJECT.test.d.ts +2 -0
  84. package/dist/tests/LeTypes.IS_OBJECT.test.d.ts.map +1 -0
  85. package/dist/tests/LeTypes.IS_OBJECT.test.js +98 -0
  86. package/dist/tests/LeTypes.IS_OBJECT.test.js.map +1 -0
  87. package/dist/tests/LeTypes.LAX.test.d.ts +2 -0
  88. package/dist/tests/LeTypes.LAX.test.d.ts.map +1 -0
  89. package/dist/tests/LeTypes.LAX.test.js +89 -0
  90. package/dist/tests/LeTypes.LAX.test.js.map +1 -0
  91. package/dist/tests/LeTypes.OBJECT.test.d.ts +2 -0
  92. package/dist/tests/LeTypes.OBJECT.test.d.ts.map +1 -0
  93. package/dist/tests/LeTypes.OBJECT.test.js +81 -0
  94. package/dist/tests/LeTypes.OBJECT.test.js.map +1 -0
  95. package/dist/tests/LeTypes.STRING.test.d.ts +2 -0
  96. package/dist/tests/LeTypes.STRING.test.d.ts.map +1 -0
  97. package/dist/tests/LeTypes.STRING.test.js +204 -0
  98. package/dist/tests/LeTypes.STRING.test.js.map +1 -0
  99. package/dist/tests/LeTypes.STRING_ANY.test.d.ts +2 -0
  100. package/dist/tests/LeTypes.STRING_ANY.test.d.ts.map +1 -0
  101. package/dist/tests/LeTypes.STRING_ANY.test.js +58 -0
  102. package/dist/tests/LeTypes.STRING_ANY.test.js.map +1 -0
  103. package/dist/tests/LeUtils.clone.test.d.ts +2 -0
  104. package/dist/tests/LeUtils.clone.test.d.ts.map +1 -0
  105. package/dist/tests/LeUtils.clone.test.js +180 -0
  106. package/dist/tests/LeUtils.clone.test.js.map +1 -0
  107. package/dist/tests/LeUtils.collections.test.d.ts +2 -0
  108. package/dist/tests/LeUtils.collections.test.d.ts.map +1 -0
  109. package/dist/tests/LeUtils.collections.test.js +149 -0
  110. package/dist/tests/LeUtils.collections.test.js.map +1 -0
  111. package/dist/tests/LeUtils.comparison.test.d.ts +2 -0
  112. package/dist/tests/LeUtils.comparison.test.d.ts.map +1 -0
  113. package/dist/tests/LeUtils.comparison.test.js +125 -0
  114. package/dist/tests/LeUtils.comparison.test.js.map +1 -0
  115. package/dist/tests/LeUtils.contains.test.d.ts +2 -0
  116. package/dist/tests/LeUtils.contains.test.d.ts.map +1 -0
  117. package/dist/tests/LeUtils.contains.test.js +52 -0
  118. package/dist/tests/LeUtils.contains.test.js.map +1 -0
  119. package/dist/tests/LeUtils.each.test.d.ts +2 -0
  120. package/dist/tests/LeUtils.each.test.d.ts.map +1 -0
  121. package/dist/tests/LeUtils.each.test.js +267 -0
  122. package/dist/tests/LeUtils.each.test.js.map +1 -0
  123. package/dist/tests/LeUtils.eachAsync.test.d.ts +2 -0
  124. package/dist/tests/LeUtils.eachAsync.test.d.ts.map +1 -0
  125. package/dist/tests/LeUtils.eachAsync.test.js +80 -0
  126. package/dist/tests/LeUtils.eachAsync.test.js.map +1 -0
  127. package/dist/tests/LeUtils.encoding.test.d.ts +2 -0
  128. package/dist/tests/LeUtils.encoding.test.d.ts.map +1 -0
  129. package/dist/tests/LeUtils.encoding.test.js +45 -0
  130. package/dist/tests/LeUtils.encoding.test.js.map +1 -0
  131. package/dist/tests/LeUtils.equals.test.d.ts +2 -0
  132. package/dist/tests/LeUtils.equals.test.d.ts.map +1 -0
  133. package/dist/tests/LeUtils.equals.test.js +328 -0
  134. package/dist/tests/LeUtils.equals.test.js.map +1 -0
  135. package/dist/tests/LeUtils.flatten.test.d.ts +2 -0
  136. package/dist/tests/LeUtils.flatten.test.d.ts.map +1 -0
  137. package/dist/tests/LeUtils.flatten.test.js +30 -0
  138. package/dist/tests/LeUtils.flatten.test.js.map +1 -0
  139. package/dist/tests/LeUtils.misc.test.d.ts +2 -0
  140. package/dist/tests/LeUtils.misc.test.d.ts.map +1 -0
  141. package/dist/tests/LeUtils.misc.test.js +50 -0
  142. package/dist/tests/LeUtils.misc.test.js.map +1 -0
  143. package/dist/tests/LeUtils.misc2.test.d.ts +2 -0
  144. package/dist/tests/LeUtils.misc2.test.d.ts.map +1 -0
  145. package/dist/tests/LeUtils.misc2.test.js +58 -0
  146. package/dist/tests/LeUtils.misc2.test.js.map +1 -0
  147. package/dist/tests/LeUtils.newlyAdded.test.d.ts +2 -0
  148. package/dist/tests/LeUtils.newlyAdded.test.d.ts.map +1 -0
  149. package/dist/tests/LeUtils.newlyAdded.test.js +121 -0
  150. package/dist/tests/LeUtils.newlyAdded.test.js.map +1 -0
  151. package/dist/tests/LeUtils.strings.test.d.ts +2 -0
  152. package/dist/tests/LeUtils.strings.test.d.ts.map +1 -0
  153. package/dist/tests/LeUtils.strings.test.js +125 -0
  154. package/dist/tests/LeUtils.strings.test.js.map +1 -0
  155. package/dist/tests/LeUtils.timing.test.d.ts +2 -0
  156. package/dist/tests/LeUtils.timing.test.d.ts.map +1 -0
  157. package/dist/tests/LeUtils.timing.test.js +72 -0
  158. package/dist/tests/LeUtils.timing.test.js.map +1 -0
  159. package/dist/tests/LeUtils.transactional.test.d.ts +2 -0
  160. package/dist/tests/LeUtils.transactional.test.d.ts.map +1 -0
  161. package/dist/tests/LeUtils.transactional.test.js +39 -0
  162. package/dist/tests/LeUtils.transactional.test.js.map +1 -0
  163. package/dist/tests/setup.d.ts +2 -0
  164. package/dist/tests/setup.d.ts.map +1 -0
  165. package/dist/tests/setup.js +6 -0
  166. package/dist/tests/setup.js.map +1 -0
  167. package/dist/vitest.config.d.ts +3 -0
  168. package/dist/vitest.config.d.ts.map +1 -0
  169. package/dist/vitest.config.js +21 -0
  170. package/dist/vitest.config.js.map +1 -0
  171. package/package.json +52 -53
  172. package/api-extractor.json +0 -43
  173. package/index.d.ts +0 -454
  174. package/index.js +0 -4160
  175. package/index.js.map +0 -1
  176. package/src/LeTypes.js +0 -254
  177. package/src/LeUtils.js +0 -3611
  178. package/src/classes/EventEmitter.js +0 -124
  179. package/src/classes/LinkedList.js +0 -145
  180. package/src/classes/SerializableMap.js +0 -17
  181. package/src/classes/TreeSet.js +0 -235
  182. package/src/index.js +0 -6
  183. package/tsconfig.d.ts +0 -1
  184. package/tsconfig.json +0 -39
package/index.js DELETED
@@ -1,4160 +0,0 @@
1
- import _toConsumableArray from '@babel/runtime/helpers/toConsumableArray';
2
- import _defineProperty from '@babel/runtime/helpers/defineProperty';
3
- import _asyncToGenerator from '@babel/runtime/helpers/asyncToGenerator';
4
- import _slicedToArray from '@babel/runtime/helpers/slicedToArray';
5
- import _typeof from '@babel/runtime/helpers/typeof';
6
- import '@babel/runtime/helpers/awaitAsyncGenerator';
7
- import _wrapAsyncGenerator from '@babel/runtime/helpers/wrapAsyncGenerator';
8
- import _regeneratorRuntime from '@babel/runtime/regenerator';
9
- import CloneDeep from 'clone-deep';
10
- import _classCallCheck from '@babel/runtime/helpers/classCallCheck';
11
- import _createClass from '@babel/runtime/helpers/createClass';
12
- import _possibleConstructorReturn from '@babel/runtime/helpers/possibleConstructorReturn';
13
- import _getPrototypeOf from '@babel/runtime/helpers/getPrototypeOf';
14
- import _inherits from '@babel/runtime/helpers/inherits';
15
- import _wrapNativeSuper from '@babel/runtime/helpers/wrapNativeSuper';
16
-
17
- var REGEX_ALL_NON_FLOAT_CHARACTERS = /[^0-9.\-]/g;
18
-
19
- /**
20
- * Returns true if the value is set (not undefined and not null).
21
- *
22
- * @param {*} value
23
- * @returns {boolean}
24
- */
25
- var ISSET = function ISSET(value) {
26
- return typeof value !== 'undefined' && value !== null;
27
- };
28
-
29
- /**
30
- * Returns true if the value is an array.
31
- *
32
- * @param {*} value
33
- * @returns {boolean}
34
- */
35
- var IS_ARRAY = function IS_ARRAY(value) {
36
- return Array.isArray(value);
37
- };
38
-
39
- /**
40
- * Ensures the given value is an array (returns the value wrapped in an array if it's not).
41
- *
42
- * @param {*} value
43
- * @returns {*[]}
44
- */
45
- var ARRAY = function ARRAY(value) {
46
- return IS_ARRAY(value) ? value : typeof value !== 'undefined' ? [value] : [];
47
- };
48
-
49
- /**
50
- * Returns true if the value is an object.
51
- *
52
- * @param {*} value
53
- * @returns {boolean}
54
- */
55
- var IS_OBJECT = function IS_OBJECT(value) {
56
- return _typeof(value) === 'object' && value !== null && !Array.isArray(value);
57
- };
58
-
59
- /**
60
- * Ensures the given value is an object (returns an empty object if it's not).
61
- *
62
- * @param value
63
- * @returns {Object}
64
- */
65
- var OBJECT = function OBJECT(value) {
66
- return IS_OBJECT(value) ? value : {};
67
- };
68
-
69
- /**
70
- * Ensures the given value is a string (casts it to a string if it's not, null and undefined will return an empty string).
71
- *
72
- * @param {*} value
73
- * @returns {string}
74
- */
75
- var STRING = function STRING(value) {
76
- return ISSET(value) ? '' + value : '';
77
- };
78
-
79
- /**
80
- * Returns the first non-null non-undefined value as a string.
81
- *
82
- * @param {*} values
83
- * @returns {string}
84
- */
85
- var STRING_ANY = function STRING_ANY() {
86
- for (var _len = arguments.length, values = new Array(_len), _key = 0; _key < _len; _key++) {
87
- values[_key] = arguments[_key];
88
- }
89
- for (var _i = 0, _values = values; _i < _values.length; _i++) {
90
- var value = _values[_i];
91
- if (ISSET(value)) {
92
- return '' + value;
93
- }
94
- }
95
- return '';
96
- };
97
-
98
- /**
99
- * Ensures the given value is a boolean.
100
- *
101
- * This will work differently than !!value, as it will try to figure out the most logical boolean value from the given value.
102
- *
103
- * @param {*} value
104
- * @returns {boolean}
105
- */
106
- var BOOL = function BOOL(value) {
107
- return BOOL_ANY(value);
108
- };
109
-
110
- /**
111
- * Returns the first non-null non-undefined boolean-castable value as a boolean.
112
- *
113
- * @param {*} values
114
- * @returns {boolean}
115
- */
116
- var BOOL_ANY = function BOOL_ANY() {
117
- for (var _len2 = arguments.length, values = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
118
- values[_key2] = arguments[_key2];
119
- }
120
- for (var _i2 = 0, _values2 = values; _i2 < _values2.length; _i2++) {
121
- var value = _values2[_i2];
122
- if (!ISSET(value)) {
123
- continue;
124
- }
125
- if (typeof value === 'boolean') {
126
- return value;
127
- }
128
- if (typeof value === 'number') {
129
- if (!isNaN(value)) {
130
- return value !== 0;
131
- }
132
- return false;
133
- }
134
- if (typeof value === 'string') {
135
- value = value.toLowerCase().trim();
136
- if (value === '' || value === 'false' || value === 'no' || value === 'off' || value === '0') {
137
- return false;
138
- }
139
- if (value === 'true' || value === 'yes' || value === 'on' || value === '1') {
140
- return true;
141
- }
142
- var _float = +value;
143
- if (!isNaN(_float)) {
144
- return _float !== 0;
145
- }
146
- // unrecognized string, let's try the next value, else we return false (after the loop)
147
- }
148
- if (IS_ARRAY(value) || IS_OBJECT(value)) {
149
- return !!value;
150
- }
151
- // unrecognized type, let's try the next value, else we return false (after the loop)
152
- }
153
- return false;
154
- };
155
-
156
- /**
157
- * Ensures the given value is an integer (attempts to cast it to an integer if it's not, null and undefined will return 0).
158
- *
159
- * @param {*} value
160
- * @returns {number}
161
- */
162
- var INT = function INT(value) {
163
- return Math.round(FLOAT(value));
164
- };
165
-
166
- /**
167
- * Returns the first non-null non-undefined int-castable value as an integer.
168
- *
169
- * @param {*} values
170
- * @returns {number}
171
- */
172
- var INT_ANY = function INT_ANY() {
173
- return Math.round(FLOAT_ANY.apply(void 0, arguments));
174
- };
175
-
176
- /**
177
- * Ensures the given value is a float (attempts to cast it to a float if it's not, null and undefined will return 0).
178
- *
179
- * @param {*} value
180
- * @returns {number}
181
- */
182
- var FLOAT = function FLOAT(value) {
183
- var v = +value;
184
- if (!isNaN(v)) {
185
- return v;
186
- }
187
- return 0;
188
- };
189
-
190
- /**
191
- * Returns the first non-null non-undefined float-castable value as a float.
192
- *
193
- * @param {*} values
194
- * @returns {number}
195
- */
196
- var FLOAT_ANY = function FLOAT_ANY() {
197
- for (var _len3 = arguments.length, values = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
198
- values[_key3] = arguments[_key3];
199
- }
200
- for (var _i3 = 0, _values3 = values; _i3 < _values3.length; _i3++) {
201
- var value = _values3[_i3];
202
- if (value !== null) {
203
- var v = +value;
204
- if (!isNaN(v)) {
205
- return v;
206
- }
207
- }
208
- }
209
- return 0;
210
- };
211
-
212
- /**
213
- * Ensures the given value is an integer (attempts to cast it to an integer if it's not, null and undefined will return 0).
214
- * This version is less strict than INT, as it relies on parseFloat instead of on +value, meaning that it will accept strings that contain a number followed by other characters, which +value doesn't.
215
- *
216
- * @param {*} value
217
- * @returns {number}
218
- */
219
- var INT_LAX = function INT_LAX(value) {
220
- return Math.round(FLOAT_LAX(value));
221
- };
222
-
223
- /**
224
- * Returns the first non-null non-undefined int-castable value as an integer.
225
- * This version is less strict than INT_ANY, as it relies on parseFloat instead of on +value, meaning that it will accept strings that contain a number followed by other characters, which +value doesn't.
226
- *
227
- * @param {*} values
228
- * @returns {number}
229
- */
230
- var INT_LAX_ANY = function INT_LAX_ANY() {
231
- return Math.round(FLOAT_LAX_ANY.apply(void 0, arguments));
232
- };
233
-
234
- /**
235
- * Ensures the given value is a float (attempts to cast it to a float if it's not, null and undefined will return 0).
236
- * This version is less strict than FLOAT, as it relies on parseFloat instead of on +value, meaning that it will accept strings that contain a number followed by other characters, which +value doesn't.
237
- *
238
- * @param {*} value
239
- * @returns {number}
240
- */
241
- var FLOAT_LAX = function FLOAT_LAX(value) {
242
- var v = typeof value === 'number' ? value : parseFloat((value + '').replace(REGEX_ALL_NON_FLOAT_CHARACTERS, ''));
243
- if (!isNaN(v)) {
244
- return v;
245
- }
246
- return 0;
247
- };
248
-
249
- /**
250
- * Returns the first non-null non-undefined float-castable value as a float.
251
- * This version is less strict than FLOAT_ANY, as it relies on parseFloat instead of on +value, meaning that it will accept strings that contain a number followed by other characters, which +value doesn't.
252
- *
253
- * @param {*} values
254
- * @returns {number}
255
- */
256
- var FLOAT_LAX_ANY = function FLOAT_LAX_ANY() {
257
- for (var _len4 = arguments.length, values = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
258
- values[_key4] = arguments[_key4];
259
- }
260
- for (var _i4 = 0, _values4 = values; _i4 < _values4.length; _i4++) {
261
- var value = _values4[_i4];
262
- if (value !== null) {
263
- var v = typeof value === 'number' ? value : parseFloat((value + '').replace(REGEX_ALL_NON_FLOAT_CHARACTERS, ''));
264
- if (!isNaN(v)) {
265
- return v;
266
- }
267
- }
268
- }
269
- return 0;
270
- };
271
-
272
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
273
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
274
- function _createForOfIteratorHelper$1(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray$1(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
275
- function _unsupportedIterableToArray$1(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray$1(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray$1(r, a) : void 0; } }
276
- function _arrayLikeToArray$1(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
277
-
278
- /**
279
- * @param {LeUtils_TransactionalValue} transactionalValue
280
- */
281
- var checkTransactionalValue = function checkTransactionalValue(transactionalValue) {
282
- if (!LeUtils.isTransactionalValueValid(transactionalValue)) {
283
- console.error('The given value is not a valid TransactionalValue:');
284
- console.error(transactionalValue);
285
- throw new Error('The given value is not a valid TransactionalValue');
286
- }
287
- };
288
-
289
- /**
290
- * @param {LeUtils_TransactionalValue} transactionalValue
291
- * @param {string} changeId
292
- * @returns {{index:number, value:*}|null}
293
- */
294
- var findTransactionalValueChange = function findTransactionalValueChange(transactionalValue, changeId) {
295
- for (var i = 0; i < transactionalValue.changes.length; i++) {
296
- var change = transactionalValue.changes[i];
297
- if (change.id === changeId) {
298
- return {
299
- index: i,
300
- value: change.value
301
- };
302
- }
303
- }
304
- return null;
305
- };
306
- var LeUtils = {
307
- /**
308
- * A deep equals implementation.
309
- *
310
- * @param {*} a The value to compare.
311
- * @param {*} b The other value to compare.
312
- * @returns {boolean} Returns true if the values are equivalent.
313
- */
314
- equals: function equals(a, b) {
315
- if (a === b) {
316
- return true;
317
- }
318
- if (a && b && _typeof(a) == 'object' && _typeof(b) == 'object') {
319
- if (a.constructor !== b.constructor) {
320
- return false;
321
- }
322
- if (Array.isArray(a)) {
323
- var _length = a.length;
324
- if (_length != b.length) {
325
- return false;
326
- }
327
- for (var i = _length; i-- !== 0;) {
328
- if (!LeUtils.equals(a[i], b[i])) {
329
- return false;
330
- }
331
- }
332
- return true;
333
- }
334
- if (a instanceof Map && b instanceof Map) {
335
- if (a.size !== b.size) {
336
- return false;
337
- }
338
- var _iterator = _createForOfIteratorHelper$1(a.entries()),
339
- _step;
340
- try {
341
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
342
- var _i = _step.value;
343
- if (!b.has(_i[0])) {
344
- return false;
345
- }
346
- }
347
- } catch (err) {
348
- _iterator.e(err);
349
- } finally {
350
- _iterator.f();
351
- }
352
- var _iterator2 = _createForOfIteratorHelper$1(a.entries()),
353
- _step2;
354
- try {
355
- for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
356
- var _i2 = _step2.value;
357
- if (!LeUtils.equals(_i2[1], b.get(_i2[0]))) {
358
- return false;
359
- }
360
- }
361
- } catch (err) {
362
- _iterator2.e(err);
363
- } finally {
364
- _iterator2.f();
365
- }
366
- return true;
367
- }
368
- if (a instanceof Set && b instanceof Set) {
369
- if (a.size !== b.size) {
370
- return false;
371
- }
372
- var _iterator3 = _createForOfIteratorHelper$1(a.entries()),
373
- _step3;
374
- try {
375
- for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
376
- var _i3 = _step3.value;
377
- if (!b.has(_i3[0])) {
378
- return false;
379
- }
380
- }
381
- } catch (err) {
382
- _iterator3.e(err);
383
- } finally {
384
- _iterator3.f();
385
- }
386
- return true;
387
- }
388
- if (ArrayBuffer.isView(a) && ArrayBuffer.isView(b)) {
389
- if ('length' in a && 'length' in b && typeof a.length === 'number' && typeof b.length === 'number') {
390
- if (a.length != b.length) {
391
- return false;
392
- }
393
- for (var _i4 = a.length; _i4-- !== 0;) {
394
- if (a[_i4] !== b[_i4]) {
395
- return false;
396
- }
397
- }
398
- return true;
399
- }
400
- if ('byteLength' in a && 'byteLength' in b && typeof a.byteLength === 'number' && typeof b.byteLength === 'number' && 'getUint8' in a && 'getUint8' in b && typeof a.getUint8 === 'function' && typeof b.getUint8 === 'function') {
401
- if (a.byteLength !== b.byteLength) {
402
- return false;
403
- }
404
- for (var _i5 = a.byteLength; _i5-- !== 0;) {
405
- if (a.getUint8(_i5) !== b.getUint8(_i5)) {
406
- return false;
407
- }
408
- }
409
- return true;
410
- }
411
- return false;
412
- }
413
- if (a.constructor === RegExp) {
414
- return a.source === b.source && a.flags === b.flags;
415
- }
416
- if (a.valueOf !== Object.prototype.valueOf) {
417
- return a.valueOf() === b.valueOf();
418
- }
419
- if (a.toString !== Object.prototype.toString) {
420
- return a.toString() === b.toString();
421
- }
422
- if (a.constructor && a.constructor !== Object && a.constructor !== Array && Object.getPrototypeOf(a) !== Object.prototype) {
423
- if (typeof a.equals === 'function') {
424
- return a.equals(b);
425
- }
426
- return false;
427
- }
428
- var keys = Object.keys(a);
429
- var length = keys.length;
430
- if (length !== Object.keys(b).length) {
431
- return false;
432
- }
433
- for (var _i6 = length; _i6-- !== 0;) {
434
- if (!Object.prototype.hasOwnProperty.call(b, keys[_i6])) {
435
- return false;
436
- }
437
- }
438
- for (var _i7 = length; _i7-- !== 0;) {
439
- var key = keys[_i7];
440
- if (key === '_owner' && a.$$typeof) {
441
- // React-specific: avoid traversing _owner, it contains circular references, and is not needed when comparing the actual element
442
- continue;
443
- }
444
- if (!LeUtils.equals(a[key], b[key])) {
445
- return false;
446
- }
447
- }
448
- return true;
449
- }
450
-
451
- // true if both are NaN, false otherwise
452
- return a !== a && b !== b;
453
- },
454
- /**
455
- * Performs a deep equality comparison between two collections (objects, maps, arrays, etc), sorting on the keys before comparing them.
456
- *
457
- * This is useful for comparing objects that have the same properties, but in a different order, and/or in a different collection type (like Maps vs Objects).
458
- *
459
- * @param {*} elementsA The elements to compare.
460
- * @param {*} elementsB The other elements to compare.
461
- * @param {string[]} [ignoreKeys=[]] An array of keys to ignore when comparing the elements. This is useful for ignoring properties that are not relevant for the comparison.
462
- * @return {boolean} Returns true if the given values are equivalent, ignoring the order of properties.
463
- */
464
- equalsMapLike: function () {
465
- var sortKeyValueArrays = function sortKeyValueArrays(pairA, pairB) {
466
- return LeUtils.compare(pairA[0], pairB[0]);
467
- };
468
- return function (elementsA, elementsB) {
469
- var ignoreKeys = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
470
- elementsA = LeUtils.mapToArray(elementsA, function (value, key) {
471
- return [key, value];
472
- }).sort(sortKeyValueArrays);
473
- elementsB = LeUtils.mapToArray(elementsB, function (value, key) {
474
- return [key, value];
475
- }).sort(sortKeyValueArrays);
476
- ignoreKeys = typeof ignoreKeys === 'string' ? ARRAY(ignoreKeys) : LeUtils.mapToArray(ignoreKeys);
477
- var indexA = 0;
478
- var indexB = 0;
479
- while (indexA < elementsA.length && indexB < elementsB.length) {
480
- var _elementsA$indexA = _slicedToArray(elementsA[indexA], 2),
481
- mapKey = _elementsA$indexA[0],
482
- mapValue = _elementsA$indexA[1];
483
- var _elementsB$indexB = _slicedToArray(elementsB[indexB], 2),
484
- ownMapKey = _elementsB$indexB[0],
485
- ownMapValue = _elementsB$indexB[1];
486
- var ignoreKeysIncludesMapKey = ignoreKeys.includes(mapKey);
487
- var ignoreKeysIncludesOwnMapKey = ignoreKeys.includes(ownMapKey);
488
- if (ignoreKeysIncludesMapKey) {
489
- indexA++;
490
- if (ignoreKeysIncludesOwnMapKey) {
491
- indexB++;
492
- }
493
- continue;
494
- } else if (ignoreKeysIncludesOwnMapKey) {
495
- indexB++;
496
- continue;
497
- }
498
- if (!LeUtils.equals(mapKey, ownMapKey) || !LeUtils.equals(mapValue, ownMapValue)) {
499
- return false;
500
- }
501
- indexA++;
502
- indexB++;
503
- }
504
- while (indexA < elementsA.length && ignoreKeys.includes(elementsA[indexA][0])) {
505
- indexA++;
506
- }
507
- if (indexA < elementsA.length) {
508
- return false;
509
- }
510
- while (indexB < elementsB.length && ignoreKeys.includes(elementsB[indexB][0])) {
511
- indexB++;
512
- }
513
- return indexB >= elementsB.length;
514
- };
515
- }(),
516
- /**
517
- * Returns a deep copy of the given value.
518
- *
519
- * @param {*} value
520
- * @returns {*}
521
- */
522
- clone: function clone(value) {
523
- return CloneDeep(value, true);
524
- },
525
- /**
526
- * Executes the given callback when the document is ready.
527
- *
528
- * @param {Function} callback
529
- * @returns {{remove:Function}}
530
- */
531
- onDomReady: function onDomReady(callback) {
532
- var _globalThis$document, _globalThis$document2;
533
- if (!(globalThis !== null && globalThis !== void 0 && globalThis.document) || !(globalThis !== null && globalThis !== void 0 && (_globalThis$document = globalThis.document) !== null && _globalThis$document !== void 0 && _globalThis$document.addEventListener) || !(globalThis !== null && globalThis !== void 0 && (_globalThis$document2 = globalThis.document) !== null && _globalThis$document2 !== void 0 && _globalThis$document2.removeEventListener)) {
534
- // no document, so we can't wait for it to be ready
535
- console.warn('LeUtils.onDomReady() was called, but there is no document available. This might happen if the code is executed in a non-browser environment.');
536
- return {
537
- remove: function remove() {}
538
- };
539
- }
540
- if (globalThis.document.readyState === 'interactive' || globalThis.document.readyState === 'complete') {
541
- return LeUtils.setTimeout(function () {
542
- return callback();
543
- }, 0);
544
- } else {
545
- var listening = true;
546
- var _callbackWrapper = function callbackWrapper() {
547
- if (listening) {
548
- listening = false;
549
- globalThis.document.removeEventListener('DOMContentLoaded', _callbackWrapper);
550
- callback();
551
- }
552
- };
553
- globalThis.document.addEventListener('DOMContentLoaded', _callbackWrapper);
554
- return {
555
- remove: function remove() {
556
- if (listening) {
557
- listening = false;
558
- globalThis.document.removeEventListener('DOMContentLoaded', _callbackWrapper);
559
- }
560
- }
561
- };
562
- }
563
- },
564
- /**
565
- * Parses the given version string, and returns an object with the major, minor, and patch numbers, as well as some comparison functions.
566
- *
567
- * Expects a version string such as:
568
- * - "1"
569
- * - "1.2"
570
- * - "1.2.3"
571
- * - "1.2.3 anything"
572
- * - "1.2.3-anything"
573
- *
574
- * @param {string|*} versionString
575
- * @returns {{major: (number), minor: (number), patch: (number), toString: (function(): string), equals: (function(string|*): boolean), smallerThan: (function(string|*): boolean), smallerThanOrEquals: (function(string|*): boolean), largerThan: (function(string|*): boolean), largerThanOrEquals: (function(string|*): boolean)}}
576
- */
577
- parseVersionString: function parseVersionString(versionString) {
578
- var _versionString, _versionString2, _versionString3;
579
- if (IS_OBJECT(versionString) && ISSET((_versionString = versionString) === null || _versionString === void 0 ? void 0 : _versionString.major) && ISSET((_versionString2 = versionString) === null || _versionString2 === void 0 ? void 0 : _versionString2.minor) && ISSET((_versionString3 = versionString) === null || _versionString3 === void 0 ? void 0 : _versionString3.patch)) {
580
- return versionString;
581
- }
582
- versionString = STRING(versionString).trim();
583
- var partsVersion = versionString.split(' ')[0].split('-')[0].split('.');
584
- var major = INT_LAX(partsVersion[0]);
585
- var minor = INT_LAX(partsVersion[1]);
586
- var patch = INT_LAX(partsVersion[2]);
587
- var THIS = {
588
- major: major,
589
- minor: minor,
590
- patch: patch,
591
- toString: function toString() {
592
- return major + '.' + minor + '.' + patch;
593
- },
594
- equals: function equals(otherVersion) {
595
- otherVersion = LeUtils.parseVersionString(otherVersion);
596
- return major === otherVersion.major && minor === otherVersion.minor && patch === otherVersion.patch;
597
- },
598
- largerThan: function largerThan(otherVersion) {
599
- otherVersion = LeUtils.parseVersionString(otherVersion);
600
- if (major > otherVersion.major) {
601
- return true;
602
- }
603
- if (major < otherVersion.major) {
604
- return false;
605
- }
606
- if (minor > otherVersion.minor) {
607
- return true;
608
- }
609
- if (minor < otherVersion.minor) {
610
- return false;
611
- }
612
- return patch > otherVersion.patch;
613
- },
614
- largerThanOrEquals: function largerThanOrEquals(otherVersion) {
615
- otherVersion = LeUtils.parseVersionString(otherVersion);
616
- if (major > otherVersion.major) {
617
- return true;
618
- }
619
- if (major < otherVersion.major) {
620
- return false;
621
- }
622
- if (minor > otherVersion.minor) {
623
- return true;
624
- }
625
- if (minor < otherVersion.minor) {
626
- return false;
627
- }
628
- return patch >= otherVersion.patch;
629
- },
630
- smallerThan: function smallerThan(otherVersion) {
631
- return !THIS.largerThanOrEquals(otherVersion);
632
- },
633
- smallerThanOrEquals: function smallerThanOrEquals(otherVersion) {
634
- return !THIS.largerThan(otherVersion);
635
- }
636
- };
637
- return THIS;
638
- },
639
- /**
640
- * Returns true if the array or object contains the given value.
641
- *
642
- * Values are compared by casting both of them to a string.
643
- *
644
- * @param {*[]|Object|Function} array
645
- * @param {*} value
646
- * @returns {boolean}
647
- */
648
- contains: function contains(array, value) {
649
- if (!array) {
650
- return false;
651
- }
652
- var result = false;
653
- value = STRING(value);
654
- LeUtils.each(array, function (val) {
655
- if (STRING(val) === value) {
656
- result = true;
657
- return false;
658
- }
659
- });
660
- return result;
661
- },
662
- /**
663
- * Returns true if the array or object contains the given value.
664
- *
665
- * Values are compared by casting both of them to a string, and then lowercasing them.
666
- *
667
- * @param {*[]|Object|Function} array
668
- * @param {*} value
669
- * @returns {boolean}
670
- */
671
- containsCaseInsensitive: function containsCaseInsensitive(array, value) {
672
- if (!array) {
673
- return false;
674
- }
675
- var result = false;
676
- value = STRING(value).toLowerCase();
677
- LeUtils.each(array, function (val) {
678
- if (STRING(val).toLowerCase() === value) {
679
- result = true;
680
- return false;
681
- }
682
- });
683
- return result;
684
- },
685
- /**
686
- * Returns true if the array or object contains all the given values.
687
- *
688
- * Values are compared by casting both of them to a string.
689
- *
690
- * @param {*[]|Object|Function} array
691
- * @param {*[]|Object|Function} values
692
- * @returns {boolean}
693
- */
694
- containsAll: function containsAll(array, values) {
695
- if (!array) {
696
- return false;
697
- }
698
- var result = true;
699
- LeUtils.each(values, function (value) {
700
- if (!LeUtils.contains(array, value)) {
701
- result = false;
702
- return false;
703
- }
704
- });
705
- return result;
706
- },
707
- /**
708
- * Returns true if the array or object contains all the given values.
709
- *
710
- * Values are compared by casting both of them to a string, and then lowercasing them.
711
- *
712
- * @param {*[]|Object|Function} array
713
- * @param {*[]|Object|Function} values
714
- * @returns {boolean}
715
- */
716
- containsAllCaseInsensitive: function containsAllCaseInsensitive(array, values) {
717
- if (!array) {
718
- return false;
719
- }
720
- var result = true;
721
- LeUtils.each(values, function (value) {
722
- if (!LeUtils.containsCaseInsensitive(array, value)) {
723
- result = false;
724
- return false;
725
- }
726
- });
727
- return result;
728
- },
729
- /**
730
- * Returns true if the array or object contains any of the given values.
731
- *
732
- * Values are compared by casting both of them to a string.
733
- *
734
- * @param {*[]|Object|Function} array
735
- * @param {*[]|Object|Function} values
736
- * @returns {boolean}
737
- */
738
- containsAny: function containsAny(array, values) {
739
- if (!array) {
740
- return false;
741
- }
742
- var result = false;
743
- LeUtils.each(values, function (value) {
744
- if (LeUtils.contains(array, value)) {
745
- result = true;
746
- return false;
747
- }
748
- });
749
- return result;
750
- },
751
- /**
752
- * Returns true if the array or object contains any of the given values.
753
- *
754
- * Values are compared by casting both of them to a string, and then lowercasing them.
755
- *
756
- * @param {*[]|Object|Function} array
757
- * @param {*[]|Object|Function} values
758
- * @returns {boolean}
759
- */
760
- containsAnyCaseInsensitive: function containsAnyCaseInsensitive(array, values) {
761
- if (!array) {
762
- return false;
763
- }
764
- var result = false;
765
- LeUtils.each(values, function (value) {
766
- if (LeUtils.containsCaseInsensitive(array, value)) {
767
- result = true;
768
- return false;
769
- }
770
- });
771
- return result;
772
- },
773
- /**
774
- * Returns true if the array or object contains none of the given values.
775
- *
776
- * Values are compared by casting both of them to a string.
777
- *
778
- * @param {*[]|Object|Function} array
779
- * @param {*[]|Object|Function} values
780
- * @returns {boolean}
781
- */
782
- containsNone: function containsNone(array, values) {
783
- if (!array) {
784
- return true;
785
- }
786
- var result = true;
787
- LeUtils.each(values, function (value) {
788
- if (LeUtils.contains(array, value)) {
789
- result = false;
790
- return false;
791
- }
792
- });
793
- return result;
794
- },
795
- /**
796
- * Returns true if the array or object contains none of the given values.
797
- *
798
- * Values are compared by casting both of them to a string, and then lowercasing them.
799
- *
800
- * @param {*[]|Object|Function} array
801
- * @param {*[]|Object|Function} values
802
- * @returns {boolean}
803
- */
804
- containsNoneCaseInsensitive: function containsNoneCaseInsensitive(array, values) {
805
- if (!array) {
806
- return true;
807
- }
808
- var result = true;
809
- LeUtils.each(values, function (value) {
810
- if (LeUtils.containsCaseInsensitive(array, value)) {
811
- result = false;
812
- return false;
813
- }
814
- });
815
- return result;
816
- },
817
- /**
818
- * Finds the first element in the given array or object that returns true from the callback, and returns an object with the index and value.
819
- *
820
- * @param {*[]|Object|Function} elements
821
- * @param {(value:*, index:*) => boolean|void} callback
822
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
823
- * @returns {{index:*, value:*}|null}
824
- */
825
- findIndexValue: function findIndexValue(elements, callback) {
826
- var optionalSkipHasOwnPropertyCheck = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
827
- var result = null;
828
- LeUtils.each(elements, function (value, index) {
829
- if (callback.call(elements[index], elements[index], index)) {
830
- result = {
831
- index: index,
832
- value: value
833
- };
834
- return false;
835
- }
836
- }, optionalSkipHasOwnPropertyCheck);
837
- return result;
838
- },
839
- /**
840
- * Finds the first element in the given array or object that returns true from the callback, and returns the index.
841
- *
842
- * @param {*[]|Object|Function} elements
843
- * @param {(value:*, index:*) => boolean|void} callback
844
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
845
- * @returns {*|null}
846
- */
847
- findIndex: function findIndex(elements, callback) {
848
- var _LeUtils$findIndexVal, _LeUtils$findIndexVal2;
849
- var optionalSkipHasOwnPropertyCheck = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
850
- return (_LeUtils$findIndexVal = (_LeUtils$findIndexVal2 = LeUtils.findIndexValue(elements, callback, optionalSkipHasOwnPropertyCheck)) === null || _LeUtils$findIndexVal2 === void 0 ? void 0 : _LeUtils$findIndexVal2.index) !== null && _LeUtils$findIndexVal !== void 0 ? _LeUtils$findIndexVal : null;
851
- },
852
- /**
853
- * Finds the first element in the given array or object that returns true from the callback, and returns the value.
854
- *
855
- * @param {*[]|Object|Function} elements
856
- * @param {(value:*, index:*) => boolean|void} callback
857
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
858
- * @returns {*|null}
859
- */
860
- find: function find(elements, callback) {
861
- var _LeUtils$findIndexVal3, _LeUtils$findIndexVal4;
862
- var optionalSkipHasOwnPropertyCheck = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
863
- return (_LeUtils$findIndexVal3 = (_LeUtils$findIndexVal4 = LeUtils.findIndexValue(elements, callback, optionalSkipHasOwnPropertyCheck)) === null || _LeUtils$findIndexVal4 === void 0 ? void 0 : _LeUtils$findIndexVal4.value) !== null && _LeUtils$findIndexVal3 !== void 0 ? _LeUtils$findIndexVal3 : null;
864
- },
865
- /**
866
- * Returns the value at the given index in the given elements.
867
- *
868
- * @param {*} elements
869
- * @param {*} index
870
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
871
- * @returns {*}
872
- */
873
- getValueAtIndex: function getValueAtIndex(elements, index) {
874
- var optionalSkipHasOwnPropertyCheck = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
875
- if (elements === null || typeof elements === 'undefined') {
876
- return undefined;
877
- }
878
- if (Array.isArray(elements)) {
879
- return elements[index];
880
- }
881
- if (_typeof(elements) === 'object' && (elements === null || elements === void 0 ? void 0 : elements.constructor) === Object) {
882
- if (optionalSkipHasOwnPropertyCheck === true || Object.prototype.hasOwnProperty.call(elements, index)) {
883
- return elements[index];
884
- }
885
- return undefined;
886
- }
887
- if (elements instanceof Map) {
888
- return elements.get(index);
889
- }
890
- if (elements instanceof Set) {
891
- return index;
892
- }
893
- if (typeof elements !== 'string') {
894
- if (ArrayBuffer.isView(elements) && !(elements instanceof DataView)) {
895
- return elements[index];
896
- }
897
- if (typeof (elements === null || elements === void 0 ? void 0 : elements[Symbol.iterator]) === 'function') {
898
- var i = 0;
899
- var _iterator4 = _createForOfIteratorHelper$1(elements),
900
- _step4;
901
- try {
902
- for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
903
- var value = _step4.value;
904
- if (i === index) {
905
- return value;
906
- }
907
- i++;
908
- }
909
- } catch (err) {
910
- _iterator4.e(err);
911
- } finally {
912
- _iterator4.f();
913
- }
914
- return undefined;
915
- }
916
- if (typeof (elements === null || elements === void 0 ? void 0 : elements.forEach) === 'function') {
917
- var result = undefined;
918
- var shouldContinue = true;
919
- elements.forEach(function (value, i) {
920
- if (shouldContinue) {
921
- if (i === index) {
922
- result = value;
923
- shouldContinue = false;
924
- }
925
- }
926
- });
927
- return result;
928
- }
929
- }
930
- if (_typeof(elements) === 'object' || typeof elements === 'function') {
931
- if (optionalSkipHasOwnPropertyCheck === true || Object.prototype.hasOwnProperty.call(elements, index)) {
932
- return elements[index];
933
- }
934
- return undefined;
935
- }
936
- return undefined;
937
- },
938
- /**
939
- * Checks if the given elements can be iterated over using LeUtils.each().
940
- *
941
- * @param {*} elements
942
- * @returns {boolean}
943
- */
944
- supportsEach: function supportsEach(elements) {
945
- if (elements === null || typeof elements === 'undefined' || typeof elements === 'string') {
946
- return false;
947
- }
948
- return !!(Array.isArray(elements) || _typeof(elements) === 'object' && (elements === null || elements === void 0 ? void 0 : elements.constructor) === Object || typeof (elements === null || elements === void 0 ? void 0 : elements[Symbol.iterator]) === 'function' || typeof (elements === null || elements === void 0 ? void 0 : elements.forEach) === 'function' || _typeof(elements) === 'object' || typeof elements === 'function');
949
- },
950
- /**
951
- * Returns an iterator that iterates over each element in the given array or object, yielding an array with the value and the index/key.
952
- *
953
- * @param {*} elements
954
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
955
- * @yields {[key:*, value:*]}
956
- */
957
- eachIterator: function eachIterator(elements) {
958
- var optionalSkipHasOwnPropertyCheck = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
959
- return /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
960
- var i, _i8, _iterator5, _step5, _step5$value, _i9, value, _iterator6, _step6, _value, _i0, _iterator7, _step7, _value2, buffer, _i1, _buffer, entry, _i10, _t, _t2, _t3, _t4, _t5, _t6, _t7;
961
- return _regeneratorRuntime.wrap(function (_context) {
962
- while (1) switch (_context.prev = _context.next) {
963
- case 0:
964
- if (!(elements === null || typeof elements === 'undefined')) {
965
- _context.next = 1;
966
- break;
967
- }
968
- return _context.abrupt("return");
969
- case 1:
970
- if (!Array.isArray(elements)) {
971
- _context.next = 5;
972
- break;
973
- }
974
- i = 0;
975
- case 2:
976
- if (!(i < elements.length)) {
977
- _context.next = 4;
978
- break;
979
- }
980
- _context.next = 3;
981
- return [elements[i], i];
982
- case 3:
983
- i++;
984
- _context.next = 2;
985
- break;
986
- case 4:
987
- return _context.abrupt("return");
988
- case 5:
989
- if (!(_typeof(elements) === 'object' && (elements === null || elements === void 0 ? void 0 : elements.constructor) === Object)) {
990
- _context.next = 9;
991
- break;
992
- }
993
- _t = _regeneratorRuntime.keys(elements);
994
- case 6:
995
- if ((_t2 = _t()).done) {
996
- _context.next = 8;
997
- break;
998
- }
999
- _i8 = _t2.value;
1000
- if (!(optionalSkipHasOwnPropertyCheck === true || Object.prototype.hasOwnProperty.call(elements, _i8))) {
1001
- _context.next = 7;
1002
- break;
1003
- }
1004
- _context.next = 7;
1005
- return [elements[_i8], _i8];
1006
- case 7:
1007
- _context.next = 6;
1008
- break;
1009
- case 8:
1010
- return _context.abrupt("return");
1011
- case 9:
1012
- if (!(elements instanceof Map)) {
1013
- _context.next = 17;
1014
- break;
1015
- }
1016
- _iterator5 = _createForOfIteratorHelper$1(elements);
1017
- _context.prev = 10;
1018
- _iterator5.s();
1019
- case 11:
1020
- if ((_step5 = _iterator5.n()).done) {
1021
- _context.next = 13;
1022
- break;
1023
- }
1024
- _step5$value = _slicedToArray(_step5.value, 2), _i9 = _step5$value[0], value = _step5$value[1];
1025
- _context.next = 12;
1026
- return [value, _i9];
1027
- case 12:
1028
- _context.next = 11;
1029
- break;
1030
- case 13:
1031
- _context.next = 15;
1032
- break;
1033
- case 14:
1034
- _context.prev = 14;
1035
- _t3 = _context["catch"](10);
1036
- _iterator5.e(_t3);
1037
- case 15:
1038
- _context.prev = 15;
1039
- _iterator5.f();
1040
- return _context.finish(15);
1041
- case 16:
1042
- return _context.abrupt("return");
1043
- case 17:
1044
- if (!(elements instanceof Set)) {
1045
- _context.next = 25;
1046
- break;
1047
- }
1048
- _iterator6 = _createForOfIteratorHelper$1(elements);
1049
- _context.prev = 18;
1050
- _iterator6.s();
1051
- case 19:
1052
- if ((_step6 = _iterator6.n()).done) {
1053
- _context.next = 21;
1054
- break;
1055
- }
1056
- _value = _step6.value;
1057
- _context.next = 20;
1058
- return [_value, _value];
1059
- case 20:
1060
- _context.next = 19;
1061
- break;
1062
- case 21:
1063
- _context.next = 23;
1064
- break;
1065
- case 22:
1066
- _context.prev = 22;
1067
- _t4 = _context["catch"](18);
1068
- _iterator6.e(_t4);
1069
- case 23:
1070
- _context.prev = 23;
1071
- _iterator6.f();
1072
- return _context.finish(23);
1073
- case 24:
1074
- return _context.abrupt("return");
1075
- case 25:
1076
- if (!(typeof elements !== 'string')) {
1077
- _context.next = 38;
1078
- break;
1079
- }
1080
- if (!(typeof (elements === null || elements === void 0 ? void 0 : elements[Symbol.iterator]) === 'function')) {
1081
- _context.next = 34;
1082
- break;
1083
- }
1084
- _i0 = 0;
1085
- _iterator7 = _createForOfIteratorHelper$1(elements);
1086
- _context.prev = 26;
1087
- _iterator7.s();
1088
- case 27:
1089
- if ((_step7 = _iterator7.n()).done) {
1090
- _context.next = 30;
1091
- break;
1092
- }
1093
- _value2 = _step7.value;
1094
- _context.next = 28;
1095
- return [_value2, _i0];
1096
- case 28:
1097
- _i0++;
1098
- case 29:
1099
- _context.next = 27;
1100
- break;
1101
- case 30:
1102
- _context.next = 32;
1103
- break;
1104
- case 31:
1105
- _context.prev = 31;
1106
- _t5 = _context["catch"](26);
1107
- _iterator7.e(_t5);
1108
- case 32:
1109
- _context.prev = 32;
1110
- _iterator7.f();
1111
- return _context.finish(32);
1112
- case 33:
1113
- return _context.abrupt("return");
1114
- case 34:
1115
- if (!(typeof (elements === null || elements === void 0 ? void 0 : elements.forEach) === 'function')) {
1116
- _context.next = 38;
1117
- break;
1118
- }
1119
- buffer = [];
1120
- elements.forEach(function (value, i) {
1121
- buffer.push([value, i]);
1122
- });
1123
- _i1 = 0, _buffer = buffer;
1124
- case 35:
1125
- if (!(_i1 < _buffer.length)) {
1126
- _context.next = 37;
1127
- break;
1128
- }
1129
- entry = _buffer[_i1];
1130
- _context.next = 36;
1131
- return entry;
1132
- case 36:
1133
- _i1++;
1134
- _context.next = 35;
1135
- break;
1136
- case 37:
1137
- return _context.abrupt("return");
1138
- case 38:
1139
- if (!(_typeof(elements) === 'object' || typeof elements === 'function')) {
1140
- _context.next = 42;
1141
- break;
1142
- }
1143
- _t6 = _regeneratorRuntime.keys(elements);
1144
- case 39:
1145
- if ((_t7 = _t6()).done) {
1146
- _context.next = 41;
1147
- break;
1148
- }
1149
- _i10 = _t7.value;
1150
- if (!(optionalSkipHasOwnPropertyCheck === true || Object.prototype.hasOwnProperty.call(elements, _i10))) {
1151
- _context.next = 40;
1152
- break;
1153
- }
1154
- _context.next = 40;
1155
- return [elements[_i10], _i10];
1156
- case 40:
1157
- _context.next = 39;
1158
- break;
1159
- case 41:
1160
- return _context.abrupt("return");
1161
- case 42:
1162
- console.warn('Executed LeUtils.eachIterator() on an invalid type: [' + _typeof(elements) + ']', elements);
1163
- case 43:
1164
- case "end":
1165
- return _context.stop();
1166
- }
1167
- }, _callee, null, [[10, 14, 15, 16], [18, 22, 23, 24], [26, 31, 32, 33]]);
1168
- })();
1169
- },
1170
- /**
1171
- * Loops through each element in the given array or object, and calls the callback for each element.
1172
- *
1173
- * @param {*} elements
1174
- * @param {(value:*, index?:*) => boolean|void} callback
1175
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
1176
- * @returns {*}
1177
- */
1178
- each: function each(elements, callback) {
1179
- var optionalSkipHasOwnPropertyCheck = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
1180
- var _iterator8 = _createForOfIteratorHelper$1(LeUtils.eachIterator(elements, optionalSkipHasOwnPropertyCheck)),
1181
- _step8;
1182
- try {
1183
- for (_iterator8.s(); !(_step8 = _iterator8.n()).done;) {
1184
- var _step8$value = _slicedToArray(_step8.value, 2),
1185
- value = _step8$value[0],
1186
- key = _step8$value[1];
1187
- if (callback.call(value, value, key) === false) {
1188
- break;
1189
- }
1190
- }
1191
- } catch (err) {
1192
- _iterator8.e(err);
1193
- } finally {
1194
- _iterator8.f();
1195
- }
1196
- return elements;
1197
- },
1198
- /**
1199
- * Like LeUtils.each(), except that it expects an async callback.
1200
- *
1201
- * @param {*} elements
1202
- * @param {(value:*, index?:*) => Promise<boolean|undefined>} asyncCallback
1203
- * @param {number} [optionalParallelCount]
1204
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
1205
- * @returns {Promise<*>}
1206
- */
1207
- eachAsync: function () {
1208
- /**
1209
- * Instead of waiting for every promise individually, this function will queue up multiple promises at once, then wait for any of them to finish, before adding more, until it has looped through all elements.
1210
- * Then, at the end, it will wait for the remaining promises to finish.
1211
- */
1212
- var eachAsyncParallel = /*#__PURE__*/function () {
1213
- var _ref2 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee4(elements, asyncCallback, optionalParallelCount, optionalSkipHasOwnPropertyCheck) {
1214
- var runningPromises, doBreak;
1215
- return _regeneratorRuntime.wrap(function (_context4) {
1216
- while (1) switch (_context4.prev = _context4.next) {
1217
- case 0:
1218
- runningPromises = new Set();
1219
- doBreak = false;
1220
- _context4.next = 1;
1221
- return LeUtils.eachAsync(elements, /*#__PURE__*/function () {
1222
- var _ref3 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee3(value, index) {
1223
- var promise;
1224
- return _regeneratorRuntime.wrap(function (_context3) {
1225
- while (1) switch (_context3.prev = _context3.next) {
1226
- case 0:
1227
- if (!doBreak) {
1228
- _context3.next = 1;
1229
- break;
1230
- }
1231
- return _context3.abrupt("return", false);
1232
- case 1:
1233
- if (!(runningPromises.size >= optionalParallelCount)) {
1234
- _context3.next = 4;
1235
- break;
1236
- }
1237
- _context3.next = 2;
1238
- return Promise.race(runningPromises);
1239
- case 2:
1240
- if (!doBreak) {
1241
- _context3.next = 3;
1242
- break;
1243
- }
1244
- return _context3.abrupt("return", false);
1245
- case 3:
1246
- _context3.next = 1;
1247
- break;
1248
- case 4:
1249
- // process this element, by creating a promise, and adding it to the queue
1250
- promise = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2() {
1251
- var _t8;
1252
- return _regeneratorRuntime.wrap(function (_context2) {
1253
- while (1) switch (_context2.prev = _context2.next) {
1254
- case 0:
1255
- _context2.next = 1;
1256
- return asyncCallback.call(value, value, index);
1257
- case 1:
1258
- _t8 = _context2.sent;
1259
- if (!(_t8 === false)) {
1260
- _context2.next = 2;
1261
- break;
1262
- }
1263
- doBreak = true;
1264
- case 2:
1265
- case "end":
1266
- return _context2.stop();
1267
- }
1268
- }, _callee2);
1269
- }))();
1270
- runningPromises.add(promise);
1271
- promise["finally"](function () {
1272
- runningPromises["delete"](promise);
1273
- });
1274
- case 5:
1275
- case "end":
1276
- return _context3.stop();
1277
- }
1278
- }, _callee3);
1279
- }));
1280
- return function (_x5, _x6) {
1281
- return _ref3.apply(this, arguments);
1282
- };
1283
- }(), 1, optionalSkipHasOwnPropertyCheck);
1284
- case 1:
1285
- _context4.next = 2;
1286
- return Promise.all(runningPromises);
1287
- case 2:
1288
- return _context4.abrupt("return", elements);
1289
- case 3:
1290
- case "end":
1291
- return _context4.stop();
1292
- }
1293
- }, _callee4);
1294
- }));
1295
- return function eachAsyncParallel(_x, _x2, _x3, _x4) {
1296
- return _ref2.apply(this, arguments);
1297
- };
1298
- }();
1299
- return /*#__PURE__*/function () {
1300
- var _ref5 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee5(elements, asyncCallback) {
1301
- var parallelCount,
1302
- optionalSkipHasOwnPropertyCheck,
1303
- _iterator9,
1304
- _step9,
1305
- _step9$value,
1306
- value,
1307
- key,
1308
- _args5 = arguments,
1309
- _t9,
1310
- _t0;
1311
- return _regeneratorRuntime.wrap(function (_context5) {
1312
- while (1) switch (_context5.prev = _context5.next) {
1313
- case 0:
1314
- parallelCount = _args5.length > 2 && _args5[2] !== undefined ? _args5[2] : 1;
1315
- optionalSkipHasOwnPropertyCheck = _args5.length > 3 && _args5[3] !== undefined ? _args5[3] : false;
1316
- if (!(elements !== null && typeof elements !== 'undefined')) {
1317
- _context5.next = 10;
1318
- break;
1319
- }
1320
- parallelCount = INT_LAX(parallelCount);
1321
- if (!(parallelCount > 1)) {
1322
- _context5.next = 2;
1323
- break;
1324
- }
1325
- _context5.next = 1;
1326
- return eachAsyncParallel(elements, asyncCallback, parallelCount, optionalSkipHasOwnPropertyCheck);
1327
- case 1:
1328
- return _context5.abrupt("return", _context5.sent);
1329
- case 2:
1330
- _iterator9 = _createForOfIteratorHelper$1(LeUtils.eachIterator(elements, optionalSkipHasOwnPropertyCheck));
1331
- _context5.prev = 3;
1332
- _iterator9.s();
1333
- case 4:
1334
- if ((_step9 = _iterator9.n()).done) {
1335
- _context5.next = 7;
1336
- break;
1337
- }
1338
- _step9$value = _slicedToArray(_step9.value, 2), value = _step9$value[0], key = _step9$value[1];
1339
- _context5.next = 5;
1340
- return asyncCallback.call(value, value, key);
1341
- case 5:
1342
- _t9 = _context5.sent;
1343
- if (!(_t9 === false)) {
1344
- _context5.next = 6;
1345
- break;
1346
- }
1347
- return _context5.abrupt("continue", 7);
1348
- case 6:
1349
- _context5.next = 4;
1350
- break;
1351
- case 7:
1352
- _context5.next = 9;
1353
- break;
1354
- case 8:
1355
- _context5.prev = 8;
1356
- _t0 = _context5["catch"](3);
1357
- _iterator9.e(_t0);
1358
- case 9:
1359
- _context5.prev = 9;
1360
- _iterator9.f();
1361
- return _context5.finish(9);
1362
- case 10:
1363
- return _context5.abrupt("return", elements);
1364
- case 11:
1365
- case "end":
1366
- return _context5.stop();
1367
- }
1368
- }, _callee5, null, [[3, 8, 9, 10]]);
1369
- }));
1370
- return function (_x7, _x8) {
1371
- return _ref5.apply(this, arguments);
1372
- };
1373
- }();
1374
- }(),
1375
- /**
1376
- * Returns an empty simplified collection (array, object, or Map), based on the given elements.
1377
- *
1378
- * Usage:
1379
- *
1380
- * ```js
1381
- * const [success, collection, add] = LeUtils.getEmptySimplifiedCollection(elements);
1382
- * ```
1383
- *
1384
- * @param {*} elements
1385
- * @returns {[boolean, *[]|Object|Map, (value:*,index:*)=>void]}
1386
- */
1387
- getEmptySimplifiedCollection: function getEmptySimplifiedCollection(elements) {
1388
- if (elements === null || typeof elements === 'undefined') {
1389
- return [false, [], function (value, index) {}];
1390
- }
1391
- var collection = null;
1392
- var add = null;
1393
- if (Array.isArray(elements)) {
1394
- collection = [];
1395
- add = function add(value, index) {
1396
- collection.push(value);
1397
- };
1398
- } else if (_typeof(elements) === 'object' && (elements === null || elements === void 0 ? void 0 : elements.constructor) === Object) {
1399
- collection = {};
1400
- add = function add(value, index) {
1401
- collection[index] = value;
1402
- };
1403
- } else if (elements instanceof Map) {
1404
- collection = new Map();
1405
- add = function add(value, index) {
1406
- collection.set(index, value);
1407
- };
1408
- } else if (typeof elements !== 'string' && (typeof (elements === null || elements === void 0 ? void 0 : elements[Symbol.iterator]) === 'function' || typeof (elements === null || elements === void 0 ? void 0 : elements.forEach) === 'function')) {
1409
- collection = [];
1410
- add = function add(value, index) {
1411
- collection.push(value);
1412
- };
1413
- } else if (_typeof(elements) === 'object' || typeof elements === 'function') {
1414
- collection = {};
1415
- add = function add(value, index) {
1416
- collection[index] = value;
1417
- };
1418
- } else {
1419
- console.warn('Executed LeUtils.getEmptySimplifiedCollection() on an invalid type: [' + _typeof(elements) + ']', elements);
1420
- return [false, [], function (value, index) {}];
1421
- }
1422
- return [true, collection, add];
1423
- },
1424
- /**
1425
- * Loops through the given elements, and returns a new collection, with only the elements that returned true (or a value equals to true) from the callback.
1426
- * If no callback is given, it will return all elements that are of a true value (for example, values that are: not null, not undefined, not false, not 0, not an empty string, not an empty array, not an empty object).
1427
- *
1428
- * @param {*} elements
1429
- * @param {(value:*, index:*) => boolean|undefined} [callback]
1430
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
1431
- * @returns {*}
1432
- */
1433
- filter: function filter(elements, callback) {
1434
- var optionalSkipHasOwnPropertyCheck = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
1435
- var _LeUtils$getEmptySimp = LeUtils.getEmptySimplifiedCollection(elements),
1436
- _LeUtils$getEmptySimp2 = _slicedToArray(_LeUtils$getEmptySimp, 3),
1437
- success = _LeUtils$getEmptySimp2[0],
1438
- collection = _LeUtils$getEmptySimp2[1],
1439
- add = _LeUtils$getEmptySimp2[2];
1440
- if (!success) {
1441
- return elements;
1442
- }
1443
- LeUtils.each(elements, function (value, index) {
1444
- if (!callback) {
1445
- if (value) {
1446
- add(value, index);
1447
- }
1448
- } else if (callback.call(value, value, index)) {
1449
- add(value, index);
1450
- }
1451
- }, optionalSkipHasOwnPropertyCheck);
1452
- return collection;
1453
- },
1454
- /**
1455
- * Loops through the given elements, and returns a new collection, with the elements that were returned from the callback.
1456
- *
1457
- * @param {*} elements
1458
- * @param {(value:*, index:*) => *} [callback]
1459
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
1460
- * @returns {*}
1461
- */
1462
- map: function map(elements, callback) {
1463
- var optionalSkipHasOwnPropertyCheck = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
1464
- var _LeUtils$getEmptySimp3 = LeUtils.getEmptySimplifiedCollection(elements),
1465
- _LeUtils$getEmptySimp4 = _slicedToArray(_LeUtils$getEmptySimp3, 3),
1466
- success = _LeUtils$getEmptySimp4[0],
1467
- collection = _LeUtils$getEmptySimp4[1],
1468
- add = _LeUtils$getEmptySimp4[2];
1469
- if (!success) {
1470
- return elements;
1471
- }
1472
- LeUtils.each(elements, function (value, index) {
1473
- if (!callback) {
1474
- add(value, index);
1475
- } else {
1476
- add(callback.call(value, value, index), index);
1477
- }
1478
- }, optionalSkipHasOwnPropertyCheck);
1479
- return collection;
1480
- },
1481
- /**
1482
- * Loops through the given elements, and returns a new array, with the elements that were returned from the callback. Always returns an array.
1483
- *
1484
- * @param {*} elements
1485
- * @param {(value:*, index:*) => *} [callback]
1486
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
1487
- * @returns {*[]}
1488
- */
1489
- mapToArray: function mapToArray(elements, callback) {
1490
- var optionalSkipHasOwnPropertyCheck = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
1491
- var result = [];
1492
- LeUtils.each(elements, function (value, index) {
1493
- if (!callback) {
1494
- result.push(value);
1495
- } else {
1496
- result.push(callback.call(value, value, index));
1497
- }
1498
- }, optionalSkipHasOwnPropertyCheck);
1499
- return result;
1500
- },
1501
- /**
1502
- * Loops through the given elements, and returns a new array, with the elements that were returned from the callback. The elements will be sorted by the result from the given comparator. Always returns an array.
1503
- *
1504
- * @param {*} elements
1505
- * @param {(valueA:*, valueB:*) => number} comparator
1506
- * @param {(value:*, index:*) => *} [callback]
1507
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
1508
- * @returns {*[]}
1509
- */
1510
- mapToArraySorted: function mapToArraySorted(elements, comparator, callback) {
1511
- var optionalSkipHasOwnPropertyCheck = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
1512
- var keys = LeUtils.sortKeys(elements, comparator, optionalSkipHasOwnPropertyCheck);
1513
- var result = [];
1514
- var _iterator0 = _createForOfIteratorHelper$1(keys),
1515
- _step0;
1516
- try {
1517
- for (_iterator0.s(); !(_step0 = _iterator0.n()).done;) {
1518
- var key = _step0.value;
1519
- var value = LeUtils.getValueAtIndex(elements, key, optionalSkipHasOwnPropertyCheck);
1520
- if (!callback) {
1521
- result.push(value);
1522
- } else {
1523
- result.push(callback.call(value, value, key));
1524
- }
1525
- }
1526
- } catch (err) {
1527
- _iterator0.e(err);
1528
- } finally {
1529
- _iterator0.f();
1530
- }
1531
- return result;
1532
- },
1533
- /**
1534
- * Loops through the given elements, and returns a new array, with the keys from the given elements, sorted by the result from the given comparator. Always returns an array.
1535
- *
1536
- * @param {*} elements
1537
- * @param {(valueA:*, valueB:*) => number} comparator
1538
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
1539
- * @returns {*[]}
1540
- */
1541
- sortKeys: function sortKeys(elements, comparator) {
1542
- var optionalSkipHasOwnPropertyCheck = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
1543
- var keys = [];
1544
- LeUtils.each(elements, function (value, index) {
1545
- keys.push(index);
1546
- }, optionalSkipHasOwnPropertyCheck);
1547
- keys.sort(function (a, b) {
1548
- return comparator(LeUtils.getValueAtIndex(elements, a, optionalSkipHasOwnPropertyCheck), LeUtils.getValueAtIndex(elements, b, optionalSkipHasOwnPropertyCheck));
1549
- });
1550
- return keys;
1551
- },
1552
- /**
1553
- * Turns the given value(s) into a 1 dimensional array.
1554
- *
1555
- * Does the same thing as Array.flat(Infinity).
1556
- *
1557
- * @param {*} array
1558
- * @returns {*[]}
1559
- */
1560
- flattenArray: function () {
1561
- var _flattenArrayRecursive = function flattenArrayRecursive(result, array) {
1562
- if (!Array.isArray(array)) {
1563
- result.push(array);
1564
- return;
1565
- }
1566
- array.forEach(function (entry) {
1567
- _flattenArrayRecursive(result, entry);
1568
- });
1569
- };
1570
- return function (array) {
1571
- if (!Array.isArray(array)) {
1572
- return [array];
1573
- }
1574
- var result = [];
1575
- array.forEach(function (entry) {
1576
- _flattenArrayRecursive(result, entry);
1577
- });
1578
- return result;
1579
- };
1580
- }(),
1581
- /**
1582
- * Turns the given value(s) into a 1 dimensional array.
1583
- *
1584
- * Compared to LeUtils.flattenArray(), this function also supports objects, Maps, Sets, and other iterable objects.
1585
- *
1586
- * @param {*} elements
1587
- * @param {boolean} [optionalSkipHasOwnPropertyCheck]
1588
- * @returns {*[]}
1589
- */
1590
- flattenToArray: function () {
1591
- var _flattenToArrayRecursive = function flattenToArrayRecursive(result, elements, optionalSkipHasOwnPropertyCheck) {
1592
- if (!LeUtils.supportsEach(elements)) {
1593
- result.push(elements);
1594
- return;
1595
- }
1596
- LeUtils.each(elements, function (entry) {
1597
- _flattenToArrayRecursive(result, entry, optionalSkipHasOwnPropertyCheck);
1598
- }, optionalSkipHasOwnPropertyCheck);
1599
- };
1600
- return function (elements) {
1601
- var optionalSkipHasOwnPropertyCheck = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
1602
- if (!LeUtils.supportsEach(elements)) {
1603
- return [elements];
1604
- }
1605
- var result = [];
1606
- LeUtils.each(elements, function (entry) {
1607
- _flattenToArrayRecursive(result, entry, optionalSkipHasOwnPropertyCheck);
1608
- }, optionalSkipHasOwnPropertyCheck);
1609
- return result;
1610
- };
1611
- }(),
1612
- /**
1613
- * Compares two values. Primarily used for sorting.
1614
- *
1615
- * @param {*} a
1616
- * @param {*} b
1617
- * @returns {number}
1618
- */
1619
- compare: function compare(a, b) {
1620
- return a < b ? -1 : a > b ? 1 : 0;
1621
- },
1622
- /**
1623
- * Compares two numbers. Primarily used for sorting.
1624
- *
1625
- * @param {number} a
1626
- * @param {number} b
1627
- * @returns {number}
1628
- */
1629
- compareNumbers: function compareNumbers(a, b) {
1630
- return a - b;
1631
- },
1632
- /**
1633
- * Compares two numeric strings. Primarily used for sorting.
1634
- *
1635
- * @param {string|number} a
1636
- * @param {string|number} b
1637
- * @returns {number}
1638
- */
1639
- compareNumericStrings: function compareNumericStrings(a, b) {
1640
- var aParts = STRING(a).split('.');
1641
- var bParts = STRING(b).split('.');
1642
- for (var i = 0; i < Math.min(aParts.length, bParts.length); i++) {
1643
- a = aParts[i].trim();
1644
- b = bParts[i].trim();
1645
- if (a.length !== b.length) {
1646
- return a.length < b.length ? -1 : 1;
1647
- }
1648
- if (a !== b) {
1649
- return a < b ? -1 : 1;
1650
- }
1651
- }
1652
- if (aParts.length !== bParts.length) {
1653
- return aParts.length < bParts.length ? -1 : 1;
1654
- }
1655
- return 0;
1656
- },
1657
- /**
1658
- * Compares two strings in a natural way, meaning that it will compare numbers in the strings as actual numbers.
1659
- *
1660
- * This will correctly sort numeric parts so that "file5.txt" comes before "file10.txt", as well as that "file/5/test.txt" comes before "file/10/test.txt".
1661
- *
1662
- * @param {string} a
1663
- * @param {string} b
1664
- * @returns {number}
1665
- */
1666
- compareNaturalStrings: function compareNaturalStrings(a, b) {
1667
- var _a$match, _b$match;
1668
- var re = /(\d+|\D+)/g; // split into runs of digits or non-digits
1669
- var aTokens = (_a$match = a.match(re)) !== null && _a$match !== void 0 ? _a$match : [];
1670
- var bTokens = (_b$match = b.match(re)) !== null && _b$match !== void 0 ? _b$match : [];
1671
- var len = Math.min(aTokens.length, bTokens.length);
1672
- for (var i = 0; i < len; i++) {
1673
- var x = aTokens[i];
1674
- var y = bTokens[i];
1675
- if (x === y) {
1676
- continue;
1677
- }
1678
-
1679
- // if both are numbers, compare as numbers
1680
- var nx = parseInt(x, 10);
1681
- var ny = parseInt(y, 10);
1682
- if (!isNaN(nx) && !isNaN(ny)) {
1683
- return nx - ny;
1684
- }
1685
-
1686
- // otherwise compare lexically
1687
- return x < y ? -1 : 1;
1688
- }
1689
- return aTokens.length - bTokens.length;
1690
- },
1691
- /**
1692
- * Compares two strings generated by LeUtils.timestamp(). Primarily used for sorting.
1693
- *
1694
- * @param {string} a
1695
- * @param {string} b
1696
- * @returns {number}
1697
- */
1698
- compareTimestampStrings: function compareTimestampStrings(a, b) {
1699
- a = LeUtils.base64ToHex(STRING(a).replaceAll('-', '+').replaceAll('_', '/'));
1700
- b = LeUtils.base64ToHex(STRING(b).replaceAll('-', '+').replaceAll('_', '/'));
1701
- return LeUtils.compare(a, b);
1702
- },
1703
- /**
1704
- * Returns true if the given object is empty, false otherwise.
1705
- *
1706
- * @param {Object} obj
1707
- * @param [optionalSkipHasOwnPropertyCheck]
1708
- * @returns {boolean}
1709
- */
1710
- isEmptyObject: function isEmptyObject(obj) {
1711
- var optionalSkipHasOwnPropertyCheck = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
1712
- for (var field in obj) {
1713
- if (optionalSkipHasOwnPropertyCheck === true || Object.prototype.hasOwnProperty.call(obj, field)) {
1714
- return false;
1715
- }
1716
- }
1717
- return true;
1718
- },
1719
- /**
1720
- * Returns the number of fields in the given object.
1721
- *
1722
- * @param {Object} obj
1723
- * @param [optionalSkipHasOwnPropertyCheck]
1724
- * @returns {number}
1725
- */
1726
- getObjectFieldsCount: function getObjectFieldsCount(obj) {
1727
- var optionalSkipHasOwnPropertyCheck = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
1728
- var count = 0;
1729
- for (var field in obj) {
1730
- if (optionalSkipHasOwnPropertyCheck === true || Object.prototype.hasOwnProperty.call(obj, field)) {
1731
- count++;
1732
- }
1733
- }
1734
- return count;
1735
- },
1736
- /**
1737
- * Returns true if the given function is a generator function (like: "function* (){}"), returns false otherwise.
1738
- *
1739
- * @param {Function} func
1740
- * @returns {boolean}
1741
- */
1742
- isGeneratorFunction: function () {
1743
- var GeneratorFunction = _regeneratorRuntime.mark(function _callee6() {
1744
- return _regeneratorRuntime.wrap(function (_context6) {
1745
- while (1) switch (_context6.prev = _context6.next) {
1746
- case 0:
1747
- case "end":
1748
- return _context6.stop();
1749
- }
1750
- }, _callee6);
1751
- }).constructor;
1752
- var AsyncGeneratorFunction = _wrapAsyncGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee7() {
1753
- return _regeneratorRuntime.wrap(function (_context7) {
1754
- while (1) switch (_context7.prev = _context7.next) {
1755
- case 0:
1756
- case "end":
1757
- return _context7.stop();
1758
- }
1759
- }, _callee7);
1760
- })).constructor;
1761
- var RegularFunction = function () {}.constructor;
1762
- var PossibleGeneratorFunctionNames = Array.from(new Set(['GeneratorFunction', 'AsyncFunction', 'AsyncGeneratorFunction', GeneratorFunction.name, AsyncGeneratorFunction.name])).filter(function (element) {
1763
- return element && element !== RegularFunction.name;
1764
- });
1765
- return function (func) {
1766
- if (!func) {
1767
- return false;
1768
- }
1769
- var constructor = func.constructor;
1770
- if (!constructor) {
1771
- return false;
1772
- }
1773
- // noinspection JSUnresolvedVariable
1774
- return constructor.name && PossibleGeneratorFunctionNames.includes(constructor.name) || constructor.displayName && PossibleGeneratorFunctionNames.includes(constructor.displayName);
1775
- };
1776
- }(),
1777
- /**
1778
- * Executes the callback after the given number of milliseconds. Passes the elapsed time in seconds to the callback.
1779
- *
1780
- * To cancel the timeout, call remove() on the result of this function (example: "const timeoutHandler = LeUtils.setTimeout((deltaTime)=>{}, 1000); timeoutHandler.remove();")
1781
- *
1782
- * @param {(deltaTime:number) => *} callback
1783
- * @param {number} ms
1784
- * @returns {{remove:Function}}
1785
- */
1786
- setTimeout: function setTimeout(callback, ms) {
1787
- var _globalThis$performan, _globalThis$performan2, _globalThis$performan3;
1788
- if (!(globalThis !== null && globalThis !== void 0 && globalThis.setTimeout) || !(globalThis !== null && globalThis !== void 0 && globalThis.clearTimeout)) {
1789
- console.warn('LeUtils.setTimeout() called in an environment without globalThis.setTimeout, returning a no-op handler.');
1790
- return {
1791
- remove: function remove() {}
1792
- };
1793
- }
1794
- ms = FLOAT_LAX(ms);
1795
- var lastTime = (_globalThis$performan = globalThis === null || globalThis === void 0 || (_globalThis$performan2 = globalThis.performance) === null || _globalThis$performan2 === void 0 || (_globalThis$performan3 = _globalThis$performan2.now) === null || _globalThis$performan3 === void 0 ? void 0 : _globalThis$performan3.call(_globalThis$performan2)) !== null && _globalThis$performan !== void 0 ? _globalThis$performan : 0;
1796
- /** @type {number|null} */
1797
- var handler = globalThis.setTimeout(function () {
1798
- var _globalThis$performan4, _globalThis$performan5, _globalThis$performan6;
1799
- var currentTime = (_globalThis$performan4 = globalThis === null || globalThis === void 0 || (_globalThis$performan5 = globalThis.performance) === null || _globalThis$performan5 === void 0 || (_globalThis$performan6 = _globalThis$performan5.now) === null || _globalThis$performan6 === void 0 ? void 0 : _globalThis$performan6.call(_globalThis$performan5)) !== null && _globalThis$performan4 !== void 0 ? _globalThis$performan4 : 0;
1800
- try {
1801
- callback((currentTime - lastTime) / 1000);
1802
- } catch (e) {
1803
- console.error(e);
1804
- }
1805
- lastTime = currentTime;
1806
- }, ms);
1807
- return {
1808
- remove: function remove() {
1809
- if (handler !== null) {
1810
- globalThis.clearTimeout(handler);
1811
- handler = null;
1812
- }
1813
- }
1814
- };
1815
- },
1816
- /**
1817
- * Executes the callback every given number of milliseconds. Passes the time difference in seconds between the last frame and now to it.
1818
- *
1819
- * To remove the interval, call remove() on the result of this function (example: "const intervalHandler = LeUtils.setInterval((deltaTime)=>{}, 1000); intervalHandler.remove();")
1820
- *
1821
- * @param {(deltaTime:number) => *} callback
1822
- * @param {number} [intervalMs]
1823
- * @param {boolean} [fireImmediately]
1824
- * @returns {{remove:Function}}
1825
- */
1826
- setInterval: function setInterval(callback) {
1827
- var _globalThis$performan7, _globalThis$performan8, _globalThis$performan9;
1828
- var intervalMs = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1000;
1829
- var fireImmediately = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
1830
- intervalMs = FLOAT_LAX_ANY(intervalMs, 1000);
1831
- if (fireImmediately) {
1832
- try {
1833
- callback(0);
1834
- } catch (e) {
1835
- console.error(e);
1836
- }
1837
- }
1838
- if (!(globalThis !== null && globalThis !== void 0 && globalThis.setInterval) || !(globalThis !== null && globalThis !== void 0 && globalThis.clearInterval)) {
1839
- console.warn('LeUtils.setInterval() called in an environment without globalThis.setInterval, returning a no-op handler.');
1840
- return {
1841
- remove: function remove() {}
1842
- };
1843
- }
1844
- var lastTime = (_globalThis$performan7 = globalThis === null || globalThis === void 0 || (_globalThis$performan8 = globalThis.performance) === null || _globalThis$performan8 === void 0 || (_globalThis$performan9 = _globalThis$performan8.now) === null || _globalThis$performan9 === void 0 ? void 0 : _globalThis$performan9.call(_globalThis$performan8)) !== null && _globalThis$performan7 !== void 0 ? _globalThis$performan7 : 0;
1845
- /** @type {number|null} */
1846
- var handler = globalThis.setInterval(function () {
1847
- var _globalThis$performan0, _globalThis$performan1, _globalThis$performan10;
1848
- var currentTime = (_globalThis$performan0 = globalThis === null || globalThis === void 0 || (_globalThis$performan1 = globalThis.performance) === null || _globalThis$performan1 === void 0 || (_globalThis$performan10 = _globalThis$performan1.now) === null || _globalThis$performan10 === void 0 ? void 0 : _globalThis$performan10.call(_globalThis$performan1)) !== null && _globalThis$performan0 !== void 0 ? _globalThis$performan0 : 0;
1849
- try {
1850
- callback((currentTime - lastTime) / 1000);
1851
- } catch (e) {
1852
- console.error(e);
1853
- }
1854
- lastTime = currentTime;
1855
- }, intervalMs);
1856
- return {
1857
- remove: function remove() {
1858
- if (handler !== null) {
1859
- globalThis.clearInterval(handler);
1860
- handler = null;
1861
- }
1862
- }
1863
- };
1864
- },
1865
- /**
1866
- * Executes the callback after the given number of frames. Passes the elapsed time in seconds to the callback.
1867
- *
1868
- * To cancel the timeout, call remove() on the result of this function (example: "const timeoutHandler = LeUtils.setAnimationFrameTimeout((deltaTime){}, 5); timeoutHandler.remove();")
1869
- *
1870
- * @param {(deltaTime:number) => *} callback
1871
- * @param {number} [frames]
1872
- * @returns {{remove:Function}}
1873
- */
1874
- setAnimationFrameTimeout: function setAnimationFrameTimeout(callback) {
1875
- var _globalThis$performan11, _globalThis$performan12, _globalThis$performan13;
1876
- var frames = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
1877
- if (!(globalThis !== null && globalThis !== void 0 && globalThis.requestAnimationFrame) || !(globalThis !== null && globalThis !== void 0 && globalThis.cancelAnimationFrame)) {
1878
- console.warn('LeUtils.setAnimationFrameTimeout() called in an environment without globalThis.requestAnimationFrame, returning a no-op handler.');
1879
- return {
1880
- remove: function remove() {}
1881
- };
1882
- }
1883
- frames = INT_LAX_ANY(frames, 1);
1884
- var run = true;
1885
- var requestAnimationFrameId = null;
1886
- var lastTime = (_globalThis$performan11 = globalThis === null || globalThis === void 0 || (_globalThis$performan12 = globalThis.performance) === null || _globalThis$performan12 === void 0 || (_globalThis$performan13 = _globalThis$performan12.now) === null || _globalThis$performan13 === void 0 ? void 0 : _globalThis$performan13.call(_globalThis$performan12)) !== null && _globalThis$performan11 !== void 0 ? _globalThis$performan11 : 0;
1887
- var _tick = function tick() {
1888
- if (run) {
1889
- if (frames <= 0) {
1890
- var _globalThis$performan14, _globalThis$performan15, _globalThis$performan16;
1891
- run = false;
1892
- requestAnimationFrameId = null;
1893
- var currentTime = (_globalThis$performan14 = globalThis === null || globalThis === void 0 || (_globalThis$performan15 = globalThis.performance) === null || _globalThis$performan15 === void 0 || (_globalThis$performan16 = _globalThis$performan15.now) === null || _globalThis$performan16 === void 0 ? void 0 : _globalThis$performan16.call(_globalThis$performan15)) !== null && _globalThis$performan14 !== void 0 ? _globalThis$performan14 : 0;
1894
- try {
1895
- callback((currentTime - lastTime) / 1000);
1896
- } catch (e) {
1897
- console.error(e);
1898
- }
1899
- lastTime = currentTime;
1900
- return;
1901
- }
1902
- frames--;
1903
- requestAnimationFrameId = globalThis.requestAnimationFrame(_tick);
1904
- }
1905
- };
1906
- _tick();
1907
- return {
1908
- remove: function remove() {
1909
- run = false;
1910
- if (requestAnimationFrameId !== null) {
1911
- globalThis.cancelAnimationFrame(requestAnimationFrameId);
1912
- requestAnimationFrameId = null;
1913
- }
1914
- }
1915
- };
1916
- },
1917
- /**
1918
- * Executes the callback every given number of frames. Passes the time difference in seconds between the last frame and now to it.
1919
- *
1920
- * To remove the interval, call remove() on the result of this function (example: "const intervalHandler = LeUtils.setAnimationFrameInterval((deltaTime)=>{}, 5); intervalHandler.remove();")
1921
- *
1922
- * @param {(deltaTime:number) => *} callback
1923
- * @param {number} [intervalFrames]
1924
- * @param {boolean} [fireImmediately]
1925
- * @returns {{remove:Function}}
1926
- */
1927
- setAnimationFrameInterval: function setAnimationFrameInterval(callback) {
1928
- var intervalFrames = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
1929
- var fireImmediately = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
1930
- intervalFrames = INT_LAX_ANY(intervalFrames, 1);
1931
- if (fireImmediately) {
1932
- try {
1933
- callback(0);
1934
- } catch (e) {
1935
- console.error(e);
1936
- }
1937
- }
1938
- if (!(globalThis !== null && globalThis !== void 0 && globalThis.requestAnimationFrame) || !(globalThis !== null && globalThis !== void 0 && globalThis.cancelAnimationFrame)) {
1939
- console.warn('LeUtils.setAnimationFrameInterval() called in an environment without globalThis.requestAnimationFrame, returning a no-op handler.');
1940
- return {
1941
- remove: function remove() {}
1942
- };
1943
- }
1944
- var run = true;
1945
- var requestAnimationFrameId = null;
1946
- var lastTimestamp = 0;
1947
- var totalTime = 0;
1948
- var frames = intervalFrames;
1949
- var _tick2 = function tick(timestamp) {
1950
- if (run) {
1951
- if (lastTimestamp === 0) {
1952
- lastTimestamp = timestamp;
1953
- }
1954
- totalTime += timestamp - lastTimestamp;
1955
- lastTimestamp = timestamp;
1956
- frames--;
1957
- if (frames <= 0) {
1958
- try {
1959
- callback(totalTime / 1000);
1960
- } catch (e) {
1961
- console.error(e);
1962
- }
1963
- totalTime = 0;
1964
- frames = intervalFrames;
1965
- }
1966
- if (run) {
1967
- requestAnimationFrameId = globalThis.requestAnimationFrame(_tick2);
1968
- }
1969
- }
1970
- };
1971
- globalThis.requestAnimationFrame(_tick2);
1972
- return {
1973
- remove: function remove() {
1974
- run = false;
1975
- if (requestAnimationFrameId !== null) {
1976
- globalThis.cancelAnimationFrame(requestAnimationFrameId);
1977
- requestAnimationFrameId = null;
1978
- }
1979
- }
1980
- };
1981
- },
1982
- /**
1983
- * Returns a promise, which will be resolved after the given number of milliseconds.
1984
- *
1985
- * @param {number} ms
1986
- * @returns {Promise<number>}
1987
- */
1988
- promiseTimeout: function promiseTimeout(ms) {
1989
- ms = FLOAT_LAX(ms);
1990
- if (ms <= 0) {
1991
- return new Promise(function (resolve) {
1992
- return resolve(0);
1993
- });
1994
- }
1995
- return new Promise(function (resolve) {
1996
- return LeUtils.setTimeout(resolve, ms);
1997
- });
1998
- },
1999
- /**
2000
- * Returns a promise, which will be resolved after the given number of frames.
2001
- *
2002
- * @param {number} frames
2003
- * @returns {Promise<number>}
2004
- */
2005
- promiseAnimationFrameTimeout: function promiseAnimationFrameTimeout(frames) {
2006
- frames = INT_LAX(frames);
2007
- if (frames <= 0) {
2008
- return new Promise(function (resolve) {
2009
- return resolve(0);
2010
- });
2011
- }
2012
- return new Promise(function (resolve) {
2013
- return LeUtils.setAnimationFrameTimeout(resolve, frames);
2014
- });
2015
- },
2016
- /**
2017
- * Allows you to do a fetch, with built-in retry and abort functionality.
2018
- *
2019
- * @param {string} url
2020
- * @param {{retries?:number|null, delay?:number|((attempt:number)=>number)|null}|Object|null} [options]
2021
- * @returns {{then:Function, catch:Function, finally:Function, remove:Function, isRemoved:Function}}
2022
- */
2023
- fetch: function (_fetch) {
2024
- function fetch(_x9, _x0) {
2025
- return _fetch.apply(this, arguments);
2026
- }
2027
- fetch.toString = function () {
2028
- return _fetch.toString();
2029
- };
2030
- return fetch;
2031
- }(function (url, options) {
2032
- var currentRetries = 0;
2033
- var retries = INT_LAX(options === null || options === void 0 ? void 0 : options.retries);
2034
- var controllerAborted = false;
2035
- var controller = null;
2036
- if (globalThis !== null && globalThis !== void 0 && globalThis.AbortController) {
2037
- controller = new AbortController();
2038
- }
2039
- var promise = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee9() {
2040
- var _attemptFetch;
2041
- return _regeneratorRuntime.wrap(function (_context9) {
2042
- while (1) switch (_context9.prev = _context9.next) {
2043
- case 0:
2044
- _attemptFetch = /*#__PURE__*/function () {
2045
- var _ref7 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee8() {
2046
- var _controller;
2047
- var _controller2, response, _controller3, _t1;
2048
- return _regeneratorRuntime.wrap(function (_context8) {
2049
- while (1) switch (_context8.prev = _context8.next) {
2050
- case 0:
2051
- if (!(controllerAborted || (_controller = controller) !== null && _controller !== void 0 && (_controller = _controller.signal) !== null && _controller !== void 0 && _controller.aborted)) {
2052
- _context8.next = 1;
2053
- break;
2054
- }
2055
- throw new Error('Aborted');
2056
- case 1:
2057
- _context8.prev = 1;
2058
- _context8.next = 2;
2059
- return fetch(url, _objectSpread(_objectSpread({
2060
- signal: (_controller2 = controller) === null || _controller2 === void 0 ? void 0 : _controller2.signal
2061
- }, options !== null && options !== void 0 ? options : {}), {}, {
2062
- retries: undefined,
2063
- delay: undefined
2064
- }));
2065
- case 2:
2066
- response = _context8.sent;
2067
- if (response.ok) {
2068
- _context8.next = 3;
2069
- break;
2070
- }
2071
- throw new Error('Network request failed: ' + response.status + ' ' + response.statusText);
2072
- case 3:
2073
- return _context8.abrupt("return", response);
2074
- case 4:
2075
- _context8.prev = 4;
2076
- _t1 = _context8["catch"](1);
2077
- if (!(controllerAborted || (_controller3 = controller) !== null && _controller3 !== void 0 && (_controller3 = _controller3.signal) !== null && _controller3 !== void 0 && _controller3.aborted)) {
2078
- _context8.next = 5;
2079
- break;
2080
- }
2081
- throw new Error('Aborted');
2082
- case 5:
2083
- if (!(currentRetries >= retries)) {
2084
- _context8.next = 6;
2085
- break;
2086
- }
2087
- throw _t1;
2088
- case 6:
2089
- currentRetries++;
2090
- _context8.next = 7;
2091
- return LeUtils.promiseTimeout(typeof (options === null || options === void 0 ? void 0 : options.delay) === 'function' ? INT_LAX_ANY(options === null || options === void 0 ? void 0 : options.delay(currentRetries), 500) : INT_LAX_ANY(options === null || options === void 0 ? void 0 : options.delay, 500));
2092
- case 7:
2093
- _context8.next = 8;
2094
- return _attemptFetch();
2095
- case 8:
2096
- return _context8.abrupt("return", _context8.sent);
2097
- case 9:
2098
- case "end":
2099
- return _context8.stop();
2100
- }
2101
- }, _callee8, null, [[1, 4]]);
2102
- }));
2103
- return function attemptFetch() {
2104
- return _ref7.apply(this, arguments);
2105
- };
2106
- }();
2107
- _context9.next = 1;
2108
- return _attemptFetch();
2109
- case 1:
2110
- return _context9.abrupt("return", _context9.sent);
2111
- case 2:
2112
- case "end":
2113
- return _context9.stop();
2114
- }
2115
- }, _callee9);
2116
- }))();
2117
- var result = {};
2118
- result.then = function () {
2119
- var _promise;
2120
- promise = (_promise = promise).then.apply(_promise, arguments);
2121
- return result;
2122
- };
2123
- result["catch"] = function () {
2124
- var _promise2;
2125
- promise = (_promise2 = promise)["catch"].apply(_promise2, arguments);
2126
- return result;
2127
- };
2128
- result["finally"] = function () {
2129
- var _promise3;
2130
- promise = (_promise3 = promise)["finally"].apply(_promise3, arguments);
2131
- return result;
2132
- };
2133
- result.remove = function () {
2134
- controllerAborted = true;
2135
- if (controller) {
2136
- var _controller4;
2137
- (_controller4 = controller).abort.apply(_controller4, arguments);
2138
- }
2139
- return result;
2140
- };
2141
- result.isRemoved = function () {
2142
- var _controller5;
2143
- return controllerAborted || !!((_controller5 = controller) !== null && _controller5 !== void 0 && (_controller5 = _controller5.signal) !== null && _controller5 !== void 0 && _controller5.aborted);
2144
- };
2145
- return result;
2146
- }),
2147
- /**
2148
- * Allows you to do a fetch, with built-in retry functionality. Caches on the requested URL, so that the same URL will not be fetched multiple times.
2149
- *
2150
- * @param {string} url
2151
- * @param {{retries?:number|null, delay?:number|((attempt:number)=>number)|null, [verify]:((data:*,response:*)=>void)|null}|null} [options]
2152
- * @param {((response:*)=>*)|null} [responseFunction] A function that will be called with the response object, and should return the data to be cached.
2153
- * @returns {Promise<*>}
2154
- */
2155
- cachedFetch: function () {
2156
- var cache = new Map();
2157
- return /*#__PURE__*/function () {
2158
- var _ref8 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee1(url, options, responseFunction) {
2159
- var result, promise;
2160
- return _regeneratorRuntime.wrap(function (_context1) {
2161
- while (1) switch (_context1.prev = _context1.next) {
2162
- case 0:
2163
- if (!cache.has(url)) {
2164
- _context1.next = 5;
2165
- break;
2166
- }
2167
- result = cache.get(url);
2168
- if (!result.data) {
2169
- _context1.next = 1;
2170
- break;
2171
- }
2172
- return _context1.abrupt("return", result.data);
2173
- case 1:
2174
- if (!result.promise) {
2175
- _context1.next = 3;
2176
- break;
2177
- }
2178
- _context1.next = 2;
2179
- return result.promise;
2180
- case 2:
2181
- return _context1.abrupt("return", _context1.sent);
2182
- case 3:
2183
- if (!result.error) {
2184
- _context1.next = 4;
2185
- break;
2186
- }
2187
- throw result.error;
2188
- case 4:
2189
- console.warn('Failed to use the cachedFetch cache, for URL: ', url, ', it is in an unexpected state: ', result);
2190
- return _context1.abrupt("return", null);
2191
- case 5:
2192
- promise = LeUtils.fetch(url, options).then(/*#__PURE__*/function () {
2193
- var _ref9 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee0(response) {
2194
- var data, _t10;
2195
- return _regeneratorRuntime.wrap(function (_context0) {
2196
- while (1) switch (_context0.prev = _context0.next) {
2197
- case 0:
2198
- if (!responseFunction) {
2199
- _context0.next = 2;
2200
- break;
2201
- }
2202
- _context0.next = 1;
2203
- return responseFunction(response);
2204
- case 1:
2205
- _t10 = _context0.sent;
2206
- _context0.next = 3;
2207
- break;
2208
- case 2:
2209
- _t10 = response;
2210
- case 3:
2211
- data = _t10;
2212
- if (!(typeof (options === null || options === void 0 ? void 0 : options.verify) === 'function')) {
2213
- _context0.next = 4;
2214
- break;
2215
- }
2216
- _context0.next = 4;
2217
- return options.verify(data, response);
2218
- case 4:
2219
- return _context0.abrupt("return", data);
2220
- case 5:
2221
- case "end":
2222
- return _context0.stop();
2223
- }
2224
- }, _callee0);
2225
- }));
2226
- return function (_x12) {
2227
- return _ref9.apply(this, arguments);
2228
- };
2229
- }()).then(function (data) {
2230
- cache.set(url, {
2231
- data: data
2232
- });
2233
- return data;
2234
- })["catch"](function (error) {
2235
- cache.set(url, {
2236
- error: error
2237
- });
2238
- console.error('Failed to fetch: ', error);
2239
- throw error;
2240
- });
2241
- if (!cache.has(url)) {
2242
- cache.set(url, {
2243
- promise: promise
2244
- });
2245
- }
2246
- _context1.next = 6;
2247
- return promise;
2248
- case 6:
2249
- return _context1.abrupt("return", _context1.sent);
2250
- case 7:
2251
- case "end":
2252
- return _context1.stop();
2253
- }
2254
- }, _callee1);
2255
- }));
2256
- return function (_x1, _x10, _x11) {
2257
- return _ref8.apply(this, arguments);
2258
- };
2259
- }();
2260
- }(),
2261
- /**
2262
- * Returns true if the user is on a smartphone device (mobile).
2263
- * Will return false if the user is on a tablet or on a desktop.
2264
- *
2265
- * In short:
2266
- * - Mobile: True
2267
- * - Tablet: False
2268
- * - Desktop: False
2269
- *
2270
- * @returns {boolean}
2271
- */
2272
- platformIsMobile: function platformIsMobile() {
2273
- var _globalThis$navigator, _globalThis$navigator2;
2274
- // noinspection JSDeprecatedSymbols, JSUnresolvedReference
2275
- /** navigator.userAgentData.mobile doesn't return the correct value on some platforms, so this is a work-around, code from: http://detectmobilebrowsers.com **/
2276
- var a = STRING((globalThis === null || globalThis === void 0 || (_globalThis$navigator = globalThis.navigator) === null || _globalThis$navigator === void 0 ? void 0 : _globalThis$navigator.userAgent) || (globalThis === null || globalThis === void 0 || (_globalThis$navigator2 = globalThis.navigator) === null || _globalThis$navigator2 === void 0 ? void 0 : _globalThis$navigator2.vendor) || (globalThis === null || globalThis === void 0 ? void 0 : globalThis.opera) || '');
2277
- var b = a.substring(0, 4);
2278
- return !!(/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series([46])0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(a) || /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br([ev])w|bumb|bw-([nu])|c55\/|capi|ccwa|cdm-|cell|chtm|cldc|cmd-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc-s|devi|dica|dmob|do([cp])o|ds(12|-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly([-_])|g1 u|g560|gene|gf-5|g-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd-([mpt])|hei-|hi(pt|ta)|hp( i|ip)|hs-c|ht(c([- _agpst])|tp)|hu(aw|tc)|i-(20|go|ma)|i230|iac([ \-/])|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja([tv])a|jbro|jemu|jigs|kddi|keji|kgt([ /])|klon|kpt |kwc-|kyo([ck])|le(no|xi)|lg( g|\/([klu])|50|54|-[a-w])|libw|lynx|m1-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t([- ov])|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30([02])|n50([025])|n7(0([01])|10)|ne(([cm])-|on|tf|wf|wg|wt)|nok([6i])|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan([adt])|pdxg|pg(13|-([1-8]|c))|phil|pire|pl(ay|uc)|pn-2|po(ck|rt|se)|prox|psio|pt-g|qa-a|qc(07|12|21|32|60|-[2-7]|i-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h-|oo|p-)|sdk\/|se(c([-01])|47|mc|nd|ri)|sgh-|shar|sie([-m])|sk-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h-|v-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl-|tdg-|tel([im])|tim-|t-mo|to(pl|sh)|ts(70|m-|m3|m5)|tx-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c([- ])|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas-|your|zeto|zte-/i.test(b));
2279
- },
2280
- /**
2281
- * Returns true if the user has a cursor (mouse, touchpad, etc).
2282
- * In this context, a cursor is defined as an input device that can hover over elements without necessarily interacting with them.
2283
- *
2284
- * @returns {boolean}
2285
- */
2286
- platformHasCursor: function platformHasCursor() {
2287
- var _globalThis$matchMedi;
2288
- return !LeUtils.platformIsMobile() && !(globalThis !== null && globalThis !== void 0 && (_globalThis$matchMedi = globalThis.matchMedia) !== null && _globalThis$matchMedi !== void 0 && (_globalThis$matchMedi = _globalThis$matchMedi.call(globalThis, '(any-hover: none)')) !== null && _globalThis$matchMedi !== void 0 && _globalThis$matchMedi.matches);
2289
- },
2290
- /**
2291
- * Returns the given string, with the first character capitalized.
2292
- *
2293
- * @param {String} string
2294
- * @returns {string}
2295
- */
2296
- capitalize: function capitalize(string) {
2297
- string = STRING(string).trim();
2298
- if (string.length <= 0) {
2299
- return string;
2300
- }
2301
- return string.charAt(0).toUpperCase() + string.slice(1);
2302
- },
2303
- /**
2304
- * Returns true if the given string ends with any of the given characters or words.
2305
- *
2306
- * @param {string} string
2307
- * @param {string|string[]} endingCharsStringOrArray
2308
- * @returns {boolean}
2309
- */
2310
- endsWithAny: function endsWithAny(string, endingCharsStringOrArray) {
2311
- string = STRING(string);
2312
- var endingCharsArray;
2313
- if (Array.isArray(endingCharsStringOrArray)) {
2314
- endingCharsArray = endingCharsStringOrArray;
2315
- } else {
2316
- endingCharsArray = STRING(endingCharsStringOrArray).split('');
2317
- }
2318
- var result = false;
2319
- LeUtils.each(endingCharsArray, function (chars) {
2320
- if (string.endsWith(STRING(chars))) {
2321
- result = true;
2322
- return false;
2323
- }
2324
- });
2325
- return result;
2326
- },
2327
- /**
2328
- * Returns true if the given string starts with any of the given characters or words.
2329
- *
2330
- * @param {string} string
2331
- * @param {string|string[]} startingCharsStringOrArray
2332
- * @returns {boolean}
2333
- */
2334
- startsWithAny: function startsWithAny(string, startingCharsStringOrArray) {
2335
- string = STRING(string);
2336
- var startingCharsArray;
2337
- if (Array.isArray(startingCharsStringOrArray)) {
2338
- startingCharsArray = startingCharsStringOrArray;
2339
- } else {
2340
- startingCharsArray = STRING(startingCharsStringOrArray).split('');
2341
- }
2342
- var result = false;
2343
- LeUtils.each(startingCharsArray, function (chars) {
2344
- if (string.startsWith(STRING(chars))) {
2345
- result = true;
2346
- return false;
2347
- }
2348
- });
2349
- return result;
2350
- },
2351
- /**
2352
- * Trims the end of the given string, by removing the given characters from it.
2353
- *
2354
- * @param {string} string
2355
- * @param {string|string[]} trimCharsStringOrArray
2356
- */
2357
- trimEnd: function trimEnd(string, trimCharsStringOrArray) {
2358
- string = STRING(string);
2359
- var endingCharsArray;
2360
- if (Array.isArray(trimCharsStringOrArray)) {
2361
- endingCharsArray = trimCharsStringOrArray;
2362
- } else {
2363
- endingCharsArray = STRING(trimCharsStringOrArray).split('');
2364
- }
2365
- var trimChars = function trimChars(chars) {
2366
- chars = STRING(chars);
2367
- if (string.endsWith(chars)) {
2368
- string = string.substring(0, string.length - chars.length);
2369
- run = true;
2370
- }
2371
- };
2372
- var run = true;
2373
- while (run) {
2374
- run = false;
2375
- LeUtils.each(endingCharsArray, trimChars);
2376
- }
2377
- return string;
2378
- },
2379
- /**
2380
- * Trims the start of the given string, by removing the given characters from it.
2381
- *
2382
- * @param {string} string
2383
- * @param {string|string[]} trimCharsStringOrArray
2384
- */
2385
- trimStart: function trimStart(string, trimCharsStringOrArray) {
2386
- string = STRING(string);
2387
- var startingCharsArray;
2388
- if (Array.isArray(trimCharsStringOrArray)) {
2389
- startingCharsArray = trimCharsStringOrArray;
2390
- } else {
2391
- startingCharsArray = STRING(trimCharsStringOrArray).split('');
2392
- }
2393
- var trimChars = function trimChars(chars) {
2394
- chars = STRING(chars);
2395
- if (string.startsWith(chars)) {
2396
- string = string.substring(chars.length);
2397
- run = true;
2398
- }
2399
- };
2400
- var run = true;
2401
- while (run) {
2402
- run = false;
2403
- LeUtils.each(startingCharsArray, trimChars);
2404
- }
2405
- return string;
2406
- },
2407
- /**
2408
- * Trims the start and end of the given string, by removing the given characters from it.
2409
- *
2410
- * @param {string} string
2411
- * @param {string|string[]} trimCharsStringOrArray
2412
- */
2413
- trim: function trim(string, trimCharsStringOrArray) {
2414
- return LeUtils.trimEnd(LeUtils.trimStart(string, trimCharsStringOrArray), trimCharsStringOrArray);
2415
- },
2416
- /**
2417
- * Returns the given string, trims the start and end, and makes sure it ends with a valid sentence ending character (such as !?;.).
2418
- *
2419
- * @param {string} sentence
2420
- * @returns {string}
2421
- */
2422
- purgeSentence: function purgeSentence(sentence) {
2423
- sentence = LeUtils.trimEnd(STRING(sentence).trim(), '.: \r\n\t');
2424
- sentence += LeUtils.endsWithAny(sentence, '!?;') ? '' : '.';
2425
- return sentence;
2426
- },
2427
- /**
2428
- * Attempts to obtain and return an error message from the given error, regardless of what is passed to this function.
2429
- *
2430
- * @param {*} error
2431
- * @returns {string}
2432
- */
2433
- purgeErrorMessage: function purgeErrorMessage(error) {
2434
- var _error;
2435
- if ((_error = error) !== null && _error !== void 0 && _error.message) {
2436
- error = error.message;
2437
- }
2438
- if (typeof error === 'string') {
2439
- var errorParts = error.split('threw an error:');
2440
- error = errorParts[errorParts.length - 1];
2441
- } else {
2442
- try {
2443
- error = JSON.stringify(error);
2444
- } catch (e) {
2445
- error = 'An unknown error occurred';
2446
- }
2447
- }
2448
- return error.trim();
2449
- },
2450
- /**
2451
- * Generates all permutations of the given names.
2452
- *
2453
- * For example, if you pass "foo" and "bar", it will return:
2454
- * - foobar
2455
- * - fooBar
2456
- * - FooBar
2457
- * - foo-bar
2458
- * - foo_bar
2459
- *
2460
- * @param {string[]} names
2461
- * @returns {string[]}
2462
- */
2463
- generateNamePermutations: function generateNamePermutations() {
2464
- for (var _len = arguments.length, names = new Array(_len), _key = 0; _key < _len; _key++) {
2465
- names[_key] = arguments[_key];
2466
- }
2467
- names = LeUtils.flattenToArray(names).map(function (name) {
2468
- return STRING(name).trim().toLowerCase();
2469
- }).filter(function (name) {
2470
- return name.length > 0;
2471
- });
2472
- var results = [];
2473
- if (names.length > 0) {
2474
- results.push(names.join('')); //foobar
2475
- results.push(names.map(LeUtils.capitalize).join('')); //FooBar
2476
- }
2477
- if (names.length > 1) {
2478
- results.push([names[0]].concat(names.slice(1).map(LeUtils.capitalize)).join('')); //fooBar
2479
- results.push(names.join('-')); //foo-bar
2480
- results.push(names.join('_')); //foo_bar
2481
- }
2482
- return results;
2483
- },
2484
- /**
2485
- * Increases the given numeric string by 1, this allows you to increase a numeric string without a limit.
2486
- *
2487
- * @param {string} string
2488
- * @returns {string}
2489
- */
2490
- increaseNumericStringByOne: function increaseNumericStringByOne(string) {
2491
- if (typeof string !== 'string') {
2492
- string = '' + string;
2493
- for (var i = string.length - 1; i >= 0; i--) {
2494
- var c = string.charAt(i);
2495
- if (c < '0' || c > '9') {
2496
- return '1';
2497
- }
2498
- }
2499
- }
2500
- if (string === '') {
2501
- return '1';
2502
- }
2503
- for (var _i11 = string.length - 1; _i11 >= 0; _i11--) {
2504
- var _c = string.charAt(_i11);
2505
- if (_c < '0' || _c > '9') {
2506
- return '1';
2507
- }
2508
- if (_c < '9') {
2509
- _c = String.fromCharCode(_c.charCodeAt(0) + 1);
2510
- string = string.substring(0, _i11) + _c + string.substring(_i11 + 1); // string[i] = (char + 1);
2511
- break;
2512
- }
2513
- string = string.substring(0, _i11) + '0' + string.substring(_i11 + 1); // string[i] = '0';
2514
- }
2515
- if (string.charAt(0) === '0') {
2516
- string = '1' + string;
2517
- }
2518
- return string;
2519
- },
2520
- /**
2521
- * Generates a base64 string (with +/ replaced by -_) that is guaranteed to be unique.
2522
- *
2523
- * @returns {string}
2524
- */
2525
- uniqueId: function () {
2526
- var previousUniqueIdsTime = null;
2527
- var previousUniqueIds = new Map();
2528
- var numberToBytes = function numberToBytes(number) {
2529
- var size = number === 0 ? 0 : Math.ceil((Math.floor(Math.log2(number)) + 1) / 8);
2530
- var bytes = new Uint8ClampedArray(size);
2531
- var x = number;
2532
- for (var i = size - 1; i >= 0; i--) {
2533
- var rightByte = x & 0xff;
2534
- bytes[i] = rightByte;
2535
- x = Math.floor(x / 0x100);
2536
- }
2537
- return bytes;
2538
- };
2539
- var generateUniqueId = function generateUniqueId() {
2540
- var now;
2541
- try {
2542
- var _globalThis$performan17, _globalThis$performan18, _globalThis$performan19, _globalThis$performan20, _globalThis$performan21;
2543
- // noinspection JSDeprecatedSymbols
2544
- now = ((globalThis === null || globalThis === void 0 || (_globalThis$performan17 = globalThis.performance) === null || _globalThis$performan17 === void 0 ? void 0 : _globalThis$performan17.timeOrigin) || (globalThis === null || globalThis === void 0 || (_globalThis$performan18 = globalThis.performance) === null || _globalThis$performan18 === void 0 || (_globalThis$performan18 = _globalThis$performan18.timing) === null || _globalThis$performan18 === void 0 ? void 0 : _globalThis$performan18.navigationStart) || 0) + ((_globalThis$performan19 = globalThis === null || globalThis === void 0 || (_globalThis$performan20 = globalThis.performance) === null || _globalThis$performan20 === void 0 || (_globalThis$performan21 = _globalThis$performan20.now) === null || _globalThis$performan21 === void 0 ? void 0 : _globalThis$performan21.call(_globalThis$performan20)) !== null && _globalThis$performan19 !== void 0 ? _globalThis$performan19 : 0);
2545
- } catch (e) {}
2546
- now = now || (Date.now ? Date.now() : new Date().getTime());
2547
- now = Math.round(now);
2548
- var nowBytes = numberToBytes(now);
2549
- var uuid = null;
2550
- try {
2551
- var _crypto;
2552
- uuid = (_crypto = crypto) === null || _crypto === void 0 ? void 0 : _crypto.randomUUID();
2553
- } catch (e) {}
2554
- if (uuid) {
2555
- uuid = LeUtils.base64ToBytes(LeUtils.hexToBase64(uuid));
2556
- } else {
2557
- var bytesChunkA = numberToBytes((Math.random() + ' ').substring(2, 12).padEnd(10, '0'));
2558
- var bytesChunkB = numberToBytes((Math.random() + ' ').substring(2, 12).padEnd(10, '0'));
2559
- var bytesChunkC = numberToBytes((Math.random() + ' ').substring(2, 12).padEnd(10, '0'));
2560
- var bytesChunkD = numberToBytes((Math.random() + ' ').substring(2, 12).padEnd(10, '0'));
2561
- uuid = new Uint8Array(bytesChunkA.length + bytesChunkB.length + bytesChunkC.length + bytesChunkD.length);
2562
- uuid.set(bytesChunkA, 0);
2563
- uuid.set(bytesChunkB, bytesChunkA.length);
2564
- uuid.set(bytesChunkC, bytesChunkA.length + bytesChunkB.length);
2565
- uuid.set(bytesChunkD, bytesChunkA.length + bytesChunkB.length + bytesChunkC.length);
2566
- }
2567
- var bytes = new Uint8Array(nowBytes.length + uuid.length);
2568
- bytes.set(nowBytes, 0);
2569
- bytes.set(uuid, nowBytes.length);
2570
- uuid = LeUtils.bytesToBase64(bytes).replaceAll('=', '').replaceAll('+', '-').replaceAll('/', '_');
2571
- return {
2572
- time: now,
2573
- id: uuid
2574
- };
2575
- };
2576
- return function () {
2577
- while (true) {
2578
- var result = generateUniqueId();
2579
- if (previousUniqueIdsTime !== result.time) {
2580
- previousUniqueIdsTime = result.time;
2581
- previousUniqueIds.clear();
2582
- previousUniqueIds.set(result.id, true);
2583
- return result.id;
2584
- } else if (previousUniqueIds.get(result.id) !== true) {
2585
- previousUniqueIds.set(result.id, true);
2586
- return result.id;
2587
- }
2588
- }
2589
- };
2590
- }(),
2591
- /**
2592
- * Generates a base64 string (with +/ replaced by -_) of the current time (in milliseconds since 1970).
2593
- *
2594
- * @param {number} [now] Optional time to use instead of the current time. If not set, the current time will be used.
2595
- * @returns {string}
2596
- */
2597
- timestamp: function () {
2598
- var numberToBytes = function numberToBytes(number) {
2599
- var size = number === 0 ? 0 : Math.ceil((Math.floor(Math.log2(number)) + 1) / 8);
2600
- var bytes = new Uint8ClampedArray(size);
2601
- var x = number;
2602
- for (var i = size - 1; i >= 0; i--) {
2603
- var rightByte = x & 0xff;
2604
- bytes[i] = rightByte;
2605
- x = Math.floor(x / 0x100);
2606
- }
2607
- return bytes;
2608
- };
2609
- return function () {
2610
- var now = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;
2611
- if (ISSET(now)) {
2612
- now = FLOAT_LAX(now);
2613
- } else {
2614
- try {
2615
- var _performance, _performance2, _performance$now, _performance3, _performance3$now;
2616
- // noinspection JSDeprecatedSymbols
2617
- now = (((_performance = performance) === null || _performance === void 0 ? void 0 : _performance.timeOrigin) || ((_performance2 = performance) === null || _performance2 === void 0 || (_performance2 = _performance2.timing) === null || _performance2 === void 0 ? void 0 : _performance2.navigationStart) || 0) + ((_performance$now = (_performance3 = performance) === null || _performance3 === void 0 || (_performance3$now = _performance3.now) === null || _performance3$now === void 0 ? void 0 : _performance3$now.call(_performance3)) !== null && _performance$now !== void 0 ? _performance$now : 0);
2618
- } catch (e) {}
2619
- now = now || (Date.now ? Date.now() : new Date().getTime());
2620
- }
2621
- now = Math.round(now);
2622
- var nowBytes = numberToBytes(now);
2623
- return LeUtils.bytesToBase64(nowBytes).replaceAll('=', '').replaceAll('+', '-').replaceAll('/', '_');
2624
- };
2625
- }(),
2626
- /**
2627
- * Returns a data URL of a 1x1 transparent pixel.
2628
- *
2629
- * @returns {string}
2630
- */
2631
- getEmptyImageSrc: function getEmptyImageSrc() {
2632
- // noinspection SpellCheckingInspection
2633
- return '';
2634
- },
2635
- /**
2636
- * Calculates and returns the percentage of the part and total ((part / total) * 100).
2637
- *
2638
- * @param {number|string} part
2639
- * @param {number|string} total
2640
- * @returns {number}
2641
- */
2642
- getPercentage: function getPercentage(part, total) {
2643
- part = FLOAT_LAX(part);
2644
- total = FLOAT_LAX(total);
2645
- if (total === 0) {
2646
- return 100;
2647
- }
2648
- return Math.max(0, Math.min(100, part / total * 100));
2649
- },
2650
- /**
2651
- * Returns the pixels of the given Image object.
2652
- *
2653
- * @param {HTMLImageElement} image
2654
- * @returns {Uint8ClampedArray}
2655
- */
2656
- getImagePixels: function getImagePixels(image) {
2657
- var _globalThis$document3, _globalThis$document4;
2658
- if (!(globalThis !== null && globalThis !== void 0 && (_globalThis$document3 = globalThis.document) !== null && _globalThis$document3 !== void 0 && _globalThis$document3.createElement) || !(globalThis !== null && globalThis !== void 0 && (_globalThis$document4 = globalThis.document) !== null && _globalThis$document4 !== void 0 && (_globalThis$document4 = _globalThis$document4.body) !== null && _globalThis$document4 !== void 0 && _globalThis$document4.appendChild)) {
2659
- console.warn('LeUtils.getImagePixels: Document is not available, returning empty pixels.');
2660
- return new Uint8ClampedArray();
2661
- }
2662
- var canvas = globalThis.document.createElement('canvas');
2663
- globalThis.document.body.appendChild(canvas);
2664
- try {
2665
- var ctx = canvas.getContext('2d');
2666
- var width = Math.floor(image.width);
2667
- var height = Math.floor(image.height);
2668
- if (!ctx || width <= 0 || height <= 0) {
2669
- return new Uint8ClampedArray();
2670
- }
2671
- canvas.width = width;
2672
- canvas.height = height;
2673
- ctx.drawImage(image, 0, 0, canvas.width, canvas.height);
2674
- return ctx.getImageData(0, 0, canvas.width, canvas.height).data;
2675
- } finally {
2676
- var _canvas$parentNode;
2677
- canvas === null || canvas === void 0 || (_canvas$parentNode = canvas.parentNode) === null || _canvas$parentNode === void 0 || _canvas$parentNode.removeChild(canvas);
2678
- }
2679
- },
2680
- /**
2681
- * Returns the data URL (mimetype "image/png") of a colored version of the given Image object.
2682
- *
2683
- * @param {HTMLImageElement} image
2684
- * @param {string} color
2685
- * @returns {string}
2686
- */
2687
- getColoredImage: function getColoredImage(image, color) {
2688
- var _globalThis$document5, _globalThis$document6;
2689
- if (!(globalThis !== null && globalThis !== void 0 && (_globalThis$document5 = globalThis.document) !== null && _globalThis$document5 !== void 0 && _globalThis$document5.createElement) || !(globalThis !== null && globalThis !== void 0 && (_globalThis$document6 = globalThis.document) !== null && _globalThis$document6 !== void 0 && (_globalThis$document6 = _globalThis$document6.body) !== null && _globalThis$document6 !== void 0 && _globalThis$document6.appendChild)) {
2690
- console.warn('LeUtils.getColoredImage: Document is not available, returning empty image src.');
2691
- return LeUtils.getEmptyImageSrc();
2692
- }
2693
- var canvas = globalThis.document.createElement('canvas');
2694
- globalThis.document.body.appendChild(canvas);
2695
- try {
2696
- var ctx = canvas.getContext('2d');
2697
- var width = Math.floor(image.width);
2698
- var height = Math.floor(image.height);
2699
- if (!ctx || width <= 0 || height <= 0) {
2700
- return LeUtils.getEmptyImageSrc();
2701
- }
2702
- canvas.width = width;
2703
- canvas.height = height;
2704
- ctx.drawImage(image, 0, 0, canvas.width, canvas.height);
2705
- ctx.globalCompositeOperation = 'source-in';
2706
- ctx.fillStyle = color;
2707
- ctx.fillRect(0, 0, canvas.width, canvas.height);
2708
- return canvas.toDataURL('image/png');
2709
- } finally {
2710
- var _canvas$parentNode2;
2711
- canvas === null || canvas === void 0 || (_canvas$parentNode2 = canvas.parentNode) === null || _canvas$parentNode2 === void 0 || _canvas$parentNode2.removeChild(canvas);
2712
- }
2713
- },
2714
- /**
2715
- * Returns the hex color of the given RGB(A).
2716
- *
2717
- * @param {number[]} rgb
2718
- * @returns {string}
2719
- */
2720
- rgbToHex: function rgbToHex(rgb) {
2721
- return '#' + rgb.map(function (x) {
2722
- var hex = x.toString(16);
2723
- return hex.length === 1 ? '0' + hex : hex;
2724
- }).join('');
2725
- },
2726
- /**
2727
- * Returns the RGB(A) of the given hex color.
2728
- *
2729
- * @param {string} hexstring
2730
- * @returns {number[]}
2731
- */
2732
- hexToRgb: function hexToRgb(hexstring) {
2733
- var _hexstring$match;
2734
- var initialHexstring = hexstring;
2735
- hexstring = hexstring.replace(/[^0-9A-F]/gi, '');
2736
- var hasAlpha = hexstring.length === 4 || hexstring.length === 8;
2737
- while (hexstring.length < 6) {
2738
- hexstring = hexstring.replace(/(.)/g, '$1$1');
2739
- }
2740
- var result = (_hexstring$match = hexstring.match(/\w{2}/g)) === null || _hexstring$match === void 0 ? void 0 : _hexstring$match.map(function (a) {
2741
- return parseInt(a, 16);
2742
- });
2743
- if (!result || result.length < 3) {
2744
- throw new Error('Invalid hex color: "' + hexstring + '" (was given "' + initialHexstring + '")');
2745
- }
2746
- return [result[0], result[1], result[2]].concat(_toConsumableArray(hasAlpha ? [result[3]] : []));
2747
- },
2748
- /**
2749
- * Returns the HSL(A) of the given RGB(A).
2750
- *
2751
- * @param {number[]} rgb
2752
- * @returns {number[]}
2753
- */
2754
- rgbToHsl: function rgbToHsl(rgb) {
2755
- var r = rgb[0] / 255;
2756
- var g = rgb[1] / 255;
2757
- var b = rgb[2] / 255;
2758
- var max = Math.max(r, g, b);
2759
- var min = Math.min(r, g, b);
2760
- var h = 0;
2761
- var s = 0;
2762
- var l = (max + min) / 2;
2763
- if (max !== min) {
2764
- var d = max - min;
2765
- s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
2766
- switch (max) {
2767
- case r:
2768
- h = (g - b) / d + (g < b ? 6 : 0);
2769
- break;
2770
- case g:
2771
- h = (b - r) / d + 2;
2772
- break;
2773
- case b:
2774
- h = (r - g) / d + 4;
2775
- break;
2776
- }
2777
- h /= 6;
2778
- }
2779
- return [h, s, l].concat(_toConsumableArray(rgb.length >= 4 ? [rgb[3] / 255] : []));
2780
- },
2781
- /**
2782
- * Returns the RGB(A) of the given HSL(A).
2783
- *
2784
- * @param {number[]} hsl
2785
- * @returns {number[]}
2786
- */
2787
- hslToRgb: function () {
2788
- var hue2rgb = function hue2rgb(p, q, t) {
2789
- if (t < 0) {
2790
- t += 1;
2791
- }
2792
- if (t > 1) {
2793
- t -= 1;
2794
- }
2795
- if (t < 1 / 6) {
2796
- return p + (q - p) * 6 * t;
2797
- }
2798
- if (t < 1 / 2) {
2799
- return q;
2800
- }
2801
- if (t < 2 / 3) {
2802
- return p + (q - p) * (2 / 3 - t) * 6;
2803
- }
2804
- return p;
2805
- };
2806
- return function (hsl) {
2807
- var h = hsl[0];
2808
- var s = hsl[1];
2809
- var l = hsl[2];
2810
- var r = 1;
2811
- var g = 1;
2812
- var b = 1;
2813
- if (s !== 0) {
2814
- var q = l < 0.5 ? l * (1 + s) : l + s - l * s;
2815
- var p = 2 * l - q;
2816
- r = hue2rgb(p, q, h + 1 / 3);
2817
- g = hue2rgb(p, q, h);
2818
- b = hue2rgb(p, q, h - 1 / 3);
2819
- }
2820
- return [r * 255, g * 255, b * 255].concat(_toConsumableArray(hsl.length >= 4 ? [hsl[3] * 255] : [])).map(function (c) {
2821
- return Math.max(0, Math.min(255, Math.round(c)));
2822
- });
2823
- };
2824
- }(),
2825
- /**
2826
- * Returns the LAB(A) of the given RGB(A).
2827
- *
2828
- * @param {number[]} rgb
2829
- * @returns {number[]}
2830
- */
2831
- rgbToLab: function rgbToLab(rgb) {
2832
- var r = rgb[0] / 255;
2833
- var g = rgb[1] / 255;
2834
- var b = rgb[2] / 255;
2835
- r = r > 0.04045 ? Math.pow((r + 0.055) / 1.055, 2.4) : r / 12.92;
2836
- g = g > 0.04045 ? Math.pow((g + 0.055) / 1.055, 2.4) : g / 12.92;
2837
- b = b > 0.04045 ? Math.pow((b + 0.055) / 1.055, 2.4) : b / 12.92;
2838
- var x = (r * 0.4124 + g * 0.3576 + b * 0.1805) / 0.95047;
2839
- var y = r * 0.2126 + g * 0.7152 + b * 0.0722;
2840
- var z = (r * 0.0193 + g * 0.1192 + b * 0.9505) / 1.08883;
2841
- x = x > 0.008856 ? Math.pow(x, 1 / 3) : 7.787 * x + 16 / 116;
2842
- y = y > 0.008856 ? Math.pow(y, 1 / 3) : 7.787 * y + 16 / 116;
2843
- z = z > 0.008856 ? Math.pow(z, 1 / 3) : 7.787 * z + 16 / 116;
2844
- return [116 * y - 16, 500 * (x - y), 200 * (y - z)].concat(_toConsumableArray(rgb.length >= 4 ? [rgb[3] / 255] : []));
2845
- },
2846
- /**
2847
- * Returns the difference (calculated with DeltaE) of the LAB values of the given RGB values.
2848
- *
2849
- * Returns a number:
2850
- *
2851
- * ```js
2852
- * < 1 is not perceptible by human eyes
2853
- * 1-2 is perceptible through close observation
2854
- * 2-10 is perceptible at a glance
2855
- * 11-49 is more similar than opposite
2856
- * 100 is exactly the opposite color
2857
- * ```
2858
- *
2859
- * @param {number[]} rgbA
2860
- * @param {number[]} rgbB
2861
- * @returns {number}
2862
- */
2863
- getDifferenceBetweenRgb: function getDifferenceBetweenRgb(rgbA, rgbB) {
2864
- var labA = LeUtils.rgbToLab(rgbA);
2865
- var labB = LeUtils.rgbToLab(rgbB);
2866
- return LeUtils.getDifferenceBetweenLab(labA, labB);
2867
- },
2868
- /**
2869
- * Returns the difference (calculated with DeltaE) of the given LAB values. Ignores the Alpha channel.
2870
- *
2871
- * Returns a number:
2872
- *
2873
- * ```js
2874
- * < 1 is not perceptible by human eyes
2875
- * 1-2 is perceptible through close observation
2876
- * 2-10 is perceptible at a glance
2877
- * 11-49 is more similar than opposite
2878
- * 100 is exactly the opposite color
2879
- * ```
2880
- *
2881
- * @param {number[]} labA
2882
- * @param {number[]} labB
2883
- * @returns {number}
2884
- */
2885
- getDifferenceBetweenLab: function getDifferenceBetweenLab(labA, labB) {
2886
- var deltaL = labA[0] - labB[0];
2887
- var deltaA = labA[1] - labB[1];
2888
- var deltaB = labA[2] - labB[2];
2889
- var c1 = Math.sqrt(labA[1] * labA[1] + labA[2] * labA[2]);
2890
- var c2 = Math.sqrt(labB[1] * labB[1] + labB[2] * labB[2]);
2891
- var deltaC = c1 - c2;
2892
- var deltaH = deltaA * deltaA + deltaB * deltaB - deltaC * deltaC;
2893
- deltaH = deltaH < 0 ? 0 : Math.sqrt(deltaH);
2894
- var sc = 1.0 + 0.045 * c1;
2895
- var sh = 1.0 + 0.015 * c1;
2896
- var deltaLKlsl = deltaL / 1.0;
2897
- var deltaCkcsc = deltaC / sc;
2898
- var deltaHkhsh = deltaH / sh;
2899
- var i = deltaLKlsl * deltaLKlsl + deltaCkcsc * deltaCkcsc + deltaHkhsh * deltaHkhsh;
2900
- return i < 0 ? 0 : Math.sqrt(i);
2901
- },
2902
- /**
2903
- * Returns the RGB(A) of the given RGB(A) values, based on the given percentage (0-100).
2904
- * This allows you to define a gradient of colors to fade in between, rather than just having a start and an end color.
2905
- *
2906
- * Usage:
2907
- *
2908
- * ```js
2909
- * LeUtils.getRgbOfGradient({
2910
- * 0: [255, 0, 0],
2911
- * 33: [255, 255, 0],
2912
- * 66: [0, 255, 0],
2913
- * 100:[0, 255, 255],
2914
- * }, 45.1234);
2915
- * ```
2916
- *
2917
- * @param {{percentage?:number[]}} gradient
2918
- * @param {number} percentage
2919
- * @returns {number[]}
2920
- */
2921
- getRgbOfGradient: function getRgbOfGradient(gradient, percentage) {
2922
- percentage = Math.max(0, Math.min(100, FLOAT_LAX(percentage)));
2923
- var closest = null;
2924
- LeUtils.each(gradient, function (color, percent) {
2925
- percent = INT_LAX(percent);
2926
- if (closest === null) {
2927
- closest = [percent, Math.abs(percentage - percent)];
2928
- } else {
2929
- var difference = Math.abs(percentage - percent);
2930
- if (difference < closest[1]) {
2931
- closest = [percent, difference];
2932
- }
2933
- }
2934
- });
2935
- if (closest === null) {
2936
- return [0, 0, 0];
2937
- }
2938
- closest = closest[0];
2939
- var HIGHER = 99999;
2940
- var LOWER = -99999;
2941
- var higher = HIGHER;
2942
- var lower = LOWER;
2943
- LeUtils.each(gradient, function (color, percent) {
2944
- percent = INT_LAX(percent);
2945
- if (percent < closest) {
2946
- if (percent > lower) {
2947
- lower = percent;
2948
- }
2949
- }
2950
- if (percent > closest) {
2951
- if (percent < higher) {
2952
- higher = percent;
2953
- }
2954
- }
2955
- });
2956
- if (higher === HIGHER && lower === LOWER || higher === lower) {
2957
- return gradient[closest];
2958
- } else if (higher !== HIGHER && lower !== LOWER) {
2959
- var higherDifference = Math.abs(higher - percentage);
2960
- var lowerDifference = Math.abs(percentage - lower);
2961
- if (higherDifference > lowerDifference) {
2962
- higher = closest;
2963
- } else {
2964
- lower = closest;
2965
- }
2966
- } else if (lower === LOWER) {
2967
- lower = closest;
2968
- } else {
2969
- higher = closest;
2970
- }
2971
- if (lower > higher) {
2972
- var tmp = higher;
2973
- higher = lower;
2974
- lower = tmp;
2975
- }
2976
- var total = higher - lower;
2977
- var part = percentage - lower;
2978
- return LeUtils.getRgbBetween(gradient[lower], gradient[higher], part / total * 100);
2979
- },
2980
- /**
2981
- * Returns the RGB(A) between the two given RGB(A) values, based on the given percentage (0-100).
2982
- *
2983
- * @param {number[]} startRgb
2984
- * @param {number[]} endRgb
2985
- * @param {number} percentage
2986
- * @returns {number[]}
2987
- */
2988
- getRgbBetween: function getRgbBetween(startRgb, endRgb, percentage) {
2989
- percentage = FLOAT_LAX(percentage);
2990
- var partEnd = Math.max(0, Math.min(1, percentage / 100.0));
2991
- var partStart = 1 - partEnd;
2992
- var length = Math.min(startRgb.length, endRgb.length);
2993
- var result = [];
2994
- for (var i = 0; i < length; i++) {
2995
- result.push(Math.max(0, Math.min(255, Math.round(startRgb[i] * partStart + endRgb[i] * partEnd))));
2996
- }
2997
- return result;
2998
- },
2999
- /**
3000
- * An implementation of the btoa function, which should work in all environments.
3001
- *
3002
- * @param {string} string
3003
- * @returns {string}
3004
- */
3005
- btoa: function btoa(string) {
3006
- var _globalThis$Buffer;
3007
- if (typeof (globalThis === null || globalThis === void 0 ? void 0 : globalThis.btoa) === 'function') {
3008
- return globalThis.btoa(string);
3009
- }
3010
- if (typeof (globalThis === null || globalThis === void 0 || (_globalThis$Buffer = globalThis.Buffer) === null || _globalThis$Buffer === void 0 ? void 0 : _globalThis$Buffer.from) === 'function') {
3011
- return globalThis.Buffer.from(string).toString('base64');
3012
- }
3013
- throw new Error('LeUtils.btoa: No btoa implementation found in this environment.');
3014
- },
3015
- /**
3016
- * An implementation of the atob function, which should work in all environments.
3017
- *
3018
- * @param {string} base64string
3019
- * @returns {string}
3020
- */
3021
- atob: function atob(base64string) {
3022
- var _globalThis$Buffer2;
3023
- if (typeof (globalThis === null || globalThis === void 0 ? void 0 : globalThis.atob) === 'function') {
3024
- return globalThis.atob(base64string);
3025
- }
3026
- if (typeof (globalThis === null || globalThis === void 0 || (_globalThis$Buffer2 = globalThis.Buffer) === null || _globalThis$Buffer2 === void 0 ? void 0 : _globalThis$Buffer2.from) === 'function') {
3027
- return globalThis.Buffer.from(base64string, 'base64').toString();
3028
- }
3029
- throw new Error('LeUtils.atob: No atob implementation found in this environment.');
3030
- },
3031
- /**
3032
- * Encodes a UTF-8 string into a base64 string.
3033
- *
3034
- * @param {string} string
3035
- * @returns {string}
3036
- */
3037
- utf8ToBase64: function utf8ToBase64(string) {
3038
- return LeUtils.btoa(encodeURIComponent(string).replace(/%([0-9A-F]{2})/g, function (match, p1) {
3039
- return String.fromCharCode(parseInt(p1, 16));
3040
- }));
3041
- },
3042
- /**
3043
- * Decodes a base64 string back into a UTF-8 string.
3044
- *
3045
- * @param {string} base64string
3046
- * @returns {string}
3047
- */
3048
- base64ToUtf8: function base64ToUtf8(base64string) {
3049
- return decodeURIComponent(LeUtils.atob(base64string.trim()).split('').map(function (c) {
3050
- return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);
3051
- }).join(''));
3052
- },
3053
- /**
3054
- * Converts a base64 string into a hex string.
3055
- *
3056
- * @param {string} base64string
3057
- * @returns {string}
3058
- */
3059
- base64ToHex: function base64ToHex(base64string) {
3060
- return LeUtils.atob(base64string.trim()).split('').map(function (c) {
3061
- return ('0' + c.charCodeAt(0).toString(16)).slice(-2);
3062
- }).join('');
3063
- },
3064
- /**
3065
- * Converts a hex string into a base64 string.
3066
- *
3067
- * @param {string} hexstring
3068
- * @returns {string}
3069
- */
3070
- hexToBase64: function hexToBase64(hexstring) {
3071
- var _hexstring$replace$ma;
3072
- var hexResult = (_hexstring$replace$ma = hexstring.replace(/[^0-9A-F]/gi, '').match(/\w{2}/g)) === null || _hexstring$replace$ma === void 0 || (_hexstring$replace$ma = _hexstring$replace$ma.map(function (a) {
3073
- return String.fromCharCode(parseInt(a, 16));
3074
- })) === null || _hexstring$replace$ma === void 0 ? void 0 : _hexstring$replace$ma.join('');
3075
- if (!hexResult) {
3076
- throw new Error('Invalid hex string: "' + hexstring + '"');
3077
- }
3078
- return LeUtils.btoa(hexResult);
3079
- },
3080
- /**
3081
- * Converts a base64 string into bytes (Uint8Array).
3082
- *
3083
- * @param {string} base64string
3084
- * @returns {Uint8Array}
3085
- */
3086
- base64ToBytes: function base64ToBytes(base64string) {
3087
- var binary = LeUtils.atob(base64string.trim());
3088
- var len = binary.length;
3089
- var data = new Uint8Array(len);
3090
- for (var i = 0; i < len; i++) {
3091
- data[i] = binary.charCodeAt(i);
3092
- }
3093
- return data;
3094
- },
3095
- /**
3096
- * Converts bytes into a base64 string.
3097
- *
3098
- * @param {ArrayLike<number>|ArrayBuffer} arraybuffer
3099
- * @returns {string}
3100
- */
3101
- bytesToBase64: function bytesToBase64(arraybuffer) {
3102
- var bytes = new Uint8Array(arraybuffer);
3103
- var len = bytes.byteLength;
3104
- var binary = '';
3105
- for (var i = 0; i < len; i++) {
3106
- binary += String.fromCharCode(bytes[i]);
3107
- }
3108
- return LeUtils.btoa(binary);
3109
- },
3110
- /**
3111
- * Downloads the given base64 string as a file.
3112
- *
3113
- * @param {string} base64string
3114
- * @param {string} [fileName]
3115
- * @param {string} [mimeType]
3116
- */
3117
- downloadFile: function downloadFile(base64string, fileName, mimeType) {
3118
- var _globalThis$document7;
3119
- if (!(globalThis !== null && globalThis !== void 0 && (_globalThis$document7 = globalThis.document) !== null && _globalThis$document7 !== void 0 && _globalThis$document7.createElement)) {
3120
- console.warn('LeUtils.downloadFile: Document is not available, cannot download file.');
3121
- return;
3122
- }
3123
- var link = globalThis.document.createElement('a');
3124
- link.setAttribute('download', typeof fileName === 'string' ? fileName : 'file');
3125
- link.href = 'data:' + mimeType + ';base64,' + base64string;
3126
- link.setAttribute('target', '_blank');
3127
- link.click();
3128
- },
3129
- /**
3130
- * Loads the value from the browser, returns undefined if the value doesn't exist.
3131
- *
3132
- * @param {string} id
3133
- * @returns {*}
3134
- */
3135
- localStorageGet: function localStorageGet(id) {
3136
- var _globalThis$localStor;
3137
- if (!(globalThis !== null && globalThis !== void 0 && (_globalThis$localStor = globalThis.localStorage) !== null && _globalThis$localStor !== void 0 && _globalThis$localStor.getItem)) {
3138
- console.warn('LeUtils.localStorageGet: LocalStorage is not available, returning undefined.');
3139
- return;
3140
- }
3141
- var result = globalThis.localStorage.getItem('LeUtils_' + id);
3142
- if (typeof result !== 'string') {
3143
- return;
3144
- }
3145
- try {
3146
- var _JSON$parse;
3147
- return (_JSON$parse = JSON.parse(result)) === null || _JSON$parse === void 0 ? void 0 : _JSON$parse['-'];
3148
- } catch (e) {}
3149
- },
3150
- /**
3151
- * Saves the given data in the browser.
3152
- *
3153
- * @param {string} id
3154
- * @param {*} data
3155
- */
3156
- localStorageSet: function localStorageSet(id, data) {
3157
- var _globalThis$localStor2;
3158
- if (!(globalThis !== null && globalThis !== void 0 && (_globalThis$localStor2 = globalThis.localStorage) !== null && _globalThis$localStor2 !== void 0 && _globalThis$localStor2.setItem)) {
3159
- console.warn('LeUtils.localStorageSet: LocalStorage is not available, cannot save data.');
3160
- return;
3161
- }
3162
- if (typeof data === 'undefined') {
3163
- globalThis.localStorage.removeItem('LeUtils_' + id);
3164
- return;
3165
- }
3166
- globalThis.localStorage.setItem('LeUtils_' + id, JSON.stringify({
3167
- '-': data
3168
- }));
3169
- },
3170
- /**
3171
- * Removes the data from the browser.
3172
- *
3173
- * @param {string} id
3174
- */
3175
- localStorageRemove: function localStorageRemove(id) {
3176
- var _globalThis$localStor3;
3177
- if (!(globalThis !== null && globalThis !== void 0 && (_globalThis$localStor3 = globalThis.localStorage) !== null && _globalThis$localStor3 !== void 0 && _globalThis$localStor3.removeItem)) {
3178
- console.warn('LeUtils.localStorageRemove: LocalStorage is not available, cannot remove data.');
3179
- return;
3180
- }
3181
- globalThis.localStorage.removeItem('LeUtils_' + id);
3182
- },
3183
- /**
3184
- * Returns whether the current hostname (globalThis.location.hostname) is private (such as localhost, 192.168.1.1, etc).
3185
- * This can be used to determine if the app is running in a development environment or not.
3186
- *
3187
- * Only "localhost" and IPv4 addresses are supported. IPv6 addresses will always return false.
3188
- *
3189
- * @returns {boolean}
3190
- */
3191
- isCurrentHostPrivate: function () {
3192
- var lastHostname = null;
3193
- var lastResult = false;
3194
- return function () {
3195
- var _globalThis$location;
3196
- if (!(globalThis !== null && globalThis !== void 0 && (_globalThis$location = globalThis.location) !== null && _globalThis$location !== void 0 && _globalThis$location.hostname)) {
3197
- console.warn('LeUtils.isCurrentHostPrivate: No location.hostname found, returning false.');
3198
- return false;
3199
- }
3200
- var hostname = globalThis.location.hostname;
3201
- if (lastHostname === hostname) {
3202
- return lastResult;
3203
- }
3204
- lastHostname = hostname;
3205
- lastResult = LeUtils.isGivenHostPrivate(lastHostname);
3206
- return lastResult;
3207
- };
3208
- }(),
3209
- /**
3210
- * Returns true if the given hostname is private (such as localhost, 192.168.1.1, etc).
3211
- *
3212
- * Only "localhost" and IPv4 addresses are supported. IPv6 addresses will always return false.
3213
- *
3214
- * @param {string} host
3215
- * @returns {boolean}
3216
- */
3217
- isGivenHostPrivate: function isGivenHostPrivate(host) {
3218
- host = STRING(host).trim();
3219
- if (!host) {
3220
- return false;
3221
- }
3222
- try {
3223
- host = new URL(host).hostname;
3224
- } catch (e) {
3225
- host = host.split(':')[0];
3226
- }
3227
- host = STRING(host).trim().toLowerCase();
3228
- if (host === 'localhost' || host === '127.0.0.1') {
3229
- return true;
3230
- }
3231
- if (!/^(\d{1,3}\.){3}\d{1,3}$/.test(host)) {
3232
- return false;
3233
- }
3234
- var parts = host.split('.');
3235
- return parts[0] === '10' ||
3236
- // 10.0.0.0 - 10.255.255.255
3237
- parts[0] === '172' && parseInt(parts[1], 10) >= 16 && parseInt(parts[1], 10) <= 31 ||
3238
- // 172.16.0.0 - 172.31.255.255
3239
- parts[0] === '192' && parts[1] === '168'; // 192.168.0.0 - 192.168.255.255
3240
- },
3241
- /**
3242
- * @typedef {Object} LeUtils_TransactionalValue
3243
- * @property {*} value
3244
- * @property {{id:string, value:*}[]} changes
3245
- */
3246
- /**
3247
- * Creates and returns a new TransactionalValue object.
3248
- * With a TransactionalValue, you can keep track of changes to a value, and commit or cancel them.
3249
- *
3250
- * Multiple uncommitted changes can be made at the same time, the last change will be the one that overwrites older changes.
3251
- * If that change is cancelled, the previous change will be the one that overwrites older changes.
3252
- * This allows you to make multiple unconfirmed changes, and confirm or cancel each of them individually at any time.
3253
- *
3254
- * @param {*} [value]
3255
- * @returns {LeUtils_TransactionalValue}
3256
- */
3257
- createTransactionalValue: function createTransactionalValue(value) {
3258
- if (typeof value === 'undefined') {
3259
- value = null;
3260
- }
3261
- return {
3262
- value: value,
3263
- changes: []
3264
- };
3265
- },
3266
- /**
3267
- * Returns true if the given value is a valid TransactionalValue, returns false if it isn't.
3268
- *
3269
- * @param {LeUtils_TransactionalValue} transactionalValue
3270
- * @returns {boolean}
3271
- */
3272
- isTransactionalValueValid: function isTransactionalValueValid(transactionalValue) {
3273
- return _typeof(transactionalValue) === 'object' && 'value' in transactionalValue && 'changes' in transactionalValue && Array.isArray(transactionalValue.changes);
3274
- },
3275
- /**
3276
- * Returns true if the given value is a TransactionalValue, false otherwise.
3277
- *
3278
- * @param {LeUtils_TransactionalValue} transactionalValue
3279
- * @returns {string}
3280
- */
3281
- transactionalValueToString: function transactionalValueToString(transactionalValue) {
3282
- if (!LeUtils.isTransactionalValueValid(transactionalValue)) {
3283
- return transactionalValue + '';
3284
- }
3285
- if (transactionalValue.changes.length <= 0) {
3286
- return '' + transactionalValue.value;
3287
- }
3288
- var valuesString = '' + transactionalValue.value;
3289
- for (var i = 0; i < transactionalValue.changes.length; i++) {
3290
- valuesString += ' -> ' + transactionalValue.changes[i].value;
3291
- }
3292
- return transactionalValue.changes[transactionalValue.changes.length - 1].value + ' (' + valuesString + ')';
3293
- },
3294
- /**
3295
- * Sets the committed value of the given TransactionalValue to the given value. Clears out the previously uncommitted changes.
3296
- *
3297
- * @param {LeUtils_TransactionalValue} transactionalValue
3298
- * @param {*} value
3299
- */
3300
- transactionSetAndCommit: function transactionSetAndCommit(transactionalValue, value) {
3301
- checkTransactionalValue(transactionalValue);
3302
- if (typeof value === 'undefined') {
3303
- value = null;
3304
- }
3305
- transactionalValue.value = value;
3306
- transactionalValue.changes = [];
3307
- },
3308
- /**
3309
- * Sets the value of the given TransactionalValue to the given value, without yet committing it, meaning it can be committed or cancelled later.
3310
- * It returns the ID of the change, which can be used to commit or cancel the change later.
3311
- *
3312
- * @param {LeUtils_TransactionalValue} transactionalValue
3313
- * @param {*} value
3314
- * @returns {string}
3315
- */
3316
- transactionSetWithoutCommitting: function transactionSetWithoutCommitting(transactionalValue, value) {
3317
- checkTransactionalValue(transactionalValue);
3318
- if (typeof value === 'undefined') {
3319
- value = null;
3320
- }
3321
- var id = LeUtils.uniqueId();
3322
- transactionalValue.changes.push({
3323
- id: id,
3324
- value: value
3325
- });
3326
- return id;
3327
- },
3328
- /**
3329
- * Commits the change with the given ID, making it the new committed value.
3330
- * Returns true if the change was found and committed, returns false if it was already overwritten by a newer committed change.
3331
- *
3332
- * @param {LeUtils_TransactionalValue} transactionalValue
3333
- * @param {string} changeId
3334
- * @returns {boolean}
3335
- */
3336
- transactionCommitChange: function transactionCommitChange(transactionalValue, changeId) {
3337
- checkTransactionalValue(transactionalValue);
3338
- var change = findTransactionalValueChange(transactionalValue, changeId);
3339
- if (change === null) {
3340
- return false;
3341
- }
3342
- transactionalValue.value = change.value;
3343
- transactionalValue.changes.splice(0, change.index + 1);
3344
- return true;
3345
- },
3346
- /**
3347
- * Cancels the change with the given ID, removing it from the uncommitted changes.
3348
- * Returns true if the change was found and removed, returns false if it was already overwritten by a newer committed change.
3349
- *
3350
- * @param {LeUtils_TransactionalValue} transactionalValue
3351
- * @param {string} changeId
3352
- * @returns {boolean}
3353
- */
3354
- transactionCancelChange: function transactionCancelChange(transactionalValue, changeId) {
3355
- checkTransactionalValue(transactionalValue);
3356
- var change = findTransactionalValueChange(transactionalValue, changeId);
3357
- if (change === null) {
3358
- return false;
3359
- }
3360
- transactionalValue.changes.splice(change.index, 1);
3361
- return true;
3362
- },
3363
- /**
3364
- * Returns true if the change was found, meaning it can still make a difference to the final committed value of this TransactionalValue.
3365
- * Returns false if it was already overwritten by a newer committed change, meaning that this change can no longer make a difference to the final committed value of this TransactionalValue.
3366
- *
3367
- * @param {LeUtils_TransactionalValue} transactionalValue
3368
- * @param {string} changeId
3369
- * @returns {boolean}
3370
- */
3371
- transactionIsChangeRelevant: function transactionIsChangeRelevant(transactionalValue, changeId) {
3372
- checkTransactionalValue(transactionalValue);
3373
- return findTransactionalValueChange(transactionalValue, changeId) !== null;
3374
- },
3375
- /**
3376
- * Returns the committed value of the given TransactionalValue.
3377
- *
3378
- * @param {LeUtils_TransactionalValue} transactionalValue
3379
- * @returns {*}
3380
- */
3381
- transactionGetCommittedValue: function transactionGetCommittedValue(transactionalValue) {
3382
- checkTransactionalValue(transactionalValue);
3383
- return transactionalValue.value;
3384
- },
3385
- /**
3386
- * Returns the value (including any uncommitted changes made to it) of the given TransactionalValue.
3387
- *
3388
- * @param {LeUtils_TransactionalValue} transactionalValue
3389
- * @returns {*}
3390
- */
3391
- transactionGetValue: function transactionGetValue(transactionalValue) {
3392
- checkTransactionalValue(transactionalValue);
3393
- if (transactionalValue.changes.length <= 0) {
3394
- return transactionalValue.value;
3395
- }
3396
- return transactionalValue.changes[transactionalValue.changes.length - 1].value;
3397
- },
3398
- /**
3399
- * Creates a worker thread. Workers have to be stored at /workers/{workerName}.worker.js for this to work.
3400
- *
3401
- * Example of a worker file:
3402
- *
3403
- * ```js
3404
- * onmessage = (message) =>
3405
- * {
3406
- * postMessage({
3407
- * ...message.data,
3408
- * results: ['...some expensive calculation involving message.data...'],
3409
- * });
3410
- * };
3411
- * ```
3412
- *
3413
- * Usage:
3414
- *
3415
- * ```js
3416
- * const {results} = await (async () =>
3417
- * {
3418
- * try
3419
- * {
3420
- * return await LeUtils.sendWorkerMessage('my-worker', {someData:[1, 2, 3, 4, 5]});
3421
- * }
3422
- * catch(error)
3423
- * {
3424
- * console.error('MyWorker: ', error);
3425
- * return {results:[]};
3426
- * }
3427
- * })();
3428
- * ```
3429
- *
3430
- * or, if you want more control over the number of threads you have (the above example will only create 1 thread per worker):
3431
- *
3432
- * ```js
3433
- * const myWorker1 = LeUtils.createWorkerThread('my-worker'); // creates a thread, you can create multiple worker threads of the same worker, to run multiple instances in parallel
3434
- * const myWorker2 = LeUtils.createWorkerThread('my-worker'); // same worker, another thread
3435
- * const {results} = await (async () =>
3436
- * {
3437
- * try
3438
- * {
3439
- * return await myWorker1.sendMessage({someData:[1, 2, 3, 4, 5]});
3440
- * }
3441
- * catch(error)
3442
- * {
3443
- * console.error('MyWorker: ', error);
3444
- * return {results:[]};
3445
- * }
3446
- * })();
3447
- * ```
3448
- *
3449
- * @param {string} name
3450
- * @returns {{worker:Worker|null, sendMessage:(data:Object,options:{timeout:number|undefined}|undefined)=>Promise<Object>}}
3451
- */
3452
- createWorkerThread: function createWorkerThread(name) {
3453
- if (!(globalThis !== null && globalThis !== void 0 && globalThis.Worker)) {
3454
- console.warn('LeUtils.createWorkerThread: Workers are not supported in this environment, returning a dummy worker.');
3455
- return {
3456
- worker: null,
3457
- sendMessage: function sendMessage(data, options) {
3458
- return new Promise(function (resolve, reject) {
3459
- reject('Workers are not supported in this environment');
3460
- });
3461
- }
3462
- };
3463
- }
3464
- var worker = new globalThis.Worker('/workers/' + name + '.worker.js');
3465
- var listeners = new Map();
3466
- var addListener = function addListener(id, callback) {
3467
- listeners.set(id, callback);
3468
- };
3469
- var removeListener = function removeListener(id) {
3470
- listeners["delete"](id);
3471
- };
3472
- var sendMessage = function sendMessage(data, options) {
3473
- return new Promise(function (resolve, reject) {
3474
- var _options$timeout;
3475
- var id = LeUtils.uniqueId();
3476
- addListener(id, resolve);
3477
- setTimeout(function () {
3478
- removeListener(id);
3479
- reject('timeout');
3480
- }, (_options$timeout = options === null || options === void 0 ? void 0 : options.timeout) !== null && _options$timeout !== void 0 ? _options$timeout : 10000);
3481
- worker.postMessage(_objectSpread({
3482
- id: id
3483
- }, data));
3484
- });
3485
- };
3486
- worker.onerror = function (error) {
3487
- console.error('Worker ' + name + ':', error);
3488
- };
3489
- worker.onmessage = function (message) {
3490
- var data = message.data;
3491
- if (data !== null && data !== void 0 && data.id) {
3492
- var callback = listeners.get(data.id);
3493
- if (callback) {
3494
- removeListener(data.id);
3495
- callback(data);
3496
- }
3497
- }
3498
- };
3499
- return {
3500
- worker: worker,
3501
- sendMessage: sendMessage
3502
- };
3503
- },
3504
- /**
3505
- * Sends a message to the given worker. Creates a worker thread for this worker if it doesn't exist yet.
3506
- *
3507
- * See {@link LeUtils#createWorkerThread} for more info on how to use workers.
3508
- *
3509
- * @param {string} workerName
3510
- * @param {Object} data
3511
- * @param {{timeout:number|undefined}} [options]
3512
- * @returns {Promise<Object>}
3513
- */
3514
- sendWorkerMessage: function () {
3515
- var workers = new Map();
3516
- return function (workerName, data, options) {
3517
- if (!workers.has(workerName)) {
3518
- workers.set(workerName, LeUtils.createWorkerThread(workerName));
3519
- }
3520
- return workers.get(workerName).sendMessage(data, options);
3521
- };
3522
- }(),
3523
- /**
3524
- * Purges the given email address, returning an empty string if it's invalid.
3525
- *
3526
- * @param {string} email
3527
- * @returns {string}
3528
- */
3529
- purgeEmail: function purgeEmail(email) {
3530
- email = STRING(email).trim().toLowerCase().replace(/\s/g, '');
3531
- if (!email.includes('@') || !email.includes('.')) {
3532
- return '';
3533
- }
3534
- return email;
3535
- },
3536
- /**
3537
- * Returns true if the focus is effectively clear, meaning that the user is not typing in an input field.
3538
- *
3539
- * @returns {boolean}
3540
- */
3541
- isFocusClear: function () {
3542
- var inputTypes = ['text', 'search', 'email', 'number', 'password', 'tel', 'time', 'url', 'week', 'month', 'date', 'datetime-local'];
3543
- return function () {
3544
- var _globalThis$document8, _globalThis$document$, _globalThis$document9;
3545
- return !((globalThis === null || globalThis === void 0 || (_globalThis$document8 = globalThis.document) === null || _globalThis$document8 === void 0 || (_globalThis$document8 = _globalThis$document8.activeElement) === null || _globalThis$document8 === void 0 || (_globalThis$document8 = _globalThis$document8.tagName) === null || _globalThis$document8 === void 0 ? void 0 : _globalThis$document8.toLowerCase()) === 'input' && inputTypes.includes((_globalThis$document$ = globalThis === null || globalThis === void 0 || (_globalThis$document9 = globalThis.document) === null || _globalThis$document9 === void 0 || (_globalThis$document9 = _globalThis$document9.activeElement) === null || _globalThis$document9 === void 0 || (_globalThis$document9 = _globalThis$document9.getAttribute('type')) === null || _globalThis$document9 === void 0 ? void 0 : _globalThis$document9.toLowerCase()) !== null && _globalThis$document$ !== void 0 ? _globalThis$document$ : ''));
3546
- };
3547
- }(),
3548
- /**
3549
- * Returns the user's locale. Returns 'en-US' if it can't be determined.
3550
- *
3551
- * @returns {string}
3552
- */
3553
- getUserLocale: function () {
3554
- var userLocale = null;
3555
- return function () {
3556
- if (userLocale === null) {
3557
- userLocale = function (_globalThis$navigator3, _globalThis$navigator4) {
3558
- var locales = (_globalThis$navigator3 = globalThis === null || globalThis === void 0 || (_globalThis$navigator4 = globalThis.navigator) === null || _globalThis$navigator4 === void 0 ? void 0 : _globalThis$navigator4.languages) !== null && _globalThis$navigator3 !== void 0 ? _globalThis$navigator3 : [];
3559
- if (!IS_ARRAY(locales) || locales.length <= 0) {
3560
- return 'en-US';
3561
- }
3562
- locales = locales.filter(function (locale) {
3563
- return typeof locale === 'string' && locale.includes('-') && locale.toLowerCase() !== 'en-us';
3564
- });
3565
- if (locales.length <= 0) {
3566
- return 'en-US';
3567
- }
3568
- var localesNoEnglish = locales.filter(function (locale) {
3569
- return !locale.toLowerCase().startsWith('en-');
3570
- });
3571
- if (localesNoEnglish.length <= 0) {
3572
- return locales[0];
3573
- }
3574
- return localesNoEnglish[0];
3575
- }();
3576
- }
3577
- return userLocale;
3578
- };
3579
- }(),
3580
- /**
3581
- * Returns the user's locale date format. Always returns YYYY MM DD, with the character in between depending on the user's locale. Returns 'YYYY/MM/DD' if the user's locale can't be determined.
3582
- *
3583
- * @returns {string}
3584
- */
3585
- getUserLocaleDateFormat: function () {
3586
- var userLocaleDateFormat = null;
3587
- return function () {
3588
- if (userLocaleDateFormat === null) {
3589
- userLocaleDateFormat = function (_globalThis$Intl) {
3590
- var _char = '/';
3591
- if (globalThis !== null && globalThis !== void 0 && (_globalThis$Intl = globalThis.Intl) !== null && _globalThis$Intl !== void 0 && _globalThis$Intl.DateTimeFormat) {
3592
- var formattedDate = new globalThis.Intl.DateTimeFormat(LeUtils.getUserLocale()).format();
3593
- if (formattedDate.includes('-')) {
3594
- _char = '-';
3595
- } else if (formattedDate.includes('. ')) {
3596
- _char = '.';
3597
- } else if (formattedDate.includes('.')) {
3598
- _char = '.';
3599
- }
3600
- }
3601
- return 'YYYY' + _char + 'MM' + _char + 'DD';
3602
- }();
3603
- }
3604
- return userLocaleDateFormat;
3605
- };
3606
- }()
3607
- };
3608
-
3609
- function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
3610
- function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
3611
- function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
3612
- function _classPrivateFieldInitSpec$2(e, t, a) { _checkPrivateRedeclaration$2(e, t), t.set(e, a); }
3613
- function _checkPrivateRedeclaration$2(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); }
3614
- function _classPrivateFieldGet$2(s, a) { return s.get(_assertClassBrand$2(s, a)); }
3615
- function _classPrivateFieldSet$2(s, a, r) { return s.set(_assertClassBrand$2(s, a), r), r; }
3616
- function _assertClassBrand$2(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); }
3617
- var _events = /*#__PURE__*/new WeakMap();
3618
- /**
3619
- * A simple event emitter class that allows you to register listeners for events, emit events, and remove listeners.
3620
- */
3621
- var EventEmitter = /*#__PURE__*/function () {
3622
- /**
3623
- * Creates a new EventEmitter instance.
3624
- */
3625
- function EventEmitter() {
3626
- _classCallCheck(this, EventEmitter);
3627
- /** @type {Map<string, Set<Function>>} */
3628
- _classPrivateFieldInitSpec$2(this, _events, void 0);
3629
- _classPrivateFieldSet$2(_events, this, new Map());
3630
- }
3631
-
3632
- /**
3633
- * Registers a listener for a specific event.
3634
- *
3635
- * @param {string} event - The name of the event to listen for.
3636
- * @param {Function} listener - The function to call when the event is emitted.
3637
- * @returns {{remove:(()=>void)}}
3638
- */
3639
- return _createClass(EventEmitter, [{
3640
- key: "on",
3641
- value: function on(event, listener) {
3642
- var _classPrivateFieldGet2,
3643
- _this = this;
3644
- if (!_classPrivateFieldGet$2(_events, this).has(event)) {
3645
- _classPrivateFieldGet$2(_events, this).set(event, new Set());
3646
- }
3647
- (_classPrivateFieldGet2 = _classPrivateFieldGet$2(_events, this).get(event)) === null || _classPrivateFieldGet2 === void 0 || _classPrivateFieldGet2.add(listener);
3648
- return {
3649
- remove: function remove() {
3650
- return _this.off(event, listener);
3651
- }
3652
- };
3653
- }
3654
-
3655
- /**
3656
- * Registers a listener for a specific event, this listener will be called only once.
3657
- *
3658
- * @param {string} event - The name of the event to listen for.
3659
- * @param {Function} listener - The function to call when the event is emitted.
3660
- * @returns {{remove:()=>void}}
3661
- */
3662
- }, {
3663
- key: "once",
3664
- value: function once(event, listener) {
3665
- var _this2 = this;
3666
- var _wrapper = function wrapper() {
3667
- _this2.off(event, _wrapper);
3668
- listener.apply(void 0, arguments);
3669
- };
3670
- this.on(event, _wrapper);
3671
- return {
3672
- remove: function remove() {
3673
- return _this2.off(event, _wrapper);
3674
- }
3675
- };
3676
- }
3677
-
3678
- /**
3679
- * Removes a listener for a specific event.
3680
- *
3681
- * @param {string} event - The name of the event to stop listening for.
3682
- * @param {Function} listener - The function to remove from the event listeners.
3683
- */
3684
- }, {
3685
- key: "off",
3686
- value: function off(event, listener) {
3687
- var listeners = _classPrivateFieldGet$2(_events, this).get(event);
3688
- if (listeners) {
3689
- listeners["delete"](listener);
3690
- if (listeners.size === 0) {
3691
- _classPrivateFieldGet$2(_events, this)["delete"](event);
3692
- }
3693
- }
3694
- }
3695
-
3696
- /**
3697
- * Emits an event, calling all registered listeners with the provided arguments.
3698
- *
3699
- * @param {string} event - The name of the event to emit.
3700
- * @param {...*} args - The arguments to pass to the listeners.
3701
- */
3702
- }, {
3703
- key: "emit",
3704
- value: function emit(event) {
3705
- var listeners = _classPrivateFieldGet$2(_events, this).get(event);
3706
- if (listeners) {
3707
- var snapshot = _toConsumableArray(listeners);
3708
- for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
3709
- args[_key - 1] = arguments[_key];
3710
- }
3711
- var _iterator = _createForOfIteratorHelper(snapshot),
3712
- _step;
3713
- try {
3714
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
3715
- var listener = _step.value;
3716
- try {
3717
- listener.apply(void 0, args);
3718
- } catch (err) {
3719
- console.error("Error in listener for \"".concat(event, "\":"), err);
3720
- }
3721
- }
3722
- } catch (err) {
3723
- _iterator.e(err);
3724
- } finally {
3725
- _iterator.f();
3726
- }
3727
- }
3728
- }
3729
-
3730
- /**
3731
- * Clears all listeners for a specific event or all events if no event is specified.
3732
- *
3733
- * @param {string} [event] - The name of the event to clear listeners for. If not provided, all events will be cleared.
3734
- */
3735
- }, {
3736
- key: "clear",
3737
- value: function clear(event) {
3738
- if (event !== undefined) {
3739
- _classPrivateFieldGet$2(_events, this)["delete"](event);
3740
- } else {
3741
- _classPrivateFieldGet$2(_events, this).clear();
3742
- }
3743
- }
3744
- }]);
3745
- }();
3746
-
3747
- function _classPrivateFieldInitSpec$1(e, t, a) { _checkPrivateRedeclaration$1(e, t), t.set(e, a); }
3748
- function _checkPrivateRedeclaration$1(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); }
3749
- function _classPrivateFieldSet$1(s, a, r) { return s.set(_assertClassBrand$1(s, a), r), r; }
3750
- function _classPrivateFieldGet$1(s, a) { return s.get(_assertClassBrand$1(s, a)); }
3751
- function _assertClassBrand$1(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); }
3752
- var LinkedListNode = /*#__PURE__*/_createClass(
3753
- /**
3754
- * @param {*} value
3755
- */
3756
- function LinkedListNode(value) {
3757
- _classCallCheck(this, LinkedListNode);
3758
- /** @type {*} */
3759
- _defineProperty(this, "value", void 0);
3760
- /** @type {LinkedListNode|null} */
3761
- _defineProperty(this, "next", null);
3762
- /** @type {LinkedListNode|null} */
3763
- _defineProperty(this, "previous", null);
3764
- this.value = value;
3765
- });
3766
- var _head = /*#__PURE__*/new WeakMap();
3767
- var _tail = /*#__PURE__*/new WeakMap();
3768
- var _size = /*#__PURE__*/new WeakMap();
3769
- var LinkedList = /*#__PURE__*/function () {
3770
- function LinkedList() {
3771
- _classCallCheck(this, LinkedList);
3772
- /** @type {LinkedListNode|null} */
3773
- _classPrivateFieldInitSpec$1(this, _head, null);
3774
- /** @type {LinkedListNode|null} */
3775
- _classPrivateFieldInitSpec$1(this, _tail, null);
3776
- /** @type {number} */
3777
- _classPrivateFieldInitSpec$1(this, _size, 0);
3778
- }
3779
-
3780
- /**
3781
- * Returns the number of elements in the list.
3782
- *
3783
- * @returns {number}
3784
- */
3785
- return _createClass(LinkedList, [{
3786
- key: "size",
3787
- get: function get() {
3788
- return _classPrivateFieldGet$1(_size, this);
3789
- }
3790
-
3791
- /**
3792
- * Adds a new value to the beginning of the list.
3793
- *
3794
- * @param {*} value
3795
- */
3796
- }, {
3797
- key: "unshift",
3798
- value: function unshift(value) {
3799
- var _this$size;
3800
- var newNode = new LinkedListNode(value);
3801
- if (_classPrivateFieldGet$1(_head, this) === null) {
3802
- _classPrivateFieldSet$1(_head, this, newNode);
3803
- _classPrivateFieldSet$1(_tail, this, newNode);
3804
- } else {
3805
- newNode.next = _classPrivateFieldGet$1(_head, this);
3806
- _classPrivateFieldGet$1(_head, this).previous = newNode;
3807
- _classPrivateFieldSet$1(_head, this, newNode);
3808
- }
3809
- _classPrivateFieldSet$1(_size, this, (_this$size = _classPrivateFieldGet$1(_size, this), _this$size++, _this$size));
3810
- }
3811
-
3812
- /**
3813
- * Adds a new value to the end of the list.
3814
- *
3815
- * @param {*} value
3816
- */
3817
- }, {
3818
- key: "push",
3819
- value: function push(value) {
3820
- var _this$size3;
3821
- var newNode = new LinkedListNode(value);
3822
- if (_classPrivateFieldGet$1(_tail, this) === null) {
3823
- _classPrivateFieldSet$1(_head, this, newNode);
3824
- _classPrivateFieldSet$1(_tail, this, newNode);
3825
- } else {
3826
- newNode.previous = _classPrivateFieldGet$1(_tail, this);
3827
- _classPrivateFieldGet$1(_tail, this).next = newNode;
3828
- _classPrivateFieldSet$1(_tail, this, newNode);
3829
- }
3830
- _classPrivateFieldSet$1(_size, this, (_this$size3 = _classPrivateFieldGet$1(_size, this), _this$size3++, _this$size3));
3831
- }
3832
-
3833
- /**
3834
- * Removes the first value from the list and returns it.
3835
- *
3836
- * @returns {*|undefined}
3837
- */
3838
- }, {
3839
- key: "shift",
3840
- value: function shift() {
3841
- var _this$size5;
3842
- if (_classPrivateFieldGet$1(_head, this) === null) {
3843
- return undefined;
3844
- }
3845
- var value = _classPrivateFieldGet$1(_head, this).value;
3846
- _classPrivateFieldSet$1(_head, this, _classPrivateFieldGet$1(_head, this).next);
3847
- if (_classPrivateFieldGet$1(_head, this) !== null) {
3848
- _classPrivateFieldGet$1(_head, this).previous = null;
3849
- } else {
3850
- _classPrivateFieldSet$1(_tail, this, null);
3851
- }
3852
- _classPrivateFieldSet$1(_size, this, (_this$size5 = _classPrivateFieldGet$1(_size, this), _this$size5--, _this$size5));
3853
- return value;
3854
- }
3855
-
3856
- /**
3857
- * Removes the last value from the list and returns it.
3858
- *
3859
- * @returns {*|undefined}
3860
- */
3861
- }, {
3862
- key: "pop",
3863
- value: function pop() {
3864
- var _this$size7;
3865
- if (_classPrivateFieldGet$1(_tail, this) === null) {
3866
- return undefined;
3867
- }
3868
- var value = _classPrivateFieldGet$1(_tail, this).value;
3869
- _classPrivateFieldSet$1(_tail, this, _classPrivateFieldGet$1(_tail, this).previous);
3870
- if (_classPrivateFieldGet$1(_tail, this) !== null) {
3871
- _classPrivateFieldGet$1(_tail, this).next = null;
3872
- } else {
3873
- _classPrivateFieldSet$1(_head, this, null);
3874
- }
3875
- _classPrivateFieldSet$1(_size, this, (_this$size7 = _classPrivateFieldGet$1(_size, this), _this$size7--, _this$size7));
3876
- return value;
3877
- }
3878
- }]);
3879
- }();
3880
-
3881
- function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
3882
- function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
3883
- /**
3884
- * SerializableMap class extends the native Map to provide a JSON representation.
3885
- *
3886
- * This class can only have string keys, as JSON does not support non-string keys.
3887
- */
3888
- var SerializableMap = /*#__PURE__*/function (_Map) {
3889
- function SerializableMap() {
3890
- _classCallCheck(this, SerializableMap);
3891
- return _callSuper(this, SerializableMap, arguments);
3892
- }
3893
- _inherits(SerializableMap, _Map);
3894
- return _createClass(SerializableMap, [{
3895
- key: "toJSON",
3896
- value:
3897
- /**
3898
- * Returns a JSON representation of the map.
3899
- *
3900
- * @returns {Object}
3901
- */
3902
- function toJSON() {
3903
- return Object.fromEntries(this);
3904
- }
3905
- }]);
3906
- }(/*#__PURE__*/_wrapNativeSuper(Map));
3907
-
3908
- function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); }
3909
- function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); }
3910
- function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); }
3911
- function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; }
3912
- function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); }
3913
-
3914
- /**
3915
- * A TreeSet is a set of elements, sorted by a comparator.
3916
- * Binary search is used to find elements, which makes it very fast to find elements.
3917
- *
3918
- * The comparator is also used to determine if two values are equal to each other.
3919
- * This way, you can have values that aren't the same be treated as if they are. This can be used to deal with issues such as floating point errors for example.
3920
- */
3921
- var _elements = /*#__PURE__*/new WeakMap();
3922
- var _comparator = /*#__PURE__*/new WeakMap();
3923
- var TreeSet = /*#__PURE__*/function () {
3924
- /**
3925
- * Creates a new TreeSet with the given elements and comparator.
3926
- *
3927
- * @param {*[]} [elements=[]] - The initial elements of the set.
3928
- * @param {(valueA:*, valueB:*) => number} [comparator=LeUtils.compare] - The comparator function to use for sorting.
3929
- */
3930
- function TreeSet(elements, comparator) {
3931
- _classCallCheck(this, TreeSet);
3932
- /** @type {*[]} */
3933
- _classPrivateFieldInitSpec(this, _elements, void 0);
3934
- /** @type {(valueA:*, valueB:*) => number} */
3935
- _classPrivateFieldInitSpec(this, _comparator, void 0);
3936
- _classPrivateFieldSet(_comparator, this, comparator || LeUtils.compare);
3937
- _classPrivateFieldSet(_elements, this, elements || []);
3938
- _classPrivateFieldGet(_elements, this).sort(_classPrivateFieldGet(_comparator, this));
3939
- }
3940
-
3941
- /**
3942
- *
3943
- *
3944
- * @param {*} value - The value to search for in the set.
3945
- * @returns {{found:boolean, index:number, value:*|undefined}} - An object containing whether the value was found, the index where it would be inserted, and the value at that index (if found).
3946
- * @private
3947
- */
3948
- return _createClass(TreeSet, [{
3949
- key: "binarySearch",
3950
- value: function binarySearch(value) {
3951
- var low = 0;
3952
- var high = _classPrivateFieldGet(_elements, this).length - 1;
3953
- while (low <= high) {
3954
- var mid = Math.floor((low + high) / 2);
3955
- var midValue = _classPrivateFieldGet(_elements, this)[mid];
3956
- var cmp = _classPrivateFieldGet(_comparator, this).call(this, midValue, value);
3957
- if (cmp < 0) {
3958
- low = mid + 1;
3959
- } else if (cmp > 0) {
3960
- high = mid - 1;
3961
- } else {
3962
- return {
3963
- found: true,
3964
- index: mid,
3965
- value: midValue
3966
- };
3967
- }
3968
- }
3969
- return {
3970
- found: false,
3971
- index: low,
3972
- value: undefined
3973
- };
3974
- }
3975
- }, {
3976
- key: "getElements",
3977
- value:
3978
- /**
3979
- * Returns the elements of the set.
3980
- */
3981
- function getElements() {
3982
- return _classPrivateFieldGet(_elements, this);
3983
- }
3984
-
3985
- /**
3986
- * Returns the comparator of the set.
3987
- *
3988
- * @returns {(valueA:*, valueB:*) => number}
3989
- */
3990
- }, {
3991
- key: "getComparator",
3992
- value: function getComparator() {
3993
- return _classPrivateFieldGet(_comparator, this);
3994
- }
3995
-
3996
- /**
3997
- * Returns the size of the set.
3998
- *
3999
- * @returns {number}
4000
- */
4001
- }, {
4002
- key: "size",
4003
- value: function size() {
4004
- return _classPrivateFieldGet(_elements, this).length;
4005
- }
4006
-
4007
- /**
4008
- * Returns true if the set is empty, false otherwise.
4009
- *
4010
- * @returns {boolean}
4011
- */
4012
- }, {
4013
- key: "isEmpty",
4014
- value: function isEmpty() {
4015
- return _classPrivateFieldGet(_elements, this).length <= 0;
4016
- }
4017
-
4018
- /**
4019
- * Returns true if the set contains a value that is equal to the given value, returns false otherwise.
4020
- *
4021
- * @param {*} value - The value to check for in the set.
4022
- * @return {boolean} - True if the set contains the value, false otherwise.
4023
- */
4024
- }, {
4025
- key: "contains",
4026
- value: function contains(value) {
4027
- return this.binarySearch(value).found;
4028
- }
4029
-
4030
- /**
4031
- * Returns the first element of the set, or undefined if it is empty.
4032
- *
4033
- * @return {*|undefined} - The first element of the set, or undefined if it is empty.
4034
- */
4035
- }, {
4036
- key: "first",
4037
- value: function first() {
4038
- return _classPrivateFieldGet(_elements, this).length > 0 ? _classPrivateFieldGet(_elements, this)[0] : undefined;
4039
- }
4040
-
4041
- /**
4042
- * Returns the last element of the set, or undefined if it is empty.
4043
- *
4044
- * @return {*|undefined} - The last element of the set, or undefined if it is empty.
4045
- */
4046
- }, {
4047
- key: "last",
4048
- value: function last() {
4049
- return _classPrivateFieldGet(_elements, this).length > 0 ? _classPrivateFieldGet(_elements, this)[_classPrivateFieldGet(_elements, this).length - 1] : undefined;
4050
- }
4051
-
4052
- /**
4053
- * Removes and returns the first element of the set, or undefined if it is empty.
4054
- *
4055
- * @returns {*|undefined} - The first element of the set, or undefined if it is empty.
4056
- */
4057
- }, {
4058
- key: "pollFirst",
4059
- value: function pollFirst() {
4060
- return _classPrivateFieldGet(_elements, this).length > 0 ? _classPrivateFieldGet(_elements, this).splice(0, 1)[0] : undefined;
4061
- }
4062
-
4063
- /**
4064
- * Removes and returns the last element of the set, or undefined if it is empty.
4065
- *
4066
- * @returns {*|undefined} - The last element of the set, or undefined if it is empty.
4067
- */
4068
- }, {
4069
- key: "pollLast",
4070
- value: function pollLast() {
4071
- return _classPrivateFieldGet(_elements, this).length > 0 ? _classPrivateFieldGet(_elements, this).splice(_classPrivateFieldGet(_elements, this).length - 1, 1)[0] : undefined;
4072
- }
4073
-
4074
- /**
4075
- * Adds the given value to the set. Will only do so if no equal value already exists.
4076
- * @param {*} value - The value to add to the set.
4077
- */
4078
- }, {
4079
- key: "add",
4080
- value: function add(value) {
4081
- var result = this.binarySearch(value);
4082
- if (result.found) {
4083
- return;
4084
- }
4085
- _classPrivateFieldGet(_elements, this).splice(result.index, 0, value);
4086
- }
4087
-
4088
- /**
4089
- * Adds all the given values to the set. Will only do so if no equal value already exists.
4090
- *
4091
- * @param {*} values - The values to add to the set.
4092
- */
4093
- }, {
4094
- key: "addAll",
4095
- value: function addAll(values) {
4096
- LeUtils.each(values, this.add.bind(this));
4097
- }
4098
-
4099
- /**
4100
- * Returns an equal value that's already in the tree set, or undefined if no equal values in it exist.
4101
- *
4102
- * @param {*} value - The value to search for in the set.
4103
- * @return {*|undefined} - The equal value if found, or undefined if not found.
4104
- */
4105
- }, {
4106
- key: "getEqualValue",
4107
- value: function getEqualValue(value) {
4108
- var result = this.binarySearch(value);
4109
- if (result.found) {
4110
- return result.value;
4111
- }
4112
- return undefined;
4113
- }
4114
-
4115
- /**
4116
- * Returns an equal value that's already in the tree set. If no equal values in it exist, the given value will be added and returned.
4117
- *
4118
- * @param {*} value - The value to search for in the set.
4119
- * @return {*} - The equal value if found, or the added value if not found.
4120
- */
4121
- }, {
4122
- key: "getEqualValueOrAdd",
4123
- value: function getEqualValueOrAdd(value) {
4124
- var result = this.binarySearch(value);
4125
- if (result.found) {
4126
- return result.value;
4127
- }
4128
- _classPrivateFieldGet(_elements, this).splice(result.index, 0, value);
4129
- return value;
4130
- }
4131
-
4132
- /**
4133
- * Returns a string representation of the TreeSet.
4134
- *
4135
- * @returns {string} - A string representation of the TreeSet, including its elements and comparator.
4136
- */
4137
- }, {
4138
- key: "toString",
4139
- value: function toString() {
4140
- return "TreeSet{elements:".concat(_classPrivateFieldGet(_elements, this), ", comparator:").concat(_classPrivateFieldGet(_comparator, this), "}");
4141
- }
4142
-
4143
- /**
4144
- * Returns a JSON representation of the TreeSet.
4145
- *
4146
- * @returns {Object} - An object containing the elements and comparator of the TreeSet.
4147
- */
4148
- }, {
4149
- key: "toJSON",
4150
- value: function toJSON() {
4151
- return {
4152
- elements: _classPrivateFieldGet(_elements, this),
4153
- comparator: _classPrivateFieldGet(_comparator, this).toString()
4154
- };
4155
- }
4156
- }]);
4157
- }();
4158
-
4159
- export { ARRAY, BOOL, BOOL_ANY, EventEmitter, FLOAT, FLOAT_ANY, FLOAT_LAX, FLOAT_LAX_ANY, INT, INT_ANY, INT_LAX, INT_LAX_ANY, ISSET, IS_ARRAY, IS_OBJECT, LeUtils, LinkedList, OBJECT, STRING, STRING_ANY, SerializableMap, TreeSet };
4160
- //# sourceMappingURL=index.js.map