MediaWiki:Common.js: различия между версиями
Страница интерфейса MediaWiki
Дополнительные действия
Actn2k (обсуждение | вклад) Нет описания правки |
Actn2k (обсуждение | вклад) Нет описания правки |
||
| Строка 1: | Строка 1: | ||
const pageName = mw.config.get("wgPageName"); | const pageName = mw.config.get("wgPageName"); | ||
if (localStorage.getItem('ѾmodeEnabled') === 'true') { | |||
startSecret(); | |||
} | |||
if (pageName == "Заглавная_страница" || pageName == "Test2") { | if (pageName == "Заглавная_страница" || pageName == "Test2") { | ||
document.documentElement.classList.replace('skin-theme-clientpref-day', 'skin-theme-clientpref-night'); | |||
} | } | ||
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 != "Шаблон:Таблица_Космический_Закон") { | if (pageName != "Шаблон:Таблица_Космический_Закон") { | ||
| Строка 30: | Строка 30: | ||
const table = document.getElementById("law"); | const table = document.getElementById("law"); | ||
if (table) { | if (table) { | ||
table.addEventListener("click", function (event) { | 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"); | |||
}); | }); | ||
} | } | ||
| Строка 58: | Строка 54: | ||
} | } | ||
mw.loader.using('jquery', function () { | 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); | |||
}); | |||
}); | }); | ||
}); | }); | ||
}); | }); | ||
mw.loader.using('mediawiki.util', | mw.loader.using('mediawiki.util', function() { | ||
mw.util.addPortletLink('p-personal', '#', 'Режим Ѿ', 'pt-omode', 'Режим Ѿ').addEventListener('click', function(e) { | |||
e.preventDefault(); | |||
toggleSecret(); | |||
}; | |||
}) | |||
}) | |||
}); | }); | ||
function startSecret() { | |||
function getVisibleTextNodes(root) { | function getVisibleTextNodes(root) { | ||
let nodes = []; | let nodes = []; | ||
function walk(node) { | function walk(node) { | ||
if (node.nodeType === Node.TEXT_NODE) { | if (node.nodeType === Node.TEXT_NODE) { | ||
| Строка 101: | Строка 102: | ||
} | } | ||
} else if (node.nodeType === Node.ELEMENT_NODE && node.tagName !== "SCRIPT" && node.tagName !== "STYLE") { | } else if (node.nodeType === Node.ELEMENT_NODE && node.tagName !== "SCRIPT" && node.tagName !== "STYLE") { | ||
for (let child of node.childNodes) | for (let child of node.childNodes) walk(child); | ||
} | } | ||
} | } | ||
| Строка 114: | Строка 113: | ||
for (let i = 0; i < node.nodeValue.length; i++) { | for (let i = 0; i < node.nodeValue.length; i++) { | ||
if (!/[\s]/.test(node.nodeValue[i])) { | if (!/[\s]/.test(node.nodeValue[i])) { | ||
available.push({ node, index: i }); | available.push({ | ||
node, | |||
index: i | |||
}); | |||
} | } | ||
} | } | ||
| Строка 121: | Строка 123: | ||
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 { node, index } = available.splice(randIndex, 1)[0]; | let { | ||
node, | |||
index | |||
} = available.splice(randIndex, 1)[0]; | |||
let chars = node.nodeValue.split(""); | let chars = node.nodeValue.split(""); | ||
chars[index] = "Ѿ"; | chars[index] = "Ѿ"; | ||
| Строка 128: | Строка 133: | ||
} | } | ||
replaceNext(); | replaceNext(); | ||
} | } | ||
function toggleSecret() { | |||
let enabled = localStorage.getItem(STORAGE_KEY) === 'true'; | |||
if (enabled) { | |||
localStorage.setItem(STORAGE_KEY, 'false'); | |||
location.reload(); | |||
} else { | |||
localStorage.setItem(STORAGE_KEY, 'true'); | |||
location.reload(); | |||
} | |||
} | |||
Версия от 12:00, 12 августа 2025
const pageName = mw.config.get("wgPageName");
if (localStorage.getItem('ѾmodeEnabled') === 'true') {
startSecret();
}
if (pageName == "Заглавная_страница" || pageName == "Test2") {
document.documentElement.classList.replace('skin-theme-clientpref-day', 'skin-theme-clientpref-night');
}
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 != "Шаблон:Таблица_Космический_Закон") {
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);
});
});
});
});
mw.loader.using('mediawiki.util', function() {
mw.util.addPortletLink('p-personal', '#', 'Режим Ѿ', 'pt-omode', 'Режим Ѿ').addEventListener('click', function(e) {
e.preventDefault();
toggleSecret();
};
})
});
function startSecret() {
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();
}
function toggleSecret() {
let enabled = localStorage.getItem(STORAGE_KEY) === 'true';
if (enabled) {
localStorage.setItem(STORAGE_KEY, 'false');
location.reload();
} else {
localStorage.setItem(STORAGE_KEY, 'true');
location.reload();
}
}