aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/client/atoms/decks.ts
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2026-01-04 17:43:59 +0900
committernsfisis <nsfisis@gmail.com>2026-01-04 19:09:58 +0900
commitf8e4be9b36a16969ac53bd9ce12ce8064be10196 (patch)
treeb2cf350d2e2e52803ff809311effb40da767d859 /src/client/atoms/decks.ts
parente1c9e5e89bb91bca2586470c786510c3e1c03826 (diff)
downloadkioku-f8e4be9b36a16969ac53bd9ce12ce8064be10196.tar.gz
kioku-f8e4be9b36a16969ac53bd9ce12ce8064be10196.tar.zst
kioku-f8e4be9b36a16969ac53bd9ce12ce8064be10196.zip
refactor(client): migrate state management from React Context to Jotai
Replace AuthProvider and SyncProvider with Jotai atoms for more granular state management and better performance. This migration: - Creates atoms for auth, sync, decks, cards, noteTypes, and study state - Uses atomFamily for parameterized state (e.g., cards by deckId) - Introduces StoreInitializer component for subscription initialization - Updates all components and pages to use useAtomValue/useSetAtom - Updates all tests to use Jotai Provider with createStore pattern 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
Diffstat (limited to 'src/client/atoms/decks.ts')
-rw-r--r--src/client/atoms/decks.ts37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/client/atoms/decks.ts b/src/client/atoms/decks.ts
new file mode 100644
index 0000000..57abef4
--- /dev/null
+++ b/src/client/atoms/decks.ts
@@ -0,0 +1,37 @@
+import { apiClient } from "../api/client";
+import { createReloadableAtom, createReloadableAtomFamily } from "./utils";
+
+export interface Deck {
+ id: string;
+ name: string;
+ description: string | null;
+ newCardsPerDay: number;
+ createdAt: string;
+ updatedAt: string;
+}
+
+// =====================
+// Decks List - Suspense-compatible
+// =====================
+
+export const decksAtom = createReloadableAtom(async () => {
+ const res = await apiClient.rpc.api.decks.$get(undefined, {
+ headers: apiClient.getAuthHeader(),
+ });
+ const data = await apiClient.handleResponse<{ decks: Deck[] }>(res);
+ return data.decks;
+});
+
+// =====================
+// Single Deck by ID - Suspense-compatible
+// =====================
+
+export const deckByIdAtomFamily = createReloadableAtomFamily(
+ async (deckId: string) => {
+ const res = await apiClient.rpc.api.decks[":id"].$get({
+ param: { id: deckId },
+ });
+ const data = await apiClient.handleResponse<{ deck: Deck }>(res);
+ return data.deck;
+ },
+);