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

Материал из База знаний АО АСП
Перейти к навигации Перейти к поиску
Нет описания правки
Метка: отменено
Нет описания правки
Метка: отменено
Строка 5: Строка 5:
     function saveTreeHTML() {
     function saveTreeHTML() {
         console.log("Сохраняем HTML дерева...");
         console.log("Сохраняем HTML дерева...");
         var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').html();
         var treeHTML = $('.CategoryTreeTag').html();
         localStorage.setItem('categoryTreeHTML', treeHTML);
         localStorage.setItem('categoryTreeHTML', treeHTML);
        console.log("HTML дерева сохранен:", treeHTML);
     }
     }


Строка 14: Строка 15:
         var treeHTML = localStorage.getItem('categoryTreeHTML');
         var treeHTML = localStorage.getItem('categoryTreeHTML');
         if (treeHTML) {
         if (treeHTML) {
             console.log("HTML дерева найден в localStorage, восстанавливаем...");
             console.log("HTML дерева из localStorage:", treeHTML);
             $('#p-categorytree-portlet .CategoryTreeTag').html(treeHTML);
             $('.CategoryTreeTag').html(treeHTML);
            console.log("HTML дерева восстановлен.");
         } else {
         } else {
             console.log("HTML дерева в localStorage не найден.");
             console.log("HTML дерева в localStorage не найден.");
            // Если дерево не сохранено, разворачиваем и сворачиваем его, а затем сохраняем
            expandAndCollapseAll(function() {
                saveTreeHTML();
                console.log("Дерево развернуто, свернуто и сохранено в localStorage.");
            });
         }
         }
     }
     }


     // Функция для разворачивания и сворачивания всех категорий
     // Восстанавливаем HTML дерева при загрузке страницы
     function expandAndCollapseAll(callback) {
     restoreTreeHTML();
        var $toggleButtons = $('#p-categorytree-portlet .CategoryTreeToggle');
        var index = 0;


        function processNext() {
    // Делегируем обработку кликов на body
            if (index >= $toggleButtons.length) {
     $('body').on('click', '.CategoryTreeItem', function(event) {
                console.log("Разворачивание и сворачивание завершено.");
                if (callback) {
                    callback();
                }
                return;
            }
 
            var $toggleButton = $($toggleButtons[index]);
            console.log("Кликаем на кнопку: " + $toggleButton.data('ct-title'));
            $toggleButton.click();
            index++;
 
            // Задержка перед следующим кликом
            setTimeout(processNext, 50); // Можно поэкспериментировать со значением задержки
        }
 
        console.log("Начинаем разворачивать и сворачивать все категории...");
        processNext();
    }
 
     $('body').on('click', '#p-categorytree-portlet .CategoryTreeItem', function(event) {
         var $target = $(event.target);
         var $target = $(event.target);
         var $item = $(this);
         var $item = $(this); // Текущий элемент CategoryTreeItem
         var $toggleButton = $item.find('.CategoryTreeToggle').first();
         var $toggleButton = $item.find('.CategoryTreeToggle').first();
         var isCategory = !$item.find('.CategoryTreePageBullet').length;
         var isCategory = !$item.find('.CategoryTreePageBullet').length; // Является ли элементом категорией


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


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


    function scrollToCategory(categoryTitle) {
     // Сохраняем HTML дерева при выгрузке страницы (например, при закрытии вкладки)
        var $categoryItem = $('#p-categorytree-portlet .CategoryTreeItem').filter(function() {
     $(window).on('beforeunload', saveTreeHTML);
            return $(this).text().trim() === categoryTitle;
        });
 
        if ($categoryItem.length) {
            console.log("Категория найдена, перематываем...");
            $('#p-categorytree-portlet').animate({
                scrollTop: $categoryItem.position().top - 50
            }, 500, function() {
                $('#p-categorytree-portlet .CategoryTreeItem').removeClass('highlighted');
                $categoryItem.addClass('highlighted');
            });
            return true;
        }
 
        return false;
    }
 
    function recursiveSearchForCategory() {
        var currentPageTitle = mw.config.get('wgTitle');
        if (!currentPageTitle) {
            console.log("Не удалось определить текущую страницу.");
            return;
        }
 
        console.log("Начинаем поиск категории для текущей страницы:", currentPageTitle);
 
        if (scrollToCategory(currentPageTitle)) {
            return;
        }
    }
 
     // Вызываем функцию для восстановления дерева при загрузке страницы
     $(document).ready(function() {
        restoreTreeHTML();
 
        // Отложенный вызов recursiveSearchForCategory
        setTimeout(function() {
            recursiveSearchForCategory();
        }, 500);
    });
});
});

Версия от 09:51, 27 февраля 2025

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

    // Функция для сохранения HTML дерева в localStorage
    function saveTreeHTML() {
        console.log("Сохраняем HTML дерева...");
        var treeHTML = $('.CategoryTreeTag').html();
        localStorage.setItem('categoryTreeHTML', treeHTML);
        console.log("HTML дерева сохранен:", treeHTML);
    }

    // Функция для восстановления HTML дерева из localStorage
    function restoreTreeHTML() {
        console.log("Восстанавливаем HTML дерева...");
        var treeHTML = localStorage.getItem('categoryTreeHTML');
        if (treeHTML) {
            console.log("HTML дерева из localStorage:", treeHTML);
            $('.CategoryTreeTag').html(treeHTML);
            console.log("HTML дерева восстановлен.");
        } else {
            console.log("HTML дерева в localStorage не найден.");
        }
    }

    // Восстанавливаем HTML дерева при загрузке страницы
    restoreTreeHTML();

    // Делегируем обработку кликов на 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; // Является ли элементом категорией

        // 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);
                    // Сохраняем HTML дерева перед переходом
                     saveTreeHTML();
                     window.location.href = link;
                  }
        }
        // Сохраняем HTML дерева после каждого клика
        saveTreeHTML();
    });

    // Сохраняем HTML дерева при выгрузке страницы (например, при закрытии вкладки)
    $(window).on('beforeunload', saveTreeHTML);
});