ts-array-lite 1.0.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.
- package/dist/array.d.ts +26 -0
- package/dist/array.js +90 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +17 -0
- package/package.json +19 -0
package/dist/array.d.ts
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export declare class ArrayUtils {
|
|
2
|
+
unique<T>(arr: T[]): T[];
|
|
3
|
+
chunk<T>(arr: T[], size: number): T[][];
|
|
4
|
+
groupBy<T>(arr: T[], key: keyof T | ((item: T) => string)): Record<string, T[]>;
|
|
5
|
+
sortBy<T>(arr: T[], key: keyof T, order?: 'asc' | 'desc'): T[];
|
|
6
|
+
shuffle<T>(arr: T[]): T[];
|
|
7
|
+
sample<T>(arr: T[]): T | undefined;
|
|
8
|
+
intersection<T>(a: T[], b: T[]): T[];
|
|
9
|
+
difference<T>(a: T[], b: T[]): T[];
|
|
10
|
+
compact<T>(arr: (T | null | undefined | false | 0 | '')[]): T[];
|
|
11
|
+
flatten<T>(arr: (T | T[])[]): T[];
|
|
12
|
+
flattenDeep<T>(arr: unknown[]): T[];
|
|
13
|
+
partition<T>(arr: T[], predicate: (item: T) => boolean): [T[], T[]];
|
|
14
|
+
pluck<T, K extends keyof T>(arr: T[], key: K): T[K][];
|
|
15
|
+
first<T>(arr: T[]): T | undefined;
|
|
16
|
+
last<T>(arr: T[]): T | undefined;
|
|
17
|
+
drop<T>(arr: T[], n?: number): T[];
|
|
18
|
+
take<T>(arr: T[], n?: number): T[];
|
|
19
|
+
sum(arr: number[]): number;
|
|
20
|
+
average(arr: number[]): number;
|
|
21
|
+
min(arr: number[]): number | undefined;
|
|
22
|
+
max(arr: number[]): number | undefined;
|
|
23
|
+
range(start: number, end: number, step?: number): number[];
|
|
24
|
+
zip<T>(...arrays: T[][]): T[][];
|
|
25
|
+
uniqBy<T>(arr: T[], key: keyof T): T[];
|
|
26
|
+
}
|
package/dist/array.js
ADDED
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ArrayUtils = void 0;
|
|
4
|
+
class ArrayUtils {
|
|
5
|
+
unique(arr) {
|
|
6
|
+
return [...new Set(arr)];
|
|
7
|
+
}
|
|
8
|
+
chunk(arr, size) {
|
|
9
|
+
const chunks = [];
|
|
10
|
+
for (let i = 0; i < arr.length; i += size) {
|
|
11
|
+
chunks.push(arr.slice(i, i + size));
|
|
12
|
+
}
|
|
13
|
+
return chunks;
|
|
14
|
+
}
|
|
15
|
+
groupBy(arr, key) {
|
|
16
|
+
return arr.reduce((groups, item) => {
|
|
17
|
+
const groupKey = typeof key === 'function' ? key(item) : String(item[key]);
|
|
18
|
+
(groups[groupKey] = groups[groupKey] || []).push(item);
|
|
19
|
+
return groups;
|
|
20
|
+
}, {});
|
|
21
|
+
}
|
|
22
|
+
sortBy(arr, key, order = 'asc') {
|
|
23
|
+
return [...arr].sort((a, b) => {
|
|
24
|
+
const aVal = a[key], bVal = b[key];
|
|
25
|
+
if (aVal < bVal)
|
|
26
|
+
return order === 'asc' ? -1 : 1;
|
|
27
|
+
if (aVal > bVal)
|
|
28
|
+
return order === 'asc' ? 1 : -1;
|
|
29
|
+
return 0;
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
shuffle(arr) {
|
|
33
|
+
const result = [...arr];
|
|
34
|
+
for (let i = result.length - 1; i > 0; i--) {
|
|
35
|
+
const j = Math.floor(Math.random() * (i + 1));
|
|
36
|
+
[result[i], result[j]] = [result[j], result[i]];
|
|
37
|
+
}
|
|
38
|
+
return result;
|
|
39
|
+
}
|
|
40
|
+
sample(arr) {
|
|
41
|
+
return arr[Math.floor(Math.random() * arr.length)];
|
|
42
|
+
}
|
|
43
|
+
intersection(a, b) {
|
|
44
|
+
return a.filter(x => b.includes(x));
|
|
45
|
+
}
|
|
46
|
+
difference(a, b) {
|
|
47
|
+
return a.filter(x => !b.includes(x));
|
|
48
|
+
}
|
|
49
|
+
compact(arr) {
|
|
50
|
+
return arr.filter(Boolean);
|
|
51
|
+
}
|
|
52
|
+
flatten(arr) {
|
|
53
|
+
return arr.reduce((flat, item) => flat.concat(Array.isArray(item) ? item : item), []);
|
|
54
|
+
}
|
|
55
|
+
flattenDeep(arr) {
|
|
56
|
+
return arr.reduce((flat, item) => flat.concat(Array.isArray(item) ? this.flattenDeep(item) : item), []);
|
|
57
|
+
}
|
|
58
|
+
partition(arr, predicate) {
|
|
59
|
+
const pass = [], fail = [];
|
|
60
|
+
arr.forEach(item => (predicate(item) ? pass : fail).push(item));
|
|
61
|
+
return [pass, fail];
|
|
62
|
+
}
|
|
63
|
+
pluck(arr, key) {
|
|
64
|
+
return arr.map(item => item[key]);
|
|
65
|
+
}
|
|
66
|
+
first(arr) { return arr[0]; }
|
|
67
|
+
last(arr) { return arr[arr.length - 1]; }
|
|
68
|
+
drop(arr, n = 1) { return arr.slice(n); }
|
|
69
|
+
take(arr, n = 1) { return arr.slice(0, n); }
|
|
70
|
+
sum(arr) { return arr.reduce((a, b) => a + b, 0); }
|
|
71
|
+
average(arr) { return arr.length ? this.sum(arr) / arr.length : 0; }
|
|
72
|
+
min(arr) { return arr.length ? Math.min(...arr) : undefined; }
|
|
73
|
+
max(arr) { return arr.length ? Math.max(...arr) : undefined; }
|
|
74
|
+
range(start, end, step = 1) {
|
|
75
|
+
const result = [];
|
|
76
|
+
for (let i = start; i < end; i += step)
|
|
77
|
+
result.push(i);
|
|
78
|
+
return result;
|
|
79
|
+
}
|
|
80
|
+
zip(...arrays) {
|
|
81
|
+
const maxLen = Math.max(...arrays.map(a => a.length));
|
|
82
|
+
return Array(maxLen).fill(0).map((_, i) => arrays.map(a => a[i]));
|
|
83
|
+
}
|
|
84
|
+
uniqBy(arr, key) {
|
|
85
|
+
const seen = new Set();
|
|
86
|
+
return arr.filter(item => { const v = item[key]; if (seen.has(v))
|
|
87
|
+
return false; seen.add(v); return true; });
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
exports.ArrayUtils = ArrayUtils;
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './array';
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./array"), exports);
|
package/package.json
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "ts-array-lite",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "Lightweight, type-safe array utility library for web developers",
|
|
5
|
+
"main": "./dist/index.js",
|
|
6
|
+
"module": "./dist/index.js",
|
|
7
|
+
"types": "./dist/index.d.ts",
|
|
8
|
+
"exports": {
|
|
9
|
+
".": {
|
|
10
|
+
"types": "./dist/index.d.ts",
|
|
11
|
+
"import": "./dist/index.js",
|
|
12
|
+
"require": "./dist/index.js"
|
|
13
|
+
}
|
|
14
|
+
},
|
|
15
|
+
"files": ["dist"],
|
|
16
|
+
"keywords": ["utils", "typescript", "array", "helpers", "lite"],
|
|
17
|
+
"author": "Gaurang Mody - G8X",
|
|
18
|
+
"license": "MIT"
|
|
19
|
+
}
|