MediaWiki:Common.js

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

Замечание: Возможно, после публикации вам придётся очистить кэш своего браузера, чтобы увидеть изменения.

  • Firefox / Safari: Удерживая клавишу Shift, нажмите на панели инструментов Обновить либо нажмите Ctrl+F5 или Ctrl+R (⌘+R на Mac)
  • Google Chrome: Нажмите Ctrl+Shift+R (⌘+Shift+R на Mac)
  • Edge: Удерживая Ctrl, нажмите Обновить либо нажмите Ctrl+F5
  • Opera: Нажмите Ctrl+F5.
$(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();
                $toggleButton.click(); // Раскрываем категорию
            } else {
                // Если категория раскрыта, даем перейти по ссылке и сворачиваем
                 console.log("Клик по ссылке категории, категория раскрыта, сворачиваем:", $target.attr('href'));
                 $toggleButton.click(); // Сворачиваем категорию
            }
        }

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