import React, { useState } from 'react'; import { StyleSheet, Modal } from 'react-native'; import { ThemedText, ThemedView } from '@/components/theme/Theme'; import DateTimePicker from '@react-native-community/datetimepicker'; import { Countdown, User } from '@/constants/Types'; import { setCountdown } from '@/constants/APIs'; import TextButton from '@/components/theme/buttons/TextButton'; type ChangeDateModalProps = { user: User; isVisible: boolean; onClose: () => void; onDateChange: (date: Date) => void; currentCountdown?: Countdown; }; const ChangeDateModal = ({ user, isVisible, onClose, onDateChange, currentCountdown }: ChangeDateModalProps) => { const [date, setDate] = useState(currentCountdown ? new Date(currentCountdown.date) : new Date()); const handleDateChange = (event: any, selectedDate?: Date) => { const currentDate = selectedDate ?? date; setDate(currentDate); }; const handleTimeChange = (event: any, selectedTime?: Date) => { const currentTime = selectedTime ?? date; setDate(currentTime); }; const handleSave = async () => { try { let updatedCountdown: Countdown; if (currentCountdown) { updatedCountdown = { ...currentCountdown, date: date }; await setCountdown(user.id, updatedCountdown); onDateChange(date); onClose(); } } catch (error) { console.error('Error saving countdown:', error); } }; return ( Set New Countdown ); }; export default ChangeDateModal; const styles = StyleSheet.create({ centeredView: { flex: 1, justifyContent: 'center', alignItems: 'center', backgroundColor: 'transparent', }, modalView: { margin: 10, padding: 35, borderRadius: 40, alignItems: 'center', shadowColor: '#000', shadowOffset: { width: 0, height: 2, }, shadowOpacity: 0.25, shadowRadius: 3.84, elevation: 5, width: '80%', }, modalText: { marginBottom: 20, textAlign: 'center', fontWeight: 'bold', fontSize: 24, lineHeight: 32, }, container: { flexDirection: 'row', justifyContent: 'space-between', alignItems: 'center', margin: 'auto', marginBottom: 20, backgroundColor: 'transparent', }, buttonContainer: { flexDirection: 'row', justifyContent: 'space-between', alignItems: 'center', margin: 'auto', backgroundColor: 'transparent', }, dateContainer: { width: '50%', justifyContent: 'center', alignItems: 'center', margin: 'auto', backgroundColor: 'transparent', }, timeContainer: { width: '50%', justifyContent: 'center', alignItems: 'center', backgroundColor: 'transparent', minWidth: 120, }, });