import { BedDouble, Plus } from 'lucide-react'; import { getTranslations } from 'next-intl/server'; import { createBookingManagementApi } from '@kit/booking-management/api'; import { formatCurrencyAmount } from '@kit/shared/dates'; import { getSupabaseServerClient } from '@kit/supabase/server-client'; import { Badge } from '@kit/ui/badge'; import { Button } from '@kit/ui/button'; import { Card, CardContent, CardHeader, CardTitle } from '@kit/ui/card'; import { AccountNotFound } from '~/components/account-not-found'; import { CmsPageShell } from '~/components/cms-page-shell'; import { EmptyState } from '~/components/empty-state'; interface PageProps { params: Promise<{ account: string }>; } export default async function RoomsPage({ params }: PageProps) { const { account } = await params; const client = getSupabaseServerClient(); const t = await getTranslations('bookings'); const { data: acct } = await client .from('accounts') .select('id') .eq('slug', account) .single(); if (!acct) { return ( ); } const api = createBookingManagementApi(client); const rooms = await api.listRooms(acct.id); return (

{t('rooms.manage')}

{rooms.length === 0 ? ( } title={t('rooms.noRooms')} description={t('rooms.addFirst')} actionLabel={t('rooms.newRoom')} /> ) : ( {t('rooms.allRooms', { count: rooms.length })}
{rooms.map((room: Record) => ( ))}
{t('rooms.roomNumber')} {t('rooms.name')} {t('rooms.type')} {t('rooms.capacity')} {t('rooms.price')} {t('rooms.active')}
{String(room.room_number ?? '—')} {String(room.name ?? '—')} {String(room.room_type ?? '—')} {String(room.capacity ?? '—')} {room.price_per_night != null ? formatCurrencyAmount( room.price_per_night as number, ) : '—'} {room.is_active !== false ? '✓' : '✗'}
)}
); }