import React, { useState } from 'react'; import { PERMITS_DATA } from '@/data/data'; import { Calendar as CalendarIcon, ChevronLeft, ChevronRight, Clock, Plus, Thermometer, X } from 'lucide-react-native'; import { ScrollView, Text, TouchableOpacity, View } from 'react-native'; import RequestPermitModal from '@/components/RenamePermitModal'; export default function PermitsScreen() { const [currentDate, setCurrentDate] = useState(new Date(2025, 11, 1)); // Dicembre 2025 Mock const [showModal, setShowModal] = useState(false); // Helpers per il calendario const daysInMonth = new Date(currentDate.getFullYear(), currentDate.getMonth() + 1, 0).getDate(); const firstDayOfMonth = new Date(currentDate.getFullYear(), currentDate.getMonth(), 1).getDay(); // 0 = Sun const adjustedFirstDay = firstDayOfMonth === 0 ? 6 : firstDayOfMonth - 1; // 0 = Mon const getEventForDay = (day: number) => { const dateStr = `${currentDate.getFullYear()}-${String(currentDate.getMonth() + 1).padStart(2, '0')}-${String(day).padStart(2, '0')}`; return PERMITS_DATA.find(leave => { if (leave.type === 'Permesso') return leave.startDate === dateStr; return dateStr >= leave.startDate && dateStr <= (leave.endDate || leave.startDate); }); }; const weekDays = ['Lun', 'Mar', 'Mer', 'Gio', 'Ven', 'Sab', 'Dom']; return ( setShowModal(false)} onSubmit={(data) => console.log('Richiesta:', data)} /> {/* Header */} Ferie e Permessi Gestisci le tue assenze {/* Calendar Widget */} {currentDate.toLocaleString('it-IT', { month: 'long', year: 'numeric' })} {/* Week Header */} {weekDays.map(day => ( {day} ))} {/* Days Grid */} {/* Empty slots for alignment */} {Array.from({ length: adjustedFirstDay }).map((_, i) => ( ))} {/* Days */} {Array.from({ length: daysInMonth }).map((_, i) => { const day = i + 1; const event = getEventForDay(day); let bgClass = 'bg-transparent'; let textClass = 'text-gray-700'; let borderClass = 'border-transparent'; if (event) { if (event.type === 'Ferie') { bgClass = 'bg-purple-100'; textClass = 'text-purple-700 font-bold'; borderClass = 'border-purple-200'; } else if (event.type === 'Permesso') { bgClass = 'bg-orange-100'; textClass = 'text-orange-700 font-bold'; borderClass = 'border-orange-200'; } else if (event.type === 'Malattia') { bgClass = 'bg-red-100'; textClass = 'text-red-700 font-bold'; borderClass = 'border-red-200'; } } return ( {day} ); })} {/* Legenda */} Ferie Permessi Malattia {/* Lista Richieste Recenti */} Le tue richieste {PERMITS_DATA.map((item) => ( {item.type === 'Ferie' && } {item.type === 'Permesso' && } {item.type === 'Malattia' && } {item.type} {item.startDate} {item.endDate ? `- ${item.endDate}` : ''} {item.type === 'Permesso' && ( {item.startTime} - {item.endTime} )} {item.status} ))} {/* FAB */} setShowModal(true)} className="absolute bottom-8 right-6 w-16 h-16 bg-[#099499] rounded-full shadow-lg items-center justify-center active:scale-90" > ); }