2022-08-25 16:29:26 +03:00
|
|
|
import useSWR from "swr";
|
|
|
|
|
|
|
|
import Widget from "../widget";
|
|
|
|
import Block from "../block";
|
|
|
|
|
2022-08-26 22:34:24 +03:00
|
|
|
export default function Emby({ service, title = "Emby" }) {
|
2022-08-25 16:29:26 +03:00
|
|
|
const config = service.widget;
|
|
|
|
|
|
|
|
function buildApiUrl(endpoint) {
|
|
|
|
const { url, key } = config;
|
|
|
|
return `${url}/emby/${endpoint}?api_key=${key}`;
|
|
|
|
}
|
|
|
|
|
|
|
|
const { data: sessionsData, error: sessionsError } = useSWR(buildApiUrl(`Sessions`), {
|
|
|
|
refreshInterval: 1000,
|
|
|
|
});
|
|
|
|
|
|
|
|
if (sessionsError) {
|
2022-08-26 22:34:24 +03:00
|
|
|
return <Widget error={`${title} API Error`} />;
|
2022-08-25 16:29:26 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!sessionsData) {
|
|
|
|
return (
|
|
|
|
<Widget>
|
|
|
|
<Block label="Playing" />
|
|
|
|
<Block label="Transcoding" />
|
|
|
|
<Block label="Bitrate" />
|
|
|
|
</Widget>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const playing = sessionsData.filter((session) => session.hasOwnProperty("NowPlayingItem"));
|
|
|
|
const transcoding = sessionsData.filter(
|
|
|
|
(session) => session.hasOwnProperty("PlayState") && session.PlayState.PlayMethod === "Transcode"
|
|
|
|
);
|
|
|
|
const bitrate = playing.reduce((acc, session) => acc + session.NowPlayingItem.Bitrate, 0);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Widget>
|
|
|
|
<Block label="Playing" value={playing.length} />
|
|
|
|
<Block label="Transcoding" value={transcoding.length} />
|
|
|
|
<Block label="Bitrate" value={`${Math.round((bitrate / 1024 / 1024) * 100) / 100} Mbps`} />
|
|
|
|
</Widget>
|
|
|
|
);
|
|
|
|
}
|