mirror of
https://github.com/karl0ss/homepage.git
synced 2025-05-01 21:13:39 +01:00
Add minecraft server status indicator
This commit is contained in:
parent
8f3ae6d674
commit
f418ee6327
@ -262,9 +262,12 @@
|
|||||||
"queued": "Queued",
|
"queued": "Queued",
|
||||||
"series": "Series"
|
"series": "Series"
|
||||||
},
|
},
|
||||||
"minecraft":{
|
"minecraft": {
|
||||||
"players": "Players",
|
"players": "Players",
|
||||||
"version": "Version"
|
"version": "Version",
|
||||||
|
"status": "Status",
|
||||||
|
"up": "Online",
|
||||||
|
"down": "Offline"
|
||||||
},
|
},
|
||||||
"miniflux": {
|
"miniflux": {
|
||||||
"read": "Read",
|
"read": "Read",
|
||||||
|
@ -1,26 +1,46 @@
|
|||||||
|
import { useTranslation } from "next-i18next";
|
||||||
|
|
||||||
import Container from "components/services/widget/container";
|
import Container from "components/services/widget/container";
|
||||||
import Block from "components/services/widget/block";
|
import Block from "components/services/widget/block";
|
||||||
import useWidgetAPI from "utils/proxy/use-widget-api";
|
import useWidgetAPI from "utils/proxy/use-widget-api";
|
||||||
|
|
||||||
export default function Component({ service }) {
|
export default function Component({ service }) {
|
||||||
const { widget } = service;
|
const { widget } = service;
|
||||||
const { data: serverData, error: serverError } = useWidgetAPI(widget, "status");
|
const { data: serverData, error: serverError } = useWidgetAPI(widget, "status");
|
||||||
if(serverError){
|
const { t } = useTranslation();
|
||||||
return <Container error={serverError} />;
|
|
||||||
}
|
if(serverError){
|
||||||
if (!serverData) {
|
return <Container error={serverError} />;
|
||||||
return (
|
}
|
||||||
<Container service={service}>
|
if (!serverData) {
|
||||||
<Block label="minecraft.players" />
|
return (
|
||||||
<Block label="minecraft.version" />
|
<Container service={service}>
|
||||||
</Container>
|
<Block label="minecraft.status"/>
|
||||||
);
|
<Block label="minecraft.players" />
|
||||||
}
|
<Block label="minecraft.version" />
|
||||||
|
</Container>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
const statusIndicator = serverData.online ?
|
||||||
<Container service={service}>
|
<span className="text-green-500">{t("minecraft.up")}</span>:
|
||||||
<Block label="minecraft.players" value={`${serverData.players.online} / ${serverData.players.max}`} />
|
<span className="text-red-500">{t("minecraft.down")}</span>;
|
||||||
<Block label="minecraft.version" value={serverData.version} />
|
|
||||||
</Container>
|
if(serverData.players){
|
||||||
);
|
return (
|
||||||
|
<Container service={service}>
|
||||||
|
<Block label="minecraft.status" value={statusIndicator} />
|
||||||
|
<Block label="minecraft.players" value={`${serverData.players.online} / ${serverData.players.max}`} />
|
||||||
|
<Block label="minecraft.version" value={serverData.version} />
|
||||||
|
</Container>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return (
|
||||||
|
<Container service={service}>
|
||||||
|
<Block label="minecraft.status" value={statusIndicator} />
|
||||||
|
<Block label="minecraft.players" value="-" />
|
||||||
|
<Block label="minecraft.version" value="-" />
|
||||||
|
</Container>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
@ -11,7 +11,8 @@ const widget = {
|
|||||||
const jsonData = asJson(data);
|
const jsonData = asJson(data);
|
||||||
return {
|
return {
|
||||||
players: jsonData.players,
|
players: jsonData.players,
|
||||||
version: jsonData.version
|
version: jsonData.version,
|
||||||
|
online: jsonData.online
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user