Добро пожаловать на Lesta Games Wiki!

Участник:_DiWoD_:ru/common.js — различия между версиями

Перейти к: навигация, поиск
Версия 03:30, 18 сентября 2023Текущая версия на 16:42, 28 сентября 2023 
не показано 6 промежуточных версии этого же участника
Строка 1:Строка 1:
?listSelectorObjBase = document.querySelectorAll('.list-selector-object');+//Получение всех блоков с табами
? +var tlbAll = document.querySelectorAll(".main-tlb");
?for (var lsof_i = 0; lsof_i < listSelectorObjBase.length; lsof_i++) {+//Выдаём каждому табу уникальный номер
? document.querySelectorAll('.lso-tabs')[lsof_i].querySelectorAll('.lso-tab')[0].classList.add('lso-tab-active');+for (mb_i = 0; mb_i < tlbAll.length; mb_i++) {
? document.querySelectorAll('.lso-lists')[lsof_i].querySelectorAll('.lso-list')[0].classList.add('lso-list-active');+ tlbAll[mb_i].setAttribute("maintabs-num", mb_i);
? for (lsof_j = 0; lsof_j < listSelectorObjBase[lsof_i].querySelectorAll('.lso-tab').length; lsof_j++) {+ //Получаем табы и листы на первом уровне вложенности
? var item = listSelectorObjBase[lsof_i].querySelectorAll('.lso-tab')[lsof_j];+ var tabAll = tlbAll[mb_i].querySelectorAll(
? item.addEventListener('click',+ '[maintabs-num="' + mb_i + '"] > * > .tab-item:nth-child(1n)'
? function(lsof_event) {+ );
? lsof_event.preventDefault();+ var listAll = tlbAll[mb_i].querySelectorAll(
? lsof_event.target.classList.add('lso-clickClass');+ '[maintabs-num="' + mb_i + '"] > .list-item:nth-child(1n)'
? for (lsof_c = 0; lsof_c < lsof_event.target.parentElement.querySelectorAll('.lso-tab').length; lsof_c++) {+ );
? var lso_childTab = lsof_event.target.parentElement.querySelectorAll('.lso-tab')[lsof_c];+ //Даём каждому табу номер блока и номер таба
? var lso_childList = lsof_event.target.parentElement.parentElement.querySelector('.lso-lists').querySelectorAll('.lso-list')[lsof_c];+ for (tb_i = 0; tb_i < tabAll.length; tb_i++) {
? lso_childTab.classList.remove('lso-tab-active');+ tabAll[tb_i].setAttribute("maintabs-num", mb_i);
? lso_childList.classList.remove('lso-list-active');+ tabAll[tb_i].setAttribute("tabtabs-num", tb_i);
? }+ var item = tabAll[tb_i];
? var lsof_k = 0;+ item.addEventListener("click", function (event) {
? while (lsof_k < lsof_event.target.parentElement.querySelectorAll('.lso-tab').length) {+ tabFun = document.querySelectorAll(".tab-item");
? if (lsof_event.target.parentElement.querySelectorAll('.lso-tab')[lsof_k].classList.contains('lso-clickClass')) {+ listFun = document.querySelectorAll(".list-item");
? lsof_event.target.parentElement.querySelectorAll('.lso-tab')[lsof_k].classList.remove('lso-clickClass');+ eventMainAtr = event.target.getAttribute("maintabs-num");
? lsof_event.target.parentElement.querySelectorAll('.lso-tab')[lsof_k].classList.add('lso-tab-active');+ eventTabAtr = event.target.getAttribute("tabtabs-num");
? lsof_event.target.parentElement.parentElement.querySelector('.lso-lists').querySelectorAll('.lso-list')[lsof_k].classList.add('lso-list-active');+ for (mb_j = 0; mb_j < tabFun.length; mb_j++) {
? }+ if (tabFun[mb_j].getAttribute("maintabs-num") === eventMainAtr) {
? lsof_k++;+ tabFun[mb_j].classList.remove("t-active");
? }+ }
? })+ }
? }+ for (mb_j = 0; mb_j < listFun.length; mb_j++) {
 + if (listFun[mb_j].getAttribute("maintabs-num") === eventMainAtr) {
 + listFun[mb_j].classList.remove("l-active");
 + }
 + }
 + listTarget = document.querySelector(
 + '[maintabs-num="' +
 + eventMainAtr +
 + '"][listtabs-num="' +
 + eventTabAtr +
 + '"]'
 + );
 + event.target.classList.add("t-active");
 + listTarget.classList.add("l-active");
 + });
 + }
 + for (lb_i = 0; lb_i < listAll.length; lb_i++) {
 + listAll[lb_i].setAttribute("maintabs-num", mb_i);
 + listAll[lb_i].setAttribute("listtabs-num", lb_i);
 + }
 +}
 +if (tlbAll.length > 0) {
 + var tabZero = document.querySelectorAll('.tab-item[tabtabs-num="' + 0 + '"]');
 + var listZero = document.querySelectorAll('.list-item[listtabs-num="' + 0 + '"]');
 + for (tz_i = 0; tz_i < tabZero.length; tz_i++) {
 + tabZero[tz_i].classList.add("t-active");
 + }
 + for (lz_i = 0; lz_i < listZero.length; lz_i++) {
 + listZero[lz_i].classList.add("l-active");
 + }
 } }

Текущая версия на 16:42, 28 сентября 2023

//Получение всех блоков с табами
var tlbAll = document.querySelectorAll(".main-tlb");
//Выдаём каждому табу уникальный номер
for (mb_i = 0; mb_i < tlbAll.length; mb_i++) {
    tlbAll[mb_i].setAttribute("maintabs-num", mb_i);
    //Получаем табы и листы на первом уровне вложенности
    var tabAll = tlbAll[mb_i].querySelectorAll(
        '[maintabs-num="' + mb_i + '"] > * > .tab-item:nth-child(1n)'
    );
    var listAll = tlbAll[mb_i].querySelectorAll(
        '[maintabs-num="' + mb_i + '"] > .list-item:nth-child(1n)'
    );
    //Даём каждому табу номер блока и номер таба
    for (tb_i = 0; tb_i < tabAll.length; tb_i++) {
        tabAll[tb_i].setAttribute("maintabs-num", mb_i);
        tabAll[tb_i].setAttribute("tabtabs-num", tb_i);
        var item = tabAll[tb_i];
        item.addEventListener("click", function (event) {
            tabFun = document.querySelectorAll(".tab-item");
            listFun = document.querySelectorAll(".list-item");
            eventMainAtr = event.target.getAttribute("maintabs-num");
            eventTabAtr = event.target.getAttribute("tabtabs-num");
            for (mb_j = 0; mb_j < tabFun.length; mb_j++) {
                if (tabFun[mb_j].getAttribute("maintabs-num") === eventMainAtr) {
                    tabFun[mb_j].classList.remove("t-active");
                }
            }
            for (mb_j = 0; mb_j < listFun.length; mb_j++) {
                if (listFun[mb_j].getAttribute("maintabs-num") === eventMainAtr) {
                    listFun[mb_j].classList.remove("l-active");
                }
            }
            listTarget = document.querySelector(
                '[maintabs-num="' +
                eventMainAtr +
                '"][listtabs-num="' +
                eventTabAtr +
                '"]'
            );
            event.target.classList.add("t-active");
            listTarget.classList.add("l-active");
        });
    }
    for (lb_i = 0; lb_i < listAll.length; lb_i++) {
        listAll[lb_i].setAttribute("maintabs-num", mb_i);
        listAll[lb_i].setAttribute("listtabs-num", lb_i);
    }
}
if (tlbAll.length > 0) {
    var tabZero = document.querySelectorAll('.tab-item[tabtabs-num="' + 0 + '"]');
    var listZero = document.querySelectorAll('.list-item[listtabs-num="' + 0 + '"]');
    for (tz_i = 0; tz_i < tabZero.length; tz_i++) {
        tabZero[tz_i].classList.add("t-active");
    }
    for (lz_i = 0; lz_i < listZero.length; lz_i++) {
        listZero[lz_i].classList.add("l-active");
    }
}