mirror of
https://github.com/michivonah/nextjs.git
synced 2025-12-22 14:06:29 +01:00
35 lines
No EOL
1.3 KiB
TypeScript
35 lines
No EOL
1.3 KiB
TypeScript
import { Card } from '@/app/ui/dashboard/cards'
|
|
import RevenueChart from '../../ui/dashboard/revenue-chart';
|
|
import LatestInvoices from '../../ui/dashboard/latest-invoices';
|
|
import { lusitana } from '../../ui/fonts';
|
|
import { Suspense } from 'react';
|
|
import { RevenueChartSkeleton, LatestInvoicesSkeleton, CardsSkeleton, CardSkeleton} from '@/app/ui/skeletons';
|
|
import CardWrapper from '@/app/ui/dashboard/cards';
|
|
import { Metadata } from 'next';
|
|
|
|
export const metadata: Metadata = {
|
|
title: 'Dashboard',
|
|
};
|
|
|
|
export default async function Page(){
|
|
return (
|
|
<main>
|
|
<h1 className={`${lusitana.className} mb-4 text-xl md:text-2x1`}>
|
|
Dashboard
|
|
</h1>
|
|
<div className='grid gap-6 sm: grid-cols-2 lg:grid-cols-4'>
|
|
<Suspense fallback={<CardSkeleton />}>
|
|
<CardWrapper />
|
|
</Suspense>
|
|
</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>
|
|
);
|
|
} |