@lichens-innovation/ts-common 1.6.2 → 1.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/dist/index.cjs +533 -0
  2. package/dist/index.cjs.map +1 -0
  3. package/dist/index.d.cts +232 -0
  4. package/dist/index.d.ts +232 -2
  5. package/dist/index.js +439 -1
  6. package/dist/index.js.map +1 -1
  7. package/package.json +15 -4
  8. package/dist/index.d.ts.map +0 -1
  9. package/dist/utils/color.utils.d.ts +0 -41
  10. package/dist/utils/color.utils.d.ts.map +0 -1
  11. package/dist/utils/color.utils.js +0 -97
  12. package/dist/utils/color.utils.js.map +0 -1
  13. package/dist/utils/date.utils.d.ts +0 -33
  14. package/dist/utils/date.utils.d.ts.map +0 -1
  15. package/dist/utils/date.utils.js +0 -66
  16. package/dist/utils/date.utils.js.map +0 -1
  17. package/dist/utils/errors.utils.d.ts +0 -2
  18. package/dist/utils/errors.utils.d.ts.map +0 -1
  19. package/dist/utils/errors.utils.js +0 -13
  20. package/dist/utils/errors.utils.js.map +0 -1
  21. package/dist/utils/http.utils.d.ts +0 -4
  22. package/dist/utils/http.utils.d.ts.map +0 -1
  23. package/dist/utils/http.utils.js +0 -20
  24. package/dist/utils/http.utils.js.map +0 -1
  25. package/dist/utils/index.d.ts +0 -14
  26. package/dist/utils/index.d.ts.map +0 -1
  27. package/dist/utils/index.js +0 -14
  28. package/dist/utils/index.js.map +0 -1
  29. package/dist/utils/number.utils.d.ts +0 -4
  30. package/dist/utils/number.utils.d.ts.map +0 -1
  31. package/dist/utils/number.utils.js +0 -30
  32. package/dist/utils/number.utils.js.map +0 -1
  33. package/dist/utils/regex.d.ts +0 -3
  34. package/dist/utils/regex.d.ts.map +0 -1
  35. package/dist/utils/regex.js +0 -3
  36. package/dist/utils/regex.js.map +0 -1
  37. package/dist/utils/string.utils.d.ts +0 -38
  38. package/dist/utils/string.utils.d.ts.map +0 -1
  39. package/dist/utils/string.utils.js +0 -63
  40. package/dist/utils/string.utils.js.map +0 -1
  41. package/dist/utils/thread.utils.d.ts +0 -2
  42. package/dist/utils/thread.utils.d.ts.map +0 -1
  43. package/dist/utils/thread.utils.js +0 -2
  44. package/dist/utils/thread.utils.js.map +0 -1
  45. package/dist/utils/time.utils.d.ts +0 -7
  46. package/dist/utils/time.utils.d.ts.map +0 -1
  47. package/dist/utils/time.utils.js +0 -11
  48. package/dist/utils/time.utils.js.map +0 -1
  49. package/dist/utils/types.utils.d.ts +0 -5
  50. package/dist/utils/types.utils.d.ts.map +0 -1
  51. package/dist/utils/types.utils.js +0 -24
  52. package/dist/utils/types.utils.js.map +0 -1
  53. package/dist/utils/units.utils.d.ts +0 -16
  54. package/dist/utils/units.utils.d.ts.map +0 -1
  55. package/dist/utils/units.utils.js +0 -37
  56. package/dist/utils/units.utils.js.map +0 -1
  57. package/dist/utils/uri.utils.d.ts +0 -12
  58. package/dist/utils/uri.utils.d.ts.map +0 -1
  59. package/dist/utils/uri.utils.js +0 -19
  60. package/dist/utils/uri.utils.js.map +0 -1
  61. package/dist/utils/websocket.utils.d.ts +0 -4
  62. package/dist/utils/websocket.utils.d.ts.map +0 -1
  63. package/dist/utils/websocket.utils.js +0 -23
  64. package/dist/utils/websocket.utils.js.map +0 -1
package/dist/index.cjs ADDED
@@ -0,0 +1,533 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/index.ts
21
+ var index_exports = {};
22
+ __export(index_exports, {
23
+ HZ_TO_RPM: () => HZ_TO_RPM,
24
+ M3PS_TO_GPM: () => M3PS_TO_GPM,
25
+ M_TO_INCHES: () => M_TO_INCHES,
26
+ NO_OP: () => NO_OP,
27
+ PA_TO_FT: () => PA_TO_FT,
28
+ PeriodsInMS: () => PeriodsInMS,
29
+ REGEX_ALPHANUMERIC: () => REGEX_ALPHANUMERIC,
30
+ REGEX_IPV4: () => REGEX_IPV4,
31
+ SCHEME_PREFIXES: () => SCHEME_PREFIXES,
32
+ W_TO_HP: () => W_TO_HP,
33
+ buildTicksForChart: () => buildTicksForChart,
34
+ capitalizeFirst: () => capitalizeFirst,
35
+ closeWebSocket: () => closeWebSocket,
36
+ countWords: () => countWords,
37
+ dateAs_HHMMSS: () => dateAs_HHMMSS,
38
+ dateAs_YYYYMMDD: () => dateAs_YYYYMMDD,
39
+ dateAs_YYYYMMDD_HHMMSS: () => dateAs_YYYYMMDD_HHMMSS,
40
+ extractBase64FromDataUri: () => extractBase64FromDataUri,
41
+ formatUnixTimestamp: () => formatUnixTimestamp,
42
+ fromHzToRpm: () => fromHzToRpm,
43
+ fromM3psToGPM: () => fromM3psToGPM,
44
+ fromMToInches: () => fromMToInches,
45
+ fromPaToFt: () => fromPaToFt,
46
+ fromWToHp: () => fromWToHp,
47
+ getColorForPercentage: () => getColorForPercentage,
48
+ getContrastTextColor: () => getContrastTextColor,
49
+ getCurrentUnixTimestamp: () => getCurrentUnixTimestamp,
50
+ getErrorMessage: () => getErrorMessage,
51
+ getLuminance: () => getLuminance,
52
+ getOpacityHexValue: () => getOpacityHexValue,
53
+ getOrderOfMagnitudeExponent: () => getOrderOfMagnitudeExponent,
54
+ getTickDomain: () => getTickDomain,
55
+ hasScheme: () => hasScheme,
56
+ hexToNormalizedRgb: () => hexToNormalizedRgb,
57
+ hexToRgb: () => hexToRgb,
58
+ isActiveTimestamp: () => isActiveTimestamp,
59
+ isAlphanumeric: () => isAlphanumeric,
60
+ isBlank: () => isBlank,
61
+ isExpiredTimestamp: () => isExpiredTimestamp,
62
+ isHttpClientErrorStatus: () => isHttpClientErrorStatus,
63
+ isHttpServerErrorStatus: () => isHttpServerErrorStatus,
64
+ isHttpSuccessStatus: () => isHttpSuccessStatus,
65
+ isLightColor: () => isLightColor,
66
+ isNotBlank: () => isNotBlank,
67
+ isNullish: () => isNullish,
68
+ isNumber: () => isNumber,
69
+ isString: () => isString,
70
+ isWsClosable: () => isWsClosable,
71
+ isWsOpenOrConnecting: () => isWsOpenOrConnecting,
72
+ nowAsDate: () => nowAsDate,
73
+ nowAsDateTime: () => nowAsDateTime,
74
+ nowAsDateTimeForFilename: () => nowAsDateTimeForFilename,
75
+ nowAsTime: () => nowAsTime,
76
+ removeDiacriticalMarks: () => removeDiacriticalMarks,
77
+ rgbToHex: () => rgbToHex,
78
+ rgbToString: () => rgbToString,
79
+ rgbaToHex: () => rgbaToHex,
80
+ rgbaToHexWithAlpha: () => rgbaToHexWithAlpha,
81
+ rgbaToString: () => rgbaToString,
82
+ roundToNiceNumber: () => roundToNiceNumber,
83
+ roundUpToNearest10: () => roundUpToNearest10,
84
+ sleep: () => sleep,
85
+ tickFormatter: () => tickFormatter,
86
+ toFixed: () => toFixed,
87
+ toToleranceLabel: () => toToleranceLabel,
88
+ tooltipValueFormatter: () => tooltipValueFormatter,
89
+ truncate: () => truncate
90
+ });
91
+ module.exports = __toCommonJS(index_exports);
92
+
93
+ // src/utils/types.utils.ts
94
+ var NO_OP = () => {
95
+ };
96
+ var isNullish = (value) => value === null || value === void 0;
97
+ var isNumber = (value) => {
98
+ if (isNullish(value)) {
99
+ return false;
100
+ }
101
+ if (typeof value !== "number") {
102
+ return false;
103
+ }
104
+ if (isNaN(value)) {
105
+ return false;
106
+ }
107
+ return true;
108
+ };
109
+ var isString = (value) => {
110
+ if (isNullish(value)) {
111
+ return false;
112
+ }
113
+ if (typeof value !== "string") {
114
+ return false;
115
+ }
116
+ return true;
117
+ };
118
+
119
+ // src/utils/chart.utils.ts
120
+ var getTickDomain = (ticks) => [0, ticks.at(-1) ?? 0];
121
+ var tickFormatter = (value) => value.toFixed(0);
122
+ var toToleranceLabel = (value) => `\xB1${(value * 100).toFixed(0)}%`;
123
+ var tooltipValueFormatter = (data) => {
124
+ if (isNullish(data)) {
125
+ return "";
126
+ }
127
+ if (typeof data === "number") {
128
+ return data.toFixed(2);
129
+ }
130
+ if (Array.isArray(data) && data.length >= 2) {
131
+ const [min, max] = data;
132
+ if (typeof min === "number" && typeof max === "number") {
133
+ return `[${min.toFixed(2)} \u2026 ${max.toFixed(2)}]`;
134
+ }
135
+ }
136
+ return String(data ?? "");
137
+ };
138
+ var roundToNiceNumber = (rawValue) => {
139
+ if (rawValue <= 0) return 0;
140
+ const magnitude = Math.pow(10, Math.floor(Math.log10(rawValue)));
141
+ const normalized = rawValue / magnitude;
142
+ let niceMultiplier;
143
+ if (normalized <= 1) niceMultiplier = 1;
144
+ else if (normalized <= 2) niceMultiplier = 2;
145
+ else if (normalized <= 2.5) niceMultiplier = 2.5;
146
+ else if (normalized <= 5) niceMultiplier = 5;
147
+ else niceMultiplier = 10;
148
+ return niceMultiplier * magnitude;
149
+ };
150
+ var roundToPrecision = (value, precision = 10) => {
151
+ const factor = 10 ** precision;
152
+ return Math.round(value * factor) / factor;
153
+ };
154
+ var buildTicksForChart = (max, targetTickCount = 10) => {
155
+ if (max <= 0) return [0];
156
+ const rawIncrement = max / targetTickCount;
157
+ const niceIncrement = roundToNiceNumber(rawIncrement);
158
+ const ticks = [];
159
+ for (let value = 0; value <= max + niceIncrement * 0.5; value += niceIncrement) {
160
+ ticks.push(roundToPrecision(value));
161
+ }
162
+ const lastTick = ticks[ticks.length - 1];
163
+ if (lastTick < max) {
164
+ ticks.push(roundToPrecision(lastTick + niceIncrement));
165
+ }
166
+ return ticks;
167
+ };
168
+
169
+ // src/utils/color.utils.ts
170
+ var rgbToHex = (r, g, b) => {
171
+ if (r > 255 || g > 255 || b > 255) {
172
+ throw new Error("Invalid color component");
173
+ }
174
+ return (r << 16 | g << 8 | b).toString(16).padStart(6, "0");
175
+ };
176
+ var hexToRgb = (hex) => {
177
+ const cleanHex = hex.replace("#", "");
178
+ const r = parseInt(cleanHex.substring(0, 2), 16);
179
+ const g = parseInt(cleanHex.substring(2, 4), 16);
180
+ const b = parseInt(cleanHex.substring(4, 6), 16);
181
+ return { r, g, b };
182
+ };
183
+ var rgbaToHex = (color) => {
184
+ return "#" + rgbToHex(color.r, color.g, color.b);
185
+ };
186
+ var getOpacityHexValue = (opacity) => {
187
+ if (opacity < 0 || opacity > 1) {
188
+ throw new Error("Invalid opacity value");
189
+ }
190
+ return Math.round(opacity * 255).toString(16).padStart(2, "0");
191
+ };
192
+ var rgbaToHexWithAlpha = (color) => {
193
+ return rgbaToHex(color) + getOpacityHexValue(color.a);
194
+ };
195
+ var rgbToString = (color) => {
196
+ return `rgb(${color.r}, ${color.g}, ${color.b})`;
197
+ };
198
+ var rgbaToString = (color) => {
199
+ return `rgba(${color.r}, ${color.g}, ${color.b}, ${color.a})`;
200
+ };
201
+ var getLuminance = (r, g, b) => {
202
+ return (0.299 * r + 0.587 * g + 0.114 * b) / 255;
203
+ };
204
+ var getContrastTextColor = (hexColor) => {
205
+ const { r, g, b } = hexToRgb(hexColor);
206
+ return getLuminance(r, g, b) > 0.5 ? "#000000" : "#ffffff";
207
+ };
208
+ var hexToNormalizedRgb = (hex) => {
209
+ const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
210
+ return result ? {
211
+ r: parseInt(result[1], 16) / 255,
212
+ g: parseInt(result[2], 16) / 255,
213
+ b: parseInt(result[3], 16) / 255
214
+ } : { r: 0, g: 0, b: 0 };
215
+ };
216
+ var isLightColor = (hex) => {
217
+ const rgb = hexToNormalizedRgb(hex);
218
+ const luminance = 0.299 * rgb.r + 0.587 * rgb.g + 0.114 * rgb.b;
219
+ return luminance > 0.5;
220
+ };
221
+ var PERCENT_COLORS = [
222
+ { pct: 0, color: { r: 255, g: 0, b: 0 } },
223
+ { pct: 0.5, color: { r: 255, g: 255, b: 0 } },
224
+ { pct: 1, color: { r: 0, g: 255, b: 0 } }
225
+ ];
226
+ var getColorForPercentage = (percent) => {
227
+ if (percent < 0 || percent > 1) {
228
+ throw new Error(`Percentage must be between 0 and 1: ${percent}`);
229
+ }
230
+ let i = 0;
231
+ for (i = 1; i < PERCENT_COLORS.length - 1; i++) {
232
+ if (percent < PERCENT_COLORS[i].pct) {
233
+ break;
234
+ }
235
+ }
236
+ const lower = PERCENT_COLORS[i - 1];
237
+ const upper = PERCENT_COLORS[i];
238
+ const range = upper.pct - lower.pct;
239
+ const rangePct = (percent - lower.pct) / range;
240
+ const pctLower = 1 - rangePct;
241
+ const pctUpper = rangePct;
242
+ const color = {
243
+ r: Math.floor(lower.color.r * pctLower + upper.color.r * pctUpper),
244
+ g: Math.floor(lower.color.g * pctLower + upper.color.g * pctUpper),
245
+ b: Math.floor(lower.color.b * pctLower + upper.color.b * pctUpper)
246
+ };
247
+ return "rgb(" + [color.r, color.g, color.b].join(",") + ")";
248
+ };
249
+
250
+ // src/utils/date.utils.ts
251
+ var import_date_fns = require("date-fns");
252
+ var dateAs_HHMMSS = (value) => {
253
+ if (isNullish(value)) return "";
254
+ return (0, import_date_fns.format)(value, "HH:mm:ss");
255
+ };
256
+ var dateAs_YYYYMMDD = (value) => {
257
+ if (isNullish(value)) return "";
258
+ return (0, import_date_fns.format)(value, "yyyy-MM-dd");
259
+ };
260
+ var dateAs_YYYYMMDD_HHMMSS = (value) => {
261
+ if (isNullish(value)) return "";
262
+ return (0, import_date_fns.format)(value, "yyyy-MM-dd HH:mm:ss");
263
+ };
264
+ var nowAsTime = () => dateAs_HHMMSS(/* @__PURE__ */ new Date());
265
+ var nowAsDate = () => dateAs_YYYYMMDD(/* @__PURE__ */ new Date());
266
+ var nowAsDateTime = () => dateAs_YYYYMMDD_HHMMSS(/* @__PURE__ */ new Date());
267
+ var nowAsDateTimeForFilename = () => {
268
+ return (0, import_date_fns.format)(/* @__PURE__ */ new Date(), "yyyy-MM-dd_HH-mm-ss");
269
+ };
270
+ var DEFAULT_DATE_FORMAT = "yyyy-MM-dd HH:mm:ss";
271
+ var formatUnixTimestamp = (timestamp, dateFormat = DEFAULT_DATE_FORMAT) => {
272
+ if (!timestamp) return "N/A";
273
+ try {
274
+ return (0, import_date_fns.format)(new Date(timestamp * 1e3), dateFormat);
275
+ } catch {
276
+ return "Invalid date";
277
+ }
278
+ };
279
+ var getCurrentUnixTimestamp = () => {
280
+ return Math.floor(Date.now() / 1e3);
281
+ };
282
+ var isExpiredTimestamp = (timestamp) => {
283
+ const now = getCurrentUnixTimestamp();
284
+ return timestamp < now;
285
+ };
286
+ var isActiveTimestamp = (timestamp) => {
287
+ const now = getCurrentUnixTimestamp();
288
+ return timestamp <= now;
289
+ };
290
+
291
+ // src/utils/errors.utils.ts
292
+ var getErrorMessage = (error) => {
293
+ if (!error) {
294
+ return "";
295
+ }
296
+ if (typeof error === "string") {
297
+ return error;
298
+ }
299
+ if (typeof error === "object" && "message" in error) {
300
+ return error.message;
301
+ }
302
+ return JSON.stringify(error);
303
+ };
304
+
305
+ // src/utils/http.utils.ts
306
+ var isHttpSuccessStatus = (status) => {
307
+ if (isNullish(status)) {
308
+ return false;
309
+ }
310
+ return status >= 200 && status < 300;
311
+ };
312
+ var isHttpClientErrorStatus = (status) => {
313
+ if (isNullish(status)) {
314
+ return false;
315
+ }
316
+ return status >= 400 && status < 500;
317
+ };
318
+ var isHttpServerErrorStatus = (status) => {
319
+ if (isNullish(status)) {
320
+ return false;
321
+ }
322
+ return status >= 500;
323
+ };
324
+
325
+ // src/utils/number.utils.ts
326
+ var toFixed = (value, decimals = 0) => {
327
+ if (isNullish(value)) return 0;
328
+ if (decimals < 0) throw new Error("[toFixed] decimals must be >= 0");
329
+ if (decimals === 0) return Math.round(value);
330
+ const multiplier = Math.pow(10, decimals);
331
+ return Math.round(value * multiplier) / multiplier;
332
+ };
333
+ var roundUpToNearest10 = (value) => {
334
+ if (isNullish(value)) return 0;
335
+ return Math.ceil(value / 10) * 10;
336
+ };
337
+ var getOrderOfMagnitudeExponent = (n) => {
338
+ if (isNullish(n)) return 0;
339
+ if (!isNumber(n)) return 0;
340
+ const absValue = Math.abs(n);
341
+ if (absValue === 0) {
342
+ return 0;
343
+ }
344
+ const integerPart = Math.floor(absValue);
345
+ return Math.floor(Math.log10(integerPart));
346
+ };
347
+
348
+ // src/utils/regex.ts
349
+ var REGEX_ALPHANUMERIC = /^[a-zA-Z0-9-_ $%#(){}:/.]+$/;
350
+ var REGEX_IPV4 = /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;
351
+
352
+ // src/utils/string.utils.ts
353
+ var isBlank = (str) => {
354
+ return isNullish(str) || str?.trim() === "";
355
+ };
356
+ var isNotBlank = (str) => {
357
+ return !isBlank(str);
358
+ };
359
+ var isAlphanumeric = (value) => {
360
+ return REGEX_ALPHANUMERIC.test(value);
361
+ };
362
+ var removeDiacriticalMarks = (value) => {
363
+ if (!value) {
364
+ return "";
365
+ }
366
+ return value.normalize("NFD").replace(/[\u0300-\u036f]/g, "");
367
+ };
368
+ var capitalizeFirst = (str) => {
369
+ if (!str) return str;
370
+ return str.charAt(0).toUpperCase() + str.slice(1);
371
+ };
372
+ var countWords = (text) => {
373
+ if (!text || text.trim().length === 0) return 0;
374
+ return text.split(/\s+/).filter((word) => word.length > 0).length;
375
+ };
376
+ var truncate = (str, maxLength, ellipsis = "...") => {
377
+ if (!str || str.length <= maxLength) return str;
378
+ return str.slice(0, maxLength - ellipsis.length) + ellipsis;
379
+ };
380
+
381
+ // src/utils/thread.utils.ts
382
+ var sleep = (milliseconds) => new Promise((resolve) => setTimeout(resolve, milliseconds));
383
+
384
+ // src/utils/time.utils.ts
385
+ var ONE_SECOND_IN_MS = 1e3;
386
+ var ONE_MINUTE_IN_MS = 60 * ONE_SECOND_IN_MS;
387
+ var ONE_HOUR_IN_MS = 60 * ONE_MINUTE_IN_MS;
388
+ var ONE_DAY_IN_MS = 24 * ONE_HOUR_IN_MS;
389
+ var PeriodsInMS = {
390
+ oneSecond: ONE_SECOND_IN_MS,
391
+ oneMinute: ONE_MINUTE_IN_MS,
392
+ oneHour: ONE_HOUR_IN_MS,
393
+ oneDay: ONE_DAY_IN_MS
394
+ };
395
+
396
+ // src/utils/units.utils.ts
397
+ var M3PS_TO_GPM = 15850.3;
398
+ var PA_TO_FT = 334553e-9;
399
+ var W_TO_HP = 134102e-8;
400
+ var M_TO_INCHES = 39.3701;
401
+ var HZ_TO_RPM = 60;
402
+ var fromM3psToGPM = (value) => {
403
+ if (isNullish(value)) return 0;
404
+ return value * M3PS_TO_GPM;
405
+ };
406
+ var fromPaToFt = (value) => {
407
+ if (isNullish(value)) return 0;
408
+ return value * PA_TO_FT;
409
+ };
410
+ var fromWToHp = (value) => {
411
+ if (isNullish(value)) return 0;
412
+ return value * W_TO_HP;
413
+ };
414
+ var fromMToInches = (value) => {
415
+ if (isNullish(value)) return 0;
416
+ return value * M_TO_INCHES;
417
+ };
418
+ var fromHzToRpm = (value) => {
419
+ if (isNullish(value)) return 0;
420
+ return value * HZ_TO_RPM;
421
+ };
422
+
423
+ // src/utils/uri.utils.ts
424
+ var SCHEME_PREFIXES = {
425
+ file: "file",
426
+ content: "content",
427
+ http: "http",
428
+ https: "https",
429
+ ftp: "ftp",
430
+ ftps: "ftps",
431
+ sftp: "sftp",
432
+ smb: "smb"
433
+ };
434
+ var SCHEME_PREFIXES_ARRAY = Object.values(SCHEME_PREFIXES);
435
+ var hasScheme = (uri) => {
436
+ if (!uri) {
437
+ return false;
438
+ }
439
+ const lowerUri = uri.toLowerCase();
440
+ return SCHEME_PREFIXES_ARRAY.some((prefix) => lowerUri.startsWith(`${prefix}://`));
441
+ };
442
+ var extractBase64FromDataUri = (dataUri) => {
443
+ return dataUri.split(",")[1] ?? dataUri;
444
+ };
445
+
446
+ // src/utils/websocket.utils.ts
447
+ var WEBSOCKET_CONNECT_STATES = [WebSocket.CONNECTING, WebSocket.OPEN];
448
+ var isWsClosable = (ws) => {
449
+ if (isNullish(ws)) return false;
450
+ return WEBSOCKET_CONNECT_STATES.includes(ws.readyState);
451
+ };
452
+ var isWsOpenOrConnecting = (ws) => {
453
+ if (isNullish(ws)) return false;
454
+ return WEBSOCKET_CONNECT_STATES.includes(ws.readyState);
455
+ };
456
+ var closeWebSocket = (ws) => {
457
+ if (isNullish(ws) || !isWsClosable(ws)) return;
458
+ try {
459
+ ws.close();
460
+ } catch {
461
+ }
462
+ };
463
+ // Annotate the CommonJS export names for ESM import in node:
464
+ 0 && (module.exports = {
465
+ HZ_TO_RPM,
466
+ M3PS_TO_GPM,
467
+ M_TO_INCHES,
468
+ NO_OP,
469
+ PA_TO_FT,
470
+ PeriodsInMS,
471
+ REGEX_ALPHANUMERIC,
472
+ REGEX_IPV4,
473
+ SCHEME_PREFIXES,
474
+ W_TO_HP,
475
+ buildTicksForChart,
476
+ capitalizeFirst,
477
+ closeWebSocket,
478
+ countWords,
479
+ dateAs_HHMMSS,
480
+ dateAs_YYYYMMDD,
481
+ dateAs_YYYYMMDD_HHMMSS,
482
+ extractBase64FromDataUri,
483
+ formatUnixTimestamp,
484
+ fromHzToRpm,
485
+ fromM3psToGPM,
486
+ fromMToInches,
487
+ fromPaToFt,
488
+ fromWToHp,
489
+ getColorForPercentage,
490
+ getContrastTextColor,
491
+ getCurrentUnixTimestamp,
492
+ getErrorMessage,
493
+ getLuminance,
494
+ getOpacityHexValue,
495
+ getOrderOfMagnitudeExponent,
496
+ getTickDomain,
497
+ hasScheme,
498
+ hexToNormalizedRgb,
499
+ hexToRgb,
500
+ isActiveTimestamp,
501
+ isAlphanumeric,
502
+ isBlank,
503
+ isExpiredTimestamp,
504
+ isHttpClientErrorStatus,
505
+ isHttpServerErrorStatus,
506
+ isHttpSuccessStatus,
507
+ isLightColor,
508
+ isNotBlank,
509
+ isNullish,
510
+ isNumber,
511
+ isString,
512
+ isWsClosable,
513
+ isWsOpenOrConnecting,
514
+ nowAsDate,
515
+ nowAsDateTime,
516
+ nowAsDateTimeForFilename,
517
+ nowAsTime,
518
+ removeDiacriticalMarks,
519
+ rgbToHex,
520
+ rgbToString,
521
+ rgbaToHex,
522
+ rgbaToHexWithAlpha,
523
+ rgbaToString,
524
+ roundToNiceNumber,
525
+ roundUpToNearest10,
526
+ sleep,
527
+ tickFormatter,
528
+ toFixed,
529
+ toToleranceLabel,
530
+ tooltipValueFormatter,
531
+ truncate
532
+ });
533
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts","../src/utils/types.utils.ts","../src/utils/chart.utils.ts","../src/utils/color.utils.ts","../src/utils/date.utils.ts","../src/utils/errors.utils.ts","../src/utils/http.utils.ts","../src/utils/number.utils.ts","../src/utils/regex.ts","../src/utils/string.utils.ts","../src/utils/thread.utils.ts","../src/utils/time.utils.ts","../src/utils/units.utils.ts","../src/utils/uri.utils.ts","../src/utils/websocket.utils.ts"],"sourcesContent":["export * from \"./utils\";\n","export const NO_OP: () => void = () => {};\n\nexport const isNullish = (value: unknown): value is null | undefined => value === null || value === undefined;\n\nexport const isNumber = (value?: unknown | null): value is number => {\n if (isNullish(value)) {\n return false;\n }\n\n if (typeof value !== 'number') {\n return false;\n }\n\n if (isNaN(value)) {\n return false;\n }\n\n return true;\n};\n\nexport const isString = (value?: unknown | null): value is string => {\n if (isNullish(value)) {\n return false;\n }\n\n if (typeof value !== 'string') {\n return false;\n }\n\n return true;\n};\n","import { isNullish } from \"./types.utils\";\n\nexport interface ToleranceArea {\n flow: number;\n toleranceRange: [number, number];\n}\n\n/**\n * A chart point with required x and y coordinates.\n */\nexport interface ChartPoint {\n x: number;\n y: number;\n}\n\n/**\n * A chart point with optional nullable x and y coordinates.\n */\nexport interface NullableChartPoint {\n x?: number | null;\n y?: number | null;\n}\n\nexport const getTickDomain = (ticks: number[]): [number, number] => [0, ticks.at(-1) ?? 0];\n\nexport const tickFormatter = (value: number): string => value.toFixed(0);\n\nexport const toToleranceLabel = (value: number): string => `±${(value * 100).toFixed(0)}%`;\n\nexport const tooltipValueFormatter = (data?: unknown | null): string => {\n if (isNullish(data)) {\n return '';\n }\n\n if (typeof data === 'number') {\n return data.toFixed(2);\n }\n\n if (Array.isArray(data) && data.length >= 2) {\n const [min, max] = data;\n if (typeof min === 'number' && typeof max === 'number') {\n return `[${min.toFixed(2)} … ${max.toFixed(2)}]`;\n }\n }\n\n return String(data ?? '');\n};\n\n/**\n * Rounds a raw value to a \"nice\" number for chart axis increments.\n * Nice numbers are easy to read: 1, 2, 2.5, 5, or 10 multiplied by a power of 10.\n *\n * @param rawValue - The raw value to round to a nice number\n * @returns A nice number close to the raw value\n *\n * @example\n * roundToNiceNumber(0.7) // returns 1\n * roundToNiceNumber(3) // returns 5\n * roundToNiceNumber(17) // returns 20\n * roundToNiceNumber(80) // returns 100\n */\nexport const roundToNiceNumber = (rawValue: number): number => {\n if (rawValue <= 0) return 0;\n\n // Get order of magnitude\n const magnitude = Math.pow(10, Math.floor(Math.log10(rawValue)));\n\n // Normalize to find the multiplier (between 1 and 10)\n const normalized = rawValue / magnitude;\n\n // Round to nice values: 1, 2, 2.5, 5, 10\n let niceMultiplier: number;\n if (normalized <= 1) niceMultiplier = 1;\n else if (normalized <= 2) niceMultiplier = 2;\n else if (normalized <= 2.5) niceMultiplier = 2.5;\n else if (normalized <= 5) niceMultiplier = 5;\n else niceMultiplier = 10;\n\n return niceMultiplier * magnitude;\n};\n\nconst roundToPrecision = (value: number, precision = 10): number => {\n const factor = 10 ** precision;\n return Math.round(value * factor) / factor;\n};\n\n/**\n * Builds an array of \"nice\" tick values for a chart axis.\n * The algorithm aims for approximately `targetTickCount` ticks with clean, readable values.\n *\n * @param max - The maximum value to display on the axis\n * @param targetTickCount - The desired number of ticks (default: 10)\n * @returns An array of tick values from 0 to at least `max`\n */\nexport const buildTicksForChart = (max: number, targetTickCount = 10): number[] => {\n if (max <= 0) return [0];\n\n // Calculate raw increment for desired tick count and round to nice value\n const rawIncrement = max / targetTickCount;\n const niceIncrement = roundToNiceNumber(rawIncrement);\n\n // Build ticks from 0 to just past max\n const ticks: number[] = [];\n for (let value = 0; value <= max + niceIncrement * 0.5; value += niceIncrement) {\n // Round to avoid floating point precision issues\n ticks.push(roundToPrecision(value));\n }\n\n // Ensure we have at least one tick >= max\n const lastTick = ticks[ticks.length - 1];\n if (lastTick < max) {\n ticks.push(roundToPrecision(lastTick + niceIncrement));\n }\n\n return ticks;\n};\n","export interface RgbColor {\n r: number;\n g: number;\n b: number;\n}\n\nexport interface RgbaColor extends RgbColor {\n a: number;\n}\n\nexport const rgbToHex = (r: number, g: number, b: number): string => {\n if (r > 255 || g > 255 || b > 255) {\n throw new Error(\"Invalid color component\");\n }\n\n return ((r << 16) | (g << 8) | b).toString(16).padStart(6, \"0\");\n};\n\nexport const hexToRgb = (hex: string): RgbColor => {\n const cleanHex = hex.replace(\"#\", \"\");\n\n const r = parseInt(cleanHex.substring(0, 2), 16);\n const g = parseInt(cleanHex.substring(2, 4), 16);\n const b = parseInt(cleanHex.substring(4, 6), 16);\n\n return { r, g, b };\n};\n\nexport const rgbaToHex = (color: RgbaColor): string => {\n return \"#\" + rgbToHex(color.r, color.g, color.b);\n};\n\nexport const getOpacityHexValue = (opacity: number): string => {\n if (opacity < 0 || opacity > 1) {\n throw new Error(\"Invalid opacity value\");\n }\n\n return Math.round(opacity * 255)\n .toString(16)\n .padStart(2, \"0\");\n};\n\nexport const rgbaToHexWithAlpha = (color: RgbaColor): string => {\n return rgbaToHex(color) + getOpacityHexValue(color.a);\n};\n\nexport const rgbToString = (color: RgbColor): string => {\n return `rgb(${color.r}, ${color.g}, ${color.b})`;\n};\n\nexport const rgbaToString = (color: RgbaColor): string => {\n return `rgba(${color.r}, ${color.g}, ${color.b}, ${color.a})`;\n};\n\nexport const getLuminance = (r: number, g: number, b: number): number => {\n return (0.299 * r + 0.587 * g + 0.114 * b) / 255;\n};\n\nexport const getContrastTextColor = (hexColor: string): string => {\n const { r, g, b } = hexToRgb(hexColor);\n return getLuminance(r, g, b) > 0.5 ? \"#000000\" : \"#ffffff\";\n};\n\n/**\n * Normalized RGB color with values between 0 and 1.\n * Useful for graphics libraries like Three.js.\n */\nexport interface NormalizedRgb {\n r: number;\n g: number;\n b: number;\n}\n\n/**\n * Convert a hex color string to normalized RGB values (0-1 range).\n * @param hex - Hex color string (with or without # prefix)\n * @returns Normalized RGB object with values between 0 and 1\n */\nexport const hexToNormalizedRgb = (hex: string): NormalizedRgb => {\n const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n return result\n ? {\n r: parseInt(result[1], 16) / 255,\n g: parseInt(result[2], 16) / 255,\n b: parseInt(result[3], 16) / 255,\n }\n : { r: 0, g: 0, b: 0 };\n};\n\n/**\n * Determine if a color is light or dark based on relative luminance.\n * Useful for choosing contrasting text colors.\n * @param hex - Hex color string\n * @returns True if the color is considered light (luminance > 0.5)\n */\nexport const isLightColor = (hex: string): boolean => {\n const rgb = hexToNormalizedRgb(hex);\n // Calculate relative luminance using standard coefficients\n const luminance = 0.299 * rgb.r + 0.587 * rgb.g + 0.114 * rgb.b;\n return luminance > 0.5;\n};\n\nconst PERCENT_COLORS = [\n { pct: 0.0, color: { r: 0xff, g: 0x00, b: 0 } },\n { pct: 0.5, color: { r: 0xff, g: 0xff, b: 0 } },\n { pct: 1.0, color: { r: 0x00, g: 0xff, b: 0 } },\n] as const;\n\n// https://stackoverflow.com/a/7128796/704681\nexport const getColorForPercentage = (percent: number): string => {\n if (percent < 0 || percent > 1) {\n throw new Error(`Percentage must be between 0 and 1: ${percent}`);\n }\n\n let i = 0;\n for (i = 1; i < PERCENT_COLORS.length - 1; i++) {\n if (percent < PERCENT_COLORS[i].pct) {\n break;\n }\n }\n\n const lower = PERCENT_COLORS[i - 1];\n const upper = PERCENT_COLORS[i];\n const range = upper.pct - lower.pct;\n const rangePct = (percent - lower.pct) / range;\n const pctLower = 1 - rangePct;\n const pctUpper = rangePct;\n const color = {\n r: Math.floor(lower.color.r * pctLower + upper.color.r * pctUpper),\n g: Math.floor(lower.color.g * pctLower + upper.color.g * pctUpper),\n b: Math.floor(lower.color.b * pctLower + upper.color.b * pctUpper),\n };\n\n return \"rgb(\" + [color.r, color.g, color.b].join(\",\") + \")\";\n};\n","import { format } from \"date-fns\";\nimport { isNullish } from \"./types.utils\";\n\nexport type DateInput = Date | string | number | null;\n\nexport const dateAs_HHMMSS = (value?: DateInput) => {\n if (isNullish(value)) return \"\";\n return format(value, \"HH:mm:ss\");\n};\n\nexport const dateAs_YYYYMMDD = (value?: DateInput) => {\n if (isNullish(value)) return \"\";\n return format(value, \"yyyy-MM-dd\");\n};\n\nexport const dateAs_YYYYMMDD_HHMMSS = (value?: DateInput) => {\n if (isNullish(value)) return \"\";\n return format(value, \"yyyy-MM-dd HH:mm:ss\");\n};\n\nexport const nowAsTime = () => dateAs_HHMMSS(new Date());\nexport const nowAsDate = () => dateAs_YYYYMMDD(new Date());\nexport const nowAsDateTime = () => dateAs_YYYYMMDD_HHMMSS(new Date());\n\nexport const nowAsDateTimeForFilename = () => {\n return format(new Date(), \"yyyy-MM-dd_HH-mm-ss\");\n};\n\nconst DEFAULT_DATE_FORMAT = \"yyyy-MM-dd HH:mm:ss\";\n\n/**\n * Format a Unix timestamp (seconds since epoch) to a human-readable string.\n * @param timestamp - Unix timestamp in seconds\n * @param dateFormat - Date format string (default: \"yyyy-MM-dd HH:mm:ss\")\n * @returns Formatted date string or \"N/A\" if invalid or zero.\n */\nexport const formatUnixTimestamp = (\n timestamp: number,\n dateFormat: string = DEFAULT_DATE_FORMAT\n): string => {\n if (!timestamp) return \"N/A\";\n try {\n return format(new Date(timestamp * 1000), dateFormat);\n } catch {\n return \"Invalid date\";\n }\n};\n\n/**\n * Get the current Unix timestamp in seconds.\n * @returns Current Unix timestamp\n */\nexport const getCurrentUnixTimestamp = (): number => {\n return Math.floor(Date.now() / 1000);\n};\n\n/**\n * Check if a Unix timestamp has expired (is in the past).\n * @param timestamp - Unix timestamp in seconds\n * @returns True if the timestamp is in the past\n */\nexport const isExpiredTimestamp = (timestamp: number): boolean => {\n const now = getCurrentUnixTimestamp();\n return timestamp < now;\n};\n\n/**\n * Check if a Unix timestamp is active (current or past).\n * @param timestamp - Unix timestamp in seconds\n * @returns True if the timestamp is current or in the past\n */\nexport const isActiveTimestamp = (timestamp: number): boolean => {\n const now = getCurrentUnixTimestamp();\n return timestamp <= now;\n};\n","export const getErrorMessage = (error: unknown): string => {\n if (!error) {\n return \"\";\n }\n\n if (typeof error === \"string\") {\n return error;\n }\n\n if (typeof error === \"object\" && \"message\" in error) {\n return (error as { message: string }).message;\n }\n\n return JSON.stringify(error);\n};\n","import { isNullish } from './types.utils';\n\nexport const isHttpSuccessStatus = (status?: number | null): boolean => {\n if (isNullish(status)) {\n return false;\n }\n\n return status >= 200 && status < 300;\n};\n\nexport const isHttpClientErrorStatus = (status?: number | null): boolean => {\n if (isNullish(status)) {\n return false;\n }\n\n return status >= 400 && status < 500;\n};\n\nexport const isHttpServerErrorStatus = (status?: number | null): boolean => {\n if (isNullish(status)) {\n return false;\n }\n\n return status >= 500;\n};\n","import { isNullish, isNumber } from \"./types.utils\";\n\n// Example: toFixed(3.14159, 3) // 3.142\nexport const toFixed = (value?: number | null, decimals = 0): number => {\n if (isNullish(value)) return 0;\n if (decimals < 0) throw new Error(\"[toFixed] decimals must be >= 0\");\n if (decimals === 0) return Math.round(value);\n\n const multiplier = Math.pow(10, decimals);\n return Math.round(value * multiplier) / multiplier;\n};\n\nexport const roundUpToNearest10 = (value?: number | null): number => {\n if (isNullish(value)) return 0;\n return Math.ceil(value / 10) * 10;\n};\n\nexport const getOrderOfMagnitudeExponent = (n?: number | null): number => {\n if (isNullish(n)) return 0;\n if (!isNumber(n)) return 0;\n\n const absValue = Math.abs(n); \n if (absValue === 0) {\n return 0;\n }\n \n const integerPart = Math.floor(absValue);\n return Math.floor(Math.log10(integerPart));\n}\n","export const REGEX_ALPHANUMERIC = /^[a-zA-Z0-9-_ $%#(){}:/.]+$/;\n\nexport const REGEX_IPV4 = /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;\n","import { REGEX_ALPHANUMERIC } from './regex';\nimport { isNullish } from './types.utils';\n\nexport const isBlank = (str?: string | null): str is null | undefined | '' => {\n return isNullish(str) || str?.trim() === '';\n};\n\nexport const isNotBlank = (str?: string | null): str is string => {\n return !isBlank(str);\n};\n\nexport const isAlphanumeric = (value: string): boolean => {\n return REGEX_ALPHANUMERIC.test(value);\n};\n\n/**\n * Removes diacritical marks (e.g., accents, umlauts) from a string.\n * This method normalizes the input string to its canonical decomposition\n * form (NFD) and removes any combining diacritical marks.\n *\n * @param {string} value - The input string to normalize.\n * @returns {string} - The normalized string with diacritical marks removed.\n *\n * @example\n * const result = removeDiacriticalMarks(\"Ça va très bien, n'est-ce pas?\");\n * console.log(result); // \"Ca va tres bien, n'est-ce pas?\"\n */\nexport const removeDiacriticalMarks = (value: string): string => {\n if (!value) {\n return '';\n }\n\n return value.normalize('NFD').replace(/[\\u0300-\\u036f]/g, '');\n};\n\n/**\n * Capitalize the first letter of a string.\n * @param str - The input string\n * @returns The string with the first character uppercased\n */\nexport const capitalizeFirst = (str: string): string => {\n if (!str) return str;\n return str.charAt(0).toUpperCase() + str.slice(1);\n};\n\n/**\n * Count the number of words in a text string.\n * Words are separated by whitespace.\n * @param text - The text to count words in\n * @returns The number of words found\n */\nexport const countWords = (text: string): number => {\n if (!text || text.trim().length === 0) return 0;\n return text.split(/\\s+/).filter((word) => word.length > 0).length;\n};\n\n/**\n * Truncate a string to a maximum length, adding an ellipsis if truncated.\n * @param str - The string to truncate\n * @param maxLength - Maximum length before truncation\n * @param ellipsis - The ellipsis string to append (default: \"...\")\n * @returns The truncated string\n */\nexport const truncate = (str: string, maxLength: number, ellipsis = \"...\"): string => {\n if (!str || str.length <= maxLength) return str;\n return str.slice(0, maxLength - ellipsis.length) + ellipsis;\n};\n","export const sleep = (milliseconds: number) =>\n new Promise((resolve) => setTimeout(resolve, milliseconds));\n","const ONE_SECOND_IN_MS = 1000;\nconst ONE_MINUTE_IN_MS = 60 * ONE_SECOND_IN_MS;\nconst ONE_HOUR_IN_MS = 60 * ONE_MINUTE_IN_MS;\nconst ONE_DAY_IN_MS = 24 * ONE_HOUR_IN_MS;\n\nexport const PeriodsInMS = {\n oneSecond: ONE_SECOND_IN_MS,\n oneMinute: ONE_MINUTE_IN_MS,\n oneHour: ONE_HOUR_IN_MS,\n oneDay: ONE_DAY_IN_MS,\n} as const;\n","import { isNullish } from \"./types.utils\";\n\n/** m³/s to gallons per minute */\nexport const M3PS_TO_GPM = 15850.3;\n\n/** Pascals to feet of head (1 Pa = 1 N/m²) */\nexport const PA_TO_FT = 0.000334553;\n\n/** Watts to Horsepower */\nexport const W_TO_HP = 0.00134102;\n\n/** meters to inches */\nexport const M_TO_INCHES = 39.3701;\n\n/** Hz to RPM (for synchronous speed) */\nexport const HZ_TO_RPM = 60;\n\nexport const fromM3psToGPM = (value?: number | null): number => {\n if (isNullish(value)) return 0;\n\n return value * M3PS_TO_GPM;\n};\n\nexport const fromPaToFt = (value?: number | null): number => {\n if (isNullish(value)) return 0;\n\n return value * PA_TO_FT;\n};\n\nexport const fromWToHp = (value?: number | null): number => {\n if (isNullish(value)) return 0;\n\n return value * W_TO_HP;\n};\n\nexport const fromMToInches = (value?: number | null): number => {\n if (isNullish(value)) return 0;\n\n return value * M_TO_INCHES;\n};\n\nexport const fromHzToRpm = (value?: number | null): number => {\n if (isNullish(value)) return 0;\n\n return value * HZ_TO_RPM;\n};\n","export const SCHEME_PREFIXES = {\n file: 'file',\n content: 'content',\n http: 'http',\n https: 'https',\n ftp: 'ftp',\n ftps: 'ftps',\n sftp: 'sftp',\n smb: 'smb',\n} as const;\n\nconst SCHEME_PREFIXES_ARRAY = Object.values(SCHEME_PREFIXES);\n\nexport const hasScheme = (uri?: string | null): boolean => {\n if (!uri) {\n return false;\n }\n\n const lowerUri = uri.toLowerCase();\n return SCHEME_PREFIXES_ARRAY.some((prefix) => lowerUri.startsWith(`${prefix}://`));\n};\n\n/**\n * Extracts the base64 data from a data URI string.\n * Data URIs have the format: data:[<mediatype>][;base64],<data>\n * This function extracts everything after the first comma.\n *\n * @param dataUri - The data URI string (e.g., \"data:image/png;base64,iVBORw0KG...\")\n * @returns The base64 data without the data URI prefix, or the original string if no comma is found\n */\nexport const extractBase64FromDataUri = (dataUri: string): string => {\n return dataUri.split(',')[1] ?? dataUri;\n};\n","import { isNullish } from \"./types.utils\";\n\nconst WEBSOCKET_CONNECT_STATES: number[] = [WebSocket.CONNECTING, WebSocket.OPEN] as const;\n\nexport const isWsClosable = (ws?: WebSocket | null): ws is WebSocket => {\n if (isNullish(ws)) return false;\n return WEBSOCKET_CONNECT_STATES.includes(ws.readyState);\n};\n\nexport const isWsOpenOrConnecting = (ws?: WebSocket | null): ws is WebSocket => {\n if (isNullish(ws)) return false;\n return WEBSOCKET_CONNECT_STATES.includes(ws.readyState);\n};\n\nexport const closeWebSocket = (ws?: WebSocket | null) => {\n if (isNullish(ws) || !isWsClosable(ws)) return;\n\n try {\n ws.close();\n } catch {\n // do nothing (best effort to close, ignore unexpected errors)\n }\n};\n"],"mappings":"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","names":[]}