2023-02-27 11:59:37 +00:00
|
|
|
import { useTranslation } from "next-i18next";
|
|
|
|
|
2023-02-23 18:24:53 +00:00
|
|
|
import Container from "components/services/widget/container";
|
|
|
|
import Block from "components/services/widget/block";
|
|
|
|
import useWidgetAPI from "utils/proxy/use-widget-api";
|
|
|
|
|
|
|
|
export default function Component({ service }) {
|
2023-02-27 11:59:37 +00:00
|
|
|
const { widget } = service;
|
|
|
|
const { data: serverData, error: serverError } = useWidgetAPI(widget, "status");
|
|
|
|
const { t } = useTranslation();
|
|
|
|
|
|
|
|
if(serverError){
|
2023-04-30 19:09:37 -04:00
|
|
|
return <Container service={service} error={serverError} />;
|
2023-02-27 11:59:37 +00:00
|
|
|
}
|
|
|
|
if (!serverData) {
|
|
|
|
return (
|
|
|
|
<Container service={service}>
|
|
|
|
<Block label="minecraft.status"/>
|
|
|
|
<Block label="minecraft.players" />
|
|
|
|
<Block label="minecraft.version" />
|
|
|
|
</Container>
|
|
|
|
);
|
|
|
|
}
|
2023-02-23 18:24:53 +00:00
|
|
|
|
2023-02-27 11:59:37 +00:00
|
|
|
const statusIndicator = serverData.online ?
|
|
|
|
<span className="text-green-500">{t("minecraft.up")}</span>:
|
|
|
|
<span className="text-red-500">{t("minecraft.down")}</span>;
|
2023-02-28 11:49:39 +00:00
|
|
|
const players = serverData.players ? `${serverData.players.online} / ${serverData.players.max}` : "-";
|
|
|
|
const version = serverData.version || "-";
|
2023-02-27 11:59:37 +00:00
|
|
|
|
|
|
|
return (
|
2023-02-28 11:49:39 +00:00
|
|
|
<Container service={service}>
|
2023-02-27 11:59:37 +00:00
|
|
|
<Block label="minecraft.status" value={statusIndicator} />
|
2023-02-28 11:49:39 +00:00
|
|
|
<Block label="minecraft.players" value={players} />
|
|
|
|
<Block label="minecraft.version" value={version} />
|
|
|
|
</Container>
|
2023-02-27 11:59:37 +00:00
|
|
|
);
|
2023-02-23 18:24:53 +00:00
|
|
|
}
|
2023-02-27 11:59:37 +00:00
|
|
|
|