mirror of
https://github.com/felipegcoutinho/openmonetis.git
synced 2026-05-09 11:01:45 +00:00
Todas as queries cacheadas do dashboard migram de `unstable_cache` para
a diretiva `use cache` com `cacheTag` e `cacheLife({ revalidate: 3 })`.
Todas as páginas e o layout do dashboard passam a chamar `connection()`
para garantir renderização dinâmica. O root layout envolve os filhos em
`<Suspense>`. `next.config.ts` remove `turbopackFileSystemCacheForDev`
e adota `cacheComponents: true`.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
42 lines
1.6 KiB
TypeScript
42 lines
1.6 KiB
TypeScript
import { connection } from "next/server";
|
|
import { DashboardGridEditable } from "@/features/dashboard/components/dashboard-grid-editable";
|
|
import { DashboardMetricsCards } from "@/features/dashboard/components/dashboard-metrics-cards";
|
|
import { DashboardWelcome } from "@/features/dashboard/components/dashboard-welcome";
|
|
import { fetchDashboardPageData } from "@/features/dashboard/page-data-queries";
|
|
import { getSingleParam } from "@/features/transactions/page-helpers";
|
|
import MonthNavigation from "@/shared/components/month-picker/month-navigation";
|
|
import { getUser } from "@/shared/lib/auth/server";
|
|
import { parsePeriodParam } from "@/shared/utils/period";
|
|
|
|
type PageSearchParams = Promise<Record<string, string | string[] | undefined>>;
|
|
|
|
type PageProps = {
|
|
searchParams?: PageSearchParams;
|
|
};
|
|
|
|
export default async function Page({ searchParams }: PageProps) {
|
|
await connection();
|
|
const user = await getUser();
|
|
const resolvedSearchParams = searchParams ? await searchParams : undefined;
|
|
const periodoParam = getSingleParam(resolvedSearchParams, "periodo");
|
|
const { period: selectedPeriod } = parsePeriodParam(periodoParam);
|
|
|
|
const { dashboardData, preferences, quickActionOptions } =
|
|
await fetchDashboardPageData(user.id, selectedPeriod);
|
|
const { dashboardWidgets } = preferences;
|
|
|
|
return (
|
|
<main className="flex flex-col gap-4">
|
|
<DashboardWelcome name={user.name} />
|
|
<MonthNavigation />
|
|
<DashboardMetricsCards metrics={dashboardData.metrics} />
|
|
<DashboardGridEditable
|
|
data={dashboardData}
|
|
period={selectedPeriod}
|
|
initialPreferences={dashboardWidgets}
|
|
quickActionOptions={quickActionOptions}
|
|
/>
|
|
</main>
|
|
);
|
|
}
|