@fragno-dev/example-fragment 0.0.5 → 0.0.7
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/.turbo/turbo-build.log +34 -13
- package/CHANGELOG.md +16 -0
- package/dist/browser/client/react.d.ts +17 -0
- package/dist/browser/client/react.d.ts.map +1 -0
- package/dist/browser/client/react.js +83 -0
- package/dist/browser/client/react.js.map +1 -0
- package/dist/browser/client/solid.d.ts +17 -0
- package/dist/browser/client/solid.d.ts.map +1 -0
- package/dist/browser/client/solid.js +121 -0
- package/dist/browser/client/solid.js.map +1 -0
- package/dist/browser/client/svelte.d.ts +17 -0
- package/dist/browser/client/svelte.d.ts.map +1 -0
- package/dist/browser/client/svelte.js +125 -0
- package/dist/browser/client/svelte.js.map +1 -0
- package/dist/browser/client/vanilla.d.ts +17 -0
- package/dist/browser/client/vanilla.d.ts.map +1 -0
- package/dist/browser/client/vanilla.js +136 -0
- package/dist/browser/client/vanilla.js.map +1 -0
- package/dist/browser/client/vue.d.ts +17 -0
- package/dist/browser/client/vue.d.ts.map +1 -0
- package/dist/browser/client/vue.js +110 -0
- package/dist/browser/client/vue.js.map +1 -0
- package/dist/browser/index.d.ts +3 -3
- package/dist/browser/index.d.ts.map +1 -1
- package/dist/browser/index.js +2 -49
- package/dist/browser/src-Bg_r9_li.js +1700 -0
- package/dist/browser/src-Bg_r9_li.js.map +1 -0
- package/dist/node/index.d.ts +2 -2
- package/dist/node/index.d.ts.map +1 -1
- package/dist/node/index.js +2 -2
- package/dist/node/index.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +49 -2
- package/src/client/react.ts +7 -0
- package/src/client/solid.ts +7 -0
- package/src/client/svelte.ts +7 -0
- package/src/client/vanilla.ts +7 -0
- package/src/client/vue.ts +7 -0
- package/src/index.ts +1 -1
- package/tsdown.config.ts +10 -1
- package/.turbo/turbo-types$colon$check.log +0 -1
- package/dist/browser/index.js.map +0 -1
package/.turbo/turbo-build.log
CHANGED
|
@@ -1,21 +1,42 @@
|
|
|
1
1
|
$ tsdown
|
|
2
|
-
[34mℹ[39m tsdown [2mv0.15.
|
|
2
|
+
[34mℹ[39m tsdown [2mv0.15.9[22m powered by rolldown [2mv1.0.0-beta.44[22m
|
|
3
3
|
rollup
|
|
4
|
-
[34mℹ[39m Using tsdown config: [4m/home/runner/work/fragno/fragno/
|
|
4
|
+
[34mℹ[39m Using tsdown config: [4m/home/runner/work/fragno/fragno/example-fragments/example-fragment/tsdown.config.ts[24m
|
|
5
5
|
[34mℹ[39m entry: [34msrc/index.ts[39m
|
|
6
6
|
[34mℹ[39m tsconfig: [34mtsconfig.json[39m
|
|
7
|
-
[34mℹ[39m entry: [34msrc/index.ts[39m
|
|
7
|
+
[34mℹ[39m entry: [34msrc/index.ts, src/client/react.ts, src/client/solid.ts, src/client/svelte.ts, src/client/vanilla.ts, src/client/vue.ts[39m
|
|
8
8
|
[34mℹ[39m tsconfig: [34mtsconfig.json[39m
|
|
9
9
|
[34mℹ[39m Build start
|
|
10
|
-
[34mℹ[39m [2mdist/browser/[22m[1mindex.js[22m [2m1.58 kB[22m [2m│ gzip: 0.64 kB[22m
|
|
11
|
-
[34mℹ[39m [2mdist/browser/[22mindex.js.map [2m5.66 kB[22m [2m│ gzip: 1.93 kB[22m
|
|
12
|
-
[34mℹ[39m [2mdist/browser/[22mindex.d.ts.map [2m0.51 kB[22m [2m│ gzip: 0.26 kB[22m
|
|
13
|
-
[34mℹ[39m [2mdist/browser/[22m[32m[1mindex.d.ts[22m[39m [2m1.82 kB[22m [2m│ gzip: 0.62 kB[22m
|
|
14
|
-
[34mℹ[39m 4 files, total: 9.57 kB
|
|
15
10
|
[34mℹ[39m [2mdist/node/[22m[1mindex.js[22m [2m2.90 kB[22m [2m│ gzip: 1.15 kB[22m
|
|
16
|
-
[34mℹ[39m [2mdist/node/[22mindex.js.map [2m5.
|
|
17
|
-
[34mℹ[39m [2mdist/node/[22mindex.d.ts.map [2m0.
|
|
11
|
+
[34mℹ[39m [2mdist/node/[22mindex.js.map [2m5.68 kB[22m [2m│ gzip: 1.96 kB[22m
|
|
12
|
+
[34mℹ[39m [2mdist/node/[22mindex.d.ts.map [2m0.56 kB[22m [2m│ gzip: 0.28 kB[22m
|
|
18
13
|
[34mℹ[39m [2mdist/node/[22m[32m[1mindex.d.ts[22m[39m [2m1.82 kB[22m [2m│ gzip: 0.62 kB[22m
|
|
19
|
-
[34mℹ[39m 4 files, total: 10.
|
|
20
|
-
[32m✔[39m Build complete in [
|
|
21
|
-
[
|
|
14
|
+
[34mℹ[39m 4 files, total: 10.96 kB
|
|
15
|
+
[32m✔[39m Build complete in [32m14994ms[39m
|
|
16
|
+
[34mℹ[39m [2mdist/browser/[22m[1mclient/solid.js[22m [2m 3.45 kB[22m [2m│ gzip: 1.15 kB[22m
|
|
17
|
+
[34mℹ[39m [2mdist/browser/[22m[1mclient/vanilla.js[22m [2m 3.40 kB[22m [2m│ gzip: 1.13 kB[22m
|
|
18
|
+
[34mℹ[39m [2mdist/browser/[22m[1mclient/svelte.js[22m [2m 3.38 kB[22m [2m│ gzip: 0.99 kB[22m
|
|
19
|
+
[34mℹ[39m [2mdist/browser/[22m[1mclient/vue.js[22m [2m 2.95 kB[22m [2m│ gzip: 1.02 kB[22m
|
|
20
|
+
[34mℹ[39m [2mdist/browser/[22m[1mclient/react.js[22m [2m 2.74 kB[22m [2m│ gzip: 1.01 kB[22m
|
|
21
|
+
[34mℹ[39m [2mdist/browser/[22m[1mindex.js[22m [2m 0.16 kB[22m [2m│ gzip: 0.11 kB[22m
|
|
22
|
+
[34mℹ[39m [2mdist/browser/[22msrc-Bg_r9_li.js.map [2m112.53 kB[22m [2m│ gzip: 30.36 kB[22m
|
|
23
|
+
[34mℹ[39m [2mdist/browser/[22msrc-Bg_r9_li.js [2m 53.08 kB[22m [2m│ gzip: 13.51 kB[22m
|
|
24
|
+
[34mℹ[39m [2mdist/browser/[22mclient/svelte.js.map [2m 7.34 kB[22m [2m│ gzip: 2.19 kB[22m
|
|
25
|
+
[34mℹ[39m [2mdist/browser/[22mclient/solid.js.map [2m 7.29 kB[22m [2m│ gzip: 2.42 kB[22m
|
|
26
|
+
[34mℹ[39m [2mdist/browser/[22mclient/vanilla.js.map [2m 6.88 kB[22m [2m│ gzip: 2.24 kB[22m
|
|
27
|
+
[34mℹ[39m [2mdist/browser/[22mclient/react.js.map [2m 6.38 kB[22m [2m│ gzip: 2.29 kB[22m
|
|
28
|
+
[34mℹ[39m [2mdist/browser/[22mclient/vue.js.map [2m 6.32 kB[22m [2m│ gzip: 2.12 kB[22m
|
|
29
|
+
[34mℹ[39m [2mdist/browser/[22mindex.d.ts.map [2m 0.56 kB[22m [2m│ gzip: 0.28 kB[22m
|
|
30
|
+
[34mℹ[39m [2mdist/browser/[22mclient/vanilla.d.ts.map [2m 0.19 kB[22m [2m│ gzip: 0.15 kB[22m
|
|
31
|
+
[34mℹ[39m [2mdist/browser/[22mclient/svelte.d.ts.map [2m 0.18 kB[22m [2m│ gzip: 0.15 kB[22m
|
|
32
|
+
[34mℹ[39m [2mdist/browser/[22mclient/react.d.ts.map [2m 0.18 kB[22m [2m│ gzip: 0.15 kB[22m
|
|
33
|
+
[34mℹ[39m [2mdist/browser/[22mclient/solid.d.ts.map [2m 0.18 kB[22m [2m│ gzip: 0.15 kB[22m
|
|
34
|
+
[34mℹ[39m [2mdist/browser/[22mclient/vue.d.ts.map [2m 0.18 kB[22m [2m│ gzip: 0.15 kB[22m
|
|
35
|
+
[34mℹ[39m [2mdist/browser/[22m[32m[1mindex.d.ts[22m[39m [2m 1.82 kB[22m [2m│ gzip: 0.62 kB[22m
|
|
36
|
+
[34mℹ[39m [2mdist/browser/[22m[32m[1mclient/vanilla.d.ts[22m[39m [2m 0.98 kB[22m [2m│ gzip: 0.44 kB[22m
|
|
37
|
+
[34mℹ[39m [2mdist/browser/[22m[32m[1mclient/svelte.d.ts[22m[39m [2m 0.96 kB[22m [2m│ gzip: 0.43 kB[22m
|
|
38
|
+
[34mℹ[39m [2mdist/browser/[22m[32m[1mclient/react.d.ts[22m[39m [2m 0.94 kB[22m [2m│ gzip: 0.43 kB[22m
|
|
39
|
+
[34mℹ[39m [2mdist/browser/[22m[32m[1mclient/solid.d.ts[22m[39m [2m 0.94 kB[22m [2m│ gzip: 0.43 kB[22m
|
|
40
|
+
[34mℹ[39m [2mdist/browser/[22m[32m[1mclient/vue.d.ts[22m[39m [2m 0.92 kB[22m [2m│ gzip: 0.42 kB[22m
|
|
41
|
+
[34mℹ[39m 25 files, total: 223.94 kB
|
|
42
|
+
[32m✔[39m Build complete in [32m15121ms[39m
|
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,21 @@
|
|
|
1
1
|
# @fragno-dev/example-fragment
|
|
2
2
|
|
|
3
|
+
## 0.0.7
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- c1483c6: Support for SolidJS and SolidStart
|
|
8
|
+
- Updated dependencies [1fa71f3]
|
|
9
|
+
- Updated dependencies [c1483c6]
|
|
10
|
+
- @fragno-dev/core@0.0.7
|
|
11
|
+
|
|
12
|
+
## 0.0.6
|
|
13
|
+
|
|
14
|
+
### Patch Changes
|
|
15
|
+
|
|
16
|
+
- Updated dependencies [c3ff022]
|
|
17
|
+
- @fragno-dev/core@0.0.6
|
|
18
|
+
|
|
3
19
|
## 0.0.5
|
|
4
20
|
|
|
5
21
|
### Patch Changes
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { FragnoPublicClientConfig } from "@fragno-dev/core";
|
|
2
|
+
import * as zod4 from "zod";
|
|
3
|
+
import * as _fragno_dev_core_react0 from "@fragno-dev/core/react";
|
|
4
|
+
import * as _fragno_dev_core_api1 from "@fragno-dev/core/api";
|
|
5
|
+
import * as zod_v4_core0 from "zod/v4/core";
|
|
6
|
+
|
|
7
|
+
//#region src/client/react.d.ts
|
|
8
|
+
declare function createExampleFragmentClient(config?: FragnoPublicClientConfig): {
|
|
9
|
+
useHash: _fragno_dev_core_react0.FragnoReactHook<"GET", "/hash", zod4.ZodString, string, string>;
|
|
10
|
+
useData: _fragno_dev_core_react0.FragnoReactHook<"GET", "/data", zod4.ZodString, string, "error">;
|
|
11
|
+
useSampleMutator: _fragno_dev_core_react0.FragnoReactMutator<_fragno_dev_core_api1.NonGetHTTPMethod, "/sample", zod4.ZodObject<{
|
|
12
|
+
message: zod4.ZodString;
|
|
13
|
+
}, zod_v4_core0.$strip> | undefined, zod4.ZodString | undefined, "MESSAGE_CANNOT_BE_DIGITS_ONLY", string>;
|
|
14
|
+
};
|
|
15
|
+
//#endregion
|
|
16
|
+
export { createExampleFragmentClient };
|
|
17
|
+
//# sourceMappingURL=react.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react.d.ts","names":[],"sources":["../../../src/client/react.ts"],"sourcesContent":[],"mappings":";;;;;;;iBAIgB,2BAAA,UAAoC;mEAA6B,IAAA,CAAA,SAAA;;;;;AAAjF,CAAA"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { a as isReadableAtom, i as isMutatorHook, n as createExampleFragmentClients, o as isStore, r as isGetHook } from "../src-Bg_r9_li.js";
|
|
2
|
+
import { useCallback, useMemo, useRef, useSyncExternalStore } from "react";
|
|
3
|
+
|
|
4
|
+
//#region ../../node_modules/.bun/nanostores@1.0.1/node_modules/nanostores/listen-keys/index.js
|
|
5
|
+
function listenKeys($store, keys, listener) {
|
|
6
|
+
let keysSet = new Set(keys).add(void 0);
|
|
7
|
+
return $store.listen((value, oldValue, changed) => {
|
|
8
|
+
if (keysSet.has(changed)) listener(value, oldValue, changed);
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
//#endregion
|
|
13
|
+
//#region ../../packages/fragno/dist/client/react.js
|
|
14
|
+
function createReactHook(hook) {
|
|
15
|
+
return ({ path, query } = {}) => {
|
|
16
|
+
const pathParamValues = path ? Object.values(path) : [];
|
|
17
|
+
const queryParamValues = query ? Object.values(query) : [];
|
|
18
|
+
const store = useMemo(() => hook.store({
|
|
19
|
+
path,
|
|
20
|
+
query
|
|
21
|
+
}), [hook, ...[...pathParamValues, ...queryParamValues]]);
|
|
22
|
+
if (typeof window === "undefined") return store.get();
|
|
23
|
+
return useStore(store);
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
function createReactMutator(hook) {
|
|
27
|
+
return () => {
|
|
28
|
+
return useStore(useMemo(() => hook.mutatorStore, [hook]));
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
function createReactStore(hook) {
|
|
32
|
+
if (isReadableAtom(hook.obj)) return () => useStore(hook.obj);
|
|
33
|
+
return () => {
|
|
34
|
+
const result = {};
|
|
35
|
+
for (const key in hook.obj) {
|
|
36
|
+
if (!Object.prototype.hasOwnProperty.call(hook.obj, key)) continue;
|
|
37
|
+
const value = hook.obj[key];
|
|
38
|
+
if (isReadableAtom(value)) result[key] = useStore(value);
|
|
39
|
+
else result[key] = value;
|
|
40
|
+
}
|
|
41
|
+
return result;
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
function useFragno(clientObj) {
|
|
45
|
+
const result = {};
|
|
46
|
+
for (const key in clientObj) {
|
|
47
|
+
if (!Object.prototype.hasOwnProperty.call(clientObj, key)) continue;
|
|
48
|
+
const hook = clientObj[key];
|
|
49
|
+
if (isGetHook(hook)) result[key] = createReactHook(hook);
|
|
50
|
+
else if (isMutatorHook(hook)) result[key] = createReactMutator(hook);
|
|
51
|
+
else if (isStore(hook)) result[key] = createReactStore(hook);
|
|
52
|
+
else result[key] = hook;
|
|
53
|
+
}
|
|
54
|
+
return result;
|
|
55
|
+
}
|
|
56
|
+
function useStore(store, options = {}) {
|
|
57
|
+
const snapshotRef = useRef(store.get());
|
|
58
|
+
const { keys, deps = [store, keys] } = options;
|
|
59
|
+
const subscribe = useCallback((onChange) => {
|
|
60
|
+
const emitChange = (value) => {
|
|
61
|
+
if (snapshotRef.current === value) return;
|
|
62
|
+
snapshotRef.current = value;
|
|
63
|
+
onChange();
|
|
64
|
+
};
|
|
65
|
+
emitChange(store.value);
|
|
66
|
+
if (keys?.length) return listenKeys(store, keys, emitChange);
|
|
67
|
+
return store.listen(emitChange);
|
|
68
|
+
}, deps);
|
|
69
|
+
const get = () => snapshotRef.current;
|
|
70
|
+
return useSyncExternalStore(subscribe, get, () => {
|
|
71
|
+
return get();
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
//#endregion
|
|
76
|
+
//#region src/client/react.ts
|
|
77
|
+
function createExampleFragmentClient(config = {}) {
|
|
78
|
+
return useFragno(createExampleFragmentClients(config));
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
//#endregion
|
|
82
|
+
export { createExampleFragmentClient };
|
|
83
|
+
//# sourceMappingURL=react.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"react.js","names":["listenKeys","$store","keys","listener","keysSet","Set","add","undefined","listen","value","oldValue","changed","has","subscribeKeys","unbind","a","isGetHook","c","isReadableAtom","o","isMutatorHook","s","isStore","hydrateFromWindow","listenKeys","useCallback","useMemo","useRef","useSyncExternalStore","createReactHook","hook","path","query","pathParamValues","Object","values","queryParamValues","store","window","get","useStore","createReactMutator","mutatorStore","createReactStore","obj","result","key","prototype","hasOwnProperty","call","value","useFragno","clientObj","options","snapshotRef","keys","deps","subscribe","onChange","emitChange","current","length","listen","FragnoHydrator","children","useFragno","createExampleFragmentClients","FragnoPublicClientConfig","createExampleFragmentClient","config"],"sources":["../../../../../node_modules/.bun/nanostores@1.0.1/node_modules/nanostores/listen-keys/index.js","../../../../../packages/fragno/dist/client/react.js","../../../src/client/react.ts"],"sourcesContent":["export function listenKeys($store, keys, listener) {\n let keysSet = new Set(keys).add(undefined)\n return $store.listen((value, oldValue, changed) => {\n if (keysSet.has(changed)) {\n listener(value, oldValue, changed)\n }\n })\n}\n\nexport function subscribeKeys($store, keys, listener) {\n let unbind = listenKeys($store, keys, listener)\n listener($store.value)\n return unbind\n}\n","import \"../api-DuzjjCT4.js\";\nimport \"../route-Dq62lXqB.js\";\nimport { a as isGetHook, c as isReadableAtom, o as isMutatorHook, s as isStore } from \"../client-C_Oc8hpD.js\";\nimport { o as hydrateFromWindow } from \"../ssr-BAhbA_3q.js\";\nimport { listenKeys } from \"nanostores\";\nimport { useCallback, useMemo, useRef, useSyncExternalStore } from \"react\";\n\n//#region src/client/react.ts\nfunction createReactHook(hook) {\n\treturn ({ path, query } = {}) => {\n\t\tconst pathParamValues = path ? Object.values(path) : [];\n\t\tconst queryParamValues = query ? Object.values(query) : [];\n\t\tconst store = useMemo(() => hook.store({\n\t\t\tpath,\n\t\t\tquery\n\t\t}), [hook, ...[...pathParamValues, ...queryParamValues]]);\n\t\tif (typeof window === \"undefined\") return store.get();\n\t\treturn useStore(store);\n\t};\n}\nfunction createReactMutator(hook) {\n\treturn () => {\n\t\treturn useStore(useMemo(() => hook.mutatorStore, [hook]));\n\t};\n}\nfunction createReactStore(hook) {\n\tif (isReadableAtom(hook.obj)) return () => useStore(hook.obj);\n\treturn () => {\n\t\tconst result = {};\n\t\tfor (const key in hook.obj) {\n\t\t\tif (!Object.prototype.hasOwnProperty.call(hook.obj, key)) continue;\n\t\t\tconst value = hook.obj[key];\n\t\t\tif (isReadableAtom(value)) result[key] = useStore(value);\n\t\t\telse result[key] = value;\n\t\t}\n\t\treturn result;\n\t};\n}\nfunction useFragno(clientObj) {\n\tconst result = {};\n\tfor (const key in clientObj) {\n\t\tif (!Object.prototype.hasOwnProperty.call(clientObj, key)) continue;\n\t\tconst hook = clientObj[key];\n\t\tif (isGetHook(hook)) result[key] = createReactHook(hook);\n\t\telse if (isMutatorHook(hook)) result[key] = createReactMutator(hook);\n\t\telse if (isStore(hook)) result[key] = createReactStore(hook);\n\t\telse result[key] = hook;\n\t}\n\treturn result;\n}\nfunction useStore(store, options = {}) {\n\tconst snapshotRef = useRef(store.get());\n\tconst { keys, deps = [store, keys] } = options;\n\tconst subscribe = useCallback((onChange) => {\n\t\tconst emitChange = (value) => {\n\t\t\tif (snapshotRef.current === value) return;\n\t\t\tsnapshotRef.current = value;\n\t\t\tonChange();\n\t\t};\n\t\temitChange(store.value);\n\t\tif (keys?.length) return listenKeys(store, keys, emitChange);\n\t\treturn store.listen(emitChange);\n\t}, deps);\n\tconst get = () => snapshotRef.current;\n\treturn useSyncExternalStore(subscribe, get, () => {\n\t\treturn get();\n\t});\n}\nfunction FragnoHydrator({ children }) {\n\tuseMemo(() => {\n\t\thydrateFromWindow();\n\t}, []);\n\treturn children;\n}\n\n//#endregion\nexport { FragnoHydrator, useFragno, useStore };\n//# sourceMappingURL=react.js.map","import { useFragno } from \"@fragno-dev/core/react\";\nimport { createExampleFragmentClients } from \"..\";\nimport type { FragnoPublicClientConfig } from \"@fragno-dev/core\";\n\nexport function createExampleFragmentClient(config: FragnoPublicClientConfig = {}) {\n return useFragno(createExampleFragmentClients(config));\n}\n"],"x_google_ignoreList":[0],"mappings":";;;;AAAA,SAAgBA,WAAWC,QAAQC,MAAMC,UAAU;CACjD,IAAIC,UAAU,IAAIC,IAAIH,KAAK,CAACI,IAAIC,OAAU;AAC1C,QAAON,OAAOO,QAAQC,OAAOC,UAAUC,YAAY;AACjD,MAAIP,QAAQQ,IAAID,QAAQ,CACtBR,UAASM,OAAOC,UAAUC,QAAQ;GAEpC;;;;;ACEJ,SAASkB,gBAAgBC,MAAM;AAC9B,SAAQ,EAAEC,MAAMC,UAAU,EAAE,KAAK;EAChC,MAAMC,kBAAkBF,OAAOG,OAAOC,OAAOJ,KAAK,GAAG,EAAE;EACvD,MAAMK,mBAAmBJ,QAAQE,OAAOC,OAAOH,MAAM,GAAG,EAAE;EAC1D,MAAMK,QAAQX,cAAcI,KAAKO,MAAM;GACtCN;GACAC;GACA,CAAC,EAAE,CAACF,MAAM,GAAG,CAAC,GAAGG,iBAAiB,GAAGG,iBAAiB,CAAC,CAAC;AACzD,MAAI,OAAOE,WAAW,YAAa,QAAOD,MAAME,KAAK;AACrD,SAAOC,SAASH,MAAM;;;AAGxB,SAASI,mBAAmBX,MAAM;AACjC,cAAa;AACZ,SAAOU,SAASd,cAAcI,KAAKY,cAAc,CAACZ,KAAK,CAAC,CAAC;;;AAG3D,SAASa,iBAAiBb,MAAM;AAC/B,KAAIZ,eAAeY,KAAKc,IAAI,CAAE,cAAaJ,SAASV,KAAKc,IAAI;AAC7D,cAAa;EACZ,MAAMC,SAAS,EAAE;AACjB,OAAK,MAAMC,OAAOhB,KAAKc,KAAK;AAC3B,OAAI,CAACV,OAAOa,UAAUC,eAAeC,KAAKnB,KAAKc,KAAKE,IAAI,CAAE;GAC1D,MAAMI,QAAQpB,KAAKc,IAAIE;AACvB,OAAI5B,eAAegC,MAAM,CAAEL,QAAOC,OAAON,SAASU,MAAM;OACnDL,QAAOC,OAAOI;;AAEpB,SAAOL;;;AAGT,SAASM,UAAUC,WAAW;CAC7B,MAAMP,SAAS,EAAE;AACjB,MAAK,MAAMC,OAAOM,WAAW;AAC5B,MAAI,CAAClB,OAAOa,UAAUC,eAAeC,KAAKG,WAAWN,IAAI,CAAE;EAC3D,MAAMhB,OAAOsB,UAAUN;AACvB,MAAI9B,UAAUc,KAAK,CAAEe,QAAOC,OAAOjB,gBAAgBC,KAAK;WAC/CV,cAAcU,KAAK,CAAEe,QAAOC,OAAOL,mBAAmBX,KAAK;WAC3DR,QAAQQ,KAAK,CAAEe,QAAOC,OAAOH,iBAAiBb,KAAK;MACvDe,QAAOC,OAAOhB;;AAEpB,QAAOe;;AAER,SAASL,SAASH,OAAOgB,UAAU,EAAE,EAAE;CACtC,MAAMC,cAAc3B,OAAOU,MAAME,KAAK,CAAC;CACvC,MAAM,EAAEgB,MAAMC,OAAO,CAACnB,OAAOkB,KAAI,KAAMF;CACvC,MAAMI,YAAYhC,aAAaiC,aAAa;EAC3C,MAAMC,cAAcT,UAAU;AAC7B,OAAII,YAAYM,YAAYV,MAAO;AACnCI,eAAYM,UAAUV;AACtBQ,aAAU;;AAEXC,aAAWtB,MAAMa,MAAM;AACvB,MAAIK,MAAMM,OAAQ,QAAOrC,WAAWa,OAAOkB,MAAMI,WAAW;AAC5D,SAAOtB,MAAMyB,OAAOH,WAAW;IAC7BH,KAAK;CACR,MAAMjB,YAAYe,YAAYM;AAC9B,QAAOhC,qBAAqB6B,WAAWlB,WAAW;AACjD,SAAOA,KAAK;GACX;;;;;AC9DH,SAAgB6B,4BAA4BC,SAAmC,EAAE,EAAE;AACjF,QAAOJ,UAAUC,6BAA6BG,OAAO,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { FragnoPublicClientConfig } from "@fragno-dev/core";
|
|
2
|
+
import * as zod9 from "zod";
|
|
3
|
+
import * as _fragno_dev_core_api2 from "@fragno-dev/core/api";
|
|
4
|
+
import * as zod_v4_core1 from "zod/v4/core";
|
|
5
|
+
import * as _fragno_dev_core_solid0 from "@fragno-dev/core/solid";
|
|
6
|
+
|
|
7
|
+
//#region src/client/solid.d.ts
|
|
8
|
+
declare function createExampleFragmentClient(config?: FragnoPublicClientConfig): {
|
|
9
|
+
useHash: _fragno_dev_core_solid0.FragnoSolidHook<"GET", "/hash", zod9.ZodString, string, string>;
|
|
10
|
+
useData: _fragno_dev_core_solid0.FragnoSolidHook<"GET", "/data", zod9.ZodString, string, "error">;
|
|
11
|
+
useSampleMutator: _fragno_dev_core_solid0.FragnoSolidMutator<_fragno_dev_core_api2.NonGetHTTPMethod, "/sample", zod9.ZodObject<{
|
|
12
|
+
message: zod9.ZodString;
|
|
13
|
+
}, zod_v4_core1.$strip> | undefined, zod9.ZodString | undefined, "MESSAGE_CANNOT_BE_DIGITS_ONLY", string>;
|
|
14
|
+
};
|
|
15
|
+
//#endregion
|
|
16
|
+
export { createExampleFragmentClient };
|
|
17
|
+
//# sourceMappingURL=solid.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"solid.d.ts","names":[],"sources":["../../../src/client/solid.ts"],"sourcesContent":[],"mappings":";;;;;;;iBAIgB,2BAAA,UAAoC;mEAA6B,IAAA,CAAA,SAAA;;;;;AAAjF,CAAA"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { a as isReadableAtom, i as isMutatorHook, n as createExampleFragmentClients, o as isStore, r as isGetHook, s as atom } from "../src-Bg_r9_li.js";
|
|
2
|
+
import { createStore, reconcile } from "solid-js/store";
|
|
3
|
+
import { createEffect, onCleanup } from "solid-js";
|
|
4
|
+
|
|
5
|
+
//#region ../../node_modules/.bun/@nanostores+solid@1.1.1+9136909fcbbc49e5/node_modules/@nanostores/solid/dist/index.js
|
|
6
|
+
function m(e, o = {}) {
|
|
7
|
+
let t = e.listen(() => {}), [r, s] = createStore({ value: e.get() }), n = e.subscribe((i) => {
|
|
8
|
+
s("value", reconcile(i, o));
|
|
9
|
+
});
|
|
10
|
+
return onCleanup(() => n()), t(), () => r.value;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
//#endregion
|
|
14
|
+
//#region ../../packages/fragno/dist/client/solid.js
|
|
15
|
+
/**
|
|
16
|
+
* Type guard to check if a value is a SolidJS Accessor.
|
|
17
|
+
*
|
|
18
|
+
* @private
|
|
19
|
+
*/
|
|
20
|
+
function isAccessor(value) {
|
|
21
|
+
return typeof value === "function";
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Converts a SolidJS Accessor to a NanoStore Atom.
|
|
25
|
+
*
|
|
26
|
+
* This is used to convert SolidJS accessors to atoms, so that we can use them in the store.
|
|
27
|
+
*
|
|
28
|
+
* @private
|
|
29
|
+
*/
|
|
30
|
+
function accessorToAtom(accessor) {
|
|
31
|
+
const a = atom(accessor());
|
|
32
|
+
createEffect(() => {
|
|
33
|
+
a.set(accessor());
|
|
34
|
+
});
|
|
35
|
+
return a;
|
|
36
|
+
}
|
|
37
|
+
function createSolidHook(hook) {
|
|
38
|
+
return ({ path, query } = {}) => {
|
|
39
|
+
const pathParams = {};
|
|
40
|
+
const queryParams = {};
|
|
41
|
+
for (const [key, value] of Object.entries(path ?? {})) {
|
|
42
|
+
const v = value;
|
|
43
|
+
pathParams[key] = isAccessor(v) ? accessorToAtom(v) : v;
|
|
44
|
+
}
|
|
45
|
+
for (const [key, value] of Object.entries(query ?? {})) {
|
|
46
|
+
const v = value;
|
|
47
|
+
queryParams[key] = isAccessor(v) ? accessorToAtom(v) : v;
|
|
48
|
+
}
|
|
49
|
+
const storeValue = m(hook.store({
|
|
50
|
+
path: pathParams,
|
|
51
|
+
query: queryParams
|
|
52
|
+
}));
|
|
53
|
+
return {
|
|
54
|
+
data: () => storeValue().data,
|
|
55
|
+
loading: () => storeValue().loading,
|
|
56
|
+
error: () => storeValue().error
|
|
57
|
+
};
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
function createSolidMutator(hook) {
|
|
61
|
+
return () => {
|
|
62
|
+
const store = m(hook.mutatorStore);
|
|
63
|
+
const mutate = async (args) => {
|
|
64
|
+
const { body, path, query } = args;
|
|
65
|
+
const pathParams = {};
|
|
66
|
+
const queryParams = {};
|
|
67
|
+
for (const [key, value] of Object.entries(path ?? {})) {
|
|
68
|
+
const v = value;
|
|
69
|
+
pathParams[key] = isAccessor(v) ? v() : v;
|
|
70
|
+
}
|
|
71
|
+
for (const [key, value] of Object.entries(query ?? {})) {
|
|
72
|
+
const v = value;
|
|
73
|
+
queryParams[key] = isAccessor(v) ? v() : v;
|
|
74
|
+
}
|
|
75
|
+
return hook.mutatorStore.mutate({
|
|
76
|
+
body,
|
|
77
|
+
path: pathParams,
|
|
78
|
+
query: queryParams
|
|
79
|
+
});
|
|
80
|
+
};
|
|
81
|
+
return {
|
|
82
|
+
mutate,
|
|
83
|
+
data: () => store().data,
|
|
84
|
+
loading: () => store().loading,
|
|
85
|
+
error: () => store().error
|
|
86
|
+
};
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
function createSolidStore(hook) {
|
|
90
|
+
if (isReadableAtom(hook.obj)) return m(hook.obj);
|
|
91
|
+
const result = {};
|
|
92
|
+
for (const key in hook.obj) {
|
|
93
|
+
if (!Object.prototype.hasOwnProperty.call(hook.obj, key)) continue;
|
|
94
|
+
const value = hook.obj[key];
|
|
95
|
+
if (isReadableAtom(value)) result[key] = m(value);
|
|
96
|
+
else result[key] = value;
|
|
97
|
+
}
|
|
98
|
+
return () => result;
|
|
99
|
+
}
|
|
100
|
+
function useFragno(clientObj) {
|
|
101
|
+
const result = {};
|
|
102
|
+
for (const key in clientObj) {
|
|
103
|
+
if (!Object.prototype.hasOwnProperty.call(clientObj, key)) continue;
|
|
104
|
+
const hook = clientObj[key];
|
|
105
|
+
if (isGetHook(hook)) result[key] = createSolidHook(hook);
|
|
106
|
+
else if (isMutatorHook(hook)) result[key] = createSolidMutator(hook);
|
|
107
|
+
else if (isStore(hook)) result[key] = createSolidStore(hook);
|
|
108
|
+
else result[key] = hook;
|
|
109
|
+
}
|
|
110
|
+
return result;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
//#endregion
|
|
114
|
+
//#region src/client/solid.ts
|
|
115
|
+
function createExampleFragmentClient(config = {}) {
|
|
116
|
+
return useFragno(createExampleFragmentClients(config));
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
//#endregion
|
|
120
|
+
export { createExampleFragmentClient };
|
|
121
|
+
//# sourceMappingURL=solid.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"solid.js","names":["createStore","c","reconcile","u","onCleanup","S","m","e","o","t","listen","r","s","value","get","n","subscribe","i","useStore","a","isGetHook","c","isReadableAtom","o","isMutatorHook","s","isStore","atom","useStore","createEffect","isAccessor","value","accessorToAtom","accessor","set","createSolidHook","hook","path","query","pathParams","queryParams","key","Object","entries","v","storeValue","store","data","loading","error","createSolidMutator","mutatorStore","mutate","args","body","createSolidStore","obj","result","prototype","hasOwnProperty","call","useFragno","clientObj","useFragno","createExampleFragmentClients","FragnoPublicClientConfig","createExampleFragmentClient","config"],"sources":["../../../../../node_modules/.bun/@nanostores+solid@1.1.1+9136909fcbbc49e5/node_modules/@nanostores/solid/dist/index.js","../../../../../packages/fragno/dist/client/solid.js","../../../src/client/solid.ts"],"sourcesContent":["import{createStore as c,reconcile as u}from\"solid-js/store\";import{onCleanup as S}from\"solid-js\";function m(e,o={}){let t=e.listen(()=>{}),[r,s]=c({value:e.get()}),n=e.subscribe(i=>{s(\"value\",u(i,o))});return S(()=>n()),t(),()=>r.value}export{m as useStore};\n","import \"../api-DuzjjCT4.js\";\nimport \"../route-Dq62lXqB.js\";\nimport { a as isGetHook, c as isReadableAtom, o as isMutatorHook, s as isStore } from \"../client-C_Oc8hpD.js\";\nimport \"../ssr-BAhbA_3q.js\";\nimport { atom } from \"nanostores\";\nimport { useStore } from \"@nanostores/solid\";\nimport { createEffect } from \"solid-js\";\n\n//#region src/client/solid.ts\n/**\n* Type guard to check if a value is a SolidJS Accessor.\n*\n* @private\n*/\nfunction isAccessor(value) {\n\treturn typeof value === \"function\";\n}\n/**\n* Converts a SolidJS Accessor to a NanoStore Atom.\n*\n* This is used to convert SolidJS accessors to atoms, so that we can use them in the store.\n*\n* @private\n*/\nfunction accessorToAtom(accessor) {\n\tconst a = atom(accessor());\n\tcreateEffect(() => {\n\t\ta.set(accessor());\n\t});\n\treturn a;\n}\nfunction createSolidHook(hook) {\n\treturn ({ path, query } = {}) => {\n\t\tconst pathParams = {};\n\t\tconst queryParams = {};\n\t\tfor (const [key, value] of Object.entries(path ?? {})) {\n\t\t\tconst v = value;\n\t\t\tpathParams[key] = isAccessor(v) ? accessorToAtom(v) : v;\n\t\t}\n\t\tfor (const [key, value] of Object.entries(query ?? {})) {\n\t\t\tconst v = value;\n\t\t\tqueryParams[key] = isAccessor(v) ? accessorToAtom(v) : v;\n\t\t}\n\t\tconst storeValue = useStore(hook.store({\n\t\t\tpath: pathParams,\n\t\t\tquery: queryParams\n\t\t}));\n\t\treturn {\n\t\t\tdata: () => storeValue().data,\n\t\t\tloading: () => storeValue().loading,\n\t\t\terror: () => storeValue().error\n\t\t};\n\t};\n}\nfunction createSolidMutator(hook) {\n\treturn () => {\n\t\tconst store = useStore(hook.mutatorStore);\n\t\tconst mutate = async (args) => {\n\t\t\tconst { body, path, query } = args;\n\t\t\tconst pathParams = {};\n\t\t\tconst queryParams = {};\n\t\t\tfor (const [key, value] of Object.entries(path ?? {})) {\n\t\t\t\tconst v = value;\n\t\t\t\tpathParams[key] = isAccessor(v) ? v() : v;\n\t\t\t}\n\t\t\tfor (const [key, value] of Object.entries(query ?? {})) {\n\t\t\t\tconst v = value;\n\t\t\t\tqueryParams[key] = isAccessor(v) ? v() : v;\n\t\t\t}\n\t\t\treturn hook.mutatorStore.mutate({\n\t\t\t\tbody,\n\t\t\t\tpath: pathParams,\n\t\t\t\tquery: queryParams\n\t\t\t});\n\t\t};\n\t\treturn {\n\t\t\tmutate,\n\t\t\tdata: () => store().data,\n\t\t\tloading: () => store().loading,\n\t\t\terror: () => store().error\n\t\t};\n\t};\n}\nfunction createSolidStore(hook) {\n\tif (isReadableAtom(hook.obj)) return useStore(hook.obj);\n\tconst result = {};\n\tfor (const key in hook.obj) {\n\t\tif (!Object.prototype.hasOwnProperty.call(hook.obj, key)) continue;\n\t\tconst value = hook.obj[key];\n\t\tif (isReadableAtom(value)) result[key] = useStore(value);\n\t\telse result[key] = value;\n\t}\n\treturn () => result;\n}\nfunction useFragno(clientObj) {\n\tconst result = {};\n\tfor (const key in clientObj) {\n\t\tif (!Object.prototype.hasOwnProperty.call(clientObj, key)) continue;\n\t\tconst hook = clientObj[key];\n\t\tif (isGetHook(hook)) result[key] = createSolidHook(hook);\n\t\telse if (isMutatorHook(hook)) result[key] = createSolidMutator(hook);\n\t\telse if (isStore(hook)) result[key] = createSolidStore(hook);\n\t\telse result[key] = hook;\n\t}\n\treturn result;\n}\n\n//#endregion\nexport { accessorToAtom, isAccessor, useFragno };\n//# sourceMappingURL=solid.js.map","import { useFragno } from \"@fragno-dev/core/solid\";\nimport { createExampleFragmentClients } from \"..\";\nimport type { FragnoPublicClientConfig } from \"@fragno-dev/core\";\n\nexport function createExampleFragmentClient(config: FragnoPublicClientConfig = {}) {\n return useFragno(createExampleFragmentClients(config));\n}\n"],"x_google_ignoreList":[0],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { FragnoPublicClientConfig } from "@fragno-dev/core";
|
|
2
|
+
import * as zod14 from "zod";
|
|
3
|
+
import * as _fragno_dev_core_api3 from "@fragno-dev/core/api";
|
|
4
|
+
import * as zod_v4_core2 from "zod/v4/core";
|
|
5
|
+
import * as _fragno_dev_core_svelte0 from "@fragno-dev/core/svelte";
|
|
6
|
+
|
|
7
|
+
//#region src/client/svelte.d.ts
|
|
8
|
+
declare function createExampleFragmentClient(config?: FragnoPublicClientConfig): {
|
|
9
|
+
useHash: _fragno_dev_core_svelte0.FragnoSvelteHook<"GET", "/hash", zod14.ZodString, string, string>;
|
|
10
|
+
useData: _fragno_dev_core_svelte0.FragnoSvelteHook<"GET", "/data", zod14.ZodString, string, "error">;
|
|
11
|
+
useSampleMutator: _fragno_dev_core_svelte0.FragnoSvelteMutator<_fragno_dev_core_api3.NonGetHTTPMethod, "/sample", zod14.ZodObject<{
|
|
12
|
+
message: zod14.ZodString;
|
|
13
|
+
}, zod_v4_core2.$strip> | undefined, zod14.ZodString | undefined, "MESSAGE_CANNOT_BE_DIGITS_ONLY", string>;
|
|
14
|
+
};
|
|
15
|
+
//#endregion
|
|
16
|
+
export { createExampleFragmentClient };
|
|
17
|
+
//# sourceMappingURL=svelte.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"svelte.d.ts","names":[],"sources":["../../../src/client/svelte.ts"],"sourcesContent":[],"mappings":";;;;;;;iBAIgB,2BAAA,UAAoC;qEAA6B,KAAA,CAAA,SAAA;;;;;AAAjF,CAAA"}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { i as isMutatorHook, n as createExampleFragmentClients, o as isStore, r as isGetHook, s as atom } from "../src-Bg_r9_li.js";
|
|
2
|
+
import { get, writable } from "svelte/store";
|
|
3
|
+
import { onDestroy } from "svelte";
|
|
4
|
+
|
|
5
|
+
//#region ../../packages/fragno/dist/client/client.svelte.js
|
|
6
|
+
function isReadable(value) {
|
|
7
|
+
return typeof value === "object" && value !== null && "subscribe" in value;
|
|
8
|
+
}
|
|
9
|
+
function isCallable(value) {
|
|
10
|
+
return typeof value === "function";
|
|
11
|
+
}
|
|
12
|
+
function readableToAtom(value) {
|
|
13
|
+
const a = atom(get(value));
|
|
14
|
+
value.subscribe((newVal) => {
|
|
15
|
+
a.set(newVal);
|
|
16
|
+
});
|
|
17
|
+
return a;
|
|
18
|
+
}
|
|
19
|
+
function runeToAtom(value) {
|
|
20
|
+
const a = atom(value());
|
|
21
|
+
$effect(() => {
|
|
22
|
+
a.set(value());
|
|
23
|
+
});
|
|
24
|
+
return a;
|
|
25
|
+
}
|
|
26
|
+
function createSvelteHook(hook) {
|
|
27
|
+
return ({ path, query } = {}) => {
|
|
28
|
+
const pathParams = {};
|
|
29
|
+
const queryParams = {};
|
|
30
|
+
for (const [key, value] of Object.entries(path ?? {})) {
|
|
31
|
+
const v = value;
|
|
32
|
+
if (isCallable(v)) pathParams[key] = runeToAtom(v);
|
|
33
|
+
else pathParams[key] = isReadable(v) ? readableToAtom(v) : v;
|
|
34
|
+
}
|
|
35
|
+
for (const [key, value] of Object.entries(query ?? {})) {
|
|
36
|
+
const v = value;
|
|
37
|
+
if (isCallable(v)) queryParams[key] = runeToAtom(v);
|
|
38
|
+
else queryParams[key] = isReadable(v) ? readableToAtom(v) : v;
|
|
39
|
+
}
|
|
40
|
+
const store = hook.store({
|
|
41
|
+
path: pathParams,
|
|
42
|
+
query: queryParams
|
|
43
|
+
});
|
|
44
|
+
const data = writable(void 0);
|
|
45
|
+
const loading = writable(false);
|
|
46
|
+
const error = writable(void 0);
|
|
47
|
+
const unsubscribe = store.subscribe((updatedStoreValue) => {
|
|
48
|
+
data.set(updatedStoreValue.data);
|
|
49
|
+
loading.set(updatedStoreValue.loading);
|
|
50
|
+
error.set(updatedStoreValue.error);
|
|
51
|
+
});
|
|
52
|
+
onDestroy(() => {
|
|
53
|
+
unsubscribe();
|
|
54
|
+
});
|
|
55
|
+
return {
|
|
56
|
+
data,
|
|
57
|
+
loading,
|
|
58
|
+
error
|
|
59
|
+
};
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
function createSvelteMutator(hook) {
|
|
63
|
+
return () => {
|
|
64
|
+
const data = writable(void 0);
|
|
65
|
+
const loading = writable(void 0);
|
|
66
|
+
const error = writable(void 0);
|
|
67
|
+
const unsubscribe = hook.mutatorStore.subscribe((storeValue) => {
|
|
68
|
+
data.set(storeValue.data);
|
|
69
|
+
loading.set(storeValue.loading);
|
|
70
|
+
error.set(storeValue.error);
|
|
71
|
+
});
|
|
72
|
+
onDestroy(() => {
|
|
73
|
+
unsubscribe();
|
|
74
|
+
});
|
|
75
|
+
const mutate = async (args) => {
|
|
76
|
+
const { body, path, query } = args;
|
|
77
|
+
const pathParams = {};
|
|
78
|
+
const queryParams = {};
|
|
79
|
+
for (const [key, value] of Object.entries(path ?? {})) {
|
|
80
|
+
const v = value;
|
|
81
|
+
pathParams[key] = isReadable(v) ? readableToAtom(v) : v;
|
|
82
|
+
}
|
|
83
|
+
for (const [key, value] of Object.entries(query ?? {})) {
|
|
84
|
+
const v = value;
|
|
85
|
+
queryParams[key] = isReadable(v) ? readableToAtom(v) : v;
|
|
86
|
+
}
|
|
87
|
+
return hook.mutatorStore.mutate({
|
|
88
|
+
body,
|
|
89
|
+
path: pathParams,
|
|
90
|
+
query: queryParams
|
|
91
|
+
});
|
|
92
|
+
};
|
|
93
|
+
return {
|
|
94
|
+
mutate,
|
|
95
|
+
loading,
|
|
96
|
+
error,
|
|
97
|
+
data
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
function createSvelteStore(hook) {
|
|
102
|
+
return hook.obj;
|
|
103
|
+
}
|
|
104
|
+
function useFragno(clientObj) {
|
|
105
|
+
const result = {};
|
|
106
|
+
for (const key in clientObj) {
|
|
107
|
+
if (!Object.prototype.hasOwnProperty.call(clientObj, key)) continue;
|
|
108
|
+
const hook = clientObj[key];
|
|
109
|
+
if (isGetHook(hook)) result[key] = createSvelteHook(hook);
|
|
110
|
+
else if (isMutatorHook(hook)) result[key] = createSvelteMutator(hook);
|
|
111
|
+
else if (isStore(hook)) result[key] = createSvelteStore(hook);
|
|
112
|
+
else result[key] = hook;
|
|
113
|
+
}
|
|
114
|
+
return result;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
//#endregion
|
|
118
|
+
//#region src/client/svelte.ts
|
|
119
|
+
function createExampleFragmentClient(config = {}) {
|
|
120
|
+
return useFragno(createExampleFragmentClients(config));
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
//#endregion
|
|
124
|
+
export { createExampleFragmentClient };
|
|
125
|
+
//# sourceMappingURL=svelte.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"svelte.js","names":["a","isGetHook","o","isMutatorHook","s","isStore","atom","get","writable","onDestroy","isReadable","value","isCallable","readableToAtom","subscribe","newVal","set","runeToAtom","$effect","createSvelteHook","hook","path","query","pathParams","queryParams","key","Object","entries","v","store","data","loading","error","unsubscribe","updatedStoreValue","createSvelteMutator","mutatorStore","storeValue","mutate","args","body","createSvelteStore","obj","useFragno","clientObj","result","prototype","hasOwnProperty","call","useFragno","createExampleFragmentClients","FragnoPublicClientConfig","createExampleFragmentClient","config"],"sources":["../../../../../packages/fragno/dist/client/client.svelte.js","../../../src/client/svelte.ts"],"sourcesContent":["import \"../api-DuzjjCT4.js\";\nimport \"../route-Dq62lXqB.js\";\nimport { a as isGetHook, o as isMutatorHook, s as isStore } from \"../client-C_Oc8hpD.js\";\nimport \"../ssr-BAhbA_3q.js\";\nimport { atom } from \"nanostores\";\nimport { get, writable } from \"svelte/store\";\nimport { onDestroy } from \"svelte\";\n\n//#region src/client/client.svelte.ts\nfunction isReadable(value) {\n\treturn typeof value === \"object\" && value !== null && \"subscribe\" in value;\n}\nfunction isCallable(value) {\n\treturn typeof value === \"function\";\n}\nfunction readableToAtom(value) {\n\tconst a = atom(get(value));\n\tvalue.subscribe((newVal) => {\n\t\ta.set(newVal);\n\t});\n\treturn a;\n}\nfunction runeToAtom(value) {\n\tconst a = atom(value());\n\t$effect(() => {\n\t\ta.set(value());\n\t});\n\treturn a;\n}\nfunction createSvelteHook(hook) {\n\treturn ({ path, query } = {}) => {\n\t\tconst pathParams = {};\n\t\tconst queryParams = {};\n\t\tfor (const [key, value] of Object.entries(path ?? {})) {\n\t\t\tconst v = value;\n\t\t\tif (isCallable(v)) pathParams[key] = runeToAtom(v);\n\t\t\telse pathParams[key] = isReadable(v) ? readableToAtom(v) : v;\n\t\t}\n\t\tfor (const [key, value] of Object.entries(query ?? {})) {\n\t\t\tconst v = value;\n\t\t\tif (isCallable(v)) queryParams[key] = runeToAtom(v);\n\t\t\telse queryParams[key] = isReadable(v) ? readableToAtom(v) : v;\n\t\t}\n\t\tconst store = hook.store({\n\t\t\tpath: pathParams,\n\t\t\tquery: queryParams\n\t\t});\n\t\tconst data = writable(void 0);\n\t\tconst loading = writable(false);\n\t\tconst error = writable(void 0);\n\t\tconst unsubscribe = store.subscribe((updatedStoreValue) => {\n\t\t\tdata.set(updatedStoreValue.data);\n\t\t\tloading.set(updatedStoreValue.loading);\n\t\t\terror.set(updatedStoreValue.error);\n\t\t});\n\t\tonDestroy(() => {\n\t\t\tunsubscribe();\n\t\t});\n\t\treturn {\n\t\t\tdata,\n\t\t\tloading,\n\t\t\terror\n\t\t};\n\t};\n}\nfunction createSvelteMutator(hook) {\n\treturn () => {\n\t\tconst data = writable(void 0);\n\t\tconst loading = writable(void 0);\n\t\tconst error = writable(void 0);\n\t\tconst unsubscribe = hook.mutatorStore.subscribe((storeValue) => {\n\t\t\tdata.set(storeValue.data);\n\t\t\tloading.set(storeValue.loading);\n\t\t\terror.set(storeValue.error);\n\t\t});\n\t\tonDestroy(() => {\n\t\t\tunsubscribe();\n\t\t});\n\t\tconst mutate = async (args) => {\n\t\t\tconst { body, path, query } = args;\n\t\t\tconst pathParams = {};\n\t\t\tconst queryParams = {};\n\t\t\tfor (const [key, value] of Object.entries(path ?? {})) {\n\t\t\t\tconst v = value;\n\t\t\t\tpathParams[key] = isReadable(v) ? readableToAtom(v) : v;\n\t\t\t}\n\t\t\tfor (const [key, value] of Object.entries(query ?? {})) {\n\t\t\t\tconst v = value;\n\t\t\t\tqueryParams[key] = isReadable(v) ? readableToAtom(v) : v;\n\t\t\t}\n\t\t\treturn hook.mutatorStore.mutate({\n\t\t\t\tbody,\n\t\t\t\tpath: pathParams,\n\t\t\t\tquery: queryParams\n\t\t\t});\n\t\t};\n\t\treturn {\n\t\t\tmutate,\n\t\t\tloading,\n\t\t\terror,\n\t\t\tdata\n\t\t};\n\t};\n}\nfunction createSvelteStore(hook) {\n\treturn hook.obj;\n}\nfunction useFragno(clientObj) {\n\tconst result = {};\n\tfor (const key in clientObj) {\n\t\tif (!Object.prototype.hasOwnProperty.call(clientObj, key)) continue;\n\t\tconst hook = clientObj[key];\n\t\tif (isGetHook(hook)) result[key] = createSvelteHook(hook);\n\t\telse if (isMutatorHook(hook)) result[key] = createSvelteMutator(hook);\n\t\telse if (isStore(hook)) result[key] = createSvelteStore(hook);\n\t\telse result[key] = hook;\n\t}\n\treturn result;\n}\n\n//#endregion\nexport { createSvelteStore, readableToAtom, runeToAtom, useFragno };\n//# sourceMappingURL=client.svelte.js.map","import { useFragno } from \"@fragno-dev/core/svelte\";\nimport { createExampleFragmentClients } from \"..\";\nimport type { FragnoPublicClientConfig } from \"@fragno-dev/core\";\n\nexport function createExampleFragmentClient(config: FragnoPublicClientConfig = {}) {\n return useFragno(createExampleFragmentClients(config));\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { FragnoPublicClientConfig } from "@fragno-dev/core";
|
|
2
|
+
import * as zod19 from "zod";
|
|
3
|
+
import * as _fragno_dev_core_api4 from "@fragno-dev/core/api";
|
|
4
|
+
import * as zod_v4_core3 from "zod/v4/core";
|
|
5
|
+
import * as _fragno_dev_core_vanilla0 from "@fragno-dev/core/vanilla";
|
|
6
|
+
|
|
7
|
+
//#region src/client/vanilla.d.ts
|
|
8
|
+
declare function createExampleFragmentClient(config?: FragnoPublicClientConfig): {
|
|
9
|
+
useHash: _fragno_dev_core_vanilla0.FragnoVanillaListeners<"GET", "/hash", zod19.ZodString, string, string>;
|
|
10
|
+
useData: _fragno_dev_core_vanilla0.FragnoVanillaListeners<"GET", "/data", zod19.ZodString, string, "error">;
|
|
11
|
+
useSampleMutator: _fragno_dev_core_vanilla0.FragnoVanillaMutator<_fragno_dev_core_api4.NonGetHTTPMethod, "/sample", zod19.ZodObject<{
|
|
12
|
+
message: zod19.ZodString;
|
|
13
|
+
}, zod_v4_core3.$strip> | undefined, zod19.ZodString | undefined, "MESSAGE_CANNOT_BE_DIGITS_ONLY", string>;
|
|
14
|
+
};
|
|
15
|
+
//#endregion
|
|
16
|
+
export { createExampleFragmentClient };
|
|
17
|
+
//# sourceMappingURL=vanilla.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vanilla.d.ts","names":[],"sources":["../../../src/client/vanilla.ts"],"sourcesContent":[],"mappings":";;;;;;;iBAIgB,2BAAA,UAAoC;4EAA6B,KAAA,CAAA,SAAA;;;;;AAAjF,CAAA"}
|