aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/client/pages/LoginPage.tsx
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/pages/LoginPage.tsx
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/pages/LoginPage.tsx')
-rw-r--r--src/client/pages/LoginPage.tsx9
1 files changed, 6 insertions, 3 deletions
diff --git a/src/client/pages/LoginPage.tsx b/src/client/pages/LoginPage.tsx
index 835c73e..0af45c6 100644
--- a/src/client/pages/LoginPage.tsx
+++ b/src/client/pages/LoginPage.tsx
@@ -1,12 +1,15 @@
import { faSpinner } from "@fortawesome/free-solid-svg-icons";
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
+import { useAtomValue, useSetAtom } from "jotai";
import { type FormEvent, useEffect, useState } from "react";
import { useLocation } from "wouter";
-import { ApiClientError, useAuth } from "../stores";
+import { ApiClientError } from "../api/client";
+import { isAuthenticatedAtom, loginAtom } from "../atoms";
export function LoginPage() {
const [, navigate] = useLocation();
- const { login, isAuthenticated } = useAuth();
+ const isAuthenticated = useAtomValue(isAuthenticatedAtom);
+ const login = useSetAtom(loginAtom);
const [username, setUsername] = useState("");
const [password, setPassword] = useState("");
const [error, setError] = useState<string | null>(null);
@@ -26,7 +29,7 @@ export function LoginPage() {
setIsSubmitting(true);
try {
- await login(username, password);
+ await login({ username, password });
navigate("/", { replace: true });
} catch (err) {
if (err instanceof ApiClientError) {