import { useState, useEffect, useRef } from 'react'; import { motion, AnimatePresence } from 'framer-motion'; import { Clock, MapPin, Users, ChevronLeft, ChevronRight, ChevronDown } from 'lucide-react'; import { schedules } from '../../data/dummy'; function Schedule() { const [currentDate, setCurrentDate] = useState(new Date()); const [selectedDate, setSelectedDate] = useState(null); const [showYearMonthPicker, setShowYearMonthPicker] = useState(false); const pickerRef = useRef(null); // 외부 클릭시 팝업 닫기 useEffect(() => { const handleClickOutside = (event) => { if (pickerRef.current && !pickerRef.current.contains(event.target)) { setShowYearMonthPicker(false); } }; if (showYearMonthPicker) { document.addEventListener('mousedown', handleClickOutside); } return () => { document.removeEventListener('mousedown', handleClickOutside); }; }, [showYearMonthPicker]); // 달력 관련 함수 const getDaysInMonth = (year, month) => new Date(year, month + 1, 0).getDate(); const getFirstDayOfMonth = (year, month) => new Date(year, month, 1).getDay(); const year = currentDate.getFullYear(); const month = currentDate.getMonth(); const daysInMonth = getDaysInMonth(year, month); const firstDay = getFirstDayOfMonth(year, month); const days = ['일', '월', '화', '수', '목', '금', '토']; // 스케줄이 있는 날짜 목록 const scheduleDates = schedules.map(s => s.date); const hasSchedule = (day) => { const dateStr = `${year}-${String(month + 1).padStart(2, '0')}-${String(day).padStart(2, '0')}`; return scheduleDates.includes(dateStr); }; const prevMonth = () => { setCurrentDate(new Date(year, month - 1, 1)); }; const nextMonth = () => { setCurrentDate(new Date(year, month + 1, 1)); }; const selectDate = (day) => { const dateStr = `${year}-${String(month + 1).padStart(2, '0')}-${String(day).padStart(2, '0')}`; if (hasSchedule(day)) { setSelectedDate(selectedDate === dateStr ? null : dateStr); } }; const selectYearMonth = (newYear, newMonth) => { setCurrentDate(new Date(newYear, newMonth, 1)); setShowYearMonthPicker(false); }; // 필터링된 스케줄 const filteredSchedules = selectedDate ? schedules.filter(s => s.date === selectedDate) : schedules; const formatDate = (dateStr) => { const date = new Date(dateStr); const dayNames = ['일', '월', '화', '수', '목', '금', '토']; return { month: date.getMonth() + 1, day: date.getDate(), weekday: dayNames[date.getDay()], }; }; // 년도 범위 (현재 년도 기준 ±5년) const currentYear = new Date().getFullYear(); const yearRange = Array.from({ length: 11 }, (_, i) => currentYear - 5 + i); return (
년도
월