@digicroz/js-kit 1.0.0 → 1.0.2

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 (61) hide show
  1. package/dist/array/index.cjs +20 -0
  2. package/dist/array/index.cjs.map +1 -0
  3. package/dist/array/index.d.cts +9 -0
  4. package/dist/array/index.d.ts +9 -0
  5. package/dist/array/index.js +18 -0
  6. package/dist/array/index.js.map +1 -0
  7. package/dist/index.cjs +314 -0
  8. package/dist/index.cjs.map +1 -0
  9. package/dist/index.d.cts +9 -0
  10. package/dist/index.d.ts +9 -0
  11. package/dist/index.js +286 -0
  12. package/dist/index.js.map +1 -0
  13. package/dist/number/index.cjs +61 -0
  14. package/dist/number/index.cjs.map +1 -0
  15. package/dist/number/index.d.cts +21 -0
  16. package/dist/number/index.d.ts +21 -0
  17. package/dist/number/index.js +55 -0
  18. package/dist/number/index.js.map +1 -0
  19. package/dist/sleep/index.cjs +93 -0
  20. package/dist/sleep/index.cjs.map +1 -0
  21. package/dist/sleep/index.d.cts +56 -0
  22. package/dist/sleep/index.d.ts +56 -0
  23. package/dist/sleep/index.js +87 -0
  24. package/dist/sleep/index.js.map +1 -0
  25. package/dist/string/capitalize.cjs +32 -0
  26. package/dist/string/capitalize.cjs.map +1 -0
  27. package/dist/string/capitalize.d.cts +15 -0
  28. package/dist/string/capitalize.d.ts +15 -0
  29. package/dist/string/capitalize.js +28 -0
  30. package/dist/string/capitalize.js.map +1 -0
  31. package/dist/string/index.cjs +51 -0
  32. package/dist/string/index.cjs.map +1 -0
  33. package/dist/string/index.d.cts +6 -0
  34. package/dist/string/index.d.ts +6 -0
  35. package/dist/string/index.js +45 -0
  36. package/dist/string/index.js.map +1 -0
  37. package/dist/string/truncate.cjs +14 -0
  38. package/dist/string/truncate.cjs.map +1 -0
  39. package/dist/string/truncate.d.cts +8 -0
  40. package/dist/string/truncate.d.ts +8 -0
  41. package/dist/string/truncate.js +12 -0
  42. package/dist/string/truncate.js.map +1 -0
  43. package/dist/time/index.cjs +55 -0
  44. package/dist/time/index.cjs.map +1 -0
  45. package/dist/time/index.d.cts +39 -0
  46. package/dist/time/index.d.ts +39 -0
  47. package/dist/time/index.js +50 -0
  48. package/dist/time/index.js.map +1 -0
  49. package/dist/types/index.cjs +4 -0
  50. package/dist/types/index.cjs.map +1 -0
  51. package/dist/types/index.d.cts +5 -0
  52. package/dist/types/index.d.ts +5 -0
  53. package/dist/types/index.js +3 -0
  54. package/dist/types/index.js.map +1 -0
  55. package/dist/utils/index.cjs +54 -0
  56. package/dist/utils/index.cjs.map +1 -0
  57. package/dist/utils/index.d.cts +43 -0
  58. package/dist/utils/index.d.ts +43 -0
  59. package/dist/utils/index.js +46 -0
  60. package/dist/utils/index.js.map +1 -0
  61. package/package.json +3 -2
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+
3
+ // src/array/index.ts
4
+ function chunk(array, size) {
5
+ if (size <= 0) {
6
+ throw new Error("Chunk size must be greater than 0");
7
+ }
8
+ if (array.length === 0) {
9
+ return [];
10
+ }
11
+ const chunks = [];
12
+ for (let i = 0; i < array.length; i += size) {
13
+ chunks.push(array.slice(i, i + size));
14
+ }
15
+ return chunks;
16
+ }
17
+
18
+ exports.chunk = chunk;
19
+ //# sourceMappingURL=index.cjs.map
20
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/array/index.ts"],"names":[],"mappings":";;;AAMO,SAAS,KAAA,CAAS,OAAY,IAAA,EAAqB;AACxD,EAAA,IAAI,QAAQ,CAAA,EAAG;AACb,IAAA,MAAM,IAAI,MAAM,mCAAmC,CAAA;AAAA;AAGrD,EAAA,IAAI,KAAA,CAAM,WAAW,CAAA,EAAG;AACtB,IAAA,OAAO,EAAC;AAAA;AAGV,EAAA,MAAM,SAAgB,EAAC;AACvB,EAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,KAAA,CAAM,MAAA,EAAQ,KAAK,IAAA,EAAM;AAC3C,IAAA,MAAA,CAAO,KAAK,KAAA,CAAM,KAAA,CAAM,CAAA,EAAG,CAAA,GAAI,IAAI,CAAC,CAAA;AAAA;AAGtC,EAAA,OAAO,MAAA;AACT","file":"index.cjs","sourcesContent":["/**\r\n * Splits an array into chunks of a specified size\r\n * @param array - The array to chunk\r\n * @param size - The size of each chunk\r\n * @returns An array of chunks\r\n */\r\nexport function chunk<T>(array: T[], size: number): T[][] {\r\n if (size <= 0) {\r\n throw new Error('Chunk size must be greater than 0');\r\n }\r\n \r\n if (array.length === 0) {\r\n return [];\r\n }\r\n \r\n const chunks: T[][] = [];\r\n for (let i = 0; i < array.length; i += size) {\r\n chunks.push(array.slice(i, i + size));\r\n }\r\n \r\n return chunks;\r\n}\r\n"]}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Splits an array into chunks of a specified size
3
+ * @param array - The array to chunk
4
+ * @param size - The size of each chunk
5
+ * @returns An array of chunks
6
+ */
7
+ declare function chunk<T>(array: T[], size: number): T[][];
8
+
9
+ export { chunk };
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Splits an array into chunks of a specified size
3
+ * @param array - The array to chunk
4
+ * @param size - The size of each chunk
5
+ * @returns An array of chunks
6
+ */
7
+ declare function chunk<T>(array: T[], size: number): T[][];
8
+
9
+ export { chunk };
@@ -0,0 +1,18 @@
1
+ // src/array/index.ts
2
+ function chunk(array, size) {
3
+ if (size <= 0) {
4
+ throw new Error("Chunk size must be greater than 0");
5
+ }
6
+ if (array.length === 0) {
7
+ return [];
8
+ }
9
+ const chunks = [];
10
+ for (let i = 0; i < array.length; i += size) {
11
+ chunks.push(array.slice(i, i + size));
12
+ }
13
+ return chunks;
14
+ }
15
+
16
+ export { chunk };
17
+ //# sourceMappingURL=index.js.map
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/array/index.ts"],"names":[],"mappings":";AAMO,SAAS,KAAA,CAAS,OAAY,IAAA,EAAqB;AACxD,EAAA,IAAI,QAAQ,CAAA,EAAG;AACb,IAAA,MAAM,IAAI,MAAM,mCAAmC,CAAA;AAAA;AAGrD,EAAA,IAAI,KAAA,CAAM,WAAW,CAAA,EAAG;AACtB,IAAA,OAAO,EAAC;AAAA;AAGV,EAAA,MAAM,SAAgB,EAAC;AACvB,EAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,KAAA,CAAM,MAAA,EAAQ,KAAK,IAAA,EAAM;AAC3C,IAAA,MAAA,CAAO,KAAK,KAAA,CAAM,KAAA,CAAM,CAAA,EAAG,CAAA,GAAI,IAAI,CAAC,CAAA;AAAA;AAGtC,EAAA,OAAO,MAAA;AACT","file":"index.js","sourcesContent":["/**\r\n * Splits an array into chunks of a specified size\r\n * @param array - The array to chunk\r\n * @param size - The size of each chunk\r\n * @returns An array of chunks\r\n */\r\nexport function chunk<T>(array: T[], size: number): T[][] {\r\n if (size <= 0) {\r\n throw new Error('Chunk size must be greater than 0');\r\n }\r\n \r\n if (array.length === 0) {\r\n return [];\r\n }\r\n \r\n const chunks: T[][] = [];\r\n for (let i = 0; i < array.length; i += size) {\r\n chunks.push(array.slice(i, i + size));\r\n }\r\n \r\n return chunks;\r\n}\r\n"]}
package/dist/index.cjs ADDED
@@ -0,0 +1,314 @@
1
+ 'use strict';
2
+
3
+ // src/array/index.ts
4
+ function chunk(array, size) {
5
+ if (size <= 0) {
6
+ throw new Error("Chunk size must be greater than 0");
7
+ }
8
+ if (array.length === 0) {
9
+ return [];
10
+ }
11
+ const chunks = [];
12
+ for (let i = 0; i < array.length; i += size) {
13
+ chunks.push(array.slice(i, i + size));
14
+ }
15
+ return chunks;
16
+ }
17
+
18
+ // src/string/capitalize.ts
19
+ function capitalize(str) {
20
+ if (typeof str !== "string") {
21
+ throw new Error("Input must be a string");
22
+ }
23
+ if (str.length === 0) {
24
+ return str;
25
+ }
26
+ return str.charAt(0).toUpperCase() + str.slice(1);
27
+ }
28
+ function capitalizeWords(str) {
29
+ if (typeof str !== "string") {
30
+ throw new Error("Input must be a string");
31
+ }
32
+ return str.replace(/\b\w/g, (char) => char.toUpperCase());
33
+ }
34
+ function convertCamelToNormalCapitalized(camelCaseString) {
35
+ const words = camelCaseString.replace(/([a-z])([A-Z])/g, "$1 $2").split(/[\s_]+/);
36
+ const capitalizedWords = words.map(
37
+ (word) => word.charAt(0).toUpperCase() + word.slice(1)
38
+ );
39
+ const normalCapitalizedString = capitalizedWords.join(" ");
40
+ return normalCapitalizedString;
41
+ }
42
+
43
+ // src/string/truncate.ts
44
+ function truncateText({
45
+ text,
46
+ maxLength = 10,
47
+ suffix = "..."
48
+ }) {
49
+ return text.length > maxLength ? text.substring(0, maxLength) + suffix : text;
50
+ }
51
+
52
+ // src/string/index.ts
53
+ function randomStringWithFixedLength(length) {
54
+ if (!Number.isInteger(length) || length <= 0) {
55
+ throw new Error("Length must be a positive integer.");
56
+ }
57
+ return Array.from({ length }, () => Math.random().toString(36)[2]).join("");
58
+ }
59
+
60
+ // src/number/index.ts
61
+ function clamp(number, lower, upper) {
62
+ if (typeof number !== "number" || typeof lower !== "number" || typeof upper !== "number") {
63
+ throw new Error("All arguments must be numbers");
64
+ }
65
+ if (lower > upper) {
66
+ throw new Error("Lower bound must be less than or equal to upper bound");
67
+ }
68
+ return Math.min(Math.max(number, lower), upper);
69
+ }
70
+ function inRange(number, lower, upper) {
71
+ if (typeof number !== "number" || typeof lower !== "number" || typeof upper !== "number") {
72
+ throw new Error("All arguments must be numbers");
73
+ }
74
+ if (lower > upper) {
75
+ throw new Error("Lower bound must be less than or equal to upper bound");
76
+ }
77
+ return number >= lower && number <= upper;
78
+ }
79
+ var convertToInt = (data) => {
80
+ if (isNaN(data)) {
81
+ throw new Error("Invalid input: not a number");
82
+ }
83
+ if (data === null || data === void 0) {
84
+ throw new Error("Invalid input: null or undefined");
85
+ }
86
+ if (typeof data === "number") {
87
+ data = data + "";
88
+ }
89
+ return +parseInt(data);
90
+ };
91
+ var convertToTwoDecimalInt = (data) => {
92
+ if (isNaN(data)) {
93
+ throw new Error("Invalid input: not a number");
94
+ }
95
+ if (data === null || data === void 0) {
96
+ throw new Error("Invalid input: null or undefined");
97
+ }
98
+ if (typeof data === "number") {
99
+ data = data + "";
100
+ }
101
+ return +parseFloat(data).toFixed(2);
102
+ };
103
+ var randomNumberWithFixedLength = (length) => {
104
+ if (length <= 0 || !Number.isInteger(length)) {
105
+ throw new Error("Length must be a positive integer.");
106
+ }
107
+ return Math.floor(
108
+ Math.pow(10, length - 1) + Math.random() * (9 * Math.pow(10, length - 1))
109
+ );
110
+ };
111
+
112
+ // src/sleep/index.ts
113
+ var sleep = (params) => {
114
+ return new Promise((resolve, reject) => {
115
+ let delayMs = 0;
116
+ try {
117
+ if (!params || Object.keys(params).length === 0) {
118
+ throw new Error("Sleep parameters cannot be empty");
119
+ }
120
+ if (params.until?.unixTimestamp) {
121
+ const now = Date.now();
122
+ const targetTime = params.until.unixTimestamp * 1e3;
123
+ delayMs = Math.max(0, targetTime - now);
124
+ if (delayMs === 0) {
125
+ resolve();
126
+ return;
127
+ }
128
+ } else if (params.random) {
129
+ if (params.random.milliseconds) {
130
+ const { min, max } = params.random.milliseconds;
131
+ if (min < 0 || max < 0 || min > max) {
132
+ throw new Error("Invalid random milliseconds range");
133
+ }
134
+ delayMs = Math.random() * (max - min) + min;
135
+ } else if (params.random.seconds) {
136
+ const { min, max } = params.random.seconds;
137
+ if (min < 0 || max < 0 || min > max) {
138
+ throw new Error("Invalid random seconds range");
139
+ }
140
+ delayMs = (Math.random() * (max - min) + min) * 1e3;
141
+ } else if (params.random.minutes) {
142
+ const { min, max } = params.random.minutes;
143
+ if (min < 0 || max < 0 || min > max) {
144
+ throw new Error("Invalid random minutes range");
145
+ }
146
+ delayMs = (Math.random() * (max - min) + min) * 60 * 1e3;
147
+ } else {
148
+ throw new Error("Random delay type must be specified (milliseconds, seconds, or minutes)");
149
+ }
150
+ } else {
151
+ if (params.milliseconds !== void 0) {
152
+ if (params.milliseconds < 0) {
153
+ throw new Error("Milliseconds cannot be negative");
154
+ }
155
+ delayMs += params.milliseconds;
156
+ }
157
+ if (params.seconds !== void 0) {
158
+ if (params.seconds < 0) {
159
+ throw new Error("Seconds cannot be negative");
160
+ }
161
+ delayMs += params.seconds * 1e3;
162
+ }
163
+ if (params.minutes !== void 0) {
164
+ if (params.minutes < 0) {
165
+ throw new Error("Minutes cannot be negative");
166
+ }
167
+ delayMs += params.minutes * 60 * 1e3;
168
+ }
169
+ if (delayMs === 0 && !params.milliseconds && !params.seconds && !params.minutes) {
170
+ throw new Error("At least one delay parameter must be specified");
171
+ }
172
+ }
173
+ const MAX_DELAY = 2147483647;
174
+ if (delayMs > MAX_DELAY) {
175
+ throw new Error(`Delay too large. Maximum delay is ${MAX_DELAY}ms`);
176
+ }
177
+ setTimeout(resolve, Math.floor(delayMs));
178
+ } catch (error) {
179
+ reject(error);
180
+ }
181
+ });
182
+ };
183
+ var sleepMs = (ms) => {
184
+ return sleep({ milliseconds: ms });
185
+ };
186
+ var sleepSeconds = (seconds) => {
187
+ return sleep({ seconds });
188
+ };
189
+ var sleepMinutes = (minutes) => {
190
+ return sleep({ minutes });
191
+ };
192
+ var sleepUntil = (unixTimestamp) => {
193
+ return sleep({ until: { unixTimestamp } });
194
+ };
195
+
196
+ // src/time/index.ts
197
+ function convertToSeconds(options = {}) {
198
+ const {
199
+ seconds = 0,
200
+ minutes = 0,
201
+ hours = 0,
202
+ days = 0,
203
+ months = 0,
204
+ years = 0
205
+ } = options;
206
+ const SECONDS_PER_MINUTE = 60;
207
+ const SECONDS_PER_HOUR = 60 * 60;
208
+ const SECONDS_PER_DAY = 60 * 60 * 24;
209
+ const SECONDS_PER_MONTH = 60 * 60 * 24 * 30;
210
+ const SECONDS_PER_YEAR = 60 * 60 * 24 * 365;
211
+ return seconds + minutes * SECONDS_PER_MINUTE + hours * SECONDS_PER_HOUR + days * SECONDS_PER_DAY + months * SECONDS_PER_MONTH + years * SECONDS_PER_YEAR;
212
+ }
213
+ var getUnixTimestampMs = (date) => {
214
+ if (date === void 0) {
215
+ return Date.now();
216
+ }
217
+ if (typeof date === "number") {
218
+ const testDate = new Date(date);
219
+ if (isNaN(testDate.getTime())) {
220
+ throw new Error("Invalid timestamp provided");
221
+ }
222
+ const now = Date.now();
223
+ const hundredYearsFromNow = now + 100 * 365 * 24 * 60 * 60 * 1e3;
224
+ if (date < 0 || date > hundredYearsFromNow) {
225
+ throw new Error("Timestamp is outside valid range");
226
+ }
227
+ return date;
228
+ }
229
+ const dateObj = new Date(date);
230
+ if (isNaN(dateObj.getTime())) {
231
+ throw new Error("Invalid date provided");
232
+ }
233
+ return dateObj.getTime();
234
+ };
235
+ var getUnixTimestamp = (date) => {
236
+ return Math.floor(getUnixTimestampMs(date) / 1e3);
237
+ };
238
+ var getFullYear = (date) => {
239
+ const targetDate = date || /* @__PURE__ */ new Date();
240
+ return targetDate.getFullYear();
241
+ };
242
+
243
+ // src/utils/index.ts
244
+ function isNodeEnvironment() {
245
+ return typeof process !== "undefined" && process.versions != null && process.versions.node != null;
246
+ }
247
+ function isBrowserEnvironment() {
248
+ return typeof window !== "undefined" && typeof document !== "undefined";
249
+ }
250
+ function isWebWorkerEnvironment() {
251
+ return typeof globalThis.importScripts === "function" && typeof window === "undefined";
252
+ }
253
+ function getEnvironment() {
254
+ if (isNodeEnvironment()) return "node";
255
+ if (isBrowserEnvironment()) return "browser";
256
+ if (isWebWorkerEnvironment()) return "webworker";
257
+ return "unknown";
258
+ }
259
+ var EnvironmentError = class extends Error {
260
+ constructor(message, requiredEnvironment, currentEnvironment) {
261
+ super(message);
262
+ this.requiredEnvironment = requiredEnvironment;
263
+ this.currentEnvironment = currentEnvironment;
264
+ this.name = "EnvironmentError";
265
+ }
266
+ };
267
+ function assertNodeEnvironment() {
268
+ if (!isNodeEnvironment()) {
269
+ throw new EnvironmentError(
270
+ "This functionality requires Node.js environment",
271
+ "node",
272
+ getEnvironment()
273
+ );
274
+ }
275
+ }
276
+ function assertBrowserEnvironment() {
277
+ if (!isBrowserEnvironment()) {
278
+ throw new EnvironmentError(
279
+ "This functionality requires browser environment",
280
+ "browser",
281
+ getEnvironment()
282
+ );
283
+ }
284
+ }
285
+
286
+ exports.EnvironmentError = EnvironmentError;
287
+ exports.assertBrowserEnvironment = assertBrowserEnvironment;
288
+ exports.assertNodeEnvironment = assertNodeEnvironment;
289
+ exports.capitalize = capitalize;
290
+ exports.capitalizeWords = capitalizeWords;
291
+ exports.chunk = chunk;
292
+ exports.clamp = clamp;
293
+ exports.convertCamelToNormalCapitalized = convertCamelToNormalCapitalized;
294
+ exports.convertToInt = convertToInt;
295
+ exports.convertToSeconds = convertToSeconds;
296
+ exports.convertToTwoDecimalInt = convertToTwoDecimalInt;
297
+ exports.getEnvironment = getEnvironment;
298
+ exports.getFullYear = getFullYear;
299
+ exports.getUnixTimestamp = getUnixTimestamp;
300
+ exports.getUnixTimestampMs = getUnixTimestampMs;
301
+ exports.inRange = inRange;
302
+ exports.isBrowserEnvironment = isBrowserEnvironment;
303
+ exports.isNodeEnvironment = isNodeEnvironment;
304
+ exports.isWebWorkerEnvironment = isWebWorkerEnvironment;
305
+ exports.randomNumberWithFixedLength = randomNumberWithFixedLength;
306
+ exports.randomStringWithFixedLength = randomStringWithFixedLength;
307
+ exports.sleep = sleep;
308
+ exports.sleepMinutes = sleepMinutes;
309
+ exports.sleepMs = sleepMs;
310
+ exports.sleepSeconds = sleepSeconds;
311
+ exports.sleepUntil = sleepUntil;
312
+ exports.truncateText = truncateText;
313
+ //# sourceMappingURL=index.cjs.map
314
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/array/index.ts","../src/string/capitalize.ts","../src/string/truncate.ts","../src/string/index.ts","../src/number/index.ts","../src/sleep/index.ts","../src/time/index.ts","../src/utils/index.ts"],"names":[],"mappings":"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","file":"index.cjs","sourcesContent":["/**\r\n * Splits an array into chunks of a specified size\r\n * @param array - The array to chunk\r\n * @param size - The size of each chunk\r\n * @returns An array of chunks\r\n */\r\nexport function chunk<T>(array: T[], size: number): T[][] {\r\n if (size <= 0) {\r\n throw new Error('Chunk size must be greater than 0');\r\n }\r\n \r\n if (array.length === 0) {\r\n return [];\r\n }\r\n \r\n const chunks: T[][] = [];\r\n for (let i = 0; i < array.length; i += size) {\r\n chunks.push(array.slice(i, i + size));\r\n }\r\n \r\n return chunks;\r\n}\r\n","/**\r\n * Capitalizes the first letter of a string\r\n * @param str - The string to capitalize\r\n * @returns The capitalized string\r\n */\r\nexport function capitalize(str: string): string {\r\n if (typeof str !== 'string') {\r\n throw new Error('Input must be a string');\r\n }\r\n \r\n if (str.length === 0) {\r\n return str;\r\n }\r\n \r\n return str.charAt(0).toUpperCase() + str.slice(1);\r\n}\r\n\r\n/**\r\n * Capitalizes the first letter of each word in a string\r\n * @param str - The string to capitalize\r\n * @returns The string with each word capitalized\r\n */\r\nexport function capitalizeWords(str: string): string {\r\n if (typeof str !== 'string') {\r\n throw new Error('Input must be a string');\r\n }\r\n \r\n return str.replace(/\\b\\w/g, (char) => char.toUpperCase());\r\n}\r\n\r\nexport function convertCamelToNormalCapitalized(\r\n camelCaseString: string\r\n): string {\r\n // Split the camelCase string into words\r\n const words = camelCaseString\r\n .replace(/([a-z])([A-Z])/g, \"$1 $2\")\r\n .split(/[\\s_]+/);\r\n\r\n // Capitalize each word\r\n const capitalizedWords = words.map(\r\n (word) => word.charAt(0).toUpperCase() + word.slice(1)\r\n );\r\n\r\n // Join the capitalized words to form the normal capitalized string\r\n const normalCapitalizedString = capitalizedWords.join(\" \");\r\n\r\n return normalCapitalizedString;\r\n}","\r\nexport type TruncateTextOptions = {\r\n text: string;\r\n maxLength?: number;\r\n suffix?: string;\r\n};\r\n\r\nexport function truncateText({\r\n text,\r\n maxLength = 10,\r\n suffix = '...',\r\n}: TruncateTextOptions): string {\r\n return text.length > maxLength\r\n ? text.substring(0, maxLength) + suffix\r\n : text;\r\n}\r\n","\r\nexport * from './capitalize';\r\nexport * from './truncate';\r\n\r\nexport function randomStringWithFixedLength(length: number): string {\r\n if (!Number.isInteger(length) || length <= 0) {\r\n throw new Error(\"Length must be a positive integer.\");\r\n }\r\n\r\n return Array.from({ length }, () => Math.random().toString(36)[2]).join(\"\");\r\n}","/**\r\n * Clamps a number within the inclusive lower and upper bounds\r\n * @param number - The number to clamp\r\n * @param lower - The lower bound\r\n * @param upper - The upper bound\r\n * @returns The clamped number\r\n */\r\nexport function clamp(number: number, lower: number, upper: number): number {\r\n if (typeof number !== 'number' || typeof lower !== 'number' || typeof upper !== 'number') {\r\n throw new Error('All arguments must be numbers');\r\n }\r\n \r\n if (lower > upper) {\r\n throw new Error('Lower bound must be less than or equal to upper bound');\r\n }\r\n \r\n return Math.min(Math.max(number, lower), upper);\r\n}\r\n\r\n/**\r\n * Checks if a number is within the inclusive range\r\n * @param number - The number to check\r\n * @param lower - The lower bound\r\n * @param upper - The upper bound\r\n * @returns True if the number is within the range\r\n */\r\nexport function inRange(number: number, lower: number, upper: number): boolean {\r\n if (typeof number !== 'number' || typeof lower !== 'number' || typeof upper !== 'number') {\r\n throw new Error('All arguments must be numbers');\r\n }\r\n \r\n if (lower > upper) {\r\n throw new Error('Lower bound must be less than or equal to upper bound');\r\n }\r\n \r\n return number >= lower && number <= upper;\r\n}\r\n\r\n\r\nexport const convertToInt = (data: any): number => {\r\n if (isNaN(data)) {\r\n throw new Error('Invalid input: not a number');\r\n }\r\n if (data === null || data === undefined) {\r\n throw new Error('Invalid input: null or undefined');\r\n }\r\n\r\n if (typeof data === 'number') {\r\n data = data + '';\r\n }\r\n\r\n return +parseInt(data);\r\n};\r\n\r\nexport const convertToTwoDecimalInt = (data: any): number => {\r\n if (isNaN(data)) {\r\n throw new Error('Invalid input: not a number');\r\n }\r\n if (data === null || data === undefined) {\r\n throw new Error('Invalid input: null or undefined');\r\n }\r\n\r\n if (typeof data === 'number') {\r\n data = data + '';\r\n }\r\n return +parseFloat(data).toFixed(2);\r\n};\r\n\r\nexport const randomNumberWithFixedLength = (length: number): number => {\r\n if (length <= 0 || !Number.isInteger(length)) {\r\n throw new Error('Length must be a positive integer.');\r\n }\r\n return Math.floor(\r\n Math.pow(10, length - 1) +\r\n Math.random() * (9 * Math.pow(10, length - 1))\r\n );\r\n};\r\n","type TSleepParams ={\r\n milliseconds?: number;\r\n seconds?: number;\r\n minutes?: number;\r\n until?: {\r\n unixTimestamp?: number;\r\n };\r\n random?:{\r\n milliseconds?: {\r\n min: number;\r\n max: number;\r\n }\r\n seconds?: {\r\n min: number;\r\n max: number;\r\n }\r\n minutes?: {\r\n min: number;\r\n max: number;\r\n }\r\n }\r\n}\r\n\r\ntype TSleepReturn = Promise<void>;\r\n\r\n/**\r\n * Sleep function that supports various delay options\r\n * @param params - Sleep parameters including fixed delays, random delays, or until timestamp\r\n * @returns Promise that resolves after the specified delay\r\n * @throws Error if invalid parameters are provided\r\n */\r\nexport const sleep = (params: TSleepParams): TSleepReturn => {\r\n return new Promise((resolve, reject) => {\r\n let delayMs = 0;\r\n\r\n try {\r\n // Validate input parameters\r\n if (!params || Object.keys(params).length === 0) {\r\n throw new Error('Sleep parameters cannot be empty');\r\n }\r\n\r\n // Handle sleeping until a specific timestamp\r\n if (params.until?.unixTimestamp) {\r\n const now = Date.now();\r\n const targetTime = params.until.unixTimestamp * 1000; // Convert to milliseconds\r\n delayMs = Math.max(0, targetTime - now);\r\n \r\n // If the timestamp is in the past, resolve immediately\r\n if (delayMs === 0) {\r\n resolve();\r\n return;\r\n }\r\n }\r\n // Handle random delays\r\n else if (params.random) {\r\n if (params.random.milliseconds) {\r\n const { min, max } = params.random.milliseconds;\r\n if (min < 0 || max < 0 || min > max) {\r\n throw new Error('Invalid random milliseconds range');\r\n }\r\n delayMs = Math.random() * (max - min) + min;\r\n } else if (params.random.seconds) {\r\n const { min, max } = params.random.seconds;\r\n if (min < 0 || max < 0 || min > max) {\r\n throw new Error('Invalid random seconds range');\r\n }\r\n delayMs = (Math.random() * (max - min) + min) * 1000;\r\n } else if (params.random.minutes) {\r\n const { min, max } = params.random.minutes;\r\n if (min < 0 || max < 0 || min > max) {\r\n throw new Error('Invalid random minutes range');\r\n }\r\n delayMs = (Math.random() * (max - min) + min) * 60 * 1000;\r\n } else {\r\n throw new Error('Random delay type must be specified (milliseconds, seconds, or minutes)');\r\n }\r\n }\r\n // Handle fixed delays\r\n else {\r\n if (params.milliseconds !== undefined) {\r\n if (params.milliseconds < 0) {\r\n throw new Error('Milliseconds cannot be negative');\r\n }\r\n delayMs += params.milliseconds;\r\n }\r\n if (params.seconds !== undefined) {\r\n if (params.seconds < 0) {\r\n throw new Error('Seconds cannot be negative');\r\n }\r\n delayMs += params.seconds * 1000;\r\n }\r\n if (params.minutes !== undefined) {\r\n if (params.minutes < 0) {\r\n throw new Error('Minutes cannot be negative');\r\n }\r\n delayMs += params.minutes * 60 * 1000;\r\n }\r\n\r\n // If no valid delay was specified\r\n if (delayMs === 0 && !params.milliseconds && !params.seconds && !params.minutes) {\r\n throw new Error('At least one delay parameter must be specified');\r\n }\r\n }\r\n\r\n // Ensure delay is not too large (prevent potential issues)\r\n const MAX_DELAY = 2147483647; // Maximum value for setTimeout\r\n if (delayMs > MAX_DELAY) {\r\n throw new Error(`Delay too large. Maximum delay is ${MAX_DELAY}ms`);\r\n }\r\n\r\n setTimeout(resolve, Math.floor(delayMs));\r\n } catch (error) {\r\n reject(error);\r\n }\r\n });\r\n};\r\n\r\n/**\r\n * Convenience function to sleep for a specific number of milliseconds\r\n * @param ms - Number of milliseconds to sleep\r\n * @returns Promise that resolves after the specified delay\r\n */\r\nexport const sleepMs = (ms: number): TSleepReturn => {\r\n return sleep({ milliseconds: ms });\r\n};\r\n\r\n/**\r\n * Convenience function to sleep for a specific number of seconds\r\n * @param seconds - Number of seconds to sleep\r\n * @returns Promise that resolves after the specified delay\r\n */\r\nexport const sleepSeconds = (seconds: number): TSleepReturn => {\r\n return sleep({ seconds });\r\n};\r\n\r\n/**\r\n * Convenience function to sleep for a specific number of minutes\r\n * @param minutes - Number of minutes to sleep\r\n * @returns Promise that resolves after the specified delay\r\n */\r\nexport const sleepMinutes = (minutes: number): TSleepReturn => {\r\n return sleep({ minutes });\r\n};\r\n\r\n/**\r\n * Convenience function to sleep until a specific Unix timestamp\r\n * @param unixTimestamp - Unix timestamp (in seconds) to sleep until\r\n * @returns Promise that resolves at the specified timestamp\r\n */\r\nexport const sleepUntil = (unixTimestamp: number): TSleepReturn => {\r\n return sleep({ until: { unixTimestamp } });\r\n};\r\n\r\n// Export the type definitions for consumers\r\nexport type { TSleepParams, TSleepReturn };","/**\r\n * Converts various time units to total seconds\r\n * @param options - Object containing optional time units\r\n * @param options.seconds - Number of seconds (default: 0)\r\n * @param options.minutes - Number of minutes (default: 0)\r\n * @param options.hours - Number of hours (default: 0)\r\n * @param options.days - Number of days (default: 0)\r\n * @param options.months - Number of months (default: 0, assumes 30 days per month)\r\n * @param options.years - Number of years (default: 0, assumes 365 days per year)\r\n * @returns Total time in seconds\r\n */\r\nexport function convertToSeconds(\r\n options: {\r\n seconds?: number\r\n minutes?: number\r\n hours?: number\r\n days?: number\r\n months?: number\r\n years?: number\r\n } = {}\r\n): number {\r\n const {\r\n seconds = 0,\r\n minutes = 0,\r\n hours = 0,\r\n days = 0,\r\n months = 0,\r\n years = 0,\r\n } = options\r\n\r\n // Time conversion constants\r\n const SECONDS_PER_MINUTE = 60\r\n const SECONDS_PER_HOUR = 60 * 60\r\n const SECONDS_PER_DAY = 60 * 60 * 24\r\n const SECONDS_PER_MONTH = 60 * 60 * 24 * 30 // Assuming 30 days per month\r\n const SECONDS_PER_YEAR = 60 * 60 * 24 * 365 // Assuming 365 days per year\r\n\r\n return (\r\n seconds +\r\n minutes * SECONDS_PER_MINUTE +\r\n hours * SECONDS_PER_HOUR +\r\n days * SECONDS_PER_DAY +\r\n months * SECONDS_PER_MONTH +\r\n years * SECONDS_PER_YEAR\r\n )\r\n}\r\n\r\n/**\r\n * Gets Unix timestamp in milliseconds\r\n * @param date - Optional Date object, date string, or timestamp. If not provided, uses current date\r\n * @returns Unix timestamp in milliseconds\r\n */\r\nexport const getUnixTimestampMs = (date?: Date | string | number): number => {\r\n if (date === undefined) {\r\n return Date.now()\r\n }\r\n\r\n if (typeof date === \"number\") {\r\n const testDate = new Date(date)\r\n if (isNaN(testDate.getTime())) {\r\n throw new Error(\"Invalid timestamp provided\")\r\n }\r\n\r\n // Timestamps should be positive and not too far in the future\r\n const now = Date.now()\r\n const hundredYearsFromNow = now + 100 * 365 * 24 * 60 * 60 * 1000 // 100 years\r\n\r\n if (date < 0 || date > hundredYearsFromNow) {\r\n throw new Error(\"Timestamp is outside valid range\")\r\n }\r\n\r\n return date\r\n }\r\n\r\n const dateObj = new Date(date)\r\n\r\n if (isNaN(dateObj.getTime())) {\r\n throw new Error(\"Invalid date provided\")\r\n }\r\n\r\n return dateObj.getTime()\r\n}\r\n\r\n/**\r\n * Gets Unix timestamp in seconds\r\n * @param date - Optional Date object, date string, or timestamp. If not provided, uses current date\r\n * @returns Unix timestamp in seconds\r\n */\r\nexport const getUnixTimestamp = (date?: Date | string | number): number => {\r\n return Math.floor(getUnixTimestampMs(date) / 1000)\r\n}\r\n\r\n/**\r\n * Gets the full year from a Date object or the current date\r\n * @param date - Optional Date object. If not provided, uses current date\r\n * @returns The full year (4 digits)\r\n */\r\nexport const getFullYear = (date?: Date): number => {\r\n const targetDate = date || new Date()\r\n return targetDate.getFullYear()\r\n}\r\n","/**\r\n * Environment detection utilities\r\n */\r\n\r\n/**\r\n * Determines if the current environment is Node.js\r\n * @returns true if running in Node.js, false otherwise\r\n */\r\nexport function isNodeEnvironment(): boolean {\r\n return typeof process !== 'undefined' && \r\n process.versions != null && \r\n process.versions.node != null;\r\n}\r\n\r\n/**\r\n * Determines if the current environment is a browser\r\n * @returns true if running in a browser, false otherwise\r\n */\r\nexport function isBrowserEnvironment(): boolean {\r\n return typeof window !== 'undefined' && \r\n typeof document !== 'undefined';\r\n}\r\n\r\n/**\r\n * Determines if the current environment is a web worker\r\n * @returns true if running in a web worker, false otherwise\r\n */\r\nexport function isWebWorkerEnvironment(): boolean {\r\n return typeof (globalThis as any).importScripts === 'function' && \r\n typeof window === 'undefined';\r\n}\r\n\r\n/**\r\n * Gets the current runtime environment\r\n * @returns 'node' | 'browser' | 'webworker' | 'unknown'\r\n */\r\nexport function getEnvironment(): 'node' | 'browser' | 'webworker' | 'unknown' {\r\n if (isNodeEnvironment()) return 'node';\r\n if (isBrowserEnvironment()) return 'browser';\r\n if (isWebWorkerEnvironment()) return 'webworker';\r\n return 'unknown';\r\n}\r\n\r\n/**\r\n * Error thrown when functionality is not supported in the current environment\r\n */\r\nexport class EnvironmentError extends Error {\r\n constructor(\r\n message: string,\r\n public readonly requiredEnvironment: string,\r\n public readonly currentEnvironment: string\r\n ) {\r\n super(message);\r\n this.name = 'EnvironmentError';\r\n }\r\n}\r\n\r\n/**\r\n * Asserts that the current environment is Node.js\r\n * @throws {EnvironmentError} if not running in Node.js\r\n */\r\nexport function assertNodeEnvironment(): void {\r\n if (!isNodeEnvironment()) {\r\n throw new EnvironmentError(\r\n 'This functionality requires Node.js environment',\r\n 'node',\r\n getEnvironment()\r\n );\r\n }\r\n}\r\n\r\n/**\r\n * Asserts that the current environment is a browser\r\n * @throws {EnvironmentError} if not running in a browser\r\n */\r\nexport function assertBrowserEnvironment(): void {\r\n if (!isBrowserEnvironment()) {\r\n throw new EnvironmentError(\r\n 'This functionality requires browser environment',\r\n 'browser',\r\n getEnvironment()\r\n );\r\n }\r\n}\r\n"]}
@@ -0,0 +1,9 @@
1
+ export { chunk } from './array/index.cjs';
2
+ export { randomStringWithFixedLength } from './string/index.cjs';
3
+ export { clamp, convertToInt, convertToTwoDecimalInt, inRange, randomNumberWithFixedLength } from './number/index.cjs';
4
+ export { TSleepParams, TSleepReturn, sleep, sleepMinutes, sleepMs, sleepSeconds, sleepUntil } from './sleep/index.cjs';
5
+ export { convertToSeconds, getFullYear, getUnixTimestamp, getUnixTimestampMs } from './time/index.cjs';
6
+ export { EnvironmentError, assertBrowserEnvironment, assertNodeEnvironment, getEnvironment, isBrowserEnvironment, isNodeEnvironment, isWebWorkerEnvironment } from './utils/index.cjs';
7
+ export { Prettify } from './types/index.cjs';
8
+ export { capitalize, capitalizeWords, convertCamelToNormalCapitalized } from './string/capitalize.cjs';
9
+ export { TruncateTextOptions, truncateText } from './string/truncate.cjs';
@@ -0,0 +1,9 @@
1
+ export { chunk } from './array/index.js';
2
+ export { randomStringWithFixedLength } from './string/index.js';
3
+ export { clamp, convertToInt, convertToTwoDecimalInt, inRange, randomNumberWithFixedLength } from './number/index.js';
4
+ export { TSleepParams, TSleepReturn, sleep, sleepMinutes, sleepMs, sleepSeconds, sleepUntil } from './sleep/index.js';
5
+ export { convertToSeconds, getFullYear, getUnixTimestamp, getUnixTimestampMs } from './time/index.js';
6
+ export { EnvironmentError, assertBrowserEnvironment, assertNodeEnvironment, getEnvironment, isBrowserEnvironment, isNodeEnvironment, isWebWorkerEnvironment } from './utils/index.js';
7
+ export { Prettify } from './types/index.js';
8
+ export { capitalize, capitalizeWords, convertCamelToNormalCapitalized } from './string/capitalize.js';
9
+ export { TruncateTextOptions, truncateText } from './string/truncate.js';