@nemigo/helpers 0.0.5 → 0.0.8

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,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/lens.d.ts ADDED
@@ -0,0 +1,64 @@
1
+ /**
2
+ * Режим работы линзы:
3
+ * - `"exclude"` (исключение)
4
+ * - `"include"` (включение)
5
+ */
6
+ export type LensMode = "exclude" | "include";
7
+ export type LensSchema<O> = {
8
+ [K in keyof O]?: boolean;
9
+ };
10
+ /**
11
+ * Конфигурация для {@link Lens}
12
+ */
13
+ export interface LensConfig<O> {
14
+ /**
15
+ * Режим работы линзы {@link LensMode}
16
+ *
17
+ * @default "exclude"
18
+ */
19
+ mode?: LensMode;
20
+ /**
21
+ * Схема, определяющая, какие ключи включить или исключить
22
+ *
23
+ * @default {}
24
+ */
25
+ schema?: LensSchema<O>;
26
+ }
27
+ /**
28
+ * Линза для фильтрации на основе схемы и режима
29
+ *
30
+ * @template O - Тип объект для схемы, с которой работает линза
31
+ */
32
+ export declare class Lens<O> {
33
+ /**
34
+ * Режим работы линзы {@link LensMode}
35
+ *
36
+ * @default "exclude"
37
+ */
38
+ _mode: LensMode;
39
+ /**
40
+ * Схема, определяющая, какие ключи включить или исключить
41
+ *
42
+ * @default {}
43
+ */
44
+ _schema: LensSchema<O>;
45
+ /**
46
+ * Создаёт экземпляр линзы
47
+ *
48
+ * @param config - Конфигурация линзы {@link LensConfig}
49
+ */
50
+ constructor(config: LensConfig<O>);
51
+ /**
52
+ * Пересборка под другую конфигурацию
53
+ *
54
+ * @param config - Конфигурация линзы {@link LensConfig}
55
+ */
56
+ reconstruct(config: LensConfig<O>): void;
57
+ /**
58
+ * Проверяет, должен ли ключ быть включён в результат
59
+ *
60
+ * @param key - Ключ для проверки
61
+ * @returns `true`, если ключ должен быть включён, иначе `false`
62
+ */
63
+ get(key: keyof O): boolean;
64
+ }
package/dist/lens.js ADDED
@@ -0,0 +1,50 @@
1
+ /**
2
+ * Линза для фильтрации на основе схемы и режима
3
+ *
4
+ * @template O - Тип объект для схемы, с которой работает линза
5
+ */
6
+ export class Lens {
7
+ /**
8
+ * Режим работы линзы {@link LensMode}
9
+ *
10
+ * @default "exclude"
11
+ */
12
+ _mode;
13
+ /**
14
+ * Схема, определяющая, какие ключи включить или исключить
15
+ *
16
+ * @default {}
17
+ */
18
+ _schema;
19
+ /**
20
+ * Создаёт экземпляр линзы
21
+ *
22
+ * @param config - Конфигурация линзы {@link LensConfig}
23
+ */
24
+ constructor(config) {
25
+ this.reconstruct(config);
26
+ }
27
+ /**
28
+ * Пересборка под другую конфигурацию
29
+ *
30
+ * @param config - Конфигурация линзы {@link LensConfig}
31
+ */
32
+ reconstruct(config) {
33
+ this._mode = config.mode ?? "exclude";
34
+ this._schema = config.schema ?? {};
35
+ }
36
+ /**
37
+ * Проверяет, должен ли ключ быть включён в результат
38
+ *
39
+ * @param key - Ключ для проверки
40
+ * @returns `true`, если ключ должен быть включён, иначе `false`
41
+ */
42
+ get(key) {
43
+ if (this._mode === "exclude") {
44
+ // Если в конфиге есть ключ в режиме исключения, то key false. Если нет — то true
45
+ return !this._schema[key];
46
+ }
47
+ // Если в конфиге есть ключ, то key true. Если нет — то false
48
+ return !!this._schema[key];
49
+ }
50
+ }
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Ищет значение флага в массиве аргументов процесса
3
+ *
4
+ * @param cmd - Команда, которой скрипт был запущен (`process.argv`)
5
+ * @param name - Имя флага, который нужно найти
6
+ * @param [strict=true] - Если `true`, выбрасывает ошибку, если флаг не найден. Если `false`, возвращает `null`
7
+ *
8
+ * @returns Значение флага (или `null`, если флаг не найден и `strict = false`)
9
+ * @throws {Error} Если `strict = true` и флаг не найден
10
+ */
11
+ declare function getProcessFlag(cmd: string[], name: string, strict: boolean): string | null;
12
+ declare function getProcessFlag(cmd: string[], name: string, strict?: true): string;
13
+ export { getProcessFlag };
package/dist/script.js ADDED
@@ -0,0 +1,14 @@
1
+ function getProcessFlag(cmd, name, strict = true) {
2
+ const argv = cmd.slice(2);
3
+ const index = argv.indexOf(name);
4
+ if (index > -1) {
5
+ const value = argv[index + 1];
6
+ if (value)
7
+ return value;
8
+ }
9
+ if (strict) {
10
+ throw new Error(`Флаг "${name}" не найден`);
11
+ }
12
+ return null;
13
+ }
14
+ export { getProcessFlag };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nemigo/helpers",
3
- "version": "0.0.5",
3
+ "version": "0.0.8",
4
4
  "private": false,
5
5
  "author": {
6
6
  "name": "Vlad Logvin",
@@ -15,10 +15,18 @@
15
15
  "format": "prettier --write ./"
16
16
  },
17
17
  "exports": {
18
+ "./cases": {
19
+ "types": "./dist/cases.d.ts",
20
+ "default": "./dist/cases.js"
21
+ },
18
22
  "./explorer": {
19
23
  "types": "./dist/explorer.d.ts",
20
24
  "default": "./dist/explorer.js"
21
25
  },
26
+ "./lens": {
27
+ "types": "./dist/lens.d.ts",
28
+ "default": "./dist/lens.js"
29
+ },
22
30
  "./msgpack": {
23
31
  "types": "./dist/msgpack.d.ts",
24
32
  "default": "./dist/msgpack.js"
@@ -26,6 +34,10 @@
26
34
  "./random": {
27
35
  "types": "./dist/random.d.ts",
28
36
  "default": "./dist/random.js"
37
+ },
38
+ "./script": {
39
+ "types": "./dist/script.d.ts",
40
+ "default": "./dist/script.js"
29
41
  }
30
42
  },
31
43
  "dependencies": {