calendar 19

This commit is contained in:
Alma 2025-04-13 15:30:00 +02:00
parent b456778234
commit 24f6751517

View File

@ -486,7 +486,29 @@ export function CalendarClient({ initialCalendars, userId, userProfile }: Calend
const response = await fetch("/api/calendars");
if (!response.ok) throw new Error("Failed to fetch calendars");
const data = await response.json();
console.log("Fetched calendars:", data); // Debug log
console.log("Fetched calendars:", data);
// Create principal calendar if it doesn't exist
if (data.length === 0 || !data.some((cal: Calendar) => cal.name === "Calendrier principal")) {
const principalCalendar = await fetch("/api/calendars", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
name: "Calendrier principal",
color: "#4f46e5",
description: "Calendrier principal",
userId,
}),
});
if (principalCalendar.ok) {
const newData = await principalCalendar.json();
data.push(newData);
}
}
setCalendars(data.map((cal: Calendar & { events: Event[] }) => ({
...cal,
events: cal.events || []
@ -624,7 +646,13 @@ export function CalendarClient({ initialCalendars, userId, userProfile }: Calend
const savedEvent = await response.json();
console.log("Event saved successfully:", savedEvent);
// Refresh calendars and update the view
await fetchCalendars();
if (calendarRef.current) {
const calendarApi = calendarRef.current.getApi();
calendarApi.refetchEvents();
}
setIsEventModalOpen(false);
setEventForm({
title: "",
@ -910,6 +938,18 @@ export function CalendarClient({ initialCalendars, userId, userProfile }: Calend
className="w-full rounded-md border border-gray-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-primary"
placeholderText="Sélectionner la date et l'heure"
customInput={<Input />}
showTimeSelectOnly={false}
inline={false}
timeClassName={() => "text-primary"}
popperModifiers={[
{
name: "preventOverflow",
options: {
padding: 10
}
}
]}
popperPlacement="bottom-start"
/>
</div>
</div>
@ -930,6 +970,18 @@ export function CalendarClient({ initialCalendars, userId, userProfile }: Calend
placeholderText="Sélectionner la date et l'heure"
minDate={getDateFromString(eventForm.start)}
customInput={<Input />}
showTimeSelectOnly={false}
inline={false}
timeClassName={() => "text-primary"}
popperModifiers={[
{
name: "preventOverflow",
options: {
padding: 10
}
}
]}
popperPlacement="bottom-start"
/>
</div>
</div>