hts/apps/migrant/app/[locale]/manage/keys/[keyAuthId]/[keyId]/layout.tsx

99 lines
2.6 KiB
TypeScript

import { CopyButton } from "@/components/dashboard/copy-button";
import { Navbar } from "@/components/dashboard/navbar";
import { PageHeader } from "@/components/dashboard/page-header";
import { Badge } from "@/components/ui/badge";
import { getTenantId } from "@/lib/auth";
// import { and, db, eq, isNull, schema } from "@/lib/db";
import { notFound } from "next/navigation";
import { PropsWithChildren } from "react";
type Props = PropsWithChildren<{
params: {
keyAuthId: string;
keyId: string;
};
}>;
export const dynamic = "force-dynamic";
export const runtime = "edge";
export default async function ApiPageLayout(props: Props) {
const tenantId = getTenantId();
// const key = await db.query.keys.findFirst({
// where: and(eq(schema.keys.id, props.params.keyId), isNull(schema.keys.deletedAt)),
// with: {
// workspace: true,
// },
// });
// if (!key || key.workspace.tenantId !== tenantId) {
// return notFound();
// }
// const api = await db.query.apis.findFirst({
// where: (table, { eq, and, isNull }) =>
// and(eq(table.keyAuthId, key.keyAuthId), isNull(table.deletedAt)),
// });
// if (!api) {
// return notFound();
// }
const api = {
id: "string",
workspaceId: "string",
name: "string",
ipWhitelist: "string",
}
const key = {
id: "string",
workspaceId: "string",
name: "string",
environment: "string",
}
const navigation = [
{
label: "Overview",
href: `/app/keys/${props.params.keyAuthId}/${props.params.keyId}`,
segment: null,
},
{
label: "Settings",
href: `/app/keys/${props.params.keyAuthId}/${props.params.keyId}/settings`,
segment: "settings",
},
{
label: "Permissions",
href: `/app/keys/${props.params.keyAuthId}/${props.params.keyId}/permissions`,
segment: "permissions",
},
{ label: "API", href: `/app/apis/${api.id}`, segment: api.id },
];
return (
<div>
<PageHeader
title={key.name ?? key.id}
actions={[
<Badge
key="keyId"
variant="secondary"
className="flex justify-between w-full gap-2 font-mono font-medium ph-no-capture"
>
{key.id}
<CopyButton value={key.id} />
</Badge>,
key.environment ? (
<Badge key="environment" variant="secondary">
{key.environment}
</Badge>
) : null,
]}
/>
<Navbar navigation={navigation} />
<main className="mt-8 mb-20">{props.children}</main>
</div>
);
}