2023-09-28 19:23:44 +01:00
|
|
|
import { DateTime } from "luxon";
|
2023-11-25 16:17:25 +00:00
|
|
|
import { useEffect } from "react";
|
2023-09-28 19:23:44 +01:00
|
|
|
|
|
|
|
import useWidgetAPI from "../../../utils/proxy/use-widget-api";
|
|
|
|
import Error from "../../../components/services/widget/error";
|
|
|
|
|
2023-11-25 16:17:25 +00:00
|
|
|
export default function Integration({ config, params, setEvents, hideErrors = false }) {
|
2023-10-17 23:26:55 -07:00
|
|
|
const { data: lidarrData, error: lidarrError } = useWidgetAPI(config, "calendar", {
|
|
|
|
...params,
|
|
|
|
includeArtist: "false",
|
|
|
|
...(config?.params ?? {}),
|
|
|
|
});
|
2023-09-28 19:23:44 +01:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (!lidarrData || lidarrError) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const eventsToAdd = {};
|
|
|
|
|
2023-10-17 23:26:55 -07:00
|
|
|
lidarrData?.forEach((event) => {
|
2023-09-28 19:23:44 +01:00
|
|
|
const title = `${event.artist.artistName} - ${event.title}`;
|
|
|
|
|
|
|
|
eventsToAdd[title] = {
|
|
|
|
title,
|
|
|
|
date: DateTime.fromISO(event.releaseDate),
|
2023-10-17 23:26:55 -07:00
|
|
|
color: config?.color ?? "green",
|
2023-10-21 00:31:19 +01:00
|
|
|
isCompleted: event.grabbed,
|
|
|
|
additional: "",
|
2023-09-28 19:23:44 +01:00
|
|
|
};
|
2023-10-17 23:26:55 -07:00
|
|
|
});
|
2023-09-28 19:23:44 +01:00
|
|
|
|
|
|
|
setEvents((prevEvents) => ({ ...prevEvents, ...eventsToAdd }));
|
|
|
|
}, [lidarrData, lidarrError, config, setEvents]);
|
|
|
|
|
|
|
|
const error = lidarrError ?? lidarrData?.error;
|
2023-10-29 20:14:06 -07:00
|
|
|
return error && !hideErrors && <Error error={{ message: `${config.type}: ${error.message ?? error}` }} />;
|
2023-09-28 19:23:44 +01:00
|
|
|
}
|