Setup system-svelte
This commit is contained in:
3
packages/system-svelte/README.md
Normal file
3
packages/system-svelte/README.md
Normal file
@ -0,0 +1,3 @@
|
||||
## @snort/system-svelte
|
||||
|
||||
Svelte hooks for @snort/system
|
25
packages/system-svelte/package.json
Normal file
25
packages/system-svelte/package.json
Normal file
@ -0,0 +1,25 @@
|
||||
{
|
||||
"name": "@snort/system-svelte",
|
||||
"version": "1.0.0",
|
||||
"description": "Svelte functions for @snort/system",
|
||||
"main": "dist/index.js",
|
||||
"types": "dist/index.d.ts",
|
||||
"repository": "https://git.v0l.io/Kieran/snort",
|
||||
"author": "Kieran",
|
||||
"license": "MIT",
|
||||
"scripts": {
|
||||
"build": "rm -rf dist && tsc"
|
||||
},
|
||||
"files": [
|
||||
"src",
|
||||
"dist"
|
||||
],
|
||||
"dependencies": {
|
||||
"@snort/shared": "^1.0.6",
|
||||
"@snort/system": "^1.0.21",
|
||||
"svelte": "^4.2.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"typescript": "^5.2.2"
|
||||
}
|
||||
}
|
1
packages/system-svelte/src/index.ts
Normal file
1
packages/system-svelte/src/index.ts
Normal file
@ -0,0 +1 @@
|
||||
export * from "./request-builder";
|
20
packages/system-svelte/src/request-builder.ts
Normal file
20
packages/system-svelte/src/request-builder.ts
Normal file
@ -0,0 +1,20 @@
|
||||
import { type NoteStore, type RequestBuilder, type StoreSnapshot, type SystemInterface } from "@snort/system";
|
||||
import { getContext } from "svelte";
|
||||
|
||||
export function useRequestBuilder<T extends NoteStore>(type: new () => T, rb: RequestBuilder) {
|
||||
const system = getContext("snort") as SystemInterface;
|
||||
type TSnap = StoreSnapshot<ReturnType<T["getSnapshotData"]>>;
|
||||
return {
|
||||
subscribe: (set: (value: TSnap) => void) => {
|
||||
const q = system.Query(type, rb);
|
||||
q.uncancel();
|
||||
const release = q.feed.hook(() => {
|
||||
set(q.feed.snapshot as TSnap);
|
||||
});
|
||||
return () => {
|
||||
q.cancel();
|
||||
release();
|
||||
};
|
||||
},
|
||||
};
|
||||
}
|
18
packages/system-svelte/tsconfig.json
Normal file
18
packages/system-svelte/tsconfig.json
Normal file
@ -0,0 +1,18 @@
|
||||
{
|
||||
"compilerOptions": {
|
||||
"baseUrl": "src",
|
||||
"target": "ES2020",
|
||||
"moduleResolution": "node",
|
||||
"esModuleInterop": true,
|
||||
"noImplicitOverride": true,
|
||||
"module": "CommonJS",
|
||||
"strict": true,
|
||||
"declaration": true,
|
||||
"declarationMap": true,
|
||||
"inlineSourceMap": true,
|
||||
"outDir": "dist",
|
||||
"skipLibCheck": true
|
||||
},
|
||||
"include": ["src/**/*.ts"],
|
||||
"files": ["src/index.ts"]
|
||||
}
|
Reference in New Issue
Block a user