2024-11-15 19:44:26 +03:00

37 lines
1.3 KiB
TypeScript

import {
LatestInvoicesSkeleton,
RevenueChartSkeleton,
} from "@/app/[lang]/dashboard/components/server/skeletons/skeletons";
import CardWrapper from "@/app/[lang]/dashboard/components/server/cards/cards";
import LatestInvoices from "@/app/[lang]/dashboard/components/server/latest-invoices/latest-invoices";
import RevenueChart from "@/app/[lang]/dashboard/components/server/revenue-chart/revenue-chart";
import { Suspense } from "react";
import { getServerTranslation } from "@/bootstrap/i18n/i18n";
import langKey from "@/bootstrap/i18n/dictionaries/lang-key";
export default async function Dashboard(props: {
params: Promise<{ lang: string }>;
}) {
const { params } = props;
const { lang } = await params;
const { t } = await getServerTranslation(lang);
return (
<main>
<h1 className="mb-4 text-xl md:text-2xl">
{t(langKey.global.dashboard)}
</h1>
<div className="grid gap-6 sm:grid-cols-2 lg:grid-cols-4">
<CardWrapper />
</div>
<div className="mt-6 grid grid-cols-1 gap-6 md:grid-cols-4 lg:grid-cols-8">
<Suspense fallback={<RevenueChartSkeleton />}>
<RevenueChart />
</Suspense>
<Suspense fallback={<LatestInvoicesSkeleton />}>
<LatestInvoices />
</Suspense>
</div>
</main>
);
}