eden2query 0.3.1 → 0.3.3

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
@@ -67,6 +67,37 @@ const queryClient = new QueryClient();
67
67
  queryClient.prefetchQuery(getOptions);
68
68
  ```
69
69
 
70
+ ### Hook builders: `createQueryHook` / `createMutationHook`
71
+
72
+ Create reusable, pre-configured hooks for a Treaty endpoint. Useful when you call the same endpoint in many components.
73
+
74
+ **Query hook** — pass the Treaty GET thunk and required query options (e.g. `queryKey`):
75
+
76
+ ```ts
77
+ const useResource = createQueryHook(
78
+ () => client.api.resource.get({ query: { q: "hello" } }),
79
+ { queryKey: ["resource"] },
80
+ );
81
+
82
+ // In a component
83
+ const { data } = useResource(); // or useResource({ refetchInterval: 1000 })
84
+ ```
85
+
86
+ **Mutation hook** — pass the Treaty mutation and optional base options:
87
+
88
+ ```ts
89
+ const usePostResource = createMutationHook(
90
+ (vars: { body: { name: string } }) => client.api.resource.post(vars.body),
91
+ { onSuccess: () => console.log("Success") },
92
+ );
93
+
94
+ // In a component
95
+ const postMutation = usePostResource();
96
+ postMutation.mutate({ body: { name: "World" } });
97
+ ```
98
+
99
+ Hooks accept the same options as `useQuery` / `useMutation`; call-time options are merged with the ones passed to `createQueryHook` / `createMutationHook`.
100
+
70
101
  ## API
71
102
 
72
103
  **`treatyQueryOptions(fn, queryOptions)`** — wraps a Treaty GET call into `queryOptions`. `fn` is a **thunk** (zero-argument function) that calls the Treaty GET, e.g. `() => client.api.resource.get({ query: { ... } })`. The second argument accepts all `queryOptions` fields except `queryFn`. Extracts `data` from the response and throws on `error`.
@@ -78,6 +109,10 @@ queryClient.prefetchQuery(getOptions);
78
109
 
79
110
  The optional second argument accepts all `mutationOptions` fields except `mutationFn` (e.g. `onSuccess`, `onSettled`, `onMutate`).
80
111
 
112
+ **`createQueryHook(fn, queryOptions)`** — returns a hook that wraps `useQuery` with the given Treaty GET thunk and base query options. The returned hook accepts the same options as `useQuery`; call-time options are merged with the base options. Use when you want a reusable hook for a specific endpoint.
113
+
114
+ **`createMutationHook(fn, mutationOptions?)`** — returns a hook that wraps `useMutation` with the given Treaty mutation and optional base mutation options. Same fn shapes as `treatyMutationOptions` (no-arg or with variables). The returned hook accepts the same options as `useMutation`. Use when you want a reusable hook for a specific mutation.
115
+
81
116
  **`InferTreatyQueryOptions<T>`** — full `UseQueryOptions` type for a given Treaty query.
82
117
 
83
118
  **`InferTreatyMutationOptions<TVariables, TResponse>`** — full `UseMutationOptions` type for a given Treaty mutation.
package/dist/index.d.ts CHANGED
@@ -1,22 +1,38 @@
1
1
  import { Treaty } from "@elysiajs/eden";
2
- import { UseMutationOptions, UseQueryOptions } from "@tanstack/react-query";
2
+ import { UseMutationOptions, UseMutationResult, UseQueryOptions, UseQueryResult } from "@tanstack/react-query";
3
3
  type TreatyResponse = Record<number, unknown>;
4
4
  type TreatyFunctionWithoutParams<TResponse extends TreatyResponse = TreatyResponse> = () => Promise<Treaty.TreatyResponse<TResponse>>;
5
5
  type TreatyFunctionWithParams<
6
6
  TParams,
7
7
  TResponse extends TreatyResponse
8
8
  > = (params: TParams) => Promise<Treaty.TreatyResponse<TResponse>>;
9
- type InferTreatyData<TResponse extends TreatyResponse> = Treaty.TreatyResponse<TResponse>["data"];
10
- type InferTreatyError<TResponse extends TreatyResponse> = Treaty.TreatyResponse<TResponse>["error"];
11
- type InferTreatyMutationOptions<
12
- TInput,
9
+ type TreatyData<TResponse extends TreatyResponse> = Treaty.TreatyResponse<TResponse>["data"];
10
+ type TreatyError<TResponse extends TreatyResponse> = Treaty.TreatyResponse<TResponse>["error"];
11
+ type TreatyMutationOptions<
12
+ TVariables,
13
+ TResponse extends TreatyResponse
14
+ > = UseMutationOptions<TreatyData<TResponse>, TreatyError<TResponse>, TVariables>;
15
+ type UseTreatyMutationResult<
16
+ TVariables,
13
17
  TResponse extends TreatyResponse
14
- > = UseMutationOptions<InferTreatyData<TResponse>, InferTreatyError<TResponse>, TInput>;
15
- type InferTreatyQueryOptions<TResponse extends Record<number, unknown>> = UseQueryOptions<InferTreatyData<TResponse>, InferTreatyError<TResponse>>;
16
- declare function treatyMutationOptions<TResponse extends TreatyResponse>(fn: TreatyFunctionWithoutParams<TResponse>, options?: Omit<InferTreatyMutationOptions<void, TResponse>, "mutationFn">): InferTreatyMutationOptions<void, TResponse>;
18
+ > = (UseMutationResult<TreatyData<TResponse>, TreatyError<TResponse>, TVariables>);
19
+ type UseTreatyQueryResult<TResponse extends TreatyResponse> = (UseQueryResult<TreatyData<TResponse>, TreatyError<TResponse>>);
20
+ type TreatyQueryOptions<TResponse extends Record<number, unknown>> = UseQueryOptions<TreatyData<TResponse>, TreatyError<TResponse>>;
21
+ type UseTreatyMutationHook<
22
+ TVariables,
23
+ TResponse extends TreatyResponse
24
+ > = ((options: Partial<Omit<TreatyMutationOptions<TVariables, TResponse>, "mutationFn">>) => UseTreatyMutationResult<TVariables, TResponse>);
25
+ type UseTreatyQueryHook<TResponse extends TreatyResponse> = ((options: Partial<Omit<TreatyQueryOptions<TResponse>, "queryFn">>) => UseTreatyQueryResult<TResponse>);
26
+ declare function treatyMutationOptions<TResponse extends TreatyResponse>(fn: TreatyFunctionWithoutParams<TResponse>, options?: Omit<TreatyMutationOptions<void, TResponse>, "mutationFn">): TreatyMutationOptions<void, TResponse>;
17
27
  declare function treatyMutationOptions<
18
28
  TVariables,
19
29
  TResponse extends TreatyResponse
20
- >(fn: TreatyFunctionWithParams<TVariables, TResponse>, options?: Omit<InferTreatyMutationOptions<TVariables, TResponse>, "mutationFn">): InferTreatyMutationOptions<TVariables, TResponse>;
21
- declare function treatyQueryOptions<TResponse extends TreatyResponse = TreatyResponse>(fn: TreatyFunctionWithoutParams<TResponse>, options: Omit<InferTreatyQueryOptions<TResponse>, "queryFn">): InferTreatyQueryOptions<TResponse>;
22
- export { treatyQueryOptions, treatyMutationOptions, TreatyFunctionWithoutParams as TreatyQueryFunction, TreatyFunctionWithParams as TreatyMutationFunction, InferTreatyQueryOptions, InferTreatyMutationOptions, InferTreatyError, InferTreatyData };
30
+ >(fn: TreatyFunctionWithParams<TVariables, TResponse>, options?: Omit<TreatyMutationOptions<TVariables, TResponse>, "mutationFn">): TreatyMutationOptions<TVariables, TResponse>;
31
+ declare function treatyQueryOptions<TResponse extends TreatyResponse = TreatyResponse>(fn: TreatyFunctionWithoutParams<TResponse>, options: Omit<TreatyQueryOptions<TResponse>, "queryFn">): TreatyQueryOptions<TResponse>;
32
+ declare function createMutationHook<TResponse extends TreatyResponse>(fn: TreatyFunctionWithoutParams<TResponse>, options?: Omit<TreatyMutationOptions<void, TResponse>, "mutationFn">): UseTreatyMutationHook<void, TResponse>;
33
+ declare function createMutationHook<
34
+ TVariables,
35
+ TResponse extends TreatyResponse
36
+ >(fn: TreatyFunctionWithParams<TVariables, TResponse>, options?: Omit<TreatyMutationOptions<TVariables, TResponse>, "mutationFn">): UseTreatyMutationHook<TVariables, TResponse>;
37
+ declare function createQueryHook<TResponse extends TreatyResponse>(fn: TreatyFunctionWithoutParams<TResponse>, createOptions: Omit<TreatyQueryOptions<TResponse>, "queryFn">): UseTreatyQueryHook<TResponse>;
38
+ export { treatyQueryOptions, treatyMutationOptions, createQueryHook, createMutationHook, UseTreatyQueryHook, UseTreatyMutationHook, TreatyQueryOptions, TreatyMutationOptions, TreatyError, TreatyData };
package/dist/index.js CHANGED
@@ -1,7 +1,9 @@
1
1
  // src/lib.ts
2
2
  import {
3
3
  mutationOptions,
4
- queryOptions
4
+ queryOptions,
5
+ useMutation,
6
+ useQuery
5
7
  } from "@tanstack/react-query";
6
8
  function treatyMutationOptions(fn, options) {
7
9
  return mutationOptions({
@@ -27,10 +29,28 @@ function treatyQueryOptions(fn, options) {
27
29
  }
28
30
  });
29
31
  }
32
+ function createMutationHook(fn, createOptions) {
33
+ return (options) => {
34
+ return useMutation({
35
+ ...treatyMutationOptions(fn, createOptions),
36
+ ...options
37
+ });
38
+ };
39
+ }
40
+ function createQueryHook(fn, createOptions) {
41
+ return (options) => {
42
+ return useQuery({
43
+ ...treatyQueryOptions(fn, createOptions),
44
+ ...options
45
+ });
46
+ };
47
+ }
30
48
  export {
31
49
  treatyQueryOptions,
32
- treatyMutationOptions
50
+ treatyMutationOptions,
51
+ createQueryHook,
52
+ createMutationHook
33
53
  };
34
54
 
35
- //# debugId=668F4CB9D073178564756E2164756E21
36
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsic3JjXFxsaWIudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbCiAgICAiaW1wb3J0IHR5cGUgeyBUcmVhdHkgfSBmcm9tIFwiQGVseXNpYWpzL2VkZW5cIjtcclxuaW1wb3J0IHtcclxuICBtdXRhdGlvbk9wdGlvbnMsXHJcbiAgcXVlcnlPcHRpb25zLFxyXG4gIHR5cGUgVXNlTXV0YXRpb25PcHRpb25zLFxyXG4gIHR5cGUgVXNlUXVlcnlPcHRpb25zLFxyXG59IGZyb20gXCJAdGFuc3RhY2svcmVhY3QtcXVlcnlcIjtcclxuXHJcbnR5cGUgVHJlYXR5UmVzcG9uc2UgPSBSZWNvcmQ8bnVtYmVyLCB1bmtub3duPjtcclxuXHJcbmV4cG9ydCB0eXBlIFRyZWF0eUZ1bmN0aW9uV2l0aG91dFBhcmFtczxcclxuICBUUmVzcG9uc2UgZXh0ZW5kcyBUcmVhdHlSZXNwb25zZSA9IFRyZWF0eVJlc3BvbnNlLFxyXG4+ID0gKCkgPT4gUHJvbWlzZTxUcmVhdHkuVHJlYXR5UmVzcG9uc2U8VFJlc3BvbnNlPj47XHJcblxyXG5leHBvcnQgdHlwZSBUcmVhdHlGdW5jdGlvbldpdGhQYXJhbXM8XHJcbiAgVFBhcmFtcyxcclxuICBUUmVzcG9uc2UgZXh0ZW5kcyBUcmVhdHlSZXNwb25zZSxcclxuPiA9IChwYXJhbXM6IFRQYXJhbXMpID0+IFByb21pc2U8VHJlYXR5LlRyZWF0eVJlc3BvbnNlPFRSZXNwb25zZT4+O1xyXG5cclxuZXhwb3J0IHR5cGUgSW5mZXJUcmVhdHlEYXRhPFRSZXNwb25zZSBleHRlbmRzIFRyZWF0eVJlc3BvbnNlPiA9XHJcbiAgVHJlYXR5LlRyZWF0eVJlc3BvbnNlPFRSZXNwb25zZT5bXCJkYXRhXCJdO1xyXG5cclxuZXhwb3J0IHR5cGUgSW5mZXJUcmVhdHlFcnJvcjxUUmVzcG9uc2UgZXh0ZW5kcyBUcmVhdHlSZXNwb25zZT4gPVxyXG4gIFRyZWF0eS5UcmVhdHlSZXNwb25zZTxUUmVzcG9uc2U+W1wiZXJyb3JcIl07XHJcblxyXG5leHBvcnQgdHlwZSBJbmZlclRyZWF0eU11dGF0aW9uT3B0aW9uczxcclxuICBUSW5wdXQsXHJcbiAgVFJlc3BvbnNlIGV4dGVuZHMgVHJlYXR5UmVzcG9uc2UsXHJcbj4gPSBVc2VNdXRhdGlvbk9wdGlvbnM8XHJcbiAgSW5mZXJUcmVhdHlEYXRhPFRSZXNwb25zZT4sXHJcbiAgSW5mZXJUcmVhdHlFcnJvcjxUUmVzcG9uc2U+LFxyXG4gIFRJbnB1dFxyXG4+O1xyXG5cclxuZXhwb3J0IHR5cGUgSW5mZXJUcmVhdHlRdWVyeU9wdGlvbnM8VFJlc3BvbnNlIGV4dGVuZHMgUmVjb3JkPG51bWJlciwgdW5rbm93bj4+ID1cclxuICBVc2VRdWVyeU9wdGlvbnM8SW5mZXJUcmVhdHlEYXRhPFRSZXNwb25zZT4sIEluZmVyVHJlYXR5RXJyb3I8VFJlc3BvbnNlPj47XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gdHJlYXR5TXV0YXRpb25PcHRpb25zPFRSZXNwb25zZSBleHRlbmRzIFRyZWF0eVJlc3BvbnNlPihcclxuICBmbjogVHJlYXR5RnVuY3Rpb25XaXRob3V0UGFyYW1zPFRSZXNwb25zZT4sXHJcbiAgb3B0aW9ucz86IE9taXQ8SW5mZXJUcmVhdHlNdXRhdGlvbk9wdGlvbnM8dm9pZCwgVFJlc3BvbnNlPiwgXCJtdXRhdGlvbkZuXCI+LFxyXG4pOiBJbmZlclRyZWF0eU11dGF0aW9uT3B0aW9uczx2b2lkLCBUUmVzcG9uc2U+O1xyXG5leHBvcnQgZnVuY3Rpb24gdHJlYXR5TXV0YXRpb25PcHRpb25zPFxyXG4gIFRWYXJpYWJsZXMsXHJcbiAgVFJlc3BvbnNlIGV4dGVuZHMgVHJlYXR5UmVzcG9uc2UsXHJcbj4oXHJcbiAgZm46IFRyZWF0eUZ1bmN0aW9uV2l0aFBhcmFtczxUVmFyaWFibGVzLCBUUmVzcG9uc2U+LFxyXG4gIG9wdGlvbnM/OiBPbWl0PEluZmVyVHJlYXR5TXV0YXRpb25PcHRpb25zPFRWYXJpYWJsZXMsIFRSZXNwb25zZT4sIFwibXV0YXRpb25GblwiPixcclxuKTogSW5mZXJUcmVhdHlNdXRhdGlvbk9wdGlvbnM8VFZhcmlhYmxlcywgVFJlc3BvbnNlPjtcclxuZXhwb3J0IGZ1bmN0aW9uIHRyZWF0eU11dGF0aW9uT3B0aW9uczxcclxuICBUVmFyaWFibGVzLFxyXG4gIFRSZXNwb25zZSBleHRlbmRzIFRyZWF0eVJlc3BvbnNlLFxyXG4+KFxyXG4gIGZuOlxyXG4gICAgfCAoKCkgPT4gUHJvbWlzZTxUcmVhdHkuVHJlYXR5UmVzcG9uc2U8VFJlc3BvbnNlPj4pXHJcbiAgICB8IFRyZWF0eUZ1bmN0aW9uV2l0aFBhcmFtczxUVmFyaWFibGVzLCBUUmVzcG9uc2U+LFxyXG4gIG9wdGlvbnM/OiBPbWl0PEluZmVyVHJlYXR5TXV0YXRpb25PcHRpb25zPFRWYXJpYWJsZXMsIFRSZXNwb25zZT4sIFwibXV0YXRpb25GblwiPixcclxuKTogSW5mZXJUcmVhdHlNdXRhdGlvbk9wdGlvbnM8VFZhcmlhYmxlcywgVFJlc3BvbnNlPiB7XHJcbiAgdHlwZSBURGF0YSA9IEluZmVyVHJlYXR5RGF0YTxUUmVzcG9uc2U+O1xyXG4gIHR5cGUgVEVycm9yID0gSW5mZXJUcmVhdHlFcnJvcjxUUmVzcG9uc2U+O1xyXG4gIHJldHVybiBtdXRhdGlvbk9wdGlvbnM8VERhdGEsIFRFcnJvciwgVFZhcmlhYmxlcz4oe1xyXG4gICAgLi4ub3B0aW9ucyxcclxuICAgIG11dGF0aW9uRm46IGFzeW5jICh2YXJpYWJsZXMpID0+IHtcclxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCAoXHJcbiAgICAgICAgZm4ubGVuZ3RoID09PSAwID8gKGZuIGFzICgpID0+IFByb21pc2U8VHJlYXR5LlRyZWF0eVJlc3BvbnNlPFRSZXNwb25zZT4+KSgpIDogKGZuIGFzIFRyZWF0eUZ1bmN0aW9uV2l0aFBhcmFtczxUVmFyaWFibGVzLCBUUmVzcG9uc2U+KSh2YXJpYWJsZXMpXHJcbiAgICAgICk7XHJcbiAgICAgIGNvbnN0IHsgZGF0YSwgZXJyb3IgfSA9IHJlc3BvbnNlO1xyXG4gICAgICBpZiAoZXJyb3IpIHRocm93IGVycm9yO1xyXG4gICAgICByZXR1cm4gZGF0YTtcclxuICAgIH0sXHJcbiAgfSk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiB0cmVhdHlRdWVyeU9wdGlvbnM8XHJcbiAgVFJlc3BvbnNlIGV4dGVuZHMgVHJlYXR5UmVzcG9uc2UgPSBUcmVhdHlSZXNwb25zZSxcclxuPihcclxuICBmbjogVHJlYXR5RnVuY3Rpb25XaXRob3V0UGFyYW1zPFRSZXNwb25zZT4sXHJcbiAgb3B0aW9uczogT21pdDxJbmZlclRyZWF0eVF1ZXJ5T3B0aW9uczxUUmVzcG9uc2U+LCBcInF1ZXJ5Rm5cIj4sXHJcbik6IEluZmVyVHJlYXR5UXVlcnlPcHRpb25zPFRSZXNwb25zZT4ge1xyXG4gIHR5cGUgVERhdGEgPSBJbmZlclRyZWF0eURhdGE8VFJlc3BvbnNlPjtcclxuICB0eXBlIFRFcnJvciA9IEluZmVyVHJlYXR5RXJyb3I8VFJlc3BvbnNlPjtcclxuICByZXR1cm4gcXVlcnlPcHRpb25zPFREYXRhLCBURXJyb3I+KHtcclxuICAgIC4uLm9wdGlvbnMsXHJcbiAgICBxdWVyeUZuOiBhc3luYyAoKSA9PiB7XHJcbiAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZm4oKTtcclxuICAgICAgY29uc3QgeyBkYXRhLCBlcnJvciB9ID0gcmVzcG9uc2U7XHJcbiAgICAgIGlmIChlcnJvcikgdGhyb3cgZXJyb3I7XHJcbiAgICAgIHJldHVybiBkYXRhO1xyXG4gICAgfSxcclxuICB9KTtcclxufSIKICBdLAogICJtYXBwaW5ncyI6ICI7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQStDTyxTQUFTLHFCQUdmLENBQ0MsSUFHQSxTQUNtRDtBQUFBLEVBR25ELE9BQU8sZ0JBQTJDO0FBQUEsT0FDN0M7QUFBQSxJQUNILFlBQVksT0FBTyxjQUFjO0FBQUEsTUFDL0IsTUFBTSxXQUFXLE9BQ2YsR0FBRyxXQUFXLElBQUssR0FBdUQsSUFBSyxHQUF1RCxTQUFTO0FBQUEsTUFFakosUUFBUSxNQUFNLFVBQVU7QUFBQSxNQUN4QixJQUFJO0FBQUEsUUFBTyxNQUFNO0FBQUEsTUFDakIsT0FBTztBQUFBO0FBQUEsRUFFWCxDQUFDO0FBQUE7QUFHSSxTQUFTLGtCQUVmLENBQ0MsSUFDQSxTQUNvQztBQUFBLEVBR3BDLE9BQU8sYUFBNEI7QUFBQSxPQUM5QjtBQUFBLElBQ0gsU0FBUyxZQUFZO0FBQUEsTUFDbkIsTUFBTSxXQUFXLE1BQU0sR0FBRztBQUFBLE1BQzFCLFFBQVEsTUFBTSxVQUFVO0FBQUEsTUFDeEIsSUFBSTtBQUFBLFFBQU8sTUFBTTtBQUFBLE1BQ2pCLE9BQU87QUFBQTtBQUFBLEVBRVgsQ0FBQztBQUFBOyIsCiAgImRlYnVnSWQiOiAiNjY4RjRDQjlEMDczMTc4NTY0NzU2RTIxNjQ3NTZFMjEiLAogICJuYW1lcyI6IFtdCn0=
55
+ //# debugId=C7B700FB8AB692F864756E2164756E21
56
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src\\lib.ts"],
  "sourcesContent": [
    "import type { Treaty } from \"@elysiajs/eden\";\r\nimport {\r\n  mutationOptions,\r\n  queryOptions,\r\n  useMutation,\r\n  useQuery,\r\n  type UseMutationOptions,\r\n  type UseMutationResult,\r\n  type UseQueryOptions,\r\n  type UseQueryResult,\r\n} from \"@tanstack/react-query\";\r\n\r\ntype TreatyResponse = Record<number, unknown>;\r\n\r\nexport type TreatyFunctionWithoutParams<\r\n  TResponse extends TreatyResponse = TreatyResponse,\r\n> = () => Promise<Treaty.TreatyResponse<TResponse>>;\r\n\r\nexport type TreatyFunctionWithParams<\r\n  TParams,\r\n  TResponse extends TreatyResponse,\r\n> = (params: TParams) => Promise<Treaty.TreatyResponse<TResponse>>;\r\n\r\nexport type TreatyFunction<\r\n  TParams,\r\n  TResponse extends TreatyResponse,\r\n> = TreatyFunctionWithoutParams<TResponse> | TreatyFunctionWithParams<TParams, TResponse>;\r\n\r\nexport type TreatyData<TResponse extends TreatyResponse> =\r\n  Treaty.TreatyResponse<TResponse>[\"data\"];\r\n\r\nexport type TreatyError<TResponse extends TreatyResponse> =\r\n  Treaty.TreatyResponse<TResponse>[\"error\"];\r\n\r\nexport type TreatyMutationOptions<\r\n  TVariables,\r\n  TResponse extends TreatyResponse,\r\n> = UseMutationOptions<\r\n  TreatyData<TResponse>,\r\n  TreatyError<TResponse>,\r\n  TVariables\r\n>;\r\n\r\nexport type UseTreatyMutationResult<\r\n  TVariables,\r\n  TResponse extends TreatyResponse,\r\n> = (\r\n  UseMutationResult<\r\n    TreatyData<TResponse>,\r\n    TreatyError<TResponse>,\r\n    TVariables\r\n  >\r\n);\r\n\r\nexport type UseTreatyQueryResult<\r\n  TResponse extends TreatyResponse,\r\n> = (\r\n  UseQueryResult<\r\n    TreatyData<TResponse>,\r\n    TreatyError<TResponse>\r\n  >\r\n);\r\n\r\nexport type TreatyQueryOptions<TResponse extends Record<number, unknown>> =\r\n  UseQueryOptions<TreatyData<TResponse>, TreatyError<TResponse>>;\r\n\r\nexport type UseTreatyMutationHook<\r\n  TVariables,\r\n  TResponse extends TreatyResponse,\r\n> = (\r\n  (options: Partial<Omit<TreatyMutationOptions<TVariables, TResponse>, \"mutationFn\">>) => \r\n    UseTreatyMutationResult<TVariables, TResponse>\r\n);\r\n\r\nexport type UseTreatyQueryHook<\r\n  TResponse extends TreatyResponse,\r\n> = (\r\n  (options: Partial<Omit<TreatyQueryOptions<TResponse>, \"queryFn\">>) => \r\n    UseTreatyQueryResult<TResponse>\r\n);\r\n\r\nexport function treatyMutationOptions<TResponse extends TreatyResponse>(\r\n  fn: TreatyFunctionWithoutParams<TResponse>,\r\n  options?: Omit<TreatyMutationOptions<void, TResponse>, \"mutationFn\">,\r\n): TreatyMutationOptions<void, TResponse>;\r\nexport function treatyMutationOptions<\r\n  TVariables,\r\n  TResponse extends TreatyResponse,\r\n>(\r\n  fn: TreatyFunctionWithParams<TVariables, TResponse>,\r\n  options?: Omit<TreatyMutationOptions<TVariables, TResponse>, \"mutationFn\">,\r\n): TreatyMutationOptions<TVariables, TResponse>;\r\nexport function treatyMutationOptions<\r\n  TVariables,\r\n  TResponse extends TreatyResponse,\r\n>(\r\n  fn: TreatyFunction<TVariables, TResponse>,\r\n  options?: Omit<TreatyMutationOptions<TVariables, TResponse>, \"mutationFn\">,\r\n): TreatyMutationOptions<TVariables, TResponse> {\r\n  type TData = TreatyData<TResponse>;\r\n  type TError = TreatyError<TResponse>;\r\n  return mutationOptions<TData, TError, TVariables>({\r\n    ...options,\r\n    mutationFn: async (variables) => {\r\n      const response = await (\r\n        fn.length === 0 ? (fn as () => Promise<Treaty.TreatyResponse<TResponse>>)() : (fn as TreatyFunctionWithParams<TVariables, TResponse>)(variables)\r\n      );\r\n      const { data, error } = response;\r\n      if (error) throw error;\r\n      return data;\r\n    },\r\n  });\r\n}\r\n\r\nexport function treatyQueryOptions<\r\n  TResponse extends TreatyResponse = TreatyResponse,\r\n>(\r\n  fn: TreatyFunctionWithoutParams<TResponse>,\r\n  options: Omit<TreatyQueryOptions<TResponse>, \"queryFn\">,\r\n): TreatyQueryOptions<TResponse> {\r\n  type TData = TreatyData<TResponse>;\r\n  type TError = TreatyError<TResponse>;\r\n  return queryOptions<TData, TError>({\r\n    ...options,\r\n    queryFn: async () => {\r\n      const response = await fn();\r\n      const { data, error } = response;\r\n      if (error) throw error;\r\n      return data;\r\n    },\r\n  });\r\n}\r\n\r\nexport function createMutationHook<TResponse extends TreatyResponse>(\r\n  fn: TreatyFunctionWithoutParams<TResponse>,\r\n  options?: Omit<TreatyMutationOptions<void, TResponse>, \"mutationFn\">,\r\n): UseTreatyMutationHook<void, TResponse>;\r\nexport function createMutationHook<\r\n  TVariables,\r\n  TResponse extends TreatyResponse,\r\n>(\r\n  fn: TreatyFunctionWithParams<TVariables, TResponse>,\r\n  options?: Omit<TreatyMutationOptions<TVariables, TResponse>, \"mutationFn\">,\r\n): UseTreatyMutationHook<TVariables, TResponse>;\r\nexport function createMutationHook<\r\n  TVariables,\r\n  TResponse extends TreatyResponse,\r\n>(\r\n  fn: TreatyFunction<TVariables, TResponse>,\r\n  createOptions?: Omit<TreatyMutationOptions<TVariables, TResponse>, \"mutationFn\">,\r\n): UseTreatyMutationHook<TVariables, TResponse> {\r\n  return (options) => {\r\n    return useMutation({\r\n      ...treatyMutationOptions(fn, createOptions),\r\n      ...options,\r\n    });\r\n  };\r\n}\r\n\r\nexport function createQueryHook<\r\n  TResponse extends TreatyResponse,\r\n>(\r\n  fn: TreatyFunctionWithoutParams<TResponse>,\r\n  createOptions: Omit<TreatyQueryOptions<TResponse>, \"queryFn\">,\r\n): UseTreatyQueryHook<TResponse> {\r\n  return (options) => {\r\n    return useQuery({\r\n      ...treatyQueryOptions(fn, createOptions),\r\n      ...options,\r\n    });\r\n  };\r\n}"
  ],
  "mappings": ";AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AA2FO,SAAS,qBAGf,CACC,IACA,SAC8C;AAAA,EAG9C,OAAO,gBAA2C;AAAA,OAC7C;AAAA,IACH,YAAY,OAAO,cAAc;AAAA,MAC/B,MAAM,WAAW,OACf,GAAG,WAAW,IAAK,GAAuD,IAAK,GAAuD,SAAS;AAAA,MAEjJ,QAAQ,MAAM,UAAU;AAAA,MACxB,IAAI;AAAA,QAAO,MAAM;AAAA,MACjB,OAAO;AAAA;AAAA,EAEX,CAAC;AAAA;AAGI,SAAS,kBAEf,CACC,IACA,SAC+B;AAAA,EAG/B,OAAO,aAA4B;AAAA,OAC9B;AAAA,IACH,SAAS,YAAY;AAAA,MACnB,MAAM,WAAW,MAAM,GAAG;AAAA,MAC1B,QAAQ,MAAM,UAAU;AAAA,MACxB,IAAI;AAAA,QAAO,MAAM;AAAA,MACjB,OAAO;AAAA;AAAA,EAEX,CAAC;AAAA;AAcI,SAAS,kBAGf,CACC,IACA,eAC8C;AAAA,EAC9C,OAAO,CAAC,YAAY;AAAA,IAClB,OAAO,YAAY;AAAA,SACd,sBAAsB,IAAI,aAAa;AAAA,SACvC;AAAA,IACL,CAAC;AAAA;AAAA;AAIE,SAAS,eAEf,CACC,IACA,eAC+B;AAAA,EAC/B,OAAO,CAAC,YAAY;AAAA,IAClB,OAAO,SAAS;AAAA,SACX,mBAAmB,IAAI,aAAa;AAAA,SACpC;AAAA,IACL,CAAC;AAAA;AAAA;",
  "debugId": "C7B700FB8AB692F864756E2164756E21",
  "names": []
}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "eden2query",
3
3
  "description": "Type-safe Eden Treaty to React Query helpers",
4
- "version": "0.3.1",
4
+ "version": "0.3.3",
5
5
  "type": "module",
6
6
  "files": [
7
7
  "dist"