feat: refactor layout structure and add error boundary for Navidrome integration

This commit is contained in:
2025-06-25 19:36:42 -05:00
parent 2084907fbe
commit 4b195af8ed
4 changed files with 61 additions and 58 deletions

View File

@@ -0,0 +1,52 @@
"use client";
import React from "react";
import { AudioPlayerProvider } from "../components/AudioPlayerContext";
import { NavidromeProvider, useNavidrome } from "../components/NavidromeContext";
import { NavidromeConfigProvider } from "../components/NavidromeConfigContext";
import { ThemeProvider } from "../components/ThemeProvider";
import { PostHogProvider } from "../components/PostHogProvider";
import Ihateserverside from "./ihateserverside";
import DynamicViewportTheme from "./DynamicViewportTheme";
import { LoginForm } from "./start-screen";
function NavidromeErrorBoundary({ children }: { children: React.ReactNode }) {
const { error } = useNavidrome();
if (error) {
return (
<div className="flex min-h-svh w-full items-center justify-center p-6 md:p-10">
{/* top right add the logo located in /icon-192.png here and the word mice */}
<div className="absolute top-4 left-4 flex items-center space-x-2">
<img src="/icon-192.png" alt="Logo" className="h-8 w-8" />
<span className="text-xl font-semibold">mice | navidrome client</span>
</div>
<div className="w-full max-w-sm">
<LoginForm />
</div>
</div>
);
}
return <>{children}</>;
}
export default function RootLayoutClient({ children }: { children: React.ReactNode }) {
return (
<PostHogProvider>
<ThemeProvider>
<DynamicViewportTheme />
<NavidromeConfigProvider>
<NavidromeProvider>
<NavidromeErrorBoundary>
<AudioPlayerProvider>
<Ihateserverside>
{children}
</Ihateserverside>
</AudioPlayerProvider>
</NavidromeErrorBoundary>
</NavidromeProvider>
</NavidromeConfigProvider>
</ThemeProvider>
</PostHogProvider>
);
}

View File

@@ -126,7 +126,6 @@ export function LoginForm({
<Card>
<CardHeader>
<CardTitle className="flex items-center gap-2">
<FaPalette className="w-5 h-5" />
Customize Your Experience
</CardTitle>
<CardDescription>
@@ -137,7 +136,10 @@ export function LoginForm({
<div className="flex flex-col gap-6">
{/* Theme Selection */}
<div className="grid gap-3">
<Label htmlFor="theme">Theme</Label>
<span>
<FaPalette className="w-5 h-5" />
<Label htmlFor="theme">Theme</Label>
</span>
<Select value={theme} onValueChange={setTheme}>
<SelectTrigger>
<SelectValue placeholder="Select a theme" />
@@ -204,7 +206,6 @@ export function LoginForm({
<Card>
<CardHeader>
<CardTitle className="flex items-center gap-2">
<FaServer className="w-5 h-5" />
Connect to Navidrome
</CardTitle>
<CardDescription>