mirror of
https://github.com/spliit-app/spliit.git
synced 2026-02-28 02:16:12 +01:00
58 lines
1.4 KiB
TypeScript
58 lines
1.4 KiB
TypeScript
import { GroupTabs } from '@/app/groups/[groupId]/group-tabs'
|
|
import { SaveGroupLocally } from '@/app/groups/[groupId]/save-recent-group'
|
|
import { ShareButton } from '@/app/groups/[groupId]/share-button'
|
|
import { getGroup } from '@/lib/api'
|
|
import { Metadata } from 'next'
|
|
import Link from 'next/link'
|
|
import { notFound } from 'next/navigation'
|
|
import { PropsWithChildren, ReactNode } from 'react'
|
|
|
|
type Props = {
|
|
params: {
|
|
groupId: string
|
|
}
|
|
modal: ReactNode
|
|
}
|
|
|
|
export async function generateMetadata({
|
|
params: { groupId },
|
|
}: Props): Promise<Metadata> {
|
|
const group = await getGroup(groupId)
|
|
|
|
return {
|
|
title: {
|
|
default: group?.name ?? '',
|
|
template: `%s · ${group?.name} · Spliit`,
|
|
},
|
|
}
|
|
}
|
|
|
|
export default async function GroupLayout({
|
|
children,
|
|
modal,
|
|
params: { groupId },
|
|
}: PropsWithChildren<Props>) {
|
|
const group = await getGroup(groupId)
|
|
if (!group) notFound()
|
|
|
|
return (
|
|
<>
|
|
<div className="flex flex-col sm:flex-row justify-between sm:items-center gap-3">
|
|
<h1 className="font-bold text-2xl">
|
|
<Link href={`/groups/${groupId}`}>{group.name}</Link>
|
|
</h1>
|
|
|
|
<div className="flex gap-2 justify-between">
|
|
<GroupTabs groupId={groupId} />
|
|
<ShareButton group={group} />
|
|
</div>
|
|
</div>
|
|
|
|
{children}
|
|
{modal}
|
|
|
|
<SaveGroupLocally group={{ id: group.id, name: group.name }} />
|
|
</>
|
|
)
|
|
}
|