MediaWiki:Test.js: различия между версиями

Страница интерфейса MediaWiki
Нет описания правки
Метка: отменено
Нет описания правки
 
(не показано 57 промежуточных версий этого же участника)
Строка 1: Строка 1:
// Дождемся загрузки DOM
(function(){
document.addEventListener('DOMContentLoaded', function() {
if(typeof mw==='undefined') return;
    // Получаем все элементы, которые будут служить переключателями
    var toggles = document.querySelectorAll('.section-toggle');


    // Перебираем каждый переключатель
var map={
    for (var i = 0; i < toggles.length; i++) {
"Клише":"#ff4d4d",
        toggles[i].addEventListener('click', function() {
"властью":"#4dff4d",
            // 'this' здесь ссылается на текущий кликнутый элемент (section-toggle)
"ответственность":"#4d4dff",
            var currentToggle = this;
"Стандартные Рабочие Процедуры":"#ff4dff",
"ядерный":"#ffa500",
"станции":"#4dffff",
"ГСБ":"#b84dff",
"диск":"#4dff88",
"СРП/КЗ":"#ffb6c1",
"банановая кожурка":"#ffff4d"
};


            // Находим следующий соседний элемент, который является collapsible-content
function esc(s){return s.replace(/[.*+?^${}()|[\]\\]/g,'\\$&');}
            // (это может быть recipe-block или section-content)
            var content = currentToggle.nextElementSibling;


            // Если найден следующий элемент и он имеет класс 'collapsible-content'
function walk(node){
            if (content && content.classList.contains('collapsible-content')) {
if(node.nodeType===3){
                // Проверяем, свернут ли блок в данный момент
var t=node.nodeValue, r=t;
                if (content.classList.contains('collapsed')) {
for(var k in map){
                    // Если свернут, разворачиваем его
r=r.replace(new RegExp(esc(k),'g'),'<span style="color:'+map[k]+'">'+k+'</span>');
                    content.classList.remove('collapsed');
}
                } else {
if(r!==t){
                    // Если развернут, сворачиваем его
var s=document.createElement('span');
                    content.classList.add('collapsed');
s.innerHTML=r;
                }
node.parentNode.replaceChild(s,node);
            }
}
        });
}
    }
}


    // Изначально сворачиваем все блоки с рецептами и эффектами
var nodes=document.querySelectorAll('.mw-parser-output p, .mw-parser-output li');
    // Это важно, чтобы они были свернуты при первой загрузке страницы
for(var i=0;i<nodes.length;i++){
    var collapsibleBlocks = document.querySelectorAll('.collapsible-content');
var cn=nodes[i].childNodes;
    for (var j = 0; j < collapsibleBlocks.length; j++) {
for(var j=0;j<cn.length;j++) walk(cn[j]);
        // Добавляем класс 'collapsed' при загрузке страницы
}
        collapsibleBlocks[j].classList.add('collapsed');
})();
    }
});

Текущая версия от 11:16, 17 января 2026

(function(){
if(typeof mw==='undefined') return;

var map={
"Клише":"#ff4d4d",
"властью":"#4dff4d",
"ответственность":"#4d4dff",
"Стандартные Рабочие Процедуры":"#ff4dff",
"ядерный":"#ffa500",
"станции":"#4dffff",
"ГСБ":"#b84dff",
"диск":"#4dff88",
"СРП/КЗ":"#ffb6c1",
"банановая кожурка":"#ffff4d"
};

function esc(s){return s.replace(/[.*+?^${}()|[\]\\]/g,'\\$&');}

function walk(node){
if(node.nodeType===3){
var t=node.nodeValue, r=t;
for(var k in map){
r=r.replace(new RegExp(esc(k),'g'),'<span style="color:'+map[k]+'">'+k+'</span>');
}
if(r!==t){
var s=document.createElement('span');
s.innerHTML=r;
node.parentNode.replaceChild(s,node);
}
}
}

var nodes=document.querySelectorAll('.mw-parser-output p, .mw-parser-output li');
for(var i=0;i<nodes.length;i++){
var cn=nodes[i].childNodes;
for(var j=0;j<cn.length;j++) walk(cn[j]);
}
})();