feat: update dependencies and refactor layout and homepage components
- Added new dependencies: @daveyplate/better-auth-ui, next-themes, and sonner. - Refactored layout component to use Providers and Toaster for better state management and notifications. - Updated homepage to utilize authClient for session management and improved user experience with navigation links for sign-in and sign-up.
This commit is contained in:
22
app/auth/[path]/page.tsx
Normal file
22
app/auth/[path]/page.tsx
Normal file
@@ -0,0 +1,22 @@
|
||||
import { AuthView } from "@daveyplate/better-auth-ui";
|
||||
import { authViewPaths } from "@daveyplate/better-auth-ui/server";
|
||||
|
||||
export const dynamicParams = false;
|
||||
|
||||
export function generateStaticParams() {
|
||||
return Object.values(authViewPaths).map((path) => ({ path }));
|
||||
}
|
||||
|
||||
export default async function AuthPage({
|
||||
params,
|
||||
}: {
|
||||
params: Promise<{ path: string }>;
|
||||
}) {
|
||||
const { path } = await params;
|
||||
|
||||
return (
|
||||
<main className="flex min-h-screen flex-col items-center justify-center p-4">
|
||||
<AuthView path={path} />
|
||||
</main>
|
||||
);
|
||||
}
|
||||
@@ -1,20 +1,12 @@
|
||||
import type { Metadata } from "next";
|
||||
import { Geist, Geist_Mono, Manrope } from "next/font/google";
|
||||
import { Manrope } from "next/font/google";
|
||||
import "./globals.css";
|
||||
import { cn } from "@/lib/utils";
|
||||
import { ConvexClientProvider } from "@/components/ui/convex-prover";
|
||||
import { Providers } from "@/components/providers";
|
||||
import { Toaster } from "@/components/ui/sonner";
|
||||
import { InitUser } from "@/components/init-user";
|
||||
|
||||
const manrope = Manrope({subsets:['latin'],variable:'--font-sans'});
|
||||
|
||||
const geistSans = Geist({
|
||||
variable: "--font-geist-sans",
|
||||
subsets: ["latin"],
|
||||
});
|
||||
|
||||
const geistMono = Geist_Mono({
|
||||
variable: "--font-geist-mono",
|
||||
subsets: ["latin"],
|
||||
});
|
||||
const manrope = Manrope({ subsets: ["latin"], variable: "--font-sans" });
|
||||
|
||||
export const metadata: Metadata = {
|
||||
title: "Create Next App",
|
||||
@@ -28,11 +20,15 @@ export default function RootLayout({
|
||||
}>) {
|
||||
return (
|
||||
<html
|
||||
lang="en"
|
||||
className={cn("h-full", "antialiased", geistSans.variable, geistMono.variable, "font-sans", manrope.variable)}
|
||||
lang="de"
|
||||
className={cn("h-full", "antialiased", "font-sans", manrope.variable)}
|
||||
>
|
||||
<body className="min-h-full flex flex-col">
|
||||
<ConvexClientProvider>{children}</ConvexClientProvider>
|
||||
<Providers>
|
||||
<InitUser />
|
||||
{children}
|
||||
<Toaster />
|
||||
</Providers>
|
||||
</body>
|
||||
</html>
|
||||
);
|
||||
|
||||
63
app/page.tsx
63
app/page.tsx
@@ -1,38 +1,51 @@
|
||||
// src/app/page.tsx — minimaler Test
|
||||
"use client";
|
||||
|
||||
import { authClient } from "@/lib/auth-client";
|
||||
import { useQuery } from "convex/react";
|
||||
import { api } from "@/convex/_generated/api";
|
||||
import Link from "next/link";
|
||||
|
||||
export default function Home() {
|
||||
const user = useQuery(api.auth.getCurrentUser);
|
||||
const { data: session, isPending } = authClient.useSession();
|
||||
|
||||
// user === undefined → Query lädt noch
|
||||
// user === null → Nicht eingeloggt
|
||||
// user === { id, name, email, ... } → Eingeloggt
|
||||
if (isPending) {
|
||||
return (
|
||||
<main className="flex min-h-screen items-center justify-center">
|
||||
<p className="text-muted-foreground">Laden...</p>
|
||||
</main>
|
||||
);
|
||||
}
|
||||
|
||||
return (
|
||||
<div>
|
||||
<h1>LemonSpace</h1>
|
||||
{user ? (
|
||||
<div>
|
||||
<p>Eingeloggt als: {user.name}</p>
|
||||
<button onClick={() => authClient.signOut()}>Logout</button>
|
||||
<main className="flex min-h-screen flex-col items-center justify-center gap-6 p-4">
|
||||
<h1 className="text-4xl font-bold">🍋 LemonSpace</h1>
|
||||
|
||||
{session?.user ? (
|
||||
<div className="flex flex-col items-center gap-4">
|
||||
<p className="text-lg">
|
||||
Willkommen, <span className="font-semibold">{session.user.name}</span>
|
||||
</p>
|
||||
<Link
|
||||
href="/dashboard"
|
||||
className="rounded-lg bg-primary px-6 py-3 text-primary-foreground hover:bg-primary/90"
|
||||
>
|
||||
Zum Dashboard
|
||||
</Link>
|
||||
</div>
|
||||
) : (
|
||||
<button
|
||||
onClick={() =>
|
||||
authClient.signUp.email({
|
||||
email: "test@lemonspace.io",
|
||||
password: "test1234",
|
||||
name: "Test User",
|
||||
})
|
||||
}
|
||||
>
|
||||
Test Signup
|
||||
</button>
|
||||
<div className="flex gap-4">
|
||||
<Link
|
||||
href="/auth/sign-in"
|
||||
className="rounded-lg bg-primary px-6 py-3 text-primary-foreground hover:bg-primary/90"
|
||||
>
|
||||
Anmelden
|
||||
</Link>
|
||||
<Link
|
||||
href="/auth/sign-up"
|
||||
className="rounded-lg border border-border px-6 py-3 hover:bg-accent"
|
||||
>
|
||||
Registrieren
|
||||
</Link>
|
||||
</div>
|
||||
)}
|
||||
</div>
|
||||
</main>
|
||||
);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user