You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
50 lines
1.7 KiB
50 lines
1.7 KiB
import { DateTime } from "luxon";
|
|
import { useEffect, useContext } from "react";
|
|
import { useTranslation } from "next-i18next";
|
|
|
|
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 { t } = useTranslation();
|
|
const { setEvents } = useContext(EventContext);
|
|
const { data: radarrData, error: radarrError } = useWidgetAPI(config, "calendar",
|
|
{ ...params, ...config?.params ?? {} }
|
|
);
|
|
useEffect(() => {
|
|
if (!radarrData || radarrError) {
|
|
return;
|
|
}
|
|
|
|
const eventsToAdd = {};
|
|
|
|
radarrData?.forEach(event => {
|
|
const cinemaTitle = `${event.title} - ${t("calendar.inCinemas")}`;
|
|
const physicalTitle = `${event.title} - ${t("calendar.physicalRelease")}`;
|
|
const digitalTitle = `${event.title} - ${t("calendar.digitalRelease")}`;
|
|
|
|
eventsToAdd[cinemaTitle] = {
|
|
title: cinemaTitle,
|
|
date: DateTime.fromISO(event.inCinemas),
|
|
color: config?.color ?? 'amber'
|
|
};
|
|
eventsToAdd[physicalTitle] = {
|
|
title: physicalTitle,
|
|
date: DateTime.fromISO(event.physicalRelease),
|
|
color: config?.color ?? 'cyan'
|
|
};
|
|
eventsToAdd[digitalTitle] = {
|
|
title: digitalTitle,
|
|
date: DateTime.fromISO(event.digitalRelease),
|
|
color: config?.color ?? 'emerald'
|
|
};
|
|
})
|
|
|
|
setEvents((prevEvents) => ({ ...prevEvents, ...eventsToAdd }));
|
|
}, [radarrData, radarrError, config, setEvents, t]);
|
|
|
|
const error = radarrError ?? radarrData?.error;
|
|
return error && <Error error={{ message: `${config.type}: ${error.message ?? error}`}} />
|
|
}
|