@orpc/shared 1.0.0-beta.3 → 1.0.0-beta.5

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/README.md CHANGED
@@ -58,6 +58,7 @@ You can find the full documentation [here](https://orpc.unnoq.com).
58
58
  - [@orpc/contract](https://www.npmjs.com/package/@orpc/contract): Build your API contract.
59
59
  - [@orpc/server](https://www.npmjs.com/package/@orpc/server): Build your API or implement API contract.
60
60
  - [@orpc/client](https://www.npmjs.com/package/@orpc/client): Consume your API on the client with type-safety.
61
+ - [@orpc/react](https://www.npmjs.com/package/@orpc/react): Utilities for integrating oRPC with React and React Server Actions.
61
62
  - [@orpc/react-query](https://www.npmjs.com/package/@orpc/react-query): Integration with [React Query](https://tanstack.com/query/latest/docs/framework/react/overview).
62
63
  - [@orpc/vue-query](https://www.npmjs.com/package/@orpc/vue-query): Integration with [Vue Query](https://tanstack.com/query/latest/docs/framework/vue/overview).
63
64
  - [@orpc/solid-query](https://www.npmjs.com/package/@orpc/solid-query): Integration with [Solid Query](https://tanstack.com/query/latest/docs/framework/solid/overview).
@@ -72,6 +73,14 @@ You can find the full documentation [here](https://orpc.unnoq.com).
72
73
 
73
74
  Provides shared utilities for oRPC packages.
74
75
 
76
+ ## Sponsors
77
+
78
+ <p align="center">
79
+ <a href="https://cdn.jsdelivr.net/gh/unnoq/unnoq/sponsors.svg">
80
+ <img src='https://cdn.jsdelivr.net/gh/unnoq/unnoq/sponsors.svg'/>
81
+ </a>
82
+ </p>
83
+
75
84
  ## License
76
85
 
77
86
  Distributed under the MIT License. See [LICENSE](https://github.com/unnoq/orpc/blob/main/LICENSE) for more information.
package/dist/index.d.mts CHANGED
@@ -1,6 +1,11 @@
1
1
  import { Promisable } from 'type-fest';
2
2
  export { IsEqual, IsNever, PartialDeep, Promisable } from 'type-fest';
3
- export { group, guard, mapEntries, mapValues, omit, trim } from 'radash';
3
+ export { group, guard, mapEntries, mapValues, omit } from 'radash';
4
+
5
+ type MaybeOptionalOptions<TOptions> = Record<never, never> extends TOptions ? [options?: TOptions] : [options: TOptions];
6
+ declare function resolveMaybeOptionalOptions<T>(rest: MaybeOptionalOptions<T>): T;
7
+
8
+ declare function toArray<T>(value: T | T[] | null | undefined): T[];
4
9
 
5
10
  type AnyFunction = (...args: any[]) => any;
6
11
  declare function once<T extends () => any>(fn: T): () => ReturnType<T>;
@@ -9,17 +14,29 @@ type OmitChainMethodDeep<T extends object, K extends keyof any> = {
9
14
  [P in keyof Omit<T, K>]: T[P] extends AnyFunction ? ((...args: Parameters<T[P]>) => OmitChainMethodDeep<ReturnType<T[P]>, K>) : T[P];
10
15
  };
11
16
 
12
- declare function toError(error: unknown): Error;
13
-
14
- type InterceptableOptions = Record<string, any>;
15
- type InterceptorOptions<TOptions extends InterceptableOptions, TResult> = Omit<TOptions, 'next'> & {
16
- next(options?: TOptions): Promise<TResult>;
17
- };
18
- type Interceptor<TOptions extends InterceptableOptions, TResult, TError> = (options: InterceptorOptions<TOptions, TResult>) => Promise<TResult> & {
17
+ type SetOptional<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
18
+ type IntersectPick<T, U> = Pick<T, keyof T & keyof U>;
19
+ type PromiseWithError<T, TError> = Promise<T> & {
19
20
  __error?: {
20
21
  type: TError;
21
22
  };
22
23
  };
24
+ /**
25
+ * The place where you can config the orpc types.
26
+ *
27
+ * - `throwableError` the error type that represent throwable errors should be `Error` or `null | undefined | {}` if you want more strict.
28
+ */
29
+ interface Registry {
30
+ }
31
+ type ThrowableError = Registry extends {
32
+ throwableError: infer T;
33
+ } ? T : Error;
34
+
35
+ type InterceptableOptions = Record<string, any>;
36
+ type InterceptorOptions<TOptions extends InterceptableOptions, TResult, TError> = Omit<TOptions, 'next'> & {
37
+ next(options?: TOptions): PromiseWithError<TResult, TError>;
38
+ };
39
+ type Interceptor<TOptions extends InterceptableOptions, TResult, TError> = (options: InterceptorOptions<TOptions, TResult, TError>) => PromiseWithError<TResult, TError>;
23
40
  /**
24
41
  * Can used for interceptors or middlewares
25
42
  */
@@ -35,24 +52,16 @@ declare function onSuccess<TOptions extends {
35
52
  /**
36
53
  * Can used for interceptors or middlewares
37
54
  */
38
- declare function onError<TError, TOptions extends {
55
+ declare function onError<TOptions extends {
39
56
  next(): any;
40
- }, TRest extends any[]>(callback: NoInfer<(error: TError, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>> & {
41
- __error?: {
42
- type: TError;
43
- };
44
- };
57
+ }, TRest extends any[]>(callback: NoInfer<(error: ReturnType<TOptions['next']> extends PromiseWithError<any, infer E> ? E : ThrowableError, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>>;
45
58
  type OnFinishState<TResult, TError> = [TResult, null, 'success'] | [undefined, TError, 'error'];
46
59
  /**
47
60
  * Can used for interceptors or middlewares
48
61
  */
49
- declare function onFinish<TError, TOptions extends {
62
+ declare function onFinish<TOptions extends {
50
63
  next(): any;
51
- }, TRest extends any[]>(callback: NoInfer<(state: OnFinishState<Awaited<ReturnType<TOptions['next']>>, TError>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>> & {
52
- __error?: {
53
- type: TError;
54
- };
55
- };
64
+ }, TRest extends any[]>(callback: NoInfer<(state: OnFinishState<Awaited<ReturnType<TOptions['next']>>, ReturnType<TOptions['next']> extends PromiseWithError<any, infer E> ? E : ThrowableError>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>>;
56
65
  declare function intercept<TOptions extends InterceptableOptions, TResult, TError>(interceptors: Interceptor<TOptions, TResult, TError>[], options: NoInfer<TOptions>, main: NoInfer<(options: TOptions) => Promisable<TResult>>): Promise<TResult>;
57
66
 
58
67
  declare function isAsyncIteratorObject(maybe: unknown): maybe is AsyncIteratorObject<any, any, any>;
@@ -74,12 +83,9 @@ declare function isObject(value: unknown): value is Record<PropertyKey, unknown>
74
83
  */
75
84
  declare function isTypescriptObject(value: unknown): value is object & Record<PropertyKey, unknown>;
76
85
  declare function clone<T>(value: T): T;
77
-
78
- type MaybeOptionalOptions<TOptions> = Record<never, never> extends TOptions ? [options?: TOptions] : [options: TOptions];
79
- type SetOptional<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
80
- type IntersectPick<T, U> = Pick<T, keyof T & keyof U>;
86
+ declare function get(object: object, path: readonly string[]): unknown;
81
87
 
82
88
  type Value<T, TArgs extends any[] = []> = T | ((...args: TArgs) => Promisable<T>);
83
89
  declare function value<T, TArgs extends any[]>(value: Value<T, TArgs>, ...args: NoInfer<TArgs>): Promise<T extends Value<infer U, any> ? U : never>;
84
90
 
85
- export { type AnyFunction, type InterceptableOptions, type Interceptor, type InterceptorOptions, type IntersectPick, type MaybeOptionalOptions, type OmitChainMethodDeep, type OnFinishState, type Segment, type SetOptional, type Value, clone, findDeepMatches, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, stringifyJSON, toError, value };
91
+ export { type AnyFunction, type InterceptableOptions, type Interceptor, type InterceptorOptions, type IntersectPick, type MaybeOptionalOptions, type OmitChainMethodDeep, type OnFinishState, type PromiseWithError, type Registry, type Segment, type SetOptional, type ThrowableError, type Value, clone, findDeepMatches, get, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, resolveMaybeOptionalOptions, stringifyJSON, toArray, value };
package/dist/index.d.ts CHANGED
@@ -1,6 +1,11 @@
1
1
  import { Promisable } from 'type-fest';
2
2
  export { IsEqual, IsNever, PartialDeep, Promisable } from 'type-fest';
3
- export { group, guard, mapEntries, mapValues, omit, trim } from 'radash';
3
+ export { group, guard, mapEntries, mapValues, omit } from 'radash';
4
+
5
+ type MaybeOptionalOptions<TOptions> = Record<never, never> extends TOptions ? [options?: TOptions] : [options: TOptions];
6
+ declare function resolveMaybeOptionalOptions<T>(rest: MaybeOptionalOptions<T>): T;
7
+
8
+ declare function toArray<T>(value: T | T[] | null | undefined): T[];
4
9
 
5
10
  type AnyFunction = (...args: any[]) => any;
6
11
  declare function once<T extends () => any>(fn: T): () => ReturnType<T>;
@@ -9,17 +14,29 @@ type OmitChainMethodDeep<T extends object, K extends keyof any> = {
9
14
  [P in keyof Omit<T, K>]: T[P] extends AnyFunction ? ((...args: Parameters<T[P]>) => OmitChainMethodDeep<ReturnType<T[P]>, K>) : T[P];
10
15
  };
11
16
 
12
- declare function toError(error: unknown): Error;
13
-
14
- type InterceptableOptions = Record<string, any>;
15
- type InterceptorOptions<TOptions extends InterceptableOptions, TResult> = Omit<TOptions, 'next'> & {
16
- next(options?: TOptions): Promise<TResult>;
17
- };
18
- type Interceptor<TOptions extends InterceptableOptions, TResult, TError> = (options: InterceptorOptions<TOptions, TResult>) => Promise<TResult> & {
17
+ type SetOptional<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
18
+ type IntersectPick<T, U> = Pick<T, keyof T & keyof U>;
19
+ type PromiseWithError<T, TError> = Promise<T> & {
19
20
  __error?: {
20
21
  type: TError;
21
22
  };
22
23
  };
24
+ /**
25
+ * The place where you can config the orpc types.
26
+ *
27
+ * - `throwableError` the error type that represent throwable errors should be `Error` or `null | undefined | {}` if you want more strict.
28
+ */
29
+ interface Registry {
30
+ }
31
+ type ThrowableError = Registry extends {
32
+ throwableError: infer T;
33
+ } ? T : Error;
34
+
35
+ type InterceptableOptions = Record<string, any>;
36
+ type InterceptorOptions<TOptions extends InterceptableOptions, TResult, TError> = Omit<TOptions, 'next'> & {
37
+ next(options?: TOptions): PromiseWithError<TResult, TError>;
38
+ };
39
+ type Interceptor<TOptions extends InterceptableOptions, TResult, TError> = (options: InterceptorOptions<TOptions, TResult, TError>) => PromiseWithError<TResult, TError>;
23
40
  /**
24
41
  * Can used for interceptors or middlewares
25
42
  */
@@ -35,24 +52,16 @@ declare function onSuccess<TOptions extends {
35
52
  /**
36
53
  * Can used for interceptors or middlewares
37
54
  */
38
- declare function onError<TError, TOptions extends {
55
+ declare function onError<TOptions extends {
39
56
  next(): any;
40
- }, TRest extends any[]>(callback: NoInfer<(error: TError, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>> & {
41
- __error?: {
42
- type: TError;
43
- };
44
- };
57
+ }, TRest extends any[]>(callback: NoInfer<(error: ReturnType<TOptions['next']> extends PromiseWithError<any, infer E> ? E : ThrowableError, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>>;
45
58
  type OnFinishState<TResult, TError> = [TResult, null, 'success'] | [undefined, TError, 'error'];
46
59
  /**
47
60
  * Can used for interceptors or middlewares
48
61
  */
49
- declare function onFinish<TError, TOptions extends {
62
+ declare function onFinish<TOptions extends {
50
63
  next(): any;
51
- }, TRest extends any[]>(callback: NoInfer<(state: OnFinishState<Awaited<ReturnType<TOptions['next']>>, TError>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>> & {
52
- __error?: {
53
- type: TError;
54
- };
55
- };
64
+ }, TRest extends any[]>(callback: NoInfer<(state: OnFinishState<Awaited<ReturnType<TOptions['next']>>, ReturnType<TOptions['next']> extends PromiseWithError<any, infer E> ? E : ThrowableError>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>>;
56
65
  declare function intercept<TOptions extends InterceptableOptions, TResult, TError>(interceptors: Interceptor<TOptions, TResult, TError>[], options: NoInfer<TOptions>, main: NoInfer<(options: TOptions) => Promisable<TResult>>): Promise<TResult>;
57
66
 
58
67
  declare function isAsyncIteratorObject(maybe: unknown): maybe is AsyncIteratorObject<any, any, any>;
@@ -74,12 +83,9 @@ declare function isObject(value: unknown): value is Record<PropertyKey, unknown>
74
83
  */
75
84
  declare function isTypescriptObject(value: unknown): value is object & Record<PropertyKey, unknown>;
76
85
  declare function clone<T>(value: T): T;
77
-
78
- type MaybeOptionalOptions<TOptions> = Record<never, never> extends TOptions ? [options?: TOptions] : [options: TOptions];
79
- type SetOptional<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
80
- type IntersectPick<T, U> = Pick<T, keyof T & keyof U>;
86
+ declare function get(object: object, path: readonly string[]): unknown;
81
87
 
82
88
  type Value<T, TArgs extends any[] = []> = T | ((...args: TArgs) => Promisable<T>);
83
89
  declare function value<T, TArgs extends any[]>(value: Value<T, TArgs>, ...args: NoInfer<TArgs>): Promise<T extends Value<infer U, any> ? U : never>;
84
90
 
85
- export { type AnyFunction, type InterceptableOptions, type Interceptor, type InterceptorOptions, type IntersectPick, type MaybeOptionalOptions, type OmitChainMethodDeep, type OnFinishState, type Segment, type SetOptional, type Value, clone, findDeepMatches, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, stringifyJSON, toError, value };
91
+ export { type AnyFunction, type InterceptableOptions, type Interceptor, type InterceptorOptions, type IntersectPick, type MaybeOptionalOptions, type OmitChainMethodDeep, type OnFinishState, type PromiseWithError, type Registry, type Segment, type SetOptional, type ThrowableError, type Value, clone, findDeepMatches, get, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, resolveMaybeOptionalOptions, stringifyJSON, toArray, value };
package/dist/index.mjs CHANGED
@@ -1,10 +1,11 @@
1
- export { group, guard, mapEntries, mapValues, omit, trim } from 'radash';
1
+ export { group, guard, mapEntries, mapValues, omit } from 'radash';
2
2
 
3
- function toError(error) {
4
- if (error instanceof Error) {
5
- return error;
6
- }
7
- return new Error("Unknown error", { cause: error });
3
+ function resolveMaybeOptionalOptions(rest) {
4
+ return rest[0] ?? {};
5
+ }
6
+
7
+ function toArray(value) {
8
+ return Array.isArray(value) ? value : value === void 0 || value === null ? [] : [value];
8
9
  }
9
10
 
10
11
  function once(fn) {
@@ -127,6 +128,16 @@ function clone(value) {
127
128
  }
128
129
  return value;
129
130
  }
131
+ function get(object, path) {
132
+ let current = object;
133
+ for (const key of path) {
134
+ if (!isTypescriptObject(current)) {
135
+ return void 0;
136
+ }
137
+ current = current[key];
138
+ }
139
+ return current;
140
+ }
130
141
 
131
142
  function value(value2, ...args) {
132
143
  if (typeof value2 === "function") {
@@ -135,4 +146,4 @@ function value(value2, ...args) {
135
146
  return value2;
136
147
  }
137
148
 
138
- export { clone, findDeepMatches, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, stringifyJSON, toError, value };
149
+ export { clone, findDeepMatches, get, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, resolveMaybeOptionalOptions, stringifyJSON, toArray, value };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@orpc/shared",
3
3
  "type": "module",
4
- "version": "1.0.0-beta.3",
4
+ "version": "1.0.0-beta.5",
5
5
  "license": "MIT",
6
6
  "homepage": "https://orpc.unnoq.com",
7
7
  "repository": {