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

Материал из База знаний АО АСП
Перейти к навигации Перейти к поиску
Нет описания правки
Нет описания правки
Строка 14: Строка 14:
         }
         }


         // 2. Если клик по ссылке, предотвращаем переход, если категория не раскрыта
         // 2. Если клик по ссылке категории, и это не страница
        // и если это не страница
         if ($target.is('a') && !$item.find('.CategoryTreePageBullet').length) {
         if ($target.is('a') && !$item.find('.CategoryTreePageBullet').length && $toggleButton.attr('aria-expanded') === 'false') {
            // Блокируем переход, если категория не раскрыта
            console.log("Клик по ссылке категории, блокируем переход:", $target.attr('href'));
            if ($toggleButton.attr('aria-expanded') === 'false') {
            event.preventDefault();
                console.log("Клик по ссылке категории, блокируем переход и раскрываем:", $target.attr('href'));
                event.preventDefault();
            }
 
            // Раскрываем категорию (или сворачиваем, если уже раскрыта)
            console.log("Раскрываем/сворачиваем категорию:", $item.text().trim());
            $toggleButton.click(); // Эмулируем клик по кнопке
         }
         }


         // 3. Раскрываем/сворачиваем категорию, если клик был не по ссылке
         // 3. Раскрываем/сворачиваем категорию, если клик был не по ссылке и не по странице
        if (!$target.is('a')) {
        if (!$target.is('a') && !$item.find('.CategoryTreePageBullet').length) {
             console.log("Клик по элементу категории, переключаем состояние:", $item.text().trim());
             console.log("Клик по элементу категории, переключаем состояние:", $item.text().trim());
             $toggleButton.click(); // Эмулируем клик по кнопке
             $toggleButton.click(); // Эмулируем клик по кнопке

Версия от 07:35, 26 февраля 2025

$(document).ready(function() {
    console.log("Скрипт дерева категорий загружен.");

    // Делегируем обработку кликов на body
    $('body').on('click', '.CategoryTreeItem', function(event) {
        var $target = $(event.target);
        var $item = $(this); // Текущий элемент CategoryTreeItem
        var $toggleButton = $item.find('.CategoryTreeToggle').first();

        // 1. Если клик был на toggle-кнопке, ничего не делаем
        if ($target.hasClass('CategoryTreeToggle')) {
            console.log("Клик на кнопке раскрытия, ничего не делаем.");
            return;
        }

        // 2. Если клик по ссылке категории, и это не страница
        if ($target.is('a') && !$item.find('.CategoryTreePageBullet').length) {
            // Блокируем переход, если категория не раскрыта
            if ($toggleButton.attr('aria-expanded') === 'false') {
                console.log("Клик по ссылке категории, блокируем переход и раскрываем:", $target.attr('href'));
                event.preventDefault();
            }

            // Раскрываем категорию (или сворачиваем, если уже раскрыта)
            console.log("Раскрываем/сворачиваем категорию:", $item.text().trim());
            $toggleButton.click(); // Эмулируем клик по кнопке
        }

        // 3. Раскрываем/сворачиваем категорию, если клик был не по ссылке и не по странице
        if (!$target.is('a') && !$item.find('.CategoryTreePageBullet').length) {
            console.log("Клик по элементу категории, переключаем состояние:", $item.text().trim());
            $toggleButton.click(); // Эмулируем клик по кнопке
        }
    });
});