aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/client/App.test.tsx
diff options
context:
space:
mode:
authornsfisis <nsfisis@gmail.com>2025-12-07 23:34:03 +0900
committernsfisis <nsfisis@gmail.com>2025-12-07 23:34:03 +0900
commit0c042ac89fc0822fcbe09c48702857faa5494ae1 (patch)
treeea1f1d180f747613343040d441a07f92b2760840 /src/client/App.test.tsx
parentae5a0bb97fbf013417a6962f7e077f0408b2a951 (diff)
downloadkioku-0c042ac89fc0822fcbe09c48702857faa5494ae1.tar.gz
kioku-0c042ac89fc0822fcbe09c48702857faa5494ae1.tar.zst
kioku-0c042ac89fc0822fcbe09c48702857faa5494ae1.zip
feat(client): add sync status indicator component
Add SyncStatusIndicator component to display current sync state in the UI header. The component shows online/offline status, syncing progress, pending changes count, and sync errors. - Create SyncProvider context to wrap SyncManager for React components - Add SyncStatusIndicator component with visual status indicators - Integrate indicator into HomePage header - Add comprehensive tests for SyncStatusIndicator and SyncProvider - Update existing tests to include SyncProvider wrapper 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
Diffstat (limited to 'src/client/App.test.tsx')
-rw-r--r--src/client/App.test.tsx7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/client/App.test.tsx b/src/client/App.test.tsx
index c11eb88..8359e67 100644
--- a/src/client/App.test.tsx
+++ b/src/client/App.test.tsx
@@ -1,13 +1,14 @@
/**
* @vitest-environment jsdom
*/
+import "fake-indexeddb/auto";
import { cleanup, render, screen } from "@testing-library/react";
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
import { Router } from "wouter";
import { memoryLocation } from "wouter/memory-location";
import { App } from "./App";
import { apiClient } from "./api/client";
-import { AuthProvider } from "./stores";
+import { AuthProvider, SyncProvider } from "./stores";
vi.mock("./api/client", () => ({
apiClient: {
@@ -53,7 +54,9 @@ function renderWithRouter(path: string) {
return render(
<Router hook={hook}>
<AuthProvider>
- <App />
+ <SyncProvider>
+ <App />
+ </SyncProvider>
</AuthProvider>
</Router>,
);