mirror of
https://github.com/gethomepage/homepage.git
synced 2026-01-09 09:54:41 +08:00
40 lines
1.5 KiB
JavaScript
40 lines
1.5 KiB
JavaScript
import Block from "components/services/widget/block";
|
|
import Container from "components/services/widget/container";
|
|
|
|
import useWidgetAPI from "utils/proxy/use-widget-api";
|
|
|
|
export const jellyseerrDefaultFields = ["pending", "approved", "available"];
|
|
|
|
export default function Component({ service }) {
|
|
const { widget } = service;
|
|
|
|
widget.fields = widget?.fields?.length ? widget.fields : jellyseerrDefaultFields;
|
|
const isIssueEnabled = widget.fields.includes("issues");
|
|
|
|
const { data: statsData, error: statsError } = useWidgetAPI(widget, "request/count");
|
|
const { data: issueData, error: issueError } = useWidgetAPI(widget, isIssueEnabled ? "issue/count" : "");
|
|
if (statsError || (isIssueEnabled && issueError)) {
|
|
return <Container service={service} error={statsError ? statsError : issueError} />;
|
|
}
|
|
|
|
if (!statsData || (isIssueEnabled && !issueData)) {
|
|
return (
|
|
<Container service={service}>
|
|
<Block label="jellyseerr.pending" />
|
|
<Block label="jellyseerr.approved" />
|
|
<Block label="jellyseerr.available" />
|
|
<Block label="jellyseerr.issues" />
|
|
</Container>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<Container service={service}>
|
|
<Block label="jellyseerr.pending" value={statsData.pending} />
|
|
<Block label="jellyseerr.approved" value={statsData.approved} />
|
|
<Block label="jellyseerr.available" value={statsData.available} />
|
|
<Block label="jellyseerr.issues" value={`${issueData?.open} / ${issueData?.total}`} />
|
|
</Container>
|
|
);
|
|
}
|