Use React’s cache to avoid some queries to the database

This commit is contained in:
Sebastien Castiel
2024-01-29 22:37:13 -05:00
parent 3847a67a19
commit 9e300e0ff0
8 changed files with 40 additions and 15 deletions

View File

@@ -1,3 +1,4 @@
import { cached } from '@/app/cached-functions'
import { ActiveUserModal } from '@/app/groups/[groupId]/expenses/active-user-modal'
import { ExpenseList } from '@/app/groups/[groupId]/expenses/expense-list'
import { Button } from '@/components/ui/button'
@@ -9,13 +10,15 @@ import {
CardTitle,
} from '@/components/ui/card'
import { Skeleton } from '@/components/ui/skeleton'
import { getGroup, getGroupExpenses } from '@/lib/api'
import { getGroupExpenses } from '@/lib/api'
import { Download, Plus } from 'lucide-react'
import { Metadata } from 'next'
import Link from 'next/link'
import { notFound } from 'next/navigation'
import { Suspense } from 'react'
export const revalidate = 3600
export const metadata: Metadata = {
title: 'Expenses',
}
@@ -25,7 +28,7 @@ export default async function GroupExpensesPage({
}: {
params: { groupId: string }
}) {
const group = await getGroup(groupId)
const group = await cached.getGroup(groupId)
if (!group) notFound()
return (
@@ -84,7 +87,7 @@ export default async function GroupExpensesPage({
}
async function Expenses({ groupId }: { groupId: string }) {
const group = await getGroup(groupId)
const group = await cached.getGroup(groupId)
if (!group) notFound()
const expenses = await getGroupExpenses(group.id)