eden2query 0.3.4 → 0.3.6
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 +40 -37
- package/dist/index.d.ts +47 -37
- package/dist/index.js +75 -29
- package/package.json +3 -1
package/README.md
CHANGED
|
@@ -67,55 +67,58 @@ const queryClient = new QueryClient();
|
|
|
67
67
|
queryClient.prefetchQuery(getOptions);
|
|
68
68
|
```
|
|
69
69
|
|
|
70
|
-
### Hook builders: `
|
|
70
|
+
### Hook builders: `treatyQueryHook` / `treatyMutationHook`
|
|
71
71
|
|
|
72
|
-
Create reusable, pre-configured hooks for a Treaty endpoint. The
|
|
72
|
+
Create reusable, pre-configured hooks for a Treaty endpoint. The first parameter is the **Treaty function**, and the second optional parameter is **`useOptions`** — a hook that returns default options (so you can use React hooks like `useQueryClient()`).
|
|
73
73
|
|
|
74
|
-
**
|
|
74
|
+
**Mutation hook** — pass the mutation function and optional `useOptions`:
|
|
75
75
|
|
|
76
76
|
```ts
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
77
|
+
function myMutationFn(variables: { name: string; q: string }) {
|
|
78
|
+
return client.api.resource.post(
|
|
79
|
+
{ name: variables.name },
|
|
80
|
+
{ query: { q: variables.q } }
|
|
81
|
+
);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
const useMutationHook = treatyMutationHook(myMutationFn, () => {
|
|
85
|
+
const queryClient = useQueryClient();
|
|
86
|
+
return {
|
|
87
|
+
onSuccess: () => {
|
|
88
|
+
queryClient.invalidateQueries({ queryKey: ["resource"] });
|
|
89
|
+
},
|
|
90
|
+
};
|
|
91
|
+
});
|
|
81
92
|
|
|
82
93
|
// In a component
|
|
83
|
-
const
|
|
94
|
+
const mutationResult = useMutationHook({
|
|
95
|
+
onSuccess: (data, variables) => {
|
|
96
|
+
console.log(data, variables);
|
|
97
|
+
},
|
|
98
|
+
});
|
|
99
|
+
mutationResult.mutate({
|
|
100
|
+
name: "World",
|
|
101
|
+
q: "hello",
|
|
102
|
+
});
|
|
84
103
|
```
|
|
85
104
|
|
|
86
|
-
**
|
|
105
|
+
**Query hook** — pass the query function and optional `useOptions` that receives the `request` and returns options including `queryKey`:
|
|
87
106
|
|
|
88
107
|
```ts
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
{ onSuccess: () => console.log("Success") },
|
|
93
|
-
);
|
|
108
|
+
function myQueryFn(request: { q: string }) {
|
|
109
|
+
return client.api.resource.get({ query: { q: request.q } });
|
|
110
|
+
}
|
|
94
111
|
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
const queryClient = useQueryClient();
|
|
100
|
-
return {
|
|
101
|
-
onSettled() {
|
|
102
|
-
queryClient.invalidateQueries({ queryKey: ["resource"] });
|
|
103
|
-
},
|
|
104
|
-
};
|
|
105
|
-
},
|
|
106
|
-
);
|
|
112
|
+
const useQueryHook = treatyQueryHook(myQueryFn, (request) => ({
|
|
113
|
+
queryKey: ["resource", request] as const,
|
|
114
|
+
enabled: true,
|
|
115
|
+
}));
|
|
107
116
|
|
|
108
117
|
// In a component
|
|
109
|
-
const
|
|
110
|
-
postMutation.mutate({ body: { name: "World" } });
|
|
111
|
-
|
|
112
|
-
const postWithInvalidation = usePostResourceWithInvalidation({
|
|
113
|
-
onSuccess: () => console.log("Success"),
|
|
114
|
-
});
|
|
115
|
-
postWithInvalidation.mutate({ body: { name: "World" } });
|
|
118
|
+
const queryResult = useQueryHook({ q: "hello" });
|
|
116
119
|
```
|
|
117
120
|
|
|
118
|
-
Hooks accept the same options as `useQuery` / `useMutation`; call-time options are merged with the base options from `useOptions`.
|
|
121
|
+
Hooks accept the same options as `useQuery` / `useMutation`; call-time options are merged with the base options from `useOptions`. Callbacks are chained: base options run first, then `useOptions` callbacks, then call-site callbacks.
|
|
119
122
|
|
|
120
123
|
## API
|
|
121
124
|
|
|
@@ -124,13 +127,13 @@ Hooks accept the same options as `useQuery` / `useMutation`; call-time options a
|
|
|
124
127
|
**`treatyMutationOptions(fn, mutationOptions?)`** — wraps a Treaty mutation into `mutationOptions`. Two shapes:
|
|
125
128
|
|
|
126
129
|
- **No-arg:** `fn` is `() => Promise<...>`. Use when the mutation has no call-time input (e.g. DELETE with fixed path params). `mutate()` is called with no arguments.
|
|
127
|
-
- **With variables:** `fn` is `(vars) => Promise<...>`. Use for POST/PUT etc. `mutate(vars)` receives a single object (e.g. `{ body, query }` or the Treaty method
|
|
130
|
+
- **With variables:** `fn` is `(vars) => Promise<...>`. Use for POST/PUT etc. `mutate(vars)` receives a single object (e.g. `{ body, query }` or the Treaty method's first argument). You can pass the Treaty method directly when its signature matches (e.g. `client.api.resource({ id }).put`).
|
|
128
131
|
|
|
129
132
|
The optional second argument accepts all `mutationOptions` fields except `mutationFn` (e.g. `onSuccess`, `onSettled`, `onMutate`).
|
|
130
133
|
|
|
131
|
-
**`
|
|
134
|
+
**`treatyMutationHook(mutationFn, useOptions?)`** — returns a hook that wraps `useMutation` with the given Treaty mutation function. **`mutationFn`** is the Treaty mutation function (e.g. `myMutationFn`). **`useOptions`** is optional; it's a hook that returns default mutation options (so you can use `useQueryClient()` for invalidation). The returned hook accepts the same options as `useMutation`; callbacks are chained (base → `useOptions` → call-site).
|
|
132
135
|
|
|
133
|
-
**`
|
|
136
|
+
**`treatyQueryHook(queryFn, useOptions?)`** — returns a hook that wraps `useQuery` with the given Treaty query function. **`queryFn`** is the Treaty query function (e.g. `myQueryFn`). **`useOptions`** is optional; it's a function `(request) => ...` that receives the query request and returns default query options including `queryKey` (so you can use React hooks like `useQueryClient()`). The returned hook is called with `(request, options?)`; callbacks are chained (base → `useOptions` → call-site).
|
|
134
137
|
|
|
135
138
|
**`InferTreatyQueryOptions<T>`** — full `UseQueryOptions` type for a given Treaty query.
|
|
136
139
|
|
package/dist/index.d.ts
CHANGED
|
@@ -1,38 +1,48 @@
|
|
|
1
1
|
import { Treaty } from "@elysiajs/eden";
|
|
2
|
-
import { UseMutationOptions, UseMutationResult, UseQueryOptions, UseQueryResult } from "@tanstack/react-query";
|
|
3
|
-
type
|
|
4
|
-
type
|
|
5
|
-
type
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
>
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
2
|
+
import { QueryKey, UseMutationOptions, UseMutationResult, UseQueryOptions, UseQueryResult } from "@tanstack/react-query";
|
|
3
|
+
type TreatyFunction = (...request: any[]) => Promise<Treaty.TreatyResponse<Record<number, unknown>>>;
|
|
4
|
+
type InferTreatyData<TFn extends TreatyFunction> = Awaited<ReturnType<TFn>>["data"];
|
|
5
|
+
type InferTreatyError<TFn extends TreatyFunction> = Awaited<ReturnType<TFn>>["error"];
|
|
6
|
+
type InferTreatyRequest<TFn extends TreatyFunction> = Parameters<TFn>[0];
|
|
7
|
+
type InferTreatyMutationOptions<TFn extends TreatyFunction> = UseMutationOptions<InferTreatyData<TFn>, InferTreatyError<TFn>, InferTreatyRequest<TFn>>;
|
|
8
|
+
type InferTreatyQueryOptions<
|
|
9
|
+
TFn extends TreatyFunction,
|
|
10
|
+
TQueryKey extends QueryKey = unknown[]
|
|
11
|
+
> = UseQueryOptions<InferTreatyData<TFn>, InferTreatyError<TFn>, InferTreatyData<TFn>, TQueryKey>;
|
|
12
|
+
declare function treatyMutationOptions<TFn extends TreatyFunction>(options: {
|
|
13
|
+
mutationFn: TFn;
|
|
14
|
+
} & Omit<InferTreatyMutationOptions<TFn>, "mutationFn">): InferTreatyMutationOptions<TFn>;
|
|
15
|
+
declare function treatyQueryOptions<
|
|
16
|
+
TFn extends TreatyFunction,
|
|
17
|
+
const TQueryKey extends QueryKey
|
|
18
|
+
>(options: {
|
|
19
|
+
queryKey: TQueryKey;
|
|
20
|
+
queryFn: TFn;
|
|
21
|
+
} & Omit<InferTreatyQueryOptions<TFn, TQueryKey>, "queryKey" | "queryFn">): InferTreatyQueryOptions<TFn, TQueryKey>;
|
|
22
|
+
type UseTreatyMutationResult<TFn extends TreatyFunction> = UseMutationResult<InferTreatyData<TFn>, InferTreatyError<TFn>, InferTreatyRequest<TFn>>;
|
|
23
|
+
type UseTreatyQueryResult<
|
|
24
|
+
TFn extends TreatyFunction,
|
|
25
|
+
TQueryKey extends QueryKey = unknown[]
|
|
26
|
+
> = UseQueryResult<InferTreatyData<TFn>, InferTreatyError<TFn>>;
|
|
27
|
+
type TreatyMutationHookOptions<TFn extends TreatyFunction> = Omit<InferTreatyMutationOptions<TFn>, "mutationFn">;
|
|
28
|
+
type TreatyQueryHookOptions<
|
|
29
|
+
TFn extends TreatyFunction,
|
|
30
|
+
TQueryKey extends QueryKey = unknown[]
|
|
31
|
+
> = Omit<InferTreatyQueryOptions<TFn, TQueryKey>, "queryKey" | "queryFn">;
|
|
32
|
+
type TreatyQueryHookUseOptions<
|
|
33
|
+
TFn extends TreatyFunction,
|
|
34
|
+
TQueryKey extends QueryKey = unknown[]
|
|
35
|
+
> = {
|
|
36
|
+
queryKey: TQueryKey;
|
|
37
|
+
} & TreatyQueryHookOptions<TFn, TQueryKey>;
|
|
38
|
+
type TreatyMutationHook<TFn extends TreatyFunction> = (options?: TreatyMutationHookOptions<TFn>) => UseTreatyMutationResult<TFn>;
|
|
39
|
+
type TreatyQueryHook<
|
|
40
|
+
TFn extends TreatyFunction,
|
|
41
|
+
TQueryKey extends QueryKey = unknown[]
|
|
42
|
+
> = (request: InferTreatyRequest<TFn>, options?: TreatyQueryHookOptions<TFn, TQueryKey>) => UseTreatyQueryResult<TFn, TQueryKey>;
|
|
43
|
+
declare function treatyMutationHook<TFn extends TreatyFunction>(mutationFn: TFn, useOptions?: () => TreatyMutationHookOptions<TFn>): TreatyMutationHook<TFn>;
|
|
44
|
+
declare function treatyQueryHook<
|
|
45
|
+
TFn extends TreatyFunction,
|
|
46
|
+
TQueryKey extends QueryKey = QueryKey
|
|
47
|
+
>(queryFn: TFn, useOptions?: (request: InferTreatyRequest<TFn>) => TreatyQueryHookUseOptions<TFn, TQueryKey>): TreatyQueryHook<TFn, TQueryKey>;
|
|
48
|
+
export { treatyQueryOptions, treatyQueryHook, treatyMutationOptions, treatyMutationHook, InferTreatyQueryOptions, InferTreatyMutationOptions };
|
package/dist/index.js
CHANGED
|
@@ -1,15 +1,57 @@
|
|
|
1
|
-
// src/
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
// src/treaty.ts
|
|
2
|
+
import { mutationOptions, queryOptions, useMutation, useQuery } from "@tanstack/react-query";
|
|
3
|
+
|
|
4
|
+
// src/utils.ts
|
|
5
|
+
function mergeMutationOptions(base, options) {
|
|
6
|
+
if (!options)
|
|
7
|
+
return base;
|
|
8
|
+
const { onSuccess, onError, onSettled, onMutate, ...rest } = options;
|
|
9
|
+
return {
|
|
10
|
+
...base,
|
|
11
|
+
...rest,
|
|
12
|
+
...onMutate !== undefined && {
|
|
13
|
+
onMutate: async (variables, context) => {
|
|
14
|
+
const prev = await base.onMutate?.(variables, context);
|
|
15
|
+
const next = await options.onMutate?.(variables, context);
|
|
16
|
+
return next !== undefined ? next : prev;
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
...onSuccess !== undefined && {
|
|
20
|
+
onSuccess: async (data, variables, onMutateResult, context) => {
|
|
21
|
+
await base.onSuccess?.(data, variables, onMutateResult, context);
|
|
22
|
+
await options.onSuccess?.(data, variables, onMutateResult, context);
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
...onError !== undefined && {
|
|
26
|
+
onError: async (error, variables, onMutateResult, context) => {
|
|
27
|
+
await base.onError?.(error, variables, onMutateResult, context);
|
|
28
|
+
await options.onError?.(error, variables, onMutateResult, context);
|
|
29
|
+
}
|
|
30
|
+
},
|
|
31
|
+
...onSettled !== undefined && {
|
|
32
|
+
onSettled: async (data, error, variables, onMutateResult, context) => {
|
|
33
|
+
await base.onSettled?.(data, error, variables, onMutateResult, context);
|
|
34
|
+
await options.onSettled?.(data, error, variables, onMutateResult, context);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
function mergeQueryOptions(base, options) {
|
|
40
|
+
if (!options)
|
|
41
|
+
return base;
|
|
42
|
+
return {
|
|
43
|
+
...base,
|
|
44
|
+
...options
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// src/treaty.ts
|
|
49
|
+
function treatyMutationOptions(options) {
|
|
50
|
+
const { mutationFn, ...rest } = options;
|
|
9
51
|
return mutationOptions({
|
|
10
|
-
...
|
|
52
|
+
...rest,
|
|
11
53
|
mutationFn: async (variables) => {
|
|
12
|
-
const response = await (
|
|
54
|
+
const response = await mutationFn(variables);
|
|
13
55
|
const { data, error } = response;
|
|
14
56
|
if (error)
|
|
15
57
|
throw error;
|
|
@@ -17,11 +59,13 @@ function treatyMutationOptions(fn, options) {
|
|
|
17
59
|
}
|
|
18
60
|
});
|
|
19
61
|
}
|
|
20
|
-
function treatyQueryOptions(
|
|
62
|
+
function treatyQueryOptions(options) {
|
|
63
|
+
const { queryFn, queryKey, ...rest } = options;
|
|
21
64
|
return queryOptions({
|
|
22
|
-
...
|
|
65
|
+
...rest,
|
|
66
|
+
queryKey,
|
|
23
67
|
queryFn: async () => {
|
|
24
|
-
const response = await
|
|
68
|
+
const response = await queryFn();
|
|
25
69
|
const { data, error } = response;
|
|
26
70
|
if (error)
|
|
27
71
|
throw error;
|
|
@@ -29,30 +73,32 @@ function treatyQueryOptions(fn, options) {
|
|
|
29
73
|
}
|
|
30
74
|
});
|
|
31
75
|
}
|
|
32
|
-
function
|
|
76
|
+
function treatyMutationHook(mutationFn, useOptions) {
|
|
33
77
|
return (options) => {
|
|
34
|
-
const
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
});
|
|
78
|
+
const baseOptions = treatyMutationOptions({ mutationFn });
|
|
79
|
+
const defaultOptions = useOptions?.();
|
|
80
|
+
const merged = mergeMutationOptions(mergeMutationOptions(baseOptions, defaultOptions), options);
|
|
81
|
+
return useMutation(merged);
|
|
39
82
|
};
|
|
40
83
|
}
|
|
41
|
-
function
|
|
42
|
-
return (options) => {
|
|
43
|
-
const
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
84
|
+
function treatyQueryHook(queryFn, useOptions) {
|
|
85
|
+
return (request, options) => {
|
|
86
|
+
const defaultOptions = useOptions?.(request);
|
|
87
|
+
const baseOptions = treatyQueryOptions({
|
|
88
|
+
queryKey: defaultOptions?.queryKey ?? ["resource", request],
|
|
89
|
+
queryFn: () => queryFn(request),
|
|
90
|
+
...defaultOptions
|
|
47
91
|
});
|
|
92
|
+
const merged = mergeQueryOptions(baseOptions, options);
|
|
93
|
+
return useQuery(merged);
|
|
48
94
|
};
|
|
49
95
|
}
|
|
50
96
|
export {
|
|
51
97
|
treatyQueryOptions,
|
|
98
|
+
treatyQueryHook,
|
|
52
99
|
treatyMutationOptions,
|
|
53
|
-
|
|
54
|
-
createTreatyMutationHook
|
|
100
|
+
treatyMutationHook
|
|
55
101
|
};
|
|
56
102
|
|
|
57
|
-
//# debugId=
|
|
58
|
-
//# 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 createTreatyMutationHook<TResponse extends TreatyResponse>(\r\n  fn: TreatyFunctionWithoutParams<TResponse>,\r\n  useOptions?: (\r\n    Omit<TreatyMutationOptions<void, TResponse>, \"mutationFn\"> | \r\n    (() => Omit<TreatyMutationOptions<void, TResponse>, \"mutationFn\">)\r\n  ),\r\n): UseTreatyMutationHook<void, TResponse>;\r\nexport function createTreatyMutationHook<\r\n  TVariables,\r\n  TResponse extends TreatyResponse,\r\n>(\r\n  fn: TreatyFunctionWithParams<TVariables, TResponse>,\r\n  useOptions?: (\r\n    Omit<TreatyMutationOptions<TVariables, TResponse>, \"mutationFn\"> | \r\n    (() => Omit<TreatyMutationOptions<TVariables, TResponse>, \"mutationFn\">)\r\n  ),\r\n): UseTreatyMutationHook<TVariables, TResponse>;\r\nexport function createTreatyMutationHook<\r\n  TVariables,\r\n  TResponse extends TreatyResponse,\r\n>(\r\n  fn: TreatyFunction<TVariables, TResponse>,\r\n  useOptions?: (\r\n    Omit<TreatyMutationOptions<TVariables, TResponse>, \"mutationFn\"> | \r\n    (() => Omit<TreatyMutationOptions<TVariables, TResponse>, \"mutationFn\">)\r\n  ),\r\n): UseTreatyMutationHook<TVariables, TResponse> {\r\n  return (options) => {\r\n    const initOptions = typeof useOptions === \"function\" ? useOptions() : useOptions;\r\n    return useMutation({\r\n      ...treatyMutationOptions(fn, initOptions),\r\n      ...options,\r\n    });\r\n  };\r\n}\r\n\r\nexport function createTreatyQueryHook<\r\n  TResponse extends TreatyResponse,\r\n>(\r\n  fn: TreatyFunctionWithoutParams<TResponse>,\r\n  useOptions: (\r\n    Omit<TreatyQueryOptions<TResponse>, \"queryFn\"> | \r\n    (() => Omit<TreatyQueryOptions<TResponse>, \"queryFn\">)\r\n  ),\r\n): UseTreatyQueryHook<TResponse> {\r\n  return (options) => {\r\n    const initOptions = typeof useOptions === \"function\" ? useOptions() : useOptions;\r\n    return useQuery({\r\n      ...treatyQueryOptions(fn, initOptions),\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;AAoBI,SAAS,wBAGf,CACC,IACA,YAI8C;AAAA,EAC9C,OAAO,CAAC,YAAY;AAAA,IAClB,MAAM,cAAc,OAAO,eAAe,aAAa,WAAW,IAAI;AAAA,IACtE,OAAO,YAAY;AAAA,SACd,sBAAsB,IAAI,WAAW;AAAA,SACrC;AAAA,IACL,CAAC;AAAA;AAAA;AAIE,SAAS,qBAEf,CACC,IACA,YAI+B;AAAA,EAC/B,OAAO,CAAC,YAAY;AAAA,IAClB,MAAM,cAAc,OAAO,eAAe,aAAa,WAAW,IAAI;AAAA,IACtE,OAAO,SAAS;AAAA,SACX,mBAAmB,IAAI,WAAW;AAAA,SAClC;AAAA,IACL,CAAC;AAAA;AAAA;",
  "debugId": "7C7D36173641BA3264756E2164756E21",
  "names": []
}
|
|
103
|
+
//# debugId=3974E80E199B9F8064756E2164756E21
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src\\treaty.ts", "src\\utils.ts"],
  "sourcesContent": [
    "import type { Treaty } from \"@elysiajs/eden\";\r\nimport { mutationOptions, queryOptions, useMutation, useQuery, type QueryKey, type UseMutationOptions, type UseMutationResult, type UseQueryOptions, type UseQueryResult } from \"@tanstack/react-query\";\r\nimport { mergeMutationOptions, mergeQueryOptions } from \"./utils\";\r\n\r\ntype TreatyFunction = (...request: any[]) => \r\n  Promise<Treaty.TreatyResponse<Record<number, unknown>>>;\r\n\r\nexport type InferTreatyData<\r\n  TFn extends TreatyFunction,\r\n> = Awaited<ReturnType<TFn>>[\"data\"];\r\n\r\nexport type InferTreatyError<\r\n  TFn extends TreatyFunction,\r\n> = Awaited<ReturnType<TFn>>[\"error\"];\r\n\r\nexport type InferTreatyRequest<\r\n  TFn extends TreatyFunction,\r\n> = Parameters<TFn>[0];\r\n\r\nexport type InferTreatyMutationOptions<\r\n  TFn extends TreatyFunction,\r\n> = UseMutationOptions<\r\n  InferTreatyData<TFn>,\r\n  InferTreatyError<TFn>,\r\n  InferTreatyRequest<TFn>\r\n>;\r\n\r\nexport type InferTreatyQueryOptions<\r\n  TFn extends TreatyFunction,\r\n  TQueryKey extends QueryKey = unknown[],\r\n> = UseQueryOptions<\r\n  InferTreatyData<TFn>,\r\n  InferTreatyError<TFn>,\r\n  InferTreatyData<TFn>,\r\n  TQueryKey\r\n>;\r\n\r\nexport function treatyMutationOptions<TFn extends TreatyFunction>(\r\n  options: {\r\n    mutationFn: TFn;\r\n  } & Omit<\r\n    InferTreatyMutationOptions<TFn>,\r\n    \"mutationFn\"\r\n  >\r\n): InferTreatyMutationOptions<TFn> {\r\n  type TData = InferTreatyData<TFn>;\r\n  type TError = InferTreatyError<TFn>;\r\n  type TVariables = InferTreatyRequest<TFn>;\r\n  const { mutationFn, ...rest } = options;\r\n  return mutationOptions<TData, TError, TVariables>({\r\n    ...rest,\r\n    mutationFn: async (variables) => {\r\n      const response = await mutationFn(variables);\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  TFn extends TreatyFunction,\r\n  const TQueryKey extends QueryKey,\r\n>(\r\n  options: {\r\n    queryKey: TQueryKey;\r\n    queryFn: TFn;\r\n  } & Omit<\r\n    InferTreatyQueryOptions<TFn, TQueryKey>,\r\n    \"queryKey\" | \"queryFn\"\r\n  >\r\n): InferTreatyQueryOptions<TFn, TQueryKey> {\r\n  type TData = InferTreatyData<TFn>;\r\n  type TError = InferTreatyError<TFn>;\r\n  const { queryFn, queryKey, ...rest } = options;\r\n  return queryOptions<TData, TError, TData, TQueryKey>({\r\n    ...rest,\r\n    queryKey,\r\n    queryFn: async () => {\r\n      const response = await queryFn();\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 type UseTreatyMutationResult<TFn extends TreatyFunction> = UseMutationResult<\r\n  InferTreatyData<TFn>,\r\n  InferTreatyError<TFn>,\r\n  InferTreatyRequest<TFn>\r\n>;\r\n\r\nexport type UseTreatyQueryResult<\r\n  TFn extends TreatyFunction,\r\n  TQueryKey extends QueryKey = unknown[],\r\n> = UseQueryResult<\r\n  InferTreatyData<TFn>,\r\n  InferTreatyError<TFn>\r\n>;\r\n\r\nexport type TreatyMutationHookOptions<TFn extends TreatyFunction> = Omit<\r\n  InferTreatyMutationOptions<TFn>,\r\n  \"mutationFn\"\r\n>;\r\n\r\nexport type TreatyQueryHookOptions<\r\n  TFn extends TreatyFunction,\r\n  TQueryKey extends QueryKey = unknown[],\r\n> = Omit<\r\n  InferTreatyQueryOptions<TFn, TQueryKey>,\r\n  \"queryKey\" | \"queryFn\"\r\n>;\r\n\r\nexport type TreatyQueryHookUseOptions<\r\n  TFn extends TreatyFunction,\r\n  TQueryKey extends QueryKey = unknown[],\r\n> = {\r\n  queryKey: TQueryKey;\r\n} & TreatyQueryHookOptions<TFn, TQueryKey>;\r\n\r\nexport type TreatyMutationHook<TFn extends TreatyFunction> = (\r\n  options?: TreatyMutationHookOptions<TFn>\r\n) => UseTreatyMutationResult<TFn>;\r\n\r\nexport type TreatyQueryHook<\r\n  TFn extends TreatyFunction,\r\n  TQueryKey extends QueryKey = unknown[],\r\n> = (\r\n  request: InferTreatyRequest<TFn>,\r\n  options?: TreatyQueryHookOptions<TFn, TQueryKey>\r\n) => UseTreatyQueryResult<TFn, TQueryKey>;\r\n\r\nexport function treatyMutationHook<TFn extends TreatyFunction>(\r\n  mutationFn: TFn,\r\n  useOptions?: () => TreatyMutationHookOptions<TFn>\r\n): TreatyMutationHook<TFn> {\r\n  return (options) => {\r\n    const baseOptions = treatyMutationOptions({ mutationFn });\r\n    const defaultOptions = useOptions?.();\r\n    const merged = mergeMutationOptions(\r\n      mergeMutationOptions(baseOptions, defaultOptions),\r\n      options\r\n    );\r\n    return useMutation(merged);\r\n  };\r\n}\r\n\r\nexport function treatyQueryHook<\r\n  TFn extends TreatyFunction,\r\n  TQueryKey extends QueryKey = QueryKey,\r\n>(\r\n  queryFn: TFn,\r\n  useOptions?: (\r\n    request: InferTreatyRequest<TFn>\r\n  ) => TreatyQueryHookUseOptions<TFn, TQueryKey>\r\n): TreatyQueryHook<TFn, TQueryKey> {\r\n  return (request, options) => {\r\n    const defaultOptions = useOptions?.(request);\r\n    const baseOptions = treatyQueryOptions({\r\n      queryKey: (defaultOptions?.queryKey ?? ([\"resource\", request] as unknown)) as TQueryKey,\r\n      queryFn: (() => queryFn(request)) as TFn,\r\n      ...defaultOptions,\r\n    });\r\n    const merged = mergeQueryOptions(\r\n      baseOptions,\r\n      options as UseQueryOptions<\r\n        InferTreatyData<TFn>,\r\n        InferTreatyError<TFn>,\r\n        InferTreatyData<TFn>,\r\n        TQueryKey\r\n      > | undefined\r\n    );\r\n    return useQuery(merged);\r\n  };\r\n}",
    "import type { QueryKey, UseMutationOptions, UseQueryOptions } from \"@tanstack/react-query\";\r\n\r\nexport function mergeMutationOptions<TData, TError, TVariables, TContext>(\r\n  base: UseMutationOptions<TData, TError, TVariables, TContext>,\r\n  options?: Partial<UseMutationOptions<TData, TError, TVariables, TContext>>\r\n): UseMutationOptions<TData, TError, TVariables, TContext> {\r\n  if (!options) return base;\r\n  const { onSuccess, onError, onSettled, onMutate, ...rest } = options;\r\n  return {\r\n    ...base,\r\n    ...rest,\r\n    ...(onMutate !== undefined && {\r\n      onMutate: async (variables, context) => {\r\n        const prev = await base.onMutate?.(variables, context);\r\n        const next = await options.onMutate?.(variables, context);\r\n        return (next !== undefined ? next : prev) as TContext;\r\n      },\r\n    }),\r\n    ...(onSuccess !== undefined && {\r\n      onSuccess: async (data, variables, onMutateResult, context) => {\r\n        await base.onSuccess?.(data, variables, onMutateResult, context);\r\n        await options.onSuccess?.(data, variables, onMutateResult, context);\r\n      },\r\n    }),\r\n    ...(onError !== undefined && {\r\n      onError: async (error, variables, onMutateResult, context) => {\r\n        await base.onError?.(error, variables, onMutateResult, context);\r\n        await options.onError?.(error, variables, onMutateResult, context);\r\n      },\r\n    }),\r\n    ...(onSettled !== undefined && {\r\n      onSettled: async (data, error, variables, onMutateResult, context) => {\r\n        await base.onSettled?.(data, error, variables, onMutateResult, context);\r\n        await options.onSettled?.(data, error, variables, onMutateResult, context);\r\n      },\r\n    }),\r\n  };\r\n}\r\n\r\nexport function mergeQueryOptions<TData, TError, TQueryKey extends QueryKey>(\r\n  base: UseQueryOptions<TData, TError, TData, TQueryKey>,\r\n  options?: Partial<UseQueryOptions<TData, TError, TData, TQueryKey>>\r\n): UseQueryOptions<TData, TError, TData, TQueryKey> {\r\n  if (!options) return base;\r\n  return {\r\n    ...base,\r\n    ...options,\r\n  };\r\n}\r\n"
  ],
  "mappings": "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",
  "debugId": "3974E80E199B9F8064756E2164756E21",
  "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.
|
|
4
|
+
"version": "0.3.6",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"files": [
|
|
7
7
|
"dist"
|
|
@@ -41,10 +41,12 @@
|
|
|
41
41
|
"peerDependencies": {
|
|
42
42
|
"@elysiajs/eden": "^1.4.6",
|
|
43
43
|
"@tanstack/react-query": "^5.90.20",
|
|
44
|
+
"react": "^19.2.4",
|
|
44
45
|
"typescript": "^5"
|
|
45
46
|
},
|
|
46
47
|
"devDependencies": {
|
|
47
48
|
"@types/bun": "latest",
|
|
49
|
+
"@types/react": "^19.2.14",
|
|
48
50
|
"bunup": "^0.16.22",
|
|
49
51
|
"elysia": "^1.4.22",
|
|
50
52
|
"prettier": "^3.4.2"
|