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

Материал из База знаний АО АСП
Перейти к навигации Перейти к поиску
Нет описания правки
Метка: отменено
Полностью удалено содержимое страницы
Метки: очистка ручная отмена
Строка 1: Строка 1:
$(document).ready(function() {
    console.log("Скрипт дерева категорий загружен.");


    function saveTreeHTML() {
        console.log("Сохраняем HTML дерева...");
        var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').prop('outerHTML');
        localStorage.setItem('categoryTreeHTML', treeHTML);
        var expandedCategories = [];
        $('#p-categorytree-portlet .CategoryTreeItem.expanded').each(function() {
            expandedCategories.push($(this).text().trim());
        });
        localStorage.setItem('expandedCategories', JSON.stringify(expandedCategories));
    }
    function restoreTreeHTML() {
        console.log("Восстанавливаем HTML дерева...");
        var treeHTML = localStorage.getItem('categoryTreeHTML');
        if (treeHTML) {
            $('#p-categorytree-portlet .CategoryTreeTag').replaceWith(treeHTML);
        }
        // Восстанавливаем только верхние уровни категорий
        var expandedCategories = JSON.parse(localStorage.getItem('expandedCategories')) || [];
        $('#p-categorytree-portlet .CategoryTreeItem').each(function() {
            var categoryName = $(this).text().trim();
            if (expandedCategories.includes(categoryName)) {
                $(this).find('.CategoryTreeToggle').first().click();
            }
        });
        // Повторно навешиваем обработчики событий
        attachCategoryEvents();
    }
    function attachCategoryEvents() {
        console.log("Повторно навешиваем обработчики событий...");
        $('body').off('click', '#p-categorytree-portlet .CategoryTreeItem').on('click', '#p-categorytree-portlet .CategoryTreeItem', function(event) {
            var $target = $(event.target);
            var $item = $(this);
            var $toggleButton = $item.find('.CategoryTreeToggle').first();
            var isCategory = !$item.find('.CategoryTreePageBullet').length;
            if ($target.hasClass('CategoryTreeToggle')) return;
            if ($target.is('a') && isCategory) {
                event.preventDefault();
                $toggleButton.click();
            } else if (isCategory) {
                $toggleButton.click();
            } else {
                var link = $item.find('a').attr('href');
                if (link) {
                    saveTreeHTML();
                    localStorage.setItem('lastOpenedPageTitle', $item.text().trim());
                    window.location.href = link;
                }
            }
            saveTreeHTML();
        });
    }
    restoreTreeHTML();
    function scrollToCategory(categoryTitle, callback) {
        var $categoryItem = $('#p-categorytree-portlet .CategoryTreeItem').filter(function() {
            return $(this).text().trim() === categoryTitle;
        });
        if ($categoryItem.length) {
            console.log("Категория найдена, перематываем...");
            $('#p-categorytree-portlet').animate({
                scrollTop: $categoryItem.position().top - 50
            }, 500, function() {
                $('.CategoryTreeItem').removeClass('highlighted');
                $categoryItem.addClass('highlighted');
                if (callback) callback(true);
            });
            localStorage.setItem('highlightedCategory', categoryTitle);
            return true;
        }
        if (callback) callback(false);
        return false;
    }
    function expandAndFindCategory($parent, callback) {
        var $toggleButton = $parent.find('.CategoryTreeToggle').first();
        if ($toggleButton.length && !$parent.hasClass('expanded')) {
            console.log("Раскрываем:", $parent.text().trim());
            $toggleButton.click();
            setTimeout(function() {
                if (scrollToCategory(mw.config.get('wgTitle'))) {
                    callback(true);
                } else {
                    callback(false);
                }
            }, 1000);
        } else {
            callback(false);
        }
    }
    function recursiveSearchForCategory() {
        console.log("Очищаем `localStorage` перед поиском...");
        localStorage.removeItem('lastOpenedPageTitle');
        localStorage.removeItem('highlightedCategory');
        var currentPageTitle = mw.config.get('wgTitle');
        if (!currentPageTitle) {
            console.log("Не удалось определить текущую страницу.");
            return;
        }
        console.log("Начинаем поиск категории для текущей страницы:", currentPageTitle);
        let found = false;
        let searchTimeout = setTimeout(() => {
            if (!found) {
                console.log("Категория не найдена за 100мс, подменяем на `Категория:Начало`...");
                currentPageTitle = "Категория:Начало";
                searchAndExpandCategory(currentPageTitle);
            }
        }, 100);
        function searchAndExpandCategory(title) {
            if (scrollToCategory(title)) {
                found = true;
                clearTimeout(searchTimeout);
                return;
            }
            var $categoryItems = $('#p-categorytree-portlet .CategoryTreeItem');
            var index = 0;
            function processNext() {
                if (index >= $categoryItems.length) {
                    console.log("Категория не найдена, подменяем на `Категория:Начало`...");
                    searchAndExpandCategory("Категория:Начало");
                    return;
                }
                var $item = $($categoryItems[index]);
                expandAndFindCategory($item, function(foundItem) {
                    if (!foundItem) {
                        index++;
                        processNext();
                    }
                });
            }
            processNext();
        }
        searchAndExpandCategory(currentPageTitle);
    }
    setTimeout(function() {
        recursiveSearchForCategory();
    }, 500);
    $(window).on('beforeunload', saveTreeHTML);
    // Первичная инициализация обработчиков событий
    attachCategoryEvents();
});

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