blob: e8f4138c51917c9b703e693de94de3a8a46e28d0 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
import Link from "next/link"
import { getServerSession } from "next-auth"
import { LogIn } from "lucide-react"
import { Button } from "@/components/ui/button"
import { ThemeToggle } from "@/components/ThemeToggle"
import { UserNav } from "@/components/UserNav"
import { authOptions } from "@/lib/auth"
export default async function Navbar() {
const session = await getServerSession(authOptions)
return (
<nav className="border-b bg-background/95 backdrop-blur supports-[backdrop-filter]:bg-background/60">
<div className="container mx-auto px-4 h-16 flex items-center justify-between">
<Link href="/" className="flex items-center space-x-2">
<div className="w-8 h-8 bg-primary rounded-md flex items-center justify-center">
<span className="text-primary-foreground font-bold text-lg">N</span>
</div>
<span className="font-bold text-xl">Next-Boilerplate</span>
</Link>
<div className="flex items-center space-x-4">
<ThemeToggle />
{session?.user ? (
<UserNav user={session.user} />
) : (
<Button asChild>
<Link href="/login">
<LogIn className="mr-2 h-4 w-4" />
Sign In
</Link>
</Button>
)}
</div>
</div>
</nav>
)
}
|