MeetUp/src/app/(main)/blocker/page.tsx
Dominik Stahl 3d07ca077f
All checks were successful
container-scan / Container Scan (pull_request) Successful in 2m34s
docker-build / docker (pull_request) Successful in 3m57s
tests / Tests (pull_request) Successful in 3m30s
feat(slot blocking): add buttons to sidebar
2025-07-01 00:09:37 +02:00

56 lines
1.9 KiB
TypeScript

'use client';
import { RedirectButton } from '@/components/buttons/redirect-button';
import BlockedSlotListEntry from '@/components/custom-ui/blocked-slot-list-entry';
import { Label } from '@/components/ui/label';
import { useGetApiBlockedSlots } from '@/generated/api/blocked-slots/blocked-slots';
export default function BlockedSlots() {
const { data: blockedSlotsData, isLoading, error } = useGetApiBlockedSlots();
if (isLoading) return <div className='text-center mt-10'>Loading...</div>;
if (error)
return (
<div className='text-center mt-10 text-red-500'>
Error loading blocked slots
</div>
);
const blockedSlots = blockedSlotsData?.data?.blocked_slots || [];
return (
<div className='relative h-full flex flex-col items-center'>
{/* Heading */}
<h1 className='text-3xl font-bold mt-8 mb-4 text-center z-10'>
My Blockers
</h1>
{/* Scrollable blocked slot list */}
<div className='w-full flex justify-center overflow-hidden'>
<div className='grid gap-8 w-[max(90%, 500px)] p-6 overflow-y-auto'>
{blockedSlots.length > 0 ? (
blockedSlots.map((slot) => (
<BlockedSlotListEntry
key={slot.id}
{...slot}
updated_at={new Date(slot.updated_at)}
created_at={new Date(slot.created_at)}
/>
))
) : (
<div className='flex flex-1 flex-col items-center justify-center min-h-[300px]'>
<Label size='large' className='justify-center text-center'>
You don&#39;t have any blockers right now
</Label>
<RedirectButton
redirectUrl='/blocker/new'
buttonText='Create New Blocker'
className='mt-4'
/>
</div>
)}
</div>
</div>
</div>
);
}