mirror of
https://github.com/karl0ss/homepage.git
synced 2025-05-07 15:53:39 +01:00
Added Jellyfin Widget to show number of movies,Series, Episodes songs #264
This commit is contained in:
parent
eaec0f075c
commit
263801677a
@ -2,6 +2,7 @@ import { useTranslation } from "next-i18next";
|
|||||||
import { BsVolumeMuteFill, BsFillPlayFill, BsPauseFill, BsCpu, BsFillCpuFill } from "react-icons/bs";
|
import { BsVolumeMuteFill, BsFillPlayFill, BsPauseFill, BsCpu, BsFillCpuFill } from "react-icons/bs";
|
||||||
import { MdOutlineSmartDisplay } from "react-icons/md";
|
import { MdOutlineSmartDisplay } from "react-icons/md";
|
||||||
|
|
||||||
|
import Block from "components/services/widget/block";
|
||||||
import Container from "components/services/widget/container";
|
import Container from "components/services/widget/container";
|
||||||
import { formatProxyUrlWithSegments } from "utils/proxy/api-helpers";
|
import { formatProxyUrlWithSegments } from "utils/proxy/api-helpers";
|
||||||
import useWidgetAPI from "utils/proxy/use-widget-api";
|
import useWidgetAPI from "utils/proxy/use-widget-api";
|
||||||
@ -161,18 +162,45 @@ export default function Component({ service }) {
|
|||||||
refreshInterval: 5000,
|
refreshInterval: 5000,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const {
|
||||||
|
data: countData,
|
||||||
|
error: countError,
|
||||||
|
} = useWidgetAPI(widget, "Count", {
|
||||||
|
refreshInterval: 60000,});
|
||||||
|
|
||||||
async function handlePlayCommand(session, command) {
|
async function handlePlayCommand(session, command) {
|
||||||
const url = formatProxyUrlWithSegments(widget, "PlayControl", {
|
const url = formatProxyUrlWithSegments(widget, "PlayControl", {
|
||||||
sessionId: session.Id,
|
sessionId: session.Id,
|
||||||
command,
|
command,
|
||||||
});
|
});
|
||||||
await fetch(url).then(() => {
|
await fetch(url).then(() => {
|
||||||
sessionMutate();
|
sessionMutate;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sessionsError) {
|
if (sessionsError || countError) {
|
||||||
return <Container error={sessionsError} />;
|
return <Container error={sessionsError || countError} />;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!sessionsData && countData) {
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<Container>
|
||||||
|
<Block label="Movies" value={t("common.number", { value: countData.MovieCount })} />
|
||||||
|
<Block label="Series" value={t("common.number", { value: countData.SeriesCount })} />
|
||||||
|
<Block label="Episodes" value={t("common.number", { value: countData.EpisodeCount })} />
|
||||||
|
<Block label="Songs" value={t("common.number", { value: countData.SongCount })} />
|
||||||
|
</Container>
|
||||||
|
<div className="flex flex-col pb-1">
|
||||||
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
|
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
||||||
|
</div>
|
||||||
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
|
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!sessionsData) {
|
if (!sessionsData) {
|
||||||
@ -200,8 +228,15 @@ export default function Component({ service }) {
|
|||||||
return 0;
|
return 0;
|
||||||
});
|
});
|
||||||
|
|
||||||
if (playing.length === 0) {
|
if (playing.length === 0 && countData) {
|
||||||
return (
|
return (
|
||||||
|
<>
|
||||||
|
<Container>
|
||||||
|
<Block label="Movies" value={t("common.number", { value: countData.MovieCount })} />
|
||||||
|
<Block label="Series" value={t("common.number", { value: countData.SeriesCount })} />
|
||||||
|
<Block label="Episodes" value={t("common.number", { value: countData.EpisodeCount })} />
|
||||||
|
<Block label="Songs" value={t("common.number", { value: countData.SongCount })} />
|
||||||
|
</Container>
|
||||||
<div className="flex flex-col pb-1 mx-1">
|
<div className="flex flex-col pb-1 mx-1">
|
||||||
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
<span className="absolute left-2 text-xs mt-[2px]">{t("emby.no_active")}</span>
|
<span className="absolute left-2 text-xs mt-[2px]">{t("emby.no_active")}</span>
|
||||||
@ -210,22 +245,39 @@ export default function Component({ service }) {
|
|||||||
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (playing.length === 1) {
|
if (playing.length === 1 && countData) {
|
||||||
const session = playing[0];
|
const session = playing[0];
|
||||||
return (
|
return (
|
||||||
|
<>
|
||||||
|
<Container>
|
||||||
|
<Block label="Movies" value={t("common.number", { value: countData.MovieCount })} />
|
||||||
|
<Block label="Series" value={t("common.number", { value: countData.SeriesCount })} />
|
||||||
|
<Block label="Episodes" value={t("common.number", { value: countData.EpisodeCount })} />
|
||||||
|
<Block label="Songs" value={t("common.number", { value: countData.SongCount })} />
|
||||||
|
</Container>
|
||||||
<div className="flex flex-col pb-1 mx-1">
|
<div className="flex flex-col pb-1 mx-1">
|
||||||
<SingleSessionEntry
|
<SingleSessionEntry
|
||||||
playCommand={(currentSession, command) => handlePlayCommand(currentSession, command)}
|
playCommand={(currentSession, command) => handlePlayCommand(currentSession, command)}
|
||||||
session={session}
|
session={session}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (countData && playing.length === -1)
|
||||||
return (
|
return (
|
||||||
|
<>
|
||||||
|
<Container>
|
||||||
|
<Block label="Movies" value={t("common.number", { value: countData.MovieCount })} />
|
||||||
|
<Block label="Series" value={t("common.number", { value: countData.SeriesCount })} />
|
||||||
|
<Block label="Episodes" value={t("common.number", { value: countData.EpisodeCount })} />
|
||||||
|
<Block label="Songs" value={t("common.number", { value: countData.SongCount })} />
|
||||||
|
</Container>
|
||||||
<div className="flex flex-col pb-1 mx-1">
|
<div className="flex flex-col pb-1 mx-1">
|
||||||
{playing.map((session) => (
|
{playing.map((session) => (
|
||||||
<SessionEntry
|
<SessionEntry
|
||||||
@ -235,5 +287,6 @@ export default function Component({ service }) {
|
|||||||
/>
|
/>
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -8,6 +8,15 @@ const widget = {
|
|||||||
Sessions: {
|
Sessions: {
|
||||||
endpoint: "Sessions",
|
endpoint: "Sessions",
|
||||||
},
|
},
|
||||||
|
Count: {
|
||||||
|
endpoint: "Items/Counts",
|
||||||
|
segments: [
|
||||||
|
"MovieCount",
|
||||||
|
"SeriesCount",
|
||||||
|
"EpisodeCount",
|
||||||
|
"SongCount"
|
||||||
|
]
|
||||||
|
},
|
||||||
PlayControl: {
|
PlayControl: {
|
||||||
method: "POST",
|
method: "POST",
|
||||||
endpoint: "Sessions/{sessionId}/Playing/{command}",
|
endpoint: "Sessions/{sessionId}/Playing/{command}",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user