Loading...
Loading...
Zustand adapter for json-render's StateStore interface. Use when integrating json-render with Zustand for state management via @json-render/zustand.
npx skill4agent add vercel-labs/json-render zustandStateStorenpm install @json-render/zustand @json-render/core @json-render/react zustandimport { createStore } from "zustand/vanilla";
import { zustandStateStore } from "@json-render/zustand";
import { StateProvider } from "@json-render/react";
// 1. Create a Zustand vanilla store
const bearStore = createStore(() => ({
count: 0,
name: "Bear",
}));
// 2. Create the json-render StateStore adapter
const store = zustandStateStore({ store: bearStore });
// 3. Use it
<StateProvider store={store}>
{/* json-render reads/writes go through Zustand */}
</StateProvider>const appStore = createStore(() => ({
ui: { count: 0 },
auth: { token: null },
}));
const store = zustandStateStore({
store: appStore,
selector: (s) => s.ui,
updater: (next, s) => s.setState({ ui: next }),
});zustandStateStore(options)StateStore| Option | Type | Required | Description |
|---|---|---|---|
| | Yes | Zustand vanilla store (from |
| | No | Select the json-render slice. Defaults to entire state. |
| | No | Apply next state to the store. Defaults to shallow merge. Override for nested slices, or use |