import { useAlert } from '@/components/AlertComponent'; import React, { JSX, useEffect, useMemo, useState } from 'react'; import { Calendar as CalendarIcon, CalendarX, Clock, Plus, Thermometer } from 'lucide-react-native'; import { ScrollView, Text, TouchableOpacity, View, ActivityIndicator, RefreshControl } from 'react-native'; import { TimeOffRequest, TimeOffRequestType } from '@/types/types'; import RequestPermitModal from '@/components/RequestPermitModal'; import CalendarWidget from '@/components/CalendarWidget'; import LoadingScreen from '@/components/LoadingScreen'; import api from '@/utils/api'; import { formatDate, formatTime } from '@/utils/dateTime'; // Icon Mapping const typeIcons: Record JSX.Element> = { Ferie: (color) => , Permesso: (color) => , Malattia: (color) => , Assenza: (color) => , }; export default function PermitsScreen() { const [showModal, setShowModal] = useState(false); const alert = useAlert(); const [permits, setPermits] = useState([]); const [types, setTypes] = useState([]); const [currentMonthDate, setCurrentMonthDate] = useState(new Date()); const [isLoading, setIsLoading] = useState(true); const [refreshing, setRefreshing] = useState(false); const fetchPermits = async () => { try { if (!refreshing) setIsLoading(true); // Fetch Permits const response = await api.get('/time-off-request/list'); setPermits(response.data); // Fetch Types const typesResponse = await api.get('/time-off-request/get-types'); setTypes(typesResponse.data); } catch (error) { console.error('Errore nel recupero dei permessi:', error); alert.showAlert('error', 'Errore', 'Impossibile recuperare i permessi. Riprova più tardi.'); } finally { setIsLoading(false); setRefreshing(false); } }; const filteredPermits = useMemo(() => { if (!permits.length) return []; // Calcoliamo inizio e fine del mese visualizzato const year = currentMonthDate.getFullYear(); const month = currentMonthDate.getMonth(); const startOfMonth = new Date(year, month, 1); // Trucco JS: giorno 0 del mese successivo = ultimo giorno del mese corrente const endOfMonth = new Date(year, month + 1, 0, 23, 59, 59); return permits.filter(item => { const itemStart = new Date(item.start_date?.toString() ?? ''); // Se non c'è end_date, assumiamo sia un giorno singolo (quindi end = start) const itemEnd = item.end_date ? new Date(item.end_date?.toString() ?? '') : new Date(item.start_date?.toString() ?? ''); // FORMULA OVERLAP: // Il permesso è visibile se inizia prima della fine del mese // E finisce dopo l'inizio del mese. return itemStart <= endOfMonth && itemEnd >= startOfMonth; }); }, [permits, currentMonthDate]); useEffect(() => { fetchPermits(); }, []); const onRefresh = () => { setRefreshing(true); fetchPermits(); }; if (isLoading && !refreshing) { return ; } return ( setShowModal(false)} onSubmit={(data) => { console.log('Richiesta:', data); fetchPermits(); }} /> {/* Header */} Ferie e Permessi Gestisci le tue assenze } > {/* Calendar Widget */} setCurrentMonthDate(date)} /> {/* Lista Richieste Recenti */} {filteredPermits.length === 0 ? ( Nessuna richiesta di permesso questo mese ) : ( Le tue richieste {filteredPermits.map((item) => ( {typeIcons[item.timeOffRequestType.name]?.(item.timeOffRequestType.color)} {item.timeOffRequestType.name} {formatDate(item.start_date?.toLocaleString())} {item.end_date ? `- ${formatDate(item.end_date.toLocaleString())}` : ''} {item.timeOffRequestType.name === 'Permesso' && ( {formatTime(item.start_time)} - {formatTime(item.end_time)} )} {/* TODO: Aggiungere funzionalità per modificare/eliminare la richiesta? */} {item.status ? 'Approvato' : 'In Attesa'} ))} )} {/* 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" > ); }