mirror of
https://github.com/gethomepage/homepage.git
synced 2026-04-28 20:00:37 -04:00
Co-authored-by: Jim Strang <jimstrang@users.noreply.github.com> Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
64 lines
1.9 KiB
JavaScript
64 lines
1.9 KiB
JavaScript
import Block from "components/services/widget/block";
|
|
import Container from "components/services/widget/container";
|
|
import { useTranslation } from "next-i18next";
|
|
|
|
import useWidgetAPI from "utils/proxy/use-widget-api";
|
|
|
|
const priorityLabels = {
|
|
1: "min",
|
|
2: "low",
|
|
3: "default",
|
|
4: "high",
|
|
5: "urgent",
|
|
};
|
|
|
|
function Truncated({ text }) {
|
|
return (
|
|
<span className="grid w-full" title={text}>
|
|
<span className="truncate">{text}</span>
|
|
</span>
|
|
);
|
|
}
|
|
|
|
export default function Component({ service }) {
|
|
const { t } = useTranslation();
|
|
const { widget } = service;
|
|
|
|
const { data: messagesData, error: messagesError } = useWidgetAPI(widget, "messages");
|
|
|
|
if (messagesError) {
|
|
return <Container service={service} error={messagesError} />;
|
|
}
|
|
|
|
if (!widget.fields || widget.fields.length === 0) {
|
|
widget.fields = ["title", "message", "priority", "lastReceived"];
|
|
} else if (widget.fields?.length > 4) {
|
|
widget.fields = widget.fields.slice(0, 4);
|
|
}
|
|
|
|
if (!messagesData) {
|
|
return (
|
|
<Container service={service}>
|
|
<Block label="ntfy.title" />
|
|
<Block label="ntfy.message" />
|
|
<Block label="ntfy.priority" />
|
|
<Block label="ntfy.lastReceived" />
|
|
<Block label="ntfy.tags" />
|
|
</Container>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<Container service={service}>
|
|
<Block label="ntfy.title" value={<Truncated text={messagesData.title ?? t("ntfy.none")} />} />
|
|
<Block label="ntfy.message" value={<Truncated text={messagesData.message ?? t("ntfy.none")} />} />
|
|
<Block label="ntfy.priority" value={t(`ntfy.${priorityLabels[messagesData.priority] ?? "default"}`)} />
|
|
<Block
|
|
label="ntfy.lastReceived"
|
|
value={messagesData.time ? t("common.relativeDate", { value: messagesData.time * 1000 }) : t("ntfy.none")}
|
|
/>
|
|
<Block label="ntfy.tags" value={messagesData.tags?.length > 0 ? messagesData.tags.join(", ") : t("ntfy.none")} />
|
|
</Container>
|
|
);
|
|
}
|