Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kumpmati/sveltekit-superactions
Call your server code from the client like normal functions.
https://github.com/kumpmati/sveltekit-superactions
api server-actions svelte sveltejs sveltekit
Last synced: 4 months ago
JSON representation
Call your server code from the client like normal functions.
- Host: GitHub
- URL: https://github.com/kumpmati/sveltekit-superactions
- Owner: kumpmati
- License: mit
- Created: 2024-07-12T14:16:38.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-07-21T18:05:06.000Z (6 months ago)
- Last Synced: 2024-09-29T10:52:02.296Z (4 months ago)
- Topics: api, server-actions, svelte, sveltejs, sveltekit
- Language: TypeScript
- Homepage: https://superactions.matsku.dev
- Size: 249 KB
- Stars: 12
- Watchers: 2
- Forks: 0
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
SvelteKit Superactions
[![Test](https://github.com/kumpmati/sveltekit-superactions/actions/workflows/test.yml/badge.svg)](https://github.com/kumpmati/sveltekit-superactions/actions/workflows/test.yml)
Call your server code from the client like normal functions.
**🚧 This library is in an early state, and breaking changes will likely happen before the API is stabilised for a v1.0 release! 🚧**
[Documentation](https://superactions.matsku.dev)
## Why?
While SvelteKit's data fetching patterns are great, but the ease-of-use of React Server Actions doesn't seem to have an equivalent in SvelteKit. The ability to just 'call a function' in the client-side, have it perform logic on the server and return the result to the client is sometimes very useful.
SvelteKit's [form actions](https://kit.svelte.dev/docs/form-actions) are a great fit for many cases, but they can be clunky when you want to call an endpoint without a form element, or when you need to send data that is too complex to be represented in FormData.
This library aims to provide additional tools alongside SvelteKit's API routes:
## Features
- [x] Type satefy between server and client
- [x] Automatic JSON conversion (request/response)
- [x] Schema validation
- [x] `zod` helper function
- [x] `joi` helper function## Installation
Install Superactions with your favourite package manager:
```bash
# npm, yarn, pnpm, bun, etc
npm i sveltekit-superactions
```## Usage
A minimal setup requires the following.
In a `+server.ts` file, define the actions that you want to use:
```ts
// src/routes/api/+server.ts
import { endpoint } from 'sveltekit-superactions';
import { db } from '$lib/server/db';
import { deleteTodo, findTodo, type TodoUpdate } from '$lib/server/handlers';// Always attach the endpoint as a POST handler
export const POST = endpoint({
// e is the RequestEvent provided by SvelteKit,
// and the second argument is the request body decoded as JSON.
editTodo: async (e, body: TodoUpdate) => {
// The returned value is automatically serialized as JSON.
// The client-side function gets its return type directly from the return type of its server action
return await db.update(body.id, body);
},// You can also just import handlers from other files and group them here.
deleteTodo,// Or give them custom names
my_handler: findTodo
});// export the type of the endpoint, so that we get types in the client
export type API = typeof POST;
```And in any Svelte component import the `superActions` function and the exported types to instantiate the client.
```svelte
import { superActions } from 'sveltekit-superactions';
import type { API } from './api/+server.js'; // exported API type// give the client the path and API types to instantiate it.
const api = superActions<API>('/api');{#await api.getTodos()}
Loading TODOs...
{:then todos}
-
{todo.text}
{#each todos as todo}
{/each}
{/await}
```