@trpc/next 11.1.2 → 11.1.3-alpha-tmp-tsdown.23
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/app-dir/client/package.json +1 -0
- package/app-dir/links/nextCache/package.json +1 -0
- package/app-dir/links/nextHttp/package.json +1 -0
- package/app-dir/server/package.json +1 -0
- package/dist/_virtual/rolldown_runtime.js +30 -0
- package/dist/app-dir/client.d.mts +13 -0
- package/dist/app-dir/client.d.mts.map +1 -0
- package/dist/app-dir/client.d.ts +12 -5
- package/dist/app-dir/client.d.ts.map +1 -1
- package/dist/app-dir/client.js +25 -43
- package/dist/app-dir/client.mjs +24 -40
- package/dist/app-dir/client.mjs.map +1 -0
- package/dist/app-dir/create-action-hook.d.mts +47 -0
- package/dist/app-dir/create-action-hook.d.mts.map +1 -0
- package/dist/app-dir/create-action-hook.d.ts +33 -36
- package/dist/app-dir/create-action-hook.d.ts.map +1 -1
- package/dist/app-dir/create-action-hook.js +85 -101
- package/dist/app-dir/create-action-hook.mjs +84 -98
- package/dist/app-dir/create-action-hook.mjs.map +1 -0
- package/dist/app-dir/links/nextCache.d.mts +16 -0
- package/dist/app-dir/links/nextCache.d.mts.map +1 -0
- package/dist/app-dir/links/nextCache.d.ts +13 -9
- package/dist/app-dir/links/nextCache.d.ts.map +1 -1
- package/dist/app-dir/links/nextCache.js +44 -58
- package/dist/app-dir/links/nextCache.mjs +43 -55
- package/dist/app-dir/links/nextCache.mjs.map +1 -0
- package/dist/app-dir/links/nextHttp.d.mts +19 -0
- package/dist/app-dir/links/nextHttp.d.mts.map +1 -0
- package/dist/app-dir/links/nextHttp.d.ts +12 -8
- package/dist/app-dir/links/nextHttp.d.ts.map +1 -1
- package/dist/app-dir/links/nextHttp.js +31 -35
- package/dist/app-dir/links/nextHttp.mjs +30 -32
- package/dist/app-dir/links/nextHttp.mjs.map +1 -0
- package/dist/app-dir/server.d.mts +36 -0
- package/dist/app-dir/server.d.mts.map +1 -0
- package/dist/app-dir/server.d.ts +30 -24
- package/dist/app-dir/server.d.ts.map +1 -1
- package/dist/app-dir/server.js +86 -112
- package/dist/app-dir/server.mjs +85 -109
- package/dist/app-dir/server.mjs.map +1 -0
- package/dist/app-dir/shared.d.mts +37 -0
- package/dist/app-dir/shared.d.mts.map +1 -0
- package/dist/app-dir/shared.d.ts +21 -39
- package/dist/app-dir/shared.d.ts.map +1 -1
- package/dist/app-dir/shared.js +12 -13
- package/dist/app-dir/shared.mjs +11 -10
- package/dist/app-dir/shared.mjs.map +1 -0
- package/dist/app-dir/types.d.mts +33 -0
- package/dist/app-dir/types.d.mts.map +1 -0
- package/dist/app-dir/types.d.ts +27 -25
- package/dist/app-dir/types.d.ts.map +1 -1
- package/dist/createTRPCNext.d.mts +38 -0
- package/dist/createTRPCNext.d.mts.map +1 -0
- package/dist/createTRPCNext.d.ts +30 -21
- package/dist/createTRPCNext.d.ts.map +1 -1
- package/dist/createTRPCNext.js +23 -35
- package/dist/createTRPCNext.mjs +22 -32
- package/dist/createTRPCNext.mjs.map +1 -0
- package/dist/index.d.mts +3 -0
- package/dist/index.d.ts +3 -3
- package/dist/index.js +4 -8
- package/dist/index.mjs +4 -2
- package/dist/ssrPrepass.d.mts +10 -0
- package/dist/ssrPrepass.d.mts.map +1 -0
- package/dist/ssrPrepass.d.ts +9 -2
- package/dist/ssrPrepass.d.ts.map +1 -1
- package/dist/ssrPrepass.js +99 -134
- package/dist/ssrPrepass.mjs +98 -131
- package/dist/ssrPrepass.mjs.map +1 -0
- package/dist/withTRPC.d.mts +55 -0
- package/dist/withTRPC.d.mts.map +1 -0
- package/dist/withTRPC.d.ts +47 -46
- package/dist/withTRPC.d.ts.map +1 -1
- package/dist/withTRPC.js +69 -82
- package/dist/withTRPC.mjs +68 -79
- package/dist/withTRPC.mjs.map +1 -0
- package/package.json +63 -33
- package/src/withTRPC.tsx +1 -2
- package/ssrPrepass/package.json +1 -0
- package/dist/index.d.ts.map +0 -1
|
@@ -1,105 +1,91 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { getTransformer } from
|
|
3
|
-
import {
|
|
4
|
-
import { transformResult } from
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
1
|
+
import { isFormData } from "./shared.mjs";
|
|
2
|
+
import { getTransformer } from "@trpc/client/unstable-internals";
|
|
3
|
+
import { useCallback, useEffect, useMemo, useRef, useState } from "react";
|
|
4
|
+
import { transformResult } from "@trpc/server/unstable-core-do-not-import";
|
|
5
|
+
import { TRPCClientError, createTRPCUntypedClient } from "@trpc/client";
|
|
6
|
+
import { observable } from "@trpc/server/observable";
|
|
7
7
|
|
|
8
|
-
|
|
8
|
+
//#region src/app-dir/create-action-hook.tsx
|
|
9
9
|
function experimental_serverActionLink(...args) {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
10
|
+
const [opts] = args;
|
|
11
|
+
const transformer = getTransformer(opts?.transformer);
|
|
12
|
+
return () => ({ op }) => observable((observer) => {
|
|
13
|
+
const context = op.context;
|
|
14
|
+
context._action(isFormData(op.input) ? op.input : transformer.input.serialize(op.input)).then((data) => {
|
|
15
|
+
const transformed = transformResult(data, transformer.output);
|
|
16
|
+
if (!transformed.ok) {
|
|
17
|
+
observer.error(TRPCClientError.from(transformed.error, {}));
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
observer.next({
|
|
21
|
+
context: op.context,
|
|
22
|
+
result: transformed.result
|
|
23
|
+
});
|
|
24
|
+
observer.complete();
|
|
25
|
+
}).catch((cause) => {
|
|
26
|
+
observer.error(TRPCClientError.from(cause));
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
29
|
}
|
|
30
|
-
// ts-prune-ignore-next
|
|
31
30
|
function experimental_createActionHook(opts) {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
// ignored
|
|
89
|
-
});
|
|
90
|
-
}, [
|
|
91
|
-
mutateAsync
|
|
92
|
-
]);
|
|
93
|
-
return useMemo(()=>({
|
|
94
|
-
...state,
|
|
95
|
-
mutate,
|
|
96
|
-
mutateAsync
|
|
97
|
-
}), [
|
|
98
|
-
mutate,
|
|
99
|
-
mutateAsync,
|
|
100
|
-
state
|
|
101
|
-
]);
|
|
102
|
-
};
|
|
31
|
+
const client = createTRPCUntypedClient(opts);
|
|
32
|
+
return function useAction(handler, useActionOpts) {
|
|
33
|
+
const count = useRef(0);
|
|
34
|
+
const [state, setState] = useState({ status: "idle" });
|
|
35
|
+
const actionOptsRef = useRef(useActionOpts);
|
|
36
|
+
actionOptsRef.current = useActionOpts;
|
|
37
|
+
useEffect(() => {
|
|
38
|
+
return () => {
|
|
39
|
+
count.current = -1;
|
|
40
|
+
actionOptsRef.current = void 0;
|
|
41
|
+
};
|
|
42
|
+
}, []);
|
|
43
|
+
const mutateAsync = useCallback((input, requestOptions) => {
|
|
44
|
+
const idx = ++count.current;
|
|
45
|
+
const context = {
|
|
46
|
+
...requestOptions?.context,
|
|
47
|
+
_action(innerInput) {
|
|
48
|
+
return handler(innerInput);
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
setState({ status: "loading" });
|
|
52
|
+
return client.mutation("serverAction", input, {
|
|
53
|
+
...requestOptions,
|
|
54
|
+
context
|
|
55
|
+
}).then(async (data) => {
|
|
56
|
+
await actionOptsRef.current?.onSuccess?.(data);
|
|
57
|
+
if (idx !== count.current) return;
|
|
58
|
+
setState({
|
|
59
|
+
status: "success",
|
|
60
|
+
data
|
|
61
|
+
});
|
|
62
|
+
}).catch(async (error) => {
|
|
63
|
+
await actionOptsRef.current?.onError?.(error);
|
|
64
|
+
throw error;
|
|
65
|
+
}).catch((error) => {
|
|
66
|
+
if (idx !== count.current) return;
|
|
67
|
+
setState({
|
|
68
|
+
status: "error",
|
|
69
|
+
error: TRPCClientError.from(error, {})
|
|
70
|
+
});
|
|
71
|
+
throw error;
|
|
72
|
+
});
|
|
73
|
+
}, [handler]);
|
|
74
|
+
const mutate = useCallback((...args) => {
|
|
75
|
+
mutateAsync(...args).catch(() => {});
|
|
76
|
+
}, [mutateAsync]);
|
|
77
|
+
return useMemo(() => ({
|
|
78
|
+
...state,
|
|
79
|
+
mutate,
|
|
80
|
+
mutateAsync
|
|
81
|
+
}), [
|
|
82
|
+
mutate,
|
|
83
|
+
mutateAsync,
|
|
84
|
+
state
|
|
85
|
+
]);
|
|
86
|
+
};
|
|
103
87
|
}
|
|
104
88
|
|
|
89
|
+
//#endregion
|
|
105
90
|
export { experimental_createActionHook, experimental_serverActionLink };
|
|
91
|
+
//# sourceMappingURL=create-action-hook.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-action-hook.mjs","names":["opts: InferrableClientTypes extends TInferrable\n ? TypeError<'Generic parameter missing in `experimental_createActionHook<HERE>()`'>\n : CreateTRPCClientOptions<TInferrable>","handler: TRPCActionHandler<TDef>","useActionOpts?: UseTRPCActionOptions<Simplify<TDef>>","input: any","requestOptions?: TRPCRequestOptions","mutate: Result['mutate']"],"sources":["../../src/app-dir/create-action-hook.tsx"],"sourcesContent":["import type {\n CreateTRPCClientOptions,\n TRPCLink,\n TRPCProcedureOptions,\n TRPCRequestOptions,\n} from '@trpc/client';\nimport { createTRPCUntypedClient, TRPCClientError } from '@trpc/client';\nimport type {\n CoercedTransformerParameters,\n TransformerOptions,\n} from '@trpc/client/unstable-internals';\nimport { getTransformer } from '@trpc/client/unstable-internals';\nimport { observable } from '@trpc/server/observable';\nimport type {\n inferClientTypes,\n InferrableClientTypes,\n MaybePromise,\n Simplify,\n TypeError,\n} from '@trpc/server/unstable-core-do-not-import';\nimport { transformResult } from '@trpc/server/unstable-core-do-not-import';\nimport { useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport type { TRPCActionHandler } from './server';\nimport type { ActionHandlerDef } from './shared';\nimport { isFormData } from './shared';\n\ntype MutationArgs<TDef extends ActionHandlerDef> = TDef['input'] extends void\n ? [input?: undefined | void, opts?: TRPCProcedureOptions]\n : [input: FormData | TDef['input'], opts?: TRPCProcedureOptions];\n\ninterface UseTRPCActionBaseResult<TDef extends ActionHandlerDef> {\n mutate: (...args: MutationArgs<TDef>) => void;\n mutateAsync: (...args: MutationArgs<TDef>) => Promise<TDef['output']>;\n}\n\ninterface UseTRPCActionSuccessResult<TDef extends ActionHandlerDef>\n extends UseTRPCActionBaseResult<TDef> {\n data: TDef['output'];\n error?: never;\n status: 'success';\n}\n\ninterface UseTRPCActionErrorResult<TDef extends ActionHandlerDef>\n extends UseTRPCActionBaseResult<TDef> {\n data?: never;\n error: TRPCClientError<TDef['errorShape']>;\n status: 'error';\n}\n\ninterface UseTRPCActionIdleResult<TDef extends ActionHandlerDef>\n extends UseTRPCActionBaseResult<TDef> {\n data?: never;\n error?: never;\n status: 'idle';\n}\n\ninterface UseTRPCActionLoadingResult<TDef extends ActionHandlerDef>\n extends UseTRPCActionBaseResult<TDef> {\n data?: never;\n error?: never;\n status: 'loading';\n}\n\n// ts-prune-ignore-next\nexport type UseTRPCActionResult<TDef extends ActionHandlerDef> =\n | UseTRPCActionErrorResult<TDef>\n | UseTRPCActionIdleResult<TDef>\n | UseTRPCActionLoadingResult<TDef>\n | UseTRPCActionSuccessResult<TDef>;\n\ntype ActionContext = {\n _action: (...args: any[]) => Promise<any>;\n};\n\n// ts-prune-ignore-next\nexport function experimental_serverActionLink<\n TInferrable extends InferrableClientTypes,\n>(\n ...args: InferrableClientTypes extends TInferrable\n ? [\n TypeError<'Generic parameter missing in `experimental_createActionHook<HERE>()` or experimental_serverActionLink<HERE>()'>,\n ]\n : inferClientTypes<TInferrable>['transformer'] extends true\n ? [\n opts: TransformerOptions<{\n transformer: true;\n }>,\n ]\n : [\n opts?: TransformerOptions<{\n transformer: false;\n }>,\n ]\n): TRPCLink<TInferrable> {\n const [opts] = args as [CoercedTransformerParameters];\n const transformer = getTransformer(opts?.transformer);\n return () =>\n ({ op }) =>\n observable((observer) => {\n const context = op.context as ActionContext;\n\n context\n ._action(\n isFormData(op.input)\n ? op.input\n : transformer.input.serialize(op.input),\n )\n .then((data) => {\n const transformed = transformResult(data, transformer.output);\n\n if (!transformed.ok) {\n observer.error(TRPCClientError.from(transformed.error, {}));\n return;\n }\n observer.next({\n context: op.context,\n result: transformed.result,\n });\n observer.complete();\n })\n .catch((cause) => {\n observer.error(TRPCClientError.from(cause));\n });\n });\n}\n\ninterface UseTRPCActionOptions<TDef extends ActionHandlerDef> {\n onSuccess?: (result: TDef['output']) => MaybePromise<void> | void;\n onError?: (result: TRPCClientError<TDef['errorShape']>) => MaybePromise<void>;\n}\n// ts-prune-ignore-next\nexport function experimental_createActionHook<\n TInferrable extends InferrableClientTypes,\n>(\n opts: InferrableClientTypes extends TInferrable\n ? TypeError<'Generic parameter missing in `experimental_createActionHook<HERE>()`'>\n : CreateTRPCClientOptions<TInferrable>,\n) {\n type ActionContext = {\n _action: (...args: any[]) => Promise<any>;\n };\n const client = createTRPCUntypedClient(\n opts as Exclude<typeof opts, TypeError<any>>,\n );\n return function useAction<TDef extends ActionHandlerDef>(\n handler: TRPCActionHandler<TDef>,\n useActionOpts?: UseTRPCActionOptions<Simplify<TDef>>,\n ) {\n const count = useRef(0);\n\n type Result = UseTRPCActionResult<TDef>;\n type State = Omit<Result, 'mutate' | 'mutateAsync'>;\n const [state, setState] = useState<State>({\n status: 'idle',\n });\n\n const actionOptsRef = useRef(useActionOpts);\n actionOptsRef.current = useActionOpts;\n\n useEffect(() => {\n return () => {\n // cleanup after unmount to prevent calling hook opts after unmount\n count.current = -1;\n actionOptsRef.current = undefined;\n };\n }, []);\n\n const mutateAsync = useCallback(\n (input: any, requestOptions?: TRPCRequestOptions) => {\n const idx = ++count.current;\n const context = {\n ...requestOptions?.context,\n _action(innerInput) {\n return handler(innerInput);\n },\n } as ActionContext;\n\n setState({\n status: 'loading',\n });\n return client\n .mutation('serverAction', input, {\n ...requestOptions,\n context,\n })\n .then(async (data) => {\n await actionOptsRef.current?.onSuccess?.(data as any);\n if (idx !== count.current) {\n return;\n }\n setState({\n status: 'success',\n data: data as any,\n });\n })\n .catch(async (error) => {\n await actionOptsRef.current?.onError?.(error);\n throw error;\n })\n .catch((error) => {\n if (idx !== count.current) {\n return;\n }\n setState({\n status: 'error',\n error: TRPCClientError.from(error, {}),\n });\n throw error;\n });\n },\n [handler],\n ) as Result['mutateAsync'];\n\n const mutate: Result['mutate'] = useCallback(\n (...args: any[]) => {\n void (mutateAsync as any)(...args).catch(() => {\n // ignored\n });\n },\n [mutateAsync],\n );\n\n return useMemo(\n () => ({\n ...state,\n mutate,\n mutateAsync,\n }),\n [mutate, mutateAsync, state],\n ) as Result;\n };\n}\n"],"mappings":";;;;;;;;AA2EA,SAAgB,8BAGd,GAAG,MAeoB;CACvB,MAAM,CAAC,KAAK,GAAG;CACf,MAAM,cAAc,eAAe,MAAM,YAAY;AACrD,QAAO,MACL,CAAC,EAAE,IAAI,KACL,WAAW,CAAC,aAAa;EACvB,MAAM,UAAU,GAAG;AAEnB,UACG,QACC,WAAW,GAAG,MAAM,GAChB,GAAG,QACH,YAAY,MAAM,UAAU,GAAG,MAAM,CAC1C,CACA,KAAK,CAAC,SAAS;GACd,MAAM,cAAc,gBAAgB,MAAM,YAAY,OAAO;AAE7D,QAAK,YAAY,IAAI;AACnB,aAAS,MAAM,gBAAgB,KAAK,YAAY,OAAO,CAAE,EAAC,CAAC;AAC3D;GACD;AACD,YAAS,KAAK;IACZ,SAAS,GAAG;IACZ,QAAQ,YAAY;GACrB,EAAC;AACF,YAAS,UAAU;EACpB,EAAC,CACD,MAAM,CAAC,UAAU;AAChB,YAAS,MAAM,gBAAgB,KAAK,MAAM,CAAC;EAC5C,EAAC;CACL,EAAC;AACP;AAOD,SAAgB,8BAGdA,MAGA;CAIA,MAAM,SAAS,wBACb,KACD;AACD,QAAO,SAAS,UACdC,SACAC,eACA;EACA,MAAM,QAAQ,OAAO,EAAE;EAIvB,MAAM,CAAC,OAAO,SAAS,GAAG,SAAgB,EACxC,QAAQ,OACT,EAAC;EAEF,MAAM,gBAAgB,OAAO,cAAc;AAC3C,gBAAc,UAAU;AAExB,YAAU,MAAM;AACd,UAAO,MAAM;AAEX,UAAM,UAAU;AAChB,kBAAc;GACf;EACF,GAAE,CAAE,EAAC;EAEN,MAAM,cAAc,YAClB,CAACC,OAAYC,mBAAwC;GACnD,MAAM,MAAM,EAAE,MAAM;GACpB,MAAM,UAAU;IACd,GAAG,gBAAgB;IACnB,QAAQ,YAAY;AAClB,YAAO,QAAQ,WAAW;IAC3B;GACF;AAED,YAAS,EACP,QAAQ,UACT,EAAC;AACF,UAAO,OACJ,SAAS,gBAAgB,OAAO;IAC/B,GAAG;IACH;GACD,EAAC,CACD,KAAK,OAAO,SAAS;AACpB,UAAM,cAAc,SAAS,YAAY,KAAY;AACrD,QAAI,QAAQ,MAAM,QAChB;AAEF,aAAS;KACP,QAAQ;KACF;IACP,EAAC;GACH,EAAC,CACD,MAAM,OAAO,UAAU;AACtB,UAAM,cAAc,SAAS,UAAU,MAAM;AAC7C,UAAM;GACP,EAAC,CACD,MAAM,CAAC,UAAU;AAChB,QAAI,QAAQ,MAAM,QAChB;AAEF,aAAS;KACP,QAAQ;KACR,OAAO,gBAAgB,KAAK,OAAO,CAAE,EAAC;IACvC,EAAC;AACF,UAAM;GACP,EAAC;EACL,GACD,CAAC,OAAQ,EACV;EAED,MAAMC,SAA2B,YAC/B,CAAC,GAAG,SAAgB;AAClB,GAAK,AAAC,YAAoB,GAAG,KAAK,CAAC,MAAM,MAAM,CAE9C,EAAC;EACH,GACD,CAAC,WAAY,EACd;AAED,SAAO,QACL,OAAO;GACL,GAAG;GACH;GACA;EACD,IACD;GAAC;GAAQ;GAAa;EAAM,EAC7B;CACF;AACF"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { TransformerOptions } from "@trpc/client/unstable-internals";
|
|
2
|
+
import { AnyRouter, inferClientTypes, inferRouterContext } from "@trpc/server/unstable-core-do-not-import";
|
|
3
|
+
import { TRPCLink } from "@trpc/client";
|
|
4
|
+
|
|
5
|
+
//#region src/app-dir/links/nextCache.d.ts
|
|
6
|
+
type NextCacheLinkOptions<TRouter extends AnyRouter> = {
|
|
7
|
+
router: TRouter;
|
|
8
|
+
createContext: () => Promise<inferRouterContext<TRouter>>;
|
|
9
|
+
/** how many seconds the cache should hold before revalidating */
|
|
10
|
+
revalidate?: number | false;
|
|
11
|
+
} & TransformerOptions<inferClientTypes<TRouter>>;
|
|
12
|
+
declare function experimental_nextCacheLink<TRouter extends AnyRouter>(opts: NextCacheLinkOptions<TRouter>): TRPCLink<TRouter>;
|
|
13
|
+
|
|
14
|
+
//#endregion
|
|
15
|
+
export { experimental_nextCacheLink };
|
|
16
|
+
//# sourceMappingURL=nextCache.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nextCache.d.mts","names":[],"sources":["../../../src/app-dir/links/nextCache.ts"],"sourcesContent":[],"mappings":";;;;;KAkBK,qCAAqC;UAChC;EADL,aAAA,EAAA,GAAA,GAEkB,OAFE,CAEM,kBAFN,CAEyB,OAFzB,CAAA,CAAA;EAAA;EAAA,UAAiB,CAAA,EAAA,MAAA,GAAA,KAAA;CAAS,GAK/C,kBAJM,CAIa,gBAJb,CAI8B,OAJ9B,CAAA,CAAA;AACwC,iBAMlC,0BANkC,CAAA,gBAMS,SANT,CAAA,CAAA,IAAA,EAO1C,oBAP0C,CAOrB,OAPqB,CAAA,CAAA,EAQ/C,QAR+C,CAQtC,OARsC,CAAA"}
|
|
@@ -1,12 +1,16 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
import
|
|
1
|
+
import { TRPCLink } from "@trpc/client";
|
|
2
|
+
import { AnyRouter, inferClientTypes, inferRouterContext } from "@trpc/server/unstable-core-do-not-import";
|
|
3
|
+
import { TransformerOptions } from "@trpc/client/unstable-internals";
|
|
4
|
+
|
|
5
|
+
//#region src/app-dir/links/nextCache.d.ts
|
|
4
6
|
type NextCacheLinkOptions<TRouter extends AnyRouter> = {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
7
|
+
router: TRouter;
|
|
8
|
+
createContext: () => Promise<inferRouterContext<TRouter>>;
|
|
9
|
+
/** how many seconds the cache should hold before revalidating */
|
|
10
|
+
revalidate?: number | false;
|
|
9
11
|
} & TransformerOptions<inferClientTypes<TRouter>>;
|
|
10
|
-
|
|
11
|
-
|
|
12
|
+
declare function experimental_nextCacheLink<TRouter extends AnyRouter>(opts: NextCacheLinkOptions<TRouter>): TRPCLink<TRouter>;
|
|
13
|
+
|
|
14
|
+
//#endregion
|
|
15
|
+
export { experimental_nextCacheLink };
|
|
12
16
|
//# sourceMappingURL=nextCache.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nextCache.d.ts","
|
|
1
|
+
{"version":3,"file":"nextCache.d.ts","names":[],"sources":["../../../src/app-dir/links/nextCache.ts"],"sourcesContent":[],"mappings":";;;;;KAkBK,qCAAqC;UAChC;EADL,aAAA,EAAA,GAAA,GAEkB,OAFE,CAEM,kBAFN,CAEyB,OAFzB,CAAA,CAAA;EAAA;EAAA,UAAiB,CAAA,EAAA,MAAA,GAAA,KAAA;CAAS,GAK/C,kBAJM,CAIa,gBAJb,CAI8B,OAJ9B,CAAA,CAAA;AACwC,iBAMlC,0BANkC,CAAA,gBAMS,SANT,CAAA,CAAA,IAAA,EAO1C,oBAP0C,CAOrB,OAPqB,CAAA,CAAA,EAQ/C,QAR+C,CAQtC,OARsC,CAAA"}
|
|
@@ -1,62 +1,48 @@
|
|
|
1
|
-
|
|
1
|
+
const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.js');
|
|
2
|
+
const require__Users_julius_dev_trpc_packages_next_src_app_dir_shared = require('../shared.js');
|
|
3
|
+
const __trpc_client_unstable_internals = require_rolldown_runtime.__toESM(require("@trpc/client/unstable-internals"));
|
|
4
|
+
const __trpc_server_unstable_core_do_not_import = require_rolldown_runtime.__toESM(require("@trpc/server/unstable-core-do-not-import"));
|
|
5
|
+
const __trpc_client = require_rolldown_runtime.__toESM(require("@trpc/client"));
|
|
6
|
+
const __trpc_server_observable = require_rolldown_runtime.__toESM(require("@trpc/server/observable"));
|
|
7
|
+
const next_cache = require_rolldown_runtime.__toESM(require("next/cache"));
|
|
2
8
|
|
|
3
|
-
|
|
4
|
-
var unstableInternals = require('@trpc/client/unstable-internals');
|
|
5
|
-
var observable = require('@trpc/server/observable');
|
|
6
|
-
var unstableCoreDoNotImport = require('@trpc/server/unstable-core-do-not-import');
|
|
7
|
-
var cache = require('next/cache');
|
|
8
|
-
var shared = require('../shared.js');
|
|
9
|
-
|
|
10
|
-
// import "server-only";
|
|
11
|
-
// ts-prune-ignore-next
|
|
9
|
+
//#region src/app-dir/links/nextCache.ts
|
|
12
10
|
function experimental_nextCacheLink(opts) {
|
|
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
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
});
|
|
48
|
-
promise.then((data)=>{
|
|
49
|
-
const transformedResult = transformer.output.deserialize(data);
|
|
50
|
-
observer.next({
|
|
51
|
-
result: {
|
|
52
|
-
data: transformedResult
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
observer.complete();
|
|
56
|
-
}).catch((cause)=>{
|
|
57
|
-
observer.error(client.TRPCClientError.from(cause));
|
|
58
|
-
});
|
|
59
|
-
});
|
|
11
|
+
const transformer = (0, __trpc_client_unstable_internals.getTransformer)(opts.transformer);
|
|
12
|
+
return () => ({ op }) => (0, __trpc_server_observable.observable)((observer) => {
|
|
13
|
+
const { path, input, type, context } = op;
|
|
14
|
+
const cacheTag = require__Users_julius_dev_trpc_packages_next_src_app_dir_shared.generateCacheTag(path, input);
|
|
15
|
+
const requestRevalidate = typeof context["revalidate"] === "number" || context["revalidate"] === false ? context["revalidate"] : void 0;
|
|
16
|
+
const revalidate = requestRevalidate ?? opts.revalidate ?? false;
|
|
17
|
+
const promise = opts.createContext().then(async (ctx) => {
|
|
18
|
+
const callProc = async (_cachebuster) => {
|
|
19
|
+
const procedureResult = await (0, __trpc_server_unstable_core_do_not_import.callProcedure)({
|
|
20
|
+
router: opts.router,
|
|
21
|
+
path,
|
|
22
|
+
getRawInput: async () => input,
|
|
23
|
+
ctx,
|
|
24
|
+
type,
|
|
25
|
+
signal: void 0
|
|
26
|
+
});
|
|
27
|
+
return transformer.input.serialize(procedureResult);
|
|
28
|
+
};
|
|
29
|
+
if (type === "query") return (0, next_cache.unstable_cache)(callProc, path.split("."), {
|
|
30
|
+
revalidate,
|
|
31
|
+
tags: [cacheTag]
|
|
32
|
+
})(cacheTag);
|
|
33
|
+
return callProc(cacheTag);
|
|
34
|
+
}).catch((cause) => {
|
|
35
|
+
observer.error(__trpc_client.TRPCClientError.from(cause));
|
|
36
|
+
});
|
|
37
|
+
promise.then((data) => {
|
|
38
|
+
const transformedResult = transformer.output.deserialize(data);
|
|
39
|
+
observer.next({ result: { data: transformedResult } });
|
|
40
|
+
observer.complete();
|
|
41
|
+
}).catch((cause) => {
|
|
42
|
+
observer.error(__trpc_client.TRPCClientError.from(cause));
|
|
43
|
+
});
|
|
44
|
+
});
|
|
60
45
|
}
|
|
61
46
|
|
|
62
|
-
|
|
47
|
+
//#endregion
|
|
48
|
+
exports.experimental_nextCacheLink = experimental_nextCacheLink;
|
|
@@ -1,60 +1,48 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { getTransformer } from
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
1
|
+
import { generateCacheTag } from "../shared.mjs";
|
|
2
|
+
import { getTransformer } from "@trpc/client/unstable-internals";
|
|
3
|
+
import { callProcedure } from "@trpc/server/unstable-core-do-not-import";
|
|
4
|
+
import { TRPCClientError } from "@trpc/client";
|
|
5
|
+
import { observable } from "@trpc/server/observable";
|
|
6
|
+
import { unstable_cache } from "next/cache";
|
|
7
7
|
|
|
8
|
-
|
|
9
|
-
// ts-prune-ignore-next
|
|
8
|
+
//#region src/app-dir/links/nextCache.ts
|
|
10
9
|
function experimental_nextCacheLink(opts) {
|
|
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
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
});
|
|
46
|
-
promise.then((data)=>{
|
|
47
|
-
const transformedResult = transformer.output.deserialize(data);
|
|
48
|
-
observer.next({
|
|
49
|
-
result: {
|
|
50
|
-
data: transformedResult
|
|
51
|
-
}
|
|
52
|
-
});
|
|
53
|
-
observer.complete();
|
|
54
|
-
}).catch((cause)=>{
|
|
55
|
-
observer.error(TRPCClientError.from(cause));
|
|
56
|
-
});
|
|
57
|
-
});
|
|
10
|
+
const transformer = getTransformer(opts.transformer);
|
|
11
|
+
return () => ({ op }) => observable((observer) => {
|
|
12
|
+
const { path, input, type, context } = op;
|
|
13
|
+
const cacheTag = generateCacheTag(path, input);
|
|
14
|
+
const requestRevalidate = typeof context["revalidate"] === "number" || context["revalidate"] === false ? context["revalidate"] : void 0;
|
|
15
|
+
const revalidate = requestRevalidate ?? opts.revalidate ?? false;
|
|
16
|
+
const promise = opts.createContext().then(async (ctx) => {
|
|
17
|
+
const callProc = async (_cachebuster) => {
|
|
18
|
+
const procedureResult = await callProcedure({
|
|
19
|
+
router: opts.router,
|
|
20
|
+
path,
|
|
21
|
+
getRawInput: async () => input,
|
|
22
|
+
ctx,
|
|
23
|
+
type,
|
|
24
|
+
signal: void 0
|
|
25
|
+
});
|
|
26
|
+
return transformer.input.serialize(procedureResult);
|
|
27
|
+
};
|
|
28
|
+
if (type === "query") return unstable_cache(callProc, path.split("."), {
|
|
29
|
+
revalidate,
|
|
30
|
+
tags: [cacheTag]
|
|
31
|
+
})(cacheTag);
|
|
32
|
+
return callProc(cacheTag);
|
|
33
|
+
}).catch((cause) => {
|
|
34
|
+
observer.error(TRPCClientError.from(cause));
|
|
35
|
+
});
|
|
36
|
+
promise.then((data) => {
|
|
37
|
+
const transformedResult = transformer.output.deserialize(data);
|
|
38
|
+
observer.next({ result: { data: transformedResult } });
|
|
39
|
+
observer.complete();
|
|
40
|
+
}).catch((cause) => {
|
|
41
|
+
observer.error(TRPCClientError.from(cause));
|
|
42
|
+
});
|
|
43
|
+
});
|
|
58
44
|
}
|
|
59
45
|
|
|
46
|
+
//#endregion
|
|
60
47
|
export { experimental_nextCacheLink };
|
|
48
|
+
//# sourceMappingURL=nextCache.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nextCache.mjs","names":["opts: NextCacheLinkOptions<TRouter>","_cachebuster: string"],"sources":["../../../src/app-dir/links/nextCache.ts"],"sourcesContent":["// import \"server-only\";\n\nimport type { TRPCLink } from '@trpc/client';\nimport { TRPCClientError } from '@trpc/client';\nimport {\n getTransformer,\n type TransformerOptions,\n} from '@trpc/client/unstable-internals';\nimport { observable } from '@trpc/server/observable';\nimport type {\n AnyRouter,\n inferClientTypes,\n inferRouterContext,\n} from '@trpc/server/unstable-core-do-not-import';\nimport { callProcedure } from '@trpc/server/unstable-core-do-not-import';\nimport { unstable_cache } from 'next/cache';\nimport { generateCacheTag } from '../shared';\n\ntype NextCacheLinkOptions<TRouter extends AnyRouter> = {\n router: TRouter;\n createContext: () => Promise<inferRouterContext<TRouter>>;\n /** how many seconds the cache should hold before revalidating */\n revalidate?: number | false;\n} & TransformerOptions<inferClientTypes<TRouter>>;\n\n// ts-prune-ignore-next\nexport function experimental_nextCacheLink<TRouter extends AnyRouter>(\n opts: NextCacheLinkOptions<TRouter>,\n): TRPCLink<TRouter> {\n const transformer = getTransformer(opts.transformer);\n return () =>\n ({ op }) =>\n observable((observer) => {\n const { path, input, type, context } = op;\n\n const cacheTag = generateCacheTag(path, input);\n // Let per-request revalidate override global revalidate\n const requestRevalidate =\n typeof context['revalidate'] === 'number' ||\n context['revalidate'] === false\n ? context['revalidate']\n : undefined;\n const revalidate = requestRevalidate ?? opts.revalidate ?? false;\n\n const promise = opts\n .createContext()\n .then(async (ctx) => {\n const callProc = async (_cachebuster: string) => {\n // // _cachebuster is not used by us but to make sure\n // // that calls with different tags are properly separated\n // // @link https://github.com/trpc/trpc/issues/4622\n const procedureResult = await callProcedure({\n router: opts.router,\n path,\n getRawInput: async () => input,\n ctx: ctx,\n type,\n signal: undefined,\n });\n\n // We need to serialize cause the cache only accepts JSON\n return transformer.input.serialize(procedureResult);\n };\n\n if (type === 'query') {\n return unstable_cache(callProc, path.split('.'), {\n revalidate,\n tags: [cacheTag],\n })(cacheTag);\n }\n\n return callProc(cacheTag);\n })\n .catch((cause) => {\n observer.error(TRPCClientError.from(cause));\n });\n\n promise\n .then((data) => {\n const transformedResult = transformer.output.deserialize(data);\n observer.next({ result: { data: transformedResult } });\n observer.complete();\n })\n .catch((cause) => {\n observer.error(TRPCClientError.from(cause));\n });\n });\n}\n"],"mappings":";;;;;;;;AA0BA,SAAgB,2BACdA,MACmB;CACnB,MAAM,cAAc,eAAe,KAAK,YAAY;AACpD,QAAO,MACL,CAAC,EAAE,IAAI,KACL,WAAW,CAAC,aAAa;EACvB,MAAM,EAAE,MAAM,OAAO,MAAM,SAAS,GAAG;EAEvC,MAAM,WAAW,iBAAiB,MAAM,MAAM;EAE9C,MAAM,2BACG,QAAQ,kBAAkB,YACjC,QAAQ,kBAAkB,QACtB,QAAQ;EAEd,MAAM,aAAa,qBAAqB,KAAK,cAAc;EAE3D,MAAM,UAAU,KACb,eAAe,CACf,KAAK,OAAO,QAAQ;GACnB,MAAM,WAAW,OAAOC,iBAAyB;IAI/C,MAAM,kBAAkB,MAAM,cAAc;KAC1C,QAAQ,KAAK;KACb;KACA,aAAa,YAAY;KACpB;KACL;KACA;IACD,EAAC;AAGF,WAAO,YAAY,MAAM,UAAU,gBAAgB;GACpD;AAED,OAAI,SAAS,QACX,QAAO,eAAe,UAAU,KAAK,MAAM,IAAI,EAAE;IAC/C;IACA,MAAM,CAAC,QAAS;GACjB,EAAC,CAAC,SAAS;AAGd,UAAO,SAAS,SAAS;EAC1B,EAAC,CACD,MAAM,CAAC,UAAU;AAChB,YAAS,MAAM,gBAAgB,KAAK,MAAM,CAAC;EAC5C,EAAC;AAEJ,UACG,KAAK,CAAC,SAAS;GACd,MAAM,oBAAoB,YAAY,OAAO,YAAY,KAAK;AAC9D,YAAS,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAmB,EAAE,EAAC;AACtD,YAAS,UAAU;EACpB,EAAC,CACD,MAAM,CAAC,UAAU;AAChB,YAAS,MAAM,gBAAgB,KAAK,MAAM,CAAC;EAC5C,EAAC;CACL,EAAC;AACP"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { AnyRootTypes, AnyRouter } from "@trpc/server/unstable-core-do-not-import";
|
|
2
|
+
import { HTTPBatchLinkOptions, HTTPLinkOptions, TRPCLink } from "@trpc/client";
|
|
3
|
+
|
|
4
|
+
//#region src/app-dir/links/nextHttp.d.ts
|
|
5
|
+
interface NextLinkBaseOptions {
|
|
6
|
+
revalidate?: number | false;
|
|
7
|
+
batch?: boolean;
|
|
8
|
+
}
|
|
9
|
+
type NextLinkSingleOptions<TRoot extends AnyRootTypes> = NextLinkBaseOptions & Omit<HTTPLinkOptions<TRoot>, 'fetch'> & {
|
|
10
|
+
batch?: false;
|
|
11
|
+
};
|
|
12
|
+
type NextLinkBatchOptions<TRoot extends AnyRootTypes> = NextLinkBaseOptions & Omit<HTTPBatchLinkOptions<TRoot>, 'fetch'> & {
|
|
13
|
+
batch: true;
|
|
14
|
+
};
|
|
15
|
+
declare function experimental_nextHttpLink<TRouter extends AnyRouter>(opts: NextLinkSingleOptions<TRouter['_def']['_config']['$types']> | NextLinkBatchOptions<TRouter['_def']['_config']['$types']>): TRPCLink<TRouter>;
|
|
16
|
+
|
|
17
|
+
//#endregion
|
|
18
|
+
export { experimental_nextHttpLink };
|
|
19
|
+
//# sourceMappingURL=nextHttp.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nextHttp.d.mts","names":[],"sources":["../../../src/app-dir/links/nextHttp.ts"],"sourcesContent":[],"mappings":";;;;UAYU,mBAAA;;EAAA,KAAA,CAAA,EAAA,OAAA;AAAmB;KAKxB,qBAAqB,CAAA,cAAe,YAAf,CAAA,GAA+B,mBAA/B,GACxB,IADwB,CACnB,eADmB,CACH,KADG,CAAA,EAAA,OAAA,CAAA,GAAA;EAAA,KAAe,CAAA,EAAA,KAAA;CAAY;KAKhD,oBAJkB,CAAA,cAIiB,YAJjB,CAAA,GAIiC,mBAJjC,GAKrB,IALqB,CAKhB,oBALgB,CAKK,KALL,CAAA,EAAA,OAAA,CAAA,GAAA;EAAK,KAArB,EAAA,IAAA;CAAe;AAAhB,iBAUU,yBAVV,CAAA,gBAUoD,SAVpD,CAAA,CAAA,IAAA,EAYA,qBAZA,CAYsB,OAZtB,CAAA,MAAA,CAAA,CAAA,SAAA,CAAA,CAAA,QAAA,CAAA,CAAA,GAaA,oBAbA,CAaqB,OAbrB,CAAA,MAAA,CAAA,CAAA,SAAA,CAAA,CAAA,QAAA,CAAA,CAAA,CAAA,EAcH,QAdG,CAcM,OAdN,CAAA"}
|
|
@@ -1,15 +1,19 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
1
|
+
import { HTTPBatchLinkOptions, HTTPLinkOptions, TRPCLink } from "@trpc/client";
|
|
2
|
+
import { AnyRootTypes, AnyRouter } from "@trpc/server/unstable-core-do-not-import";
|
|
3
|
+
|
|
4
|
+
//#region src/app-dir/links/nextHttp.d.ts
|
|
3
5
|
interface NextLinkBaseOptions {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
+
revalidate?: number | false;
|
|
7
|
+
batch?: boolean;
|
|
6
8
|
}
|
|
7
9
|
type NextLinkSingleOptions<TRoot extends AnyRootTypes> = NextLinkBaseOptions & Omit<HTTPLinkOptions<TRoot>, 'fetch'> & {
|
|
8
|
-
|
|
10
|
+
batch?: false;
|
|
9
11
|
};
|
|
10
12
|
type NextLinkBatchOptions<TRoot extends AnyRootTypes> = NextLinkBaseOptions & Omit<HTTPBatchLinkOptions<TRoot>, 'fetch'> & {
|
|
11
|
-
|
|
13
|
+
batch: true;
|
|
12
14
|
};
|
|
13
|
-
|
|
14
|
-
|
|
15
|
+
declare function experimental_nextHttpLink<TRouter extends AnyRouter>(opts: NextLinkSingleOptions<TRouter['_def']['_config']['$types']> | NextLinkBatchOptions<TRouter['_def']['_config']['$types']>): TRPCLink<TRouter>;
|
|
16
|
+
|
|
17
|
+
//#endregion
|
|
18
|
+
export { experimental_nextHttpLink };
|
|
15
19
|
//# sourceMappingURL=nextHttp.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nextHttp.d.ts","
|
|
1
|
+
{"version":3,"file":"nextHttp.d.ts","names":[],"sources":["../../../src/app-dir/links/nextHttp.ts"],"sourcesContent":[],"mappings":";;;;UAYU,mBAAA;;EAAA,KAAA,CAAA,EAAA,OAAA;AAAmB;KAKxB,qBAAqB,CAAA,cAAe,YAAf,CAAA,GAA+B,mBAA/B,GACxB,IADwB,CACnB,eADmB,CACH,KADG,CAAA,EAAA,OAAA,CAAA,GAAA;EAAA,KAAe,CAAA,EAAA,KAAA;CAAY;KAKhD,oBAJkB,CAAA,cAIiB,YAJjB,CAAA,GAIiC,mBAJjC,GAKrB,IALqB,CAKhB,oBALgB,CAKK,KALL,CAAA,EAAA,OAAA,CAAA,GAAA;EAAK,KAArB,EAAA,IAAA;CAAe;AAAhB,iBAUU,yBAVV,CAAA,gBAUoD,SAVpD,CAAA,CAAA,IAAA,EAYA,qBAZA,CAYsB,OAZtB,CAAA,MAAA,CAAA,CAAA,SAAA,CAAA,CAAA,QAAA,CAAA,CAAA,GAaA,oBAbA,CAaqB,OAbrB,CAAA,MAAA,CAAA,CAAA,SAAA,CAAA,CAAA,QAAA,CAAA,CAAA,CAAA,EAcH,QAdG,CAcM,OAdN,CAAA"}
|