mirror of
https://github.com/gethomepage/homepage.git
synced 2026-01-10 10:32:09 +08:00
* Feature: Added agenda view for calendar, calendar improvements * Fix duplicate event keys * Additional hover on title, not date * Show date once in list * Rename monthly view for consistency * Remove unneeded key props * CSS cleanup, dont slice title to arbitrary 42 chars which can break column layouts * Simplify agenda components * Fix show date once in list --------- Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
42 lines
1.4 KiB
JavaScript
42 lines
1.4 KiB
JavaScript
import { DateTime } from "luxon";
|
|
import { useEffect, useContext } from "react";
|
|
|
|
import useWidgetAPI from "../../../utils/proxy/use-widget-api";
|
|
import { EventContext } from "../../../utils/contexts/calendar";
|
|
import Error from "../../../components/services/widget/error";
|
|
|
|
export default function Integration({ config, params }) {
|
|
const { setEvents } = useContext(EventContext);
|
|
const { data: readarrData, error: readarrError } = useWidgetAPI(config, "calendar", {
|
|
...params,
|
|
includeAuthor: "true",
|
|
...(config?.params ?? {}),
|
|
});
|
|
|
|
useEffect(() => {
|
|
if (!readarrData || readarrError) {
|
|
return;
|
|
}
|
|
|
|
const eventsToAdd = {};
|
|
|
|
readarrData?.forEach((event) => {
|
|
const authorName = event.author?.authorName ?? event.authorTitle.replace(event.title, "");
|
|
const title = `${authorName} - ${event.title} ${event?.seriesTitle ? `(${event.seriesTitle})` : ""} `;
|
|
|
|
eventsToAdd[title] = {
|
|
title,
|
|
date: DateTime.fromISO(event.releaseDate),
|
|
color: config?.color ?? "rose",
|
|
isCompleted: event.grabbed,
|
|
additional: "",
|
|
};
|
|
});
|
|
|
|
setEvents((prevEvents) => ({ ...prevEvents, ...eventsToAdd }));
|
|
}, [readarrData, readarrError, config, setEvents]);
|
|
|
|
const error = readarrError ?? readarrData?.error;
|
|
return error && <Error error={{ message: `${config.type}: ${error.message ?? error}` }} />;
|
|
}
|