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.
homepage/src/widgets/todoist/categories/label.jsx

42 lines
1.5 KiB

import { useEffect, useState } from "react";
import { useTranslation } from "next-i18next";
import useWidgetAPI from "../../../utils/proxy/use-widget-api";
import Error from "../../../components/services/widget/error";
import Agenda from "../agenda";
export default function Label({ widget }) {
const { t } = useTranslation();
const { data: tasksData, error: tasksError } = useWidgetAPI(widget, "getTasksWithLabel", {
refreshInterval: widget.refreshInterval || 300000, // 5 minutes, use default if not provided
label: widget.name
});
const [tasks, setEvents] = useState([]); // State to hold events
useEffect(() => {
if (!tasksError && tasksData && tasksData.length > 0) { // Check if tasksData is not empty
// Process label data and set tasks
const tasksToAdd = tasksData.slice(0, widget.maxTasks || tasksData.length).map((task) => ({
title: task.content || t("Untitled Task by Label"),
date: task.due ? new Date(task.due.date) : null,
color: task.color || "blue", // Adjust color based on your preference
description: task.tags ? task.tags.join(", ") : "",
url: task.url,
id: task.id,
}));
// Update the events state
setEvents(tasksToAdd);
}
}, [tasksData, tasksError, widget, setEvents, t]);
const error = tasksError ?? tasksData?.error;
if (error && !widget.hideErrors) {
return <Error error={{ message: `${widget.type}: ${error.message ?? error}` }} />;
}
// Render the Agenda component if tasks is not empty
return <Agenda tasks={tasks} />;
}