@nemigo/helpers 0.0.8 → 0.0.10

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.
@@ -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
+ };
@@ -0,0 +1,45 @@
1
+ /**
2
+ * Приведение -/+ 0 к 0
3
+ */
4
+ export declare const toZero: (value: number) => number;
5
+ /**
6
+ * Округляет число до заданного количества знаков после запятой
7
+ *
8
+ * Если переданное значение является `NaN` возвращает 0
9
+ *
10
+ * @param {number} value - Число для округления
11
+ * @param {number} [fraction=2] - Количество знаков после запятой
12
+ * @returns {number} Округленное число
13
+ */
14
+ export declare const toRound: (value: number, fraction?: number) => number;
15
+ /**
16
+ * Вычисляет сумму всех переданных аргументов
17
+ *
18
+ * Сумма округляется с использованием функции {@link toRound}
19
+ *
20
+ * @param {...number} args - Числа для суммирования
21
+ * @returns {number} Округленная сумма переданных чисел (или 0)
22
+ */
23
+ export declare const sum: (...args: number[]) => number;
24
+ /**
25
+ * Вычисляет произведение всех переданных аргументов
26
+ *
27
+ * Произведение округляется с использованием функции {@link toRound}
28
+ *
29
+ * @param {...number} args - Числа для перемножения.
30
+ * @returns {number} Округленное произведение переданных чисел (или 1)
31
+ */
32
+ export declare const mult: (...args: number[]) => number;
33
+ /**
34
+ * Ограничивает значение в заданном диапазоне [min, max]
35
+ *
36
+ * Если значение меньше min, вернёт min. Если больше max — вернёт max.
37
+ * Иначе возвращает само значение без изменений.
38
+ *
39
+ * @param {number} v - Исходное значение для ограничения
40
+ * @param {number} min - Нижняя граница диапазона
41
+ * @param {number} max - Верхняя граница диапазона
42
+ *
43
+ * @returns {number} Значение, ограниченное диапазоном [min, max]
44
+ */
45
+ export declare const clamp: (v: number, min: number, max: number) => number;
@@ -0,0 +1,50 @@
1
+ /**
2
+ * Приведение -/+ 0 к 0
3
+ */
4
+ export const toZero = (value) => (value === 0 ? 0 : value);
5
+ /**
6
+ * Округляет число до заданного количества знаков после запятой
7
+ *
8
+ * Если переданное значение является `NaN` возвращает 0
9
+ *
10
+ * @param {number} value - Число для округления
11
+ * @param {number} [fraction=2] - Количество знаков после запятой
12
+ * @returns {number} Округленное число
13
+ */
14
+ export const toRound = (value, fraction = 2) => {
15
+ if (isNaN(value) || value === 0)
16
+ return 0;
17
+ return Number(value.toFixed(fraction));
18
+ };
19
+ //...
20
+ /**
21
+ * Вычисляет сумму всех переданных аргументов
22
+ *
23
+ * Сумма округляется с использованием функции {@link toRound}
24
+ *
25
+ * @param {...number} args - Числа для суммирования
26
+ * @returns {number} Округленная сумма переданных чисел (или 0)
27
+ */
28
+ export const sum = (...args) => toRound(args.reduce((acc, v) => acc + v, 0));
29
+ /**
30
+ * Вычисляет произведение всех переданных аргументов
31
+ *
32
+ * Произведение округляется с использованием функции {@link toRound}
33
+ *
34
+ * @param {...number} args - Числа для перемножения.
35
+ * @returns {number} Округленное произведение переданных чисел (или 1)
36
+ */
37
+ export const mult = (...args) => toRound(args.reduce((acc, v) => acc * v, 1));
38
+ /**
39
+ * Ограничивает значение в заданном диапазоне [min, max]
40
+ *
41
+ * Если значение меньше min, вернёт min. Если больше max — вернёт max.
42
+ * Иначе возвращает само значение без изменений.
43
+ *
44
+ * @param {number} v - Исходное значение для ограничения
45
+ * @param {number} min - Нижняя граница диапазона
46
+ * @param {number} max - Верхняя граница диапазона
47
+ *
48
+ * @returns {number} Значение, ограниченное диапазоном [min, max]
49
+ */
50
+ export const clamp = (v, min, max) => Math.max(Math.min(v, max), min);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nemigo/helpers",
3
- "version": "0.0.8",
3
+ "version": "0.0.10",
4
4
  "private": false,
5
5
  "author": {
6
6
  "name": "Vlad Logvin",
@@ -19,6 +19,10 @@
19
19
  "types": "./dist/cases.d.ts",
20
20
  "default": "./dist/cases.js"
21
21
  },
22
+ "./clean": {
23
+ "types": "./dist/clean.d.ts",
24
+ "default": "./dist/clean.js"
25
+ },
22
26
  "./explorer": {
23
27
  "types": "./dist/explorer.d.ts",
24
28
  "default": "./dist/explorer.js"
@@ -35,6 +39,10 @@
35
39
  "types": "./dist/random.d.ts",
36
40
  "default": "./dist/random.js"
37
41
  },
42
+ "./phymath": {
43
+ "types": "./dist/phymath.d.ts",
44
+ "default": "./dist/phymath.js"
45
+ },
38
46
  "./script": {
39
47
  "types": "./dist/script.d.ts",
40
48
  "default": "./dist/script.js"