@nmtjs/common 0.14.4 → 0.15.0-beta.1

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/LICENSE.md CHANGED
@@ -1,4 +1,4 @@
1
- Copyright (c) 2024 Denis Ilchyshyn
1
+ Copyright (c) 2025 Denys Ilchyshyn
2
2
 
3
3
  Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
4
4
 
package/README.md CHANGED
@@ -6,4 +6,4 @@
6
6
  - binary data streaming and event subscriptions
7
7
  - contract-based API
8
8
  - end-to-end type safety
9
- - CPU-intensive task execution on separate workers
9
+ - CPU-intensive task execution on separate workers
package/package.json CHANGED
@@ -2,20 +2,17 @@
2
2
  "name": "@nmtjs/common",
3
3
  "type": "module",
4
4
  "exports": {
5
- ".": {
6
- "types": "./dist/index.d.ts",
7
- "import": "./dist/index.js",
8
- "module-sync": "./dist/index.js"
9
- }
5
+ ".": "./dist/index.js"
10
6
  },
11
7
  "files": [
12
8
  "dist",
13
9
  "LICENSE.md",
14
10
  "README.md"
15
11
  ],
16
- "version": "0.14.4",
12
+ "version": "0.15.0-beta.1",
17
13
  "scripts": {
18
- "build": "tsc",
14
+ "clean-build": "tsc --build --clean",
15
+ "build": "tsc --build --declaration --sourceMap",
19
16
  "type-check": "tsc --noEmit"
20
17
  }
21
18
  }
package/dist/index.d.ts DELETED
@@ -1,2 +0,0 @@
1
- export * from './types.ts';
2
- export * from './utils.ts';
package/dist/index.js DELETED
@@ -1,2 +0,0 @@
1
- export * from "./types.js";
2
- export * from "./utils.js";
package/dist/types.d.ts DELETED
@@ -1,31 +0,0 @@
1
- export interface TypeProvider {
2
- readonly input: unknown;
3
- readonly output: unknown;
4
- }
5
- export type CallTypeProvider<T extends TypeProvider, V> = (T & {
6
- input: V;
7
- })['output'];
8
- export type ClassConstructor<T = any, A extends any[] = any[]> = (abstract new (...args: A) => T) | (new (...args: A) => T);
9
- export type ClassInstance<T> = T extends ClassConstructor<infer U> ? U : never;
10
- export type ClassConstructorArgs<T, A = never> = T extends ClassConstructor<any, infer U> ? U : A;
11
- export type Callback<T extends any[] = any[], R = any> = (...args: T) => R;
12
- export type OmitFirstItem<T extends any[]> = T extends [any, ...infer U] ? U : [];
13
- export type ErrorClass = new (...args: any[]) => Error;
14
- export type Extra = Record<string, any>;
15
- export type Async<T> = T | Promise<T>;
16
- export type ArrayMap<T extends readonly any[], K extends keyof T[number]> = {
17
- [I in keyof T]: T[I][K];
18
- };
19
- export type UnionToIntersection<U> = (U extends any ? (k: U) => void : never) extends (k: infer I) => void ? I : never;
20
- export type Merge<T1 extends Record<string, any>, T2 extends Record<string, any>> = {
21
- [K in keyof T1 | keyof T2]: K extends keyof T2 ? T2[K] : K extends keyof T1 ? T1[K] : never;
22
- };
23
- export type OneOf<TypesArray extends any[], Res = never, AllProperties = MergeTypes<TypesArray>> = TypesArray extends [infer Head, ...infer Rem] ? OneOf<Rem, Res | OnlyFirst<Head, AllProperties>, AllProperties> : Res;
24
- type MergeTypes<TypesArray extends any[], Res = {}> = TypesArray extends [
25
- infer Head,
26
- ...infer Rem
27
- ] ? MergeTypes<Rem, Res & Head> : Res;
28
- type OnlyFirst<F, S> = F & {
29
- [Key in keyof Omit<S, keyof F>]?: never;
30
- };
31
- export {};
package/dist/types.js DELETED
@@ -1 +0,0 @@
1
- export {};
package/dist/utils.d.ts DELETED
@@ -1,31 +0,0 @@
1
- import type { Callback } from './types.ts';
2
- export declare const noopFn: () => void;
3
- export declare function merge<T extends any[]>(...objects: T): any;
4
- export declare function defer<T extends Callback>(cb: T, ms?: number, ...args: Parameters<T>): Promise<Awaited<ReturnType<T>>>;
5
- export declare function range(count: number, start?: number): {
6
- [Symbol.iterator](): {
7
- next(): {
8
- done: boolean;
9
- value: number;
10
- };
11
- };
12
- };
13
- export declare function debounce(cb: Callback, delay: number): ((...args: any[]) => void) & {
14
- clear: () => any;
15
- };
16
- export interface InteractivePromise<T = any> {
17
- promise: Promise<T>;
18
- resolve: (value: T) => void;
19
- reject: (error: any) => void;
20
- toArgs: () => [resolve: this['resolve'], reject: this['reject']];
21
- }
22
- export declare function createPromise<T>(): InteractivePromise<T>;
23
- export declare function onAbort<T extends Callback>(signal: AbortSignal, cb: T, reason?: any): () => void;
24
- export declare function withTimeout(value: Promise<any>, timeout: number, timeoutError: Error, controller?: AbortController): Promise<unknown>;
25
- export declare function tryCaptureStackTrace(depth?: number): string | undefined;
26
- export declare function isGeneratorFunction(value: any): value is GeneratorFunction;
27
- export declare function isAsyncGeneratorFunction(value: any): value is AsyncGeneratorFunction;
28
- export declare function throwError(message: string, ErrorClass?: ErrorConstructor): never;
29
- export declare function once(target: EventTarget, event: string): Promise<void>;
30
- export declare function onceAborted(signal: AbortSignal): Promise<void>;
31
- export declare function isAbortError(error: any): boolean;
package/dist/utils.js DELETED
@@ -1,99 +0,0 @@
1
- export const noopFn = () => { };
2
- export function merge(...objects) {
3
- return Object.assign({}, ...objects);
4
- }
5
- export function defer(cb, ms = 1, ...args) {
6
- return new Promise((resolve, reject) => setTimeout(async () => {
7
- try {
8
- resolve(await cb(...args));
9
- }
10
- catch (error) {
11
- reject(error);
12
- }
13
- }, ms));
14
- }
15
- export function range(count, start = 0) {
16
- let current = start;
17
- return {
18
- [Symbol.iterator]() {
19
- return {
20
- next() {
21
- if (current < count) {
22
- return { done: false, value: current++ };
23
- }
24
- else {
25
- return { done: true, value: current };
26
- }
27
- },
28
- };
29
- },
30
- };
31
- }
32
- export function debounce(cb, delay) {
33
- let timer;
34
- const clear = () => timer && clearTimeout(timer);
35
- const fn = (...args) => {
36
- clear();
37
- timer = setTimeout(cb, delay, ...args);
38
- };
39
- return Object.assign(fn, { clear });
40
- }
41
- // TODO: Promise.withResolvers?
42
- export function createPromise() {
43
- let resolve;
44
- let reject;
45
- const promise = new Promise((res, rej) => {
46
- resolve = res;
47
- reject = rej;
48
- });
49
- // @ts-expect-error
50
- return { resolve, reject, promise, toArgs: () => [resolve, reject] };
51
- }
52
- export function onAbort(signal, cb, reason) {
53
- const listener = () => cb(reason ?? signal.reason);
54
- signal.addEventListener('abort', listener, { once: true });
55
- return () => signal.removeEventListener('abort', listener);
56
- }
57
- export function withTimeout(value, timeout, timeoutError, controller) {
58
- return new Promise((resolve, reject) => {
59
- const timer = setTimeout(reject, timeout, timeoutError);
60
- const clearTimer = () => clearTimeout(timer);
61
- const rejectWithTimeout = (error) => {
62
- reject(error);
63
- controller?.abort(error);
64
- };
65
- value.then(resolve).catch(rejectWithTimeout).finally(clearTimer);
66
- });
67
- }
68
- export function tryCaptureStackTrace(depth = 0) {
69
- return (new Error().stack
70
- ?.split('\n')
71
- .slice(4 + depth)
72
- .join('\n') ?? undefined);
73
- }
74
- export function isGeneratorFunction(value) {
75
- return (typeof value === 'function' &&
76
- value.constructor.name === 'GeneratorFunction');
77
- }
78
- export function isAsyncGeneratorFunction(value) {
79
- return (typeof value === 'function' &&
80
- value.constructor.name === 'AsyncGeneratorFunction');
81
- }
82
- export function throwError(message, ErrorClass = Error) {
83
- throw new ErrorClass(message);
84
- }
85
- export function once(target, event) {
86
- return new Promise((resolve) => {
87
- target.addEventListener(event, () => resolve(), { once: true });
88
- });
89
- }
90
- export function onceAborted(signal) {
91
- return once(signal, 'abort');
92
- }
93
- export function isAbortError(error) {
94
- return ((error instanceof Error &&
95
- error.name === 'AbortError' &&
96
- 'code' in error &&
97
- (error.code === 20 || error.code === 'ABORT_ERR')) ||
98
- (error instanceof Event && error.type === 'abort'));
99
- }