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 [data, setData] = useState({ hits: [] }); const fail = t('minecraft:fail') useEffect(() => { const fetchData = async () => { const result = await axios( 'https://api.mcsrvstat.us/2/yude.jp', ); setData(result.data); }; fetchData(); }, []); if (data === undefined){ console.log("[Minecraft Query] データの取得に失敗しました。 / Failed to retrieve data.") return (

{fail}

) }else{ const status = data.online const player = data.players && data.players.online const playing = t('minecraft:playing', {count: player}) const no_one = t('minecraft:no_one') const offline = t('minecraft:offline') const loading = t('minecraft:loading') return (

{(() => { if (status == true) { if (player == undefined || player == 0) { return {no_one} } else { return {playing} }}else if (status == false) { return {offline} }else { return {loading} } })()}

) } }