/* Copyright (C) 2024 Manuel Bustillo*/ 'use client'; import { loadGroups } from '@/app/api/groups'; import { loadGuests } from '@/app/api/guests'; import { Group, Guest } from '@/app/lib/definitions'; import { classNames } from '@/app/ui/components/button'; import GuestFormDialog from '@/app/ui/components/guest-form-dialog'; import GroupsTable from '@/app/ui/groups/table'; import SkeletonTable from '@/app/ui/guests/skeleton-row'; import GuestsTable from '@/app/ui/guests/table'; import { TabPanel, TabView } from 'primereact/tabview'; import { Suspense, useState } from 'react'; export default function Page() { function refreshGuests() { loadGuests((guests) => { setGuests(guests); setGuestsLoaded(true); }); } function refreshGroups() { loadGroups((groups) => { setGroups(groups); setGroupsLoaded(true); }); } const [groupsLoaded, setGroupsLoaded] = useState(false); const [groups, setGroups] = useState>([]); const [guestsLoaded, setGuestsLoaded] = useState(false); const [guests, setGuests] = useState>([]); const [guestBeingEdited, setGuestBeingEdited] = useState(undefined); !groupsLoaded && refreshGroups(); !guestsLoaded && refreshGuests(); return (
{ refreshGuests(); setGuestBeingEdited(undefined) }} guest={guestBeingEdited} visible={guestBeingEdited !== undefined} onHide={() => { setGuestBeingEdited(undefined) }} /> }> setGuestBeingEdited(guest)} />
}>
); }