import React, { useState } from 'react'; import { View, Text, Modal, TouchableOpacity, TextInput, ScrollView, Alert } from 'react-native'; import DateTimePicker, { DateType, useDefaultStyles } from 'react-native-ui-datepicker'; import { TimeOffRequest, TimeOffRequestType } from '@/types/types'; import { X } from 'lucide-react-native'; import { TimePickerModal } from './TimePickerModal'; import api from '@/utils/api'; interface RequestPermitModalProps { visible: boolean; types: TimeOffRequestType[]; onClose: () => void; onSubmit: (data: any) => void; } export default function RequestPermitModal({ visible, types, onClose, onSubmit }: RequestPermitModalProps) { const defaultStyles = useDefaultStyles(); const [type, setType] = useState(types[0]); // Default to first type const [date, setDate] = useState(); const [range, setRange] = useState<{ startDate: DateType; endDate: DateType; }>({ startDate: undefined, endDate: undefined }); const [showStartPicker, setShowStartPicker] = useState(false); const [showEndPicker, setShowEndPicker] = useState(false); const [startTime, setStartTime] = useState(''); const [endTime, setEndTime] = useState(''); // Funzione per resettare le selezioni di data const clearCalendar = () => { setDate(undefined); setRange({ startDate: undefined, endDate: undefined }); setStartTime(''); setEndTime(''); setType(types[0]); }; const saveRequest = async (requestData: any) => { try { // Chiamata API per salvare la richiesta const response = await api.post('/time-off-request/save-request', requestData); Alert.alert('Successo', 'La tua richiesta è stata inviata con successo.'); } catch (error) { console.error('Errore nell\'invio della richiesta:', error); Alert.alert('Errore', 'Impossibile inviare la richiesta. Riprova più tardi.'); } }; // Funzione per inviare la richiesta const handleSubmit = ( type: TimeOffRequestType | undefined, date: DateType | undefined, range: { startDate: DateType | undefined; endDate: DateType | undefined }, startTime: string, endTime: string ) => { if (!type) { alert('Seleziona una tipologia di assenza.'); return; } // Validazioni if (type.time_required === 0) { if (!range.startDate && !range.endDate) { alert('Seleziona almeno una data.'); return; } } else { if (!date) { alert('Seleziona una data.'); return; } if (!startTime || !endTime) { alert('Seleziona l\'orario di inizio e fine.'); return; } else if (startTime >= endTime) { alert('L\'orario di fine deve essere successivo all\'orario di inizio.'); return; } } // Costruzione oggetto request const requestData = { id_type: type.id, start_date: type.time_required === 0 ? range.startDate : date, end_date: type.time_required === 0 ? range.endDate : null, start_time: type.time_required === 1 ? startTime : null, end_time: type.time_required === 1 ? endTime : null, }; saveRequest(requestData); onSubmit(requestData); onClose(); }; return ( {/* Header Modale */} Nuova Richiesta {/* Tipologia */} Tipologia Assenza {types.map((t) => ( setType(t)} className={`py-4 px-5 rounded-xl border-2 items-center justify-center ${type?.id === t.id ? 'border-[#099499] bg-teal-50' : 'border-gray-100 bg-white' }`} > {t.name} ))} {/* Date and Time Selection */} {type?.time_required === 0 ? ( setRange(params)} timeZone='Universal' locale='it' styles={{ ...defaultStyles, selected: { backgroundColor: '#099499' } }} /> ) : ( setDate(date)} timeZone='Universal' locale='it' styles={{ ...defaultStyles, selected: { backgroundColor: '#099499' } }} /> Dalle Ore setShowStartPicker(true)}> Alle Ore setShowEndPicker(true)}> )} setStartTime(time)} onClose={() => setShowStartPicker(false)} /> setEndTime(time)} onClose={() => setShowEndPicker(false)} /> { clearCalendar(); onClose(); }} className="flex-1 py-4 bg-gray-200 rounded-2xl shadow-sm active:bg-gray-300" > Annulla Richiesta { handleSubmit(type, date, range, startTime, endTime); }} className="flex-1 py-4 bg-[#099499] rounded-2xl shadow-lg active:scale-[0.98]" > Invia Richiesta ); };