Шаблон:Онлайн: відмінності між версіями

Матеріал з Бастіон-16
Перейти до навігації Перейти до пошуку
Немає опису редагування
Мітка: Ручний відкіт
Немає опису редагування
Рядок 53: Рядок 53:


     <script>
     <script>
        const SERVER_IP = "play.bastion16.co.ua"; // Замініть на вашу IP-адресу або домен
      document.addEventListener("DOMContentLoaded", function () {
    const SERVER_IP = "play.bastion16.co.ua";


        async function fetchServerStatus() {
    async function fetchServerStatus() {
            try {
        const motdElement = document.getElementById("motd");
                console.log("Виконую запит до mcstatus.io...");
        const playerCountElement = document.getElementById("playerCount");
                let response = await fetch(`https://api.mcstatus.io/v2/status/java/${SERVER_IP}`);
        const playersElement = document.getElementById("players");
                if (!response.ok) throw new Error(`HTTP помилка! Статус: ${response.status}`);
        const serverIconElement = document.getElementById("server-icon");
                let data = await response.json();
                console.log("Отримані дані:", data);


                let motdElement = document.getElementById("motd");
        if (!motdElement || !playerCountElement || !playersElement || !serverIconElement) {
                if (data.motd && Array.isArray(data.motd.html)) {
            console.error("Не вдалося знайти всі потрібні елементи DOM.");
                    motdElement.innerHTML = data.motd.html.join(" ");
            return;
                } else if (data.motd && typeof data.motd.html === "string") {
        }
                    motdElement.innerHTML = data.motd.html;
                } else {
                    motdElement.innerHTML = "Сервер без MOTD";
                }


                let playerCountElement = document.getElementById("playerCount");
        try {
                playerCountElement.innerText = `Гравців онлайн: ${data.players ? data.players.online : 0}`;
            console.log("Виконую запит до mcstatus.io...");
            let response = await fetch(`https://api.mcstatus.io/v2/status/java/${SERVER_IP}`);
            if (!response.ok) throw new Error(`HTTP помилка! Статус: ${response.status}`);
            let data = await response.json();
            console.log("Отримані дані:", data);


                let playersElement = document.getElementById("players");
            motdElement.innerHTML = data.motd?.html?.join(" ") || "Сервер без MOTD";
                playersElement.innerHTML = "";
            playerCountElement.innerText = `Гравців онлайн: ${data.players?.online || 0}`;
            playersElement.innerHTML = "";


                if (data.players && data.players.online > 0 && data.players.list && data.players.list.length > 0) {
            if (data.players?.online > 0 && data.players.list?.length > 0) {
                    data.players.list.forEach(player => {
                data.players.list.forEach(player => {
                        let playerName = player.name_raw || player.name;
                    let playerName = player.name_raw || player.name;
                        let playerSkinURL = `https://mineskin.eu/helm/${playerName}/24.png`;
                    let playerSkinURL = `https://mineskin.eu/helm/${playerName}/24.png`;


                        let listItem = document.createElement("li");
                    let listItem = document.createElement("li");
                        let img = document.createElement("img");
                    let img = document.createElement("img");
                        let span = document.createElement("span");
                    let span = document.createElement("span");


                        img.src = playerSkinURL;
                    img.src = playerSkinURL;
                        img.alt = playerName;
                    img.alt = playerName;
                        span.textContent = playerName;
                    span.textContent = playerName;


                        listItem.appendChild(img);
                    listItem.appendChild(img);
                        listItem.appendChild(span);
                    listItem.appendChild(span);
                        playersElement.appendChild(listItem);
                    playersElement.appendChild(listItem);
                    });
                });
                } else {
            } else {
                    playersElement.innerHTML = "<li>Немає гравців онлайн</li>";
                playersElement.innerHTML = "<li>Немає гравців онлайн</li>";
                }
            }


                let serverIconElement = document.getElementById("server-icon");
            if (data.icon) {
                if (data.icon) {
                serverIconElement.src = data.icon;
                    serverIconElement.src = data.icon;
                serverIconElement.style.display = "block";
                    serverIconElement.style.display = "block";
            } else {
                } else {
                serverIconElement.style.display = "none";
                    serverIconElement.style.display = "none";
                }
            } catch (error) {
                console.error("Помилка під час отримання статусу сервера:", error);
                document.getElementById("motd").innerText = "Не вдалося завантажити MOTD";
                document.getElementById("playerCount").innerText = "Не вдалося завантажити дані";
                document.getElementById("players").innerHTML = "<li>Помилка завантаження</li>";
             }
             }
        } catch (error) {
            console.error("Помилка під час отримання статусу сервера:", error);
            motdElement.innerText = "Не вдалося завантажити MOTD";
            playerCountElement.innerText = "Не вдалося завантажити дані";
            playersElement.innerHTML = "<li>Помилка завантаження</li>";
         }
         }
    }
    fetchServerStatus();
    setInterval(fetchServerStatus, 30000); // Оновлення кожні 30 секунд
});


        fetchServerStatus();
        setInterval(fetchServerStatus, 30000); // Оновлення кожні 30 секунд
     </script>
     </script>
</body>
</body>
</html>
</html>

Версія за 14:12, 11 січня 2025

MC Онлайн Гравці

MC Онлайн Гравці

Завантаження MOTD...

Завантаження...