67 lines
2.1 KiB
TypeScript
67 lines
2.1 KiB
TypeScript
import { prisma } from "@repo/db";
|
|
import { getServerSession } from "../../api/auth/[...nextauth]/auth";
|
|
import { ProfileForm, SocialForm, PasswordForm, DeleteForm } from "./_components/forms";
|
|
import { GearIcon } from "@radix-ui/react-icons";
|
|
import { Error } from "_components/Error";
|
|
import { getUserPenaltys } from "@repo/shared-components";
|
|
|
|
export default async function Page() {
|
|
const session = await getServerSession();
|
|
if (!session)
|
|
return <Error statusCode={401} title="Du musst angemeldet sein, um diese Seite zu sehen." />;
|
|
const user = await prisma.user.findFirst({
|
|
where: {
|
|
id: session.user.id,
|
|
},
|
|
include: {
|
|
DiscordAccount: true,
|
|
Penaltys: true,
|
|
},
|
|
});
|
|
const userPenaltys = await prisma.penalty.findMany({
|
|
where: {
|
|
userId: session.user.id,
|
|
suspended: false,
|
|
},
|
|
});
|
|
const activePenaltys = await getUserPenaltys(session.user.id);
|
|
|
|
const userReports = await prisma.report.findMany({
|
|
where: {
|
|
reportedUserId: session.user.id,
|
|
},
|
|
});
|
|
|
|
if (!user) return <Error statusCode={401} title="Dein Account wurde nicht gefunden" />;
|
|
const discordAccount = user?.DiscordAccount;
|
|
return (
|
|
<div className="grid grid-cols-6 gap-4">
|
|
<div className="col-span-full">
|
|
<p className="flex items-center gap-2 text-left text-2xl font-semibold">
|
|
<GearIcon className="h-5 w-5" /> Einstellungen
|
|
</p>
|
|
</div>
|
|
<div className="card bg-base-200 col-span-6 mb-4 shadow-xl xl:col-span-3">
|
|
<ProfileForm
|
|
user={user}
|
|
discordAccount={discordAccount}
|
|
penaltys={[...activePenaltys.openBans, ...activePenaltys.openTimeban]}
|
|
/>
|
|
</div>
|
|
<div className="card bg-base-200 col-span-6 mb-4 shadow-xl xl:col-span-3">
|
|
<SocialForm
|
|
user={user}
|
|
discordAccount={discordAccount}
|
|
penaltys={[...activePenaltys.openBans, ...activePenaltys.openTimeban]}
|
|
/>
|
|
</div>
|
|
<div className="card bg-base-200 col-span-6 mb-4 shadow-xl xl:col-span-3">
|
|
<PasswordForm />
|
|
</div>
|
|
<div className="card bg-base-200 col-span-6 mb-4 shadow-xl xl:col-span-3">
|
|
<DeleteForm user={user} reports={userReports} penaltys={userPenaltys} />
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|