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

Материал из База знаний АО АСП
Перейти к навигации Перейти к поиску
Нет описания правки
Нет описания правки
Строка 8: Строка 8:
         var $toggleButton = $item.find('.CategoryTreeToggle').first();
         var $toggleButton = $item.find('.CategoryTreeToggle').first();
         var isCategory = !$item.find('.CategoryTreePageBullet').length; // Является ли элементом категорией
         var isCategory = !$item.find('.CategoryTreePageBullet').length; // Является ли элементом категорией
        var isExpanded = $toggleButton.attr('aria-expanded') === 'true';


         // 1. Если клик был на toggle-кнопке, ничего не делаем
         // 1. Если клик был на toggle-кнопке, ничего не делаем
Строка 17: Строка 18:
         // 2. Если клик по ссылке категории
         // 2. Если клик по ссылке категории
         if ($target.is('a') && isCategory) {
         if ($target.is('a') && isCategory) {
             // Если категория не раскрыта, блокируем переход и раскрываем
             // Предотвращаем переход по ссылке
             if ($toggleButton.attr('aria-expanded') === 'false') {
             event.preventDefault();
                console.log("Клик по ссылке категории, категория закрыта, блокируем переход и раскрываем:", $target.attr('href'));
 
                event.preventDefault();
            // Переключаем состояние категории (раскрываем или сворачиваем)
                $toggleButton.click(); // Раскрываем категорию
            console.log("Клик по ссылке категории, переключаем состояние:", $target.attr('href'));
            } else {
            $toggleButton.click();
                // Если категория раскрыта, просто сворачиваем её, переход по ссылке не нужен
        }
                console.log("Клик по ссылке категории, категория открыта, сворачиваем:", $target.attr('href'));
        // 3. Если клик по элементу категории (не ссылке и не странице)
                event.preventDefault(); // Предотвращаем переход по ссылке
        else if (isCategory) {
                $toggleButton.click(); // Сворачиваем категорию
            // Переключаем состояние категории (раскрываем или сворачиваем)
            }
            console.log("Клик по элементу категории (не ссылка), переключаем состояние:", $item.text().trim());
            $toggleButton.click();
         }
         }
            // 4. Если клик по ссылке страницы или на элемент страницы
        else  {
              // Получаем ссылку страницы
                var link = $item.find('a').attr('href');
              // Переходим по ссылке страницы
                if (link) {
                    console.log("Клик по элементу страницы, переходим:", link);
                    window.location.href = link;
                  }   


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

Версия от 12:57, 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();
        var isCategory = !$item.find('.CategoryTreePageBullet').length; // Является ли элементом категорией
        var isExpanded = $toggleButton.attr('aria-expanded') === 'true';

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

        // 2. Если клик по ссылке категории
        if ($target.is('a') && isCategory) {
            // Предотвращаем переход по ссылке
            event.preventDefault();

            // Переключаем состояние категории (раскрываем или сворачиваем)
            console.log("Клик по ссылке категории, переключаем состояние:", $target.attr('href'));
            $toggleButton.click();
        }
         // 3. Если клик по элементу категории (не ссылке и не странице)
        else if (isCategory) {
            // Переключаем состояние категории (раскрываем или сворачиваем)
            console.log("Клик по элементу категории (не ссылка), переключаем состояние:", $item.text().trim());
            $toggleButton.click();
        }
            // 4. Если клик по ссылке страницы или на элемент страницы
        else  {
              // Получаем ссылку страницы
                var link = $item.find('a').attr('href');
              // Переходим по ссылке страницы
                 if (link) {
                    console.log("Клик по элементу страницы, переходим:", link);
                     window.location.href = link;
                  }    

        }
    });
});