@nemigo/helpers 0.0.7 → 0.0.9
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/cases.d.ts +30 -0
- package/dist/cases.js +69 -0
- package/dist/clean.d.ts +13 -0
- package/dist/clean.js +46 -0
- package/package.json +9 -1
package/dist/cases.d.ts
ADDED
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export type CaseResult<V, T> = (value: V | null, mutate: boolean) => T;
|
|
2
|
+
/**
|
|
3
|
+
* Отлов строковых значений
|
|
4
|
+
*
|
|
5
|
+
* - `string` → `string`, `false`
|
|
6
|
+
* - `number` → `string`, `true`
|
|
7
|
+
* - `NaN` → `null`, `false`
|
|
8
|
+
* - `ETC` → `null`, `false`
|
|
9
|
+
*/
|
|
10
|
+
export declare const caseString: <T>(value: unknown, call: CaseResult<string, T>) => T;
|
|
11
|
+
/**
|
|
12
|
+
* Отлов числовых значений
|
|
13
|
+
*
|
|
14
|
+
* - `number` → `number`, `false`
|
|
15
|
+
* - `string` → `number`, `true`
|
|
16
|
+
* - `NaN` → `null`, `false`
|
|
17
|
+
* - `ETC` → `null`, `false`
|
|
18
|
+
*/
|
|
19
|
+
export declare const caseNumber: <T>(value: unknown, call: CaseResult<number, T>) => T;
|
|
20
|
+
/**
|
|
21
|
+
* Отлов булевых значений
|
|
22
|
+
*
|
|
23
|
+
* - `boolean` -> `boolean`, `false`
|
|
24
|
+
* - `"false"` -> `boolean`, `true`
|
|
25
|
+
* - `"true"` -> `boolean`, `true`
|
|
26
|
+
* - `0` -> `boolean`, `true`
|
|
27
|
+
* - `1` -> `boolean`, `true`
|
|
28
|
+
* - `ETC` → `null`, `false`
|
|
29
|
+
*/
|
|
30
|
+
export declare const caseBoolean: <T>(value: unknown, call: CaseResult<boolean, T>) => T;
|
package/dist/cases.js
ADDED
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Отлов строковых значений
|
|
3
|
+
*
|
|
4
|
+
* - `string` → `string`, `false`
|
|
5
|
+
* - `number` → `string`, `true`
|
|
6
|
+
* - `NaN` → `null`, `false`
|
|
7
|
+
* - `ETC` → `null`, `false`
|
|
8
|
+
*/
|
|
9
|
+
export const caseString = (value, call) => {
|
|
10
|
+
switch (typeof value) {
|
|
11
|
+
case "string":
|
|
12
|
+
return call(value, false);
|
|
13
|
+
case "number":
|
|
14
|
+
if (!isNaN(value))
|
|
15
|
+
return call(String(value), true);
|
|
16
|
+
}
|
|
17
|
+
return call(null, false);
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* Отлов числовых значений
|
|
21
|
+
*
|
|
22
|
+
* - `number` → `number`, `false`
|
|
23
|
+
* - `string` → `number`, `true`
|
|
24
|
+
* - `NaN` → `null`, `false`
|
|
25
|
+
* - `ETC` → `null`, `false`
|
|
26
|
+
*/
|
|
27
|
+
export const caseNumber = (value, call) => {
|
|
28
|
+
switch (typeof value) {
|
|
29
|
+
case "number":
|
|
30
|
+
return call(isNaN(value) ? null : value, false);
|
|
31
|
+
case "string": {
|
|
32
|
+
const trimmed = value.trim();
|
|
33
|
+
const number = Number(trimmed);
|
|
34
|
+
if (!isNaN(number) && value !== "")
|
|
35
|
+
return call(number, true);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return call(null, false);
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* Отлов булевых значений
|
|
42
|
+
*
|
|
43
|
+
* - `boolean` -> `boolean`, `false`
|
|
44
|
+
* - `"false"` -> `boolean`, `true`
|
|
45
|
+
* - `"true"` -> `boolean`, `true`
|
|
46
|
+
* - `0` -> `boolean`, `true`
|
|
47
|
+
* - `1` -> `boolean`, `true`
|
|
48
|
+
* - `ETC` → `null`, `false`
|
|
49
|
+
*/
|
|
50
|
+
export const caseBoolean = (value, call) => {
|
|
51
|
+
switch (typeof value) {
|
|
52
|
+
case "boolean":
|
|
53
|
+
return call(value, false);
|
|
54
|
+
case "number":
|
|
55
|
+
if (value === 0)
|
|
56
|
+
return call(false, true);
|
|
57
|
+
if (value === 1)
|
|
58
|
+
return call(true, true);
|
|
59
|
+
break;
|
|
60
|
+
case "string": {
|
|
61
|
+
const flat = value.trim().toLowerCase();
|
|
62
|
+
if (flat === "false")
|
|
63
|
+
return call(false, true);
|
|
64
|
+
if (flat === "true")
|
|
65
|
+
return call(true, true);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return call(null, false);
|
|
69
|
+
};
|
package/dist/clean.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Очищает рекурсивно C КОПИРОВАНИЕМ объект (в т.ч. и массивы) от пустых, неопределенных или нулевых значений.
|
|
3
|
+
* Дополнительно удаляет пустые объекты и массивы, которые могут появиться после очистки.
|
|
4
|
+
* Если аргумент не является объектом, он возвращается без изменений
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* const original = { a: 1, b: null, c: { d: '', e: { f: undefined } } };
|
|
8
|
+
* const cleaned = deepObjectClean(original);
|
|
9
|
+
*
|
|
10
|
+
* console.log(cleaned); // { a: 1 }
|
|
11
|
+
* console.log(original); // {{ a: 1, b: null, c: { d: '', e: { f: undefined } } }
|
|
12
|
+
*/
|
|
13
|
+
export declare const deepObjectClean: <O>(data: O) => O;
|
package/dist/clean.js
ADDED
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Очищает рекурсивно C КОПИРОВАНИЕМ объект (в т.ч. и массивы) от пустых, неопределенных или нулевых значений.
|
|
3
|
+
* Дополнительно удаляет пустые объекты и массивы, которые могут появиться после очистки.
|
|
4
|
+
* Если аргумент не является объектом, он возвращается без изменений
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* const original = { a: 1, b: null, c: { d: '', e: { f: undefined } } };
|
|
8
|
+
* const cleaned = deepObjectClean(original);
|
|
9
|
+
*
|
|
10
|
+
* console.log(cleaned); // { a: 1 }
|
|
11
|
+
* console.log(original); // {{ a: 1, b: null, c: { d: '', e: { f: undefined } } }
|
|
12
|
+
*/
|
|
13
|
+
export const deepObjectClean = (data) => {
|
|
14
|
+
if (typeof data !== "object" || data === null)
|
|
15
|
+
return data;
|
|
16
|
+
if (Array.isArray(data)) {
|
|
17
|
+
return data.reduce((acc, value) => {
|
|
18
|
+
if (value !== "" && value !== null && value !== undefined) {
|
|
19
|
+
if (typeof value === "object") {
|
|
20
|
+
const cleaned = deepObjectClean(value);
|
|
21
|
+
if (Object.keys(cleaned).length !== 0)
|
|
22
|
+
acc.push(cleaned);
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
acc.push(value);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return acc;
|
|
29
|
+
}, []);
|
|
30
|
+
}
|
|
31
|
+
const result = {};
|
|
32
|
+
for (const key in data) {
|
|
33
|
+
const value = data[key];
|
|
34
|
+
if (value !== "" && value !== null && value !== undefined) {
|
|
35
|
+
if (typeof value === "object") {
|
|
36
|
+
const cleaned = deepObjectClean(value);
|
|
37
|
+
if (Object.keys(cleaned).length !== 0)
|
|
38
|
+
result[key] = cleaned;
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
result[key] = value;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return result;
|
|
46
|
+
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nemigo/helpers",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.9",
|
|
4
4
|
"private": false,
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "Vlad Logvin",
|
|
@@ -15,6 +15,14 @@
|
|
|
15
15
|
"format": "prettier --write ./"
|
|
16
16
|
},
|
|
17
17
|
"exports": {
|
|
18
|
+
"./cases": {
|
|
19
|
+
"types": "./dist/cases.d.ts",
|
|
20
|
+
"default": "./dist/cases.js"
|
|
21
|
+
},
|
|
22
|
+
"./clean": {
|
|
23
|
+
"types": "./dist/clean.d.ts",
|
|
24
|
+
"default": "./dist/clean.js"
|
|
25
|
+
},
|
|
18
26
|
"./explorer": {
|
|
19
27
|
"types": "./dist/explorer.d.ts",
|
|
20
28
|
"default": "./dist/explorer.js"
|