data:image/s3,"s3://crabby-images/a0507/a050798f526c7d69fc72266fcdf2a531723739a4" alt="🛌🎣 Rest hooks"
data:image/s3,"s3://crabby-images/ea2ad/ea2ad7051a04b3895ad2d7d4d7aee930c47eadfb" alt="PRs Welcome"
Making dynamic sites performant, scalable, simple to build with any API design.
Simple TypeScript definition
class Article extends Entity {
readonly id: number | undefined = undefined;
readonly title: string = '';
readonly body: string = '';
pk() { return this.id; }
}
const ArticleEndpoint = {
fetch: async ({ id }: { id: string }) => {
return await (await fetch(`http://test.com/articles/${id}`)).json();
},
getFetchKey({ id }: { id: string }) {
return `GET /articles/${userId}`;
},
schema: Article,
type: 'read' as const,
}
One line data hookup
const article = useResource(ArticleEndpoint, { id });
return (
<>
<h2>{article.title}</h2>
<p>{article.body}</p>
</>
);
Mutation
const update = useFetcher(ArticleEndpoint);
return <ArticleForm onSubmit={data => update({ id }, data)} />;
And subscriptions
const price = useResource(PriceEndpoint, { symbol });
useSubscription(PriceEndpoint, { symbol });+
return price.value;
...all typed ...fast ...and consistent
For the small price of 7kb gziped. 🏁Get started now
Features
Special thanks
Thanks to @0xcaff, @melissafzhang
and @alexiswolfish for their valuable feedback.