diff --git a/src/pages/calendar/Schedule.tsx b/src/pages/calendar/Schedule.tsx index 85be941..52d758d 100644 --- a/src/pages/calendar/Schedule.tsx +++ b/src/pages/calendar/Schedule.tsx @@ -1,7 +1,7 @@ import ICAL from "ical.js" import dayjs from "dayjs" import { useEffect, useMemo, useRef, useState } from "react" -import { Alert, Button, Calendar, Link, Spinner } from "@heroui/react" +import { Alert, Button, Calendar, Link, Spinner, Select, SelectItem } from "@heroui/react" import { today, getLocalTimeZone } from "@internationalized/date" import "dayjs/locale/zh-cn" @@ -83,7 +83,8 @@ const extractScheduleEvents = (icalComp: ICAL.Component): ScheduleEvent[] => { end: event.endDate.toJSDate(), summary: event.summary, description: event.description, - recurrenceId: "123", + recurrenceId: event.uid || event.startDate.toString(), + }] } return expandEventOccurrences(event, rangeEnd) @@ -109,6 +110,12 @@ export default function Schedule() { const calendarRef = useRef(null) const [loading, setLoading] = useState(true) + const currentYear = focusedDate.year + const currentMonth = focusedDate.month + + const years = Array.from({ length: 10 }, (_, i) => currentYear - 5 + i) + const months = Array.from({ length: 12 }, (_, i) => i + 1) + useEffect(() => { const rangeStart = ICAL.Time.fromJSDate(dayjs(focusedDate.toDate(getLocalTimeZone())).startOf("month").toDate()) const rangeEnd = ICAL.Time.fromJSDate(dayjs(focusedDate.toDate(getLocalTimeZone())).endOf("month").toDate()) @@ -191,6 +198,54 @@ export default function Schedule() {
日程
+ + {/* Mobile Date Selector */} +
+
+ + +
+