MediaWiki:Common.js: различия между версиями
Страница интерфейса MediaWiki
Дополнительные действия
Admin (обсуждение | вклад) Нет описания правки |
Admin (обсуждение | вклад) Нет описания правки |
||
| Строка 93: | Строка 93: | ||
if (pageName == "Заглавная_страница") { | if (pageName == "Заглавная_страница") { | ||
document.querySelector('.pashalka-jopa-trigger').addEventListener('click', () => { | document.querySelector('.pashalka-jopa-trigger').addEventListener('click', () => { | ||
let | function getVisibleTextNodes(root) { | ||
let | let nodes = []; | ||
function walk(node) { | |||
if (node.nodeType === Node.TEXT_NODE) { | |||
if (node.nodeValue.trim() !== "" && node.parentNode.offsetParent !== null) { | |||
nodes.push(node); | |||
} | |||
} else if (node.nodeType === Node.ELEMENT_NODE && node.tagName !== "SCRIPT" && node.tagName !== "STYLE") { | |||
for (let child of node.childNodes) { | |||
walk(child); | |||
} | |||
} | |||
} | |||
walk(root); | |||
return nodes; | |||
} | |||
let textNodes = getVisibleTextNodes(document.body); | |||
let available = []; | let available = []; | ||
for (let | for (let node of textNodes) { | ||
for (let i = 0; i < node.nodeValue.length; i++) { | |||
if (!/[\s]/.test(node.nodeValue[i])) { | |||
available.push({ node, index: i }); | |||
} | |||
} | } | ||
} | } | ||
| Строка 104: | Строка 121: | ||
if (available.length === 0) return; | if (available.length === 0) return; | ||
let randIndex = Math.floor(Math.random() * available.length); | let randIndex = Math.floor(Math.random() * available.length); | ||
let | let { node, index } = available.splice(randIndex, 1)[0]; | ||
chars[ | let chars = node.nodeValue.split(""); | ||
chars[index] = "Ѿ"; | |||
node.nodeValue = chars.join(""); | |||
setTimeout(replaceNext, 1); | setTimeout(replaceNext, 1); | ||
} | } | ||
Версия от 11:02, 12 августа 2025
const pageName = mw.config.get("wgPageName");
document.querySelectorAll(".server-hook").forEach(function(element) {
var ip = element.getAttribute("data-ip");
var port = element.getAttribute("data-port");
var url = "https://wiki.ss13-bluemoon.ru/nodeapi/status?ip="+encodeURIComponent(ip)+"&port="+encodeURIComponent(port);
fetch(url)
.then(function(response) {
if (!response.ok) {
throw new Error(response.status);
}
return response.json();
})
.then(function(data) {
element.textContent = data.response.players;
})
.catch(function(error) {
element.textContent = "⨉";
});
});
if (pageName == "Заглавная_страница" || pageName == "Test2") {
document.documentElement.classList.replace('skin-theme-clientpref-day', 'skin-theme-clientpref-night');
}
if (pageName != "Шаблон:Таблица_Космический_Закон") {
let current = null;
let currentCell = null;
const table = document.getElementById("law");
if (table) {
table.addEventListener("click", function (event) {
const cell = event.target.closest("td");
if (!cell) return;
if (!cell.dataset.id) return;
if (current !== null) {
document.getElementById(current).style.display = "none";
if (currentCell) currentCell.classList.remove("law-selected");
}
if (cell.dataset.id === current) {
current = null;
currentCell = null;
return;
}
current = cell.dataset.id;
currentCell = cell;
document.getElementById(current).style.display = "block";
cell.classList.add("law-selected");
});
}
} else {
const allObjects = document.querySelectorAll(".law-object");
allObjects.forEach(el => el.style.display = "block");
}
mw.loader.using('jquery', function () {
$(function () {
$('.vtabs').each(function () {
const $container = $(this);
const $buttons = $container.find('.vtabs-button');
const $contents = $container.find('.vtabs-content');
$buttons.each(function (index) {
$(this).on('click', function () {
$buttons.removeClass('active');
$contents.removeClass('active');
$(this).addClass('active');
$contents.eq(index).addClass('active');
});
});
});
});
});
mw.loader.using('mediawiki.util', function () {
$(function () {
$('.colstr-header').each(function () {
$(this).on('click', function () {
const $panel = $(this).closest('.colstr-panel');
const isOpen = $panel.toggleClass('open').hasClass('open');
$(this).attr('aria-expanded', isOpen);
});
});
});
});
let isJopa = false;
if (pageName == "Заглавная_страница") {
document.querySelector('.pashalka-jopa-trigger').addEventListener('click', () => {
function getVisibleTextNodes(root) {
let nodes = [];
function walk(node) {
if (node.nodeType === Node.TEXT_NODE) {
if (node.nodeValue.trim() !== "" && node.parentNode.offsetParent !== null) {
nodes.push(node);
}
} else if (node.nodeType === Node.ELEMENT_NODE && node.tagName !== "SCRIPT" && node.tagName !== "STYLE") {
for (let child of node.childNodes) {
walk(child);
}
}
}
walk(root);
return nodes;
}
let textNodes = getVisibleTextNodes(document.body);
let available = [];
for (let node of textNodes) {
for (let i = 0; i < node.nodeValue.length; i++) {
if (!/[\s]/.test(node.nodeValue[i])) {
available.push({ node, index: i });
}
}
}
function replaceNext() {
if (available.length === 0) return;
let randIndex = Math.floor(Math.random() * available.length);
let { node, index } = available.splice(randIndex, 1)[0];
let chars = node.nodeValue.split("");
chars[index] = "Ѿ";
node.nodeValue = chars.join("");
setTimeout(replaceNext, 1);
}
replaceNext();
});
}