0
0
mirror of https://github.com/yude-jp/yude.jp synced 2024-06-09 23:36:01 +09:00
yude.jp/pages/components/Minecraft.js

52 lines
1.6 KiB
JavaScript

import React, { useState, useEffect } from 'react';
import useTranslation from 'next-translate/useTranslation'
import { useRouter } from 'next/router'
import axios from 'axios';
export default function Minecraft(props) {
const router = useRouter()
const { locale, locales, defaultLocale, pathname } = router
const { t, lang } = useTranslation("minecraft")
const [dataMinecraft, setDataMinecraft] = useState({ hits: [] });
const [data, setData] = useState({ hits: [] });
useEffect(() => {
const fetchData = async () => {
const result = await axios(
'https://eu.mc-api.net/v3/server/ping/yude.jp',
);
setData(result.data);
};
fetchData();
}, []);
if (data === undefined){
console.log("[Minecraft Query] データの取得に失敗しました。 / Failed to retrieve data.")
console.log(data)
return (
<p>Failed to retrieve data</p>
)
}else{
console.log(data)
const status = data.online
const player = data.players && data.players.now
const playing = t('minecraft:playing', {count: player})
const no_one = t('minecraft:no_one')
const offline = t('minecraft:offline')
return (
<p className="text-center">
{(() => {
if (status) {
if (player == undefined) {
return <span>{no_one}</span>
} else {
return <span>{playing}</span>
}}else{
return <span>{offline}</span>
}
})()}
</p>
)
}
}