Добро пожаловать на Леста Игры Wiki!

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

Перейти к: навигация, поиск
Версия 15:14, 17 сентября 2023
Временный код для теста
Текущая версия на 16:42, 28 сентября 2023 
не показано 7 промежуточных версии этого же участника
Строка 1:Строка 1:
?listSelectorObjBase = document.querySelectorAll('.list-selector-object');+//Получение всех блоков с табами
? +var tlbAll = document.querySelectorAll(".main-tlb");
?for (var i = 0; i < listSelectorObjBase.length; i++) {+//Выдаём каждому табу уникальный номер
? document.querySelectorAll('.lso-tabs')[i].querySelectorAll('.lso-tab')[0].classList.add('lso-tab-active');+for (mb_i = 0; mb_i < tlbAll.length; mb_i++) {
? document.querySelectorAll('.lso-lists')[i].querySelectorAll('.lso-list')[0].classList.add('lso-list-active');+ tlbAll[mb_i].setAttribute("maintabs-num", mb_i);
? for (d = 0; d < listSelectorObjBase[i].querySelectorAll('.lso-tab').length; d++) {+ //Получаем табы и листы на первом уровне вложенности
? var item = listSelectorObjBase[i].querySelectorAll('.lso-tab')[d];+ var tabAll = tlbAll[mb_i].querySelectorAll(
? item.addEventListener('click', function(event) {+ '[maintabs-num="' + mb_i + '"] > * > .tab-item:nth-child(1n)'
? event.preventDefault();+ );
? event.target.classList.add('lso-clickClass');+ var listAll = tlbAll[mb_i].querySelectorAll(
? for (b = 0; b < event.target.parentElement.querySelectorAll('.lso-tab').length; b++) {+ '[maintabs-num="' + mb_i + '"] > .list-item:nth-child(1n)'
? var child = event.target.parentElement.querySelectorAll('.lso-tab')[b];+ );
? child.classList.remove('lso-tab-active');+ //Даём каждому табу номер блока и номер таба
? }+ for (tb_i = 0; tb_i < tabAll.length; tb_i++) {
? for (b = 0; b < event.target.parentElement.parentElement.querySelector('.lso-lists').querySelectorAll('.lso-list').length; b++) {+ tabAll[tb_i].setAttribute("maintabs-num", mb_i);
? var child = event.target.parentElement.parentElement.querySelector('.lso-lists').querySelectorAll('.lso-list')[b];+ tabAll[tb_i].setAttribute("tabtabs-num", tb_i);
? child.classList.remove('lso-list-active');+ 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");
 + }
  }  }
? var j = 0;+ for (mb_j = 0; mb_j < listFun.length; mb_j++) {
? while (j < event.target.parentElement.querySelectorAll('.lso-tab').length) {+ if (listFun[mb_j].getAttribute("maintabs-num") === eventMainAtr) {
? if(event.target.parentElement.querySelectorAll('.lso-tab')[j].classList.contains('lso-clickClass')) {+ listFun[mb_j].classList.remove("l-active");
? event.target.parentElement.querySelectorAll('.lso-tab')[j].classList.remove('lso-clickClass');+
? event.target.parentElement.querySelectorAll('.lso-tab')[j].classList.add('lso-tab-active');+
? event.target.parentElement.parentElement.querySelector('.lso-lists').querySelectorAll('.lso-list')[j].classList.add('lso-list-active');+
  }  }
? j++; 
  }  }
? })+ 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");
    }
}