2024-05-26 18:37:36 -07:00

47 lines
1.2 KiB
TypeScript

import { UserButton, currentUser } from "@clerk/nextjs"
import { redirect } from "next/navigation"
import Dashboard from "@/components/dashboard"
import Navbar from "@/components/dashboard/navbar"
import { Sandbox, User } from "@/lib/types"
export default async function DashboardPage() {
const user = await currentUser()
if (!user) {
redirect("/")
}
const userRes = await fetch(
`${process.env.NEXT_PUBLIC_DATABASE_WORKER_URL}/api/user?id=${user.id}`,
{
headers: {
Authorization: `${process.env.NEXT_PUBLIC_WORKERS_KEY}`,
},
}
)
const userData = (await userRes.json()) as User
const sharedRes = await fetch(
`${process.env.NEXT_PUBLIC_DATABASE_WORKER_URL}/api/sandbox/share?id=${user.id}`,
{
headers: {
Authorization: `${process.env.NEXT_PUBLIC_WORKERS_KEY}`,
},
}
)
const shared = (await sharedRes.json()) as {
id: string
name: string
type: "react" | "node"
author: string
sharedOn: Date
}[]
return (
<div className="w-screen h-screen flex flex-col overflow-hidden overscroll-none">
<Navbar userData={userData} />
<Dashboard sandboxes={userData.sandbox} shared={shared} />
</div>
)
}