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

Материал из База знаний АО АСП
Перейти к навигации Перейти к поиску
Нет описания правки
Метка: отменено
Нет описания правки
Метка: отменено
Строка 2: Строка 2:
     console.log("Скрипт дерева категорий загружен.");
     console.log("Скрипт дерева категорий загружен.");


     function scrollToCategory(categoryTitle, callback) {
    function saveTreeHTML() {
        console.log("Сохраняем HTML дерева...");
        var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').html();
        localStorage.setItem('categoryTreeHTML', treeHTML);
    }
 
    function restoreTreeHTML() {
        console.log("Восстанавливаем HTML дерева...");
        var treeHTML = localStorage.getItem('categoryTreeHTML');
        if (treeHTML) {
            $('#p-categorytree-portlet .CategoryTreeTag').html(treeHTML);
        }
    }
 
    restoreTreeHTML();
 
    $('body').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();
                // Переходим по ссылке без сохранения заголовка страницы
                window.location.href = link;
            }
        }
        //Сохраняем дерево после каждого клика уберём, чтоб не дёргало
        //saveTreeHTML();
    });
 
     function scrollToCategory(categoryTitle) {
         var $categoryItem = $('#p-categorytree-portlet .CategoryTreeItem').filter(function() {
         var $categoryItem = $('#p-categorytree-portlet .CategoryTreeItem').filter(function() {
             return $(this).text().trim() === categoryTitle;
             return $(this).text().trim() === categoryTitle;
Строка 12: Строка 54:
                 scrollTop: $categoryItem.position().top - 50
                 scrollTop: $categoryItem.position().top - 50
             }, 500, function() {
             }, 500, function() {
                 $('.CategoryTreeItem').removeClass('highlighted');
                // Убираем подсветку со всех элементов и добавляем только к текущему
                 $('#p-categorytree-portlet .CategoryTreeItem').removeClass('highlighted');
                 $categoryItem.addClass('highlighted');
                 $categoryItem.addClass('highlighted');
                if (callback) callback(true);
             });
             });
             return true;
             return true;
         }
         }


        if (callback) callback(false);
         return false;
         return false;
     }
     }


     function expandParentCategories($categoryItem, callback) {
     function expandAndFindCategory($parent, callback) {
         var $parentCategory = $categoryItem.closest('.CategoryTreeChildren').prev('.CategoryTreeItem');
         var $toggleButton = $parent.find('.CategoryTreeToggle').first();
        if ($parentCategory.length) {
        if ($toggleButton.length && !$parent.hasClass('expanded')) {
            var $toggleButton = $parentCategory.find('.CategoryTreeToggle').first();
            $toggleButton.click();
            if ($toggleButton.length && !$parentCategory.hasClass('expanded')) {
 
                console.log("Раскрываем родительскую категорию:", $parentCategory.text().trim());
            setTimeout(function() {
                $toggleButton.click();
                 if (scrollToCategory(mw.config.get('wgTitle'))) {
                 setTimeout(function() {
                     callback(true);
                     expandParentCategories($parentCategory, callback);
                 } else {
                 }, 800);
                    callback(false);
            } else {
                }
                callback();
             }, 1000);
             }
         } else {
         } else {
             callback();
             callback(false);
         }
         }
     }
     }


     function recursiveSearchForCategory() {
     function recursiveSearchForCategory() {
        // Убираем очистку localStorage, т.к. больше не используем lastOpenedPageTitle
         var currentPageTitle = mw.config.get('wgTitle');
         var currentPageTitle = mw.config.get('wgTitle');
         if (!currentPageTitle) {
         if (!currentPageTitle) {
Строка 51: Строка 91:
         console.log("Начинаем поиск категории для текущей страницы:", currentPageTitle);
         console.log("Начинаем поиск категории для текущей страницы:", currentPageTitle);


        var $categoryItem = $('#p-categorytree-portlet .CategoryTreeItem').filter(function() {
         if (scrollToCategory(currentPageTitle)) {
            return $(this).text().trim() === currentPageTitle;
        });
 
         if ($categoryItem.length) {
            expandParentCategories($categoryItem, function() {
                scrollToCategory(currentPageTitle);
            });
             return;
             return;
         }
         }


        console.log("Категория не найдена сразу, начинаем раскрытие...");
         var $categoryItems = $('#p-categorytree-portlet .CategoryTreeItem');
         var $categoryItems = $('#p-categorytree-portlet .CategoryTreeItem');
         var index = 0;
         var index = 0;
Строка 73: Строка 105:


             var $item = $($categoryItems[index]);
             var $item = $($categoryItems[index]);
             expandParentCategories($item, function() {
             expandAndFindCategory($item, function(found) {
                 if (!scrollToCategory(currentPageTitle)) {
                 if (!found) {
                     index++;
                     index++;
                     processNext();
                     processNext();
Строка 87: Строка 119:
         recursiveSearchForCategory();
         recursiveSearchForCategory();
     }, 500);
     }, 500);
    $(window).on('beforeunload', saveTreeHTML);
});
});

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

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

    function saveTreeHTML() {
        console.log("Сохраняем HTML дерева...");
        var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').html();
        localStorage.setItem('categoryTreeHTML', treeHTML);
    }

    function restoreTreeHTML() {
        console.log("Восстанавливаем HTML дерева...");
        var treeHTML = localStorage.getItem('categoryTreeHTML');
        if (treeHTML) {
            $('#p-categorytree-portlet .CategoryTreeTag').html(treeHTML);
        }
    }

    restoreTreeHTML();

    $('body').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();
                // Переходим по ссылке без сохранения заголовка страницы
                window.location.href = link;
            }
        }
        //Сохраняем дерево после каждого клика уберём, чтоб не дёргало
        //saveTreeHTML();
    });

    function scrollToCategory(categoryTitle) {
        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() {
                // Убираем подсветку со всех элементов и добавляем только к текущему
                $('#p-categorytree-portlet .CategoryTreeItem').removeClass('highlighted');
                $categoryItem.addClass('highlighted');
            });
            return true;
        }

        return false;
    }

    function expandAndFindCategory($parent, callback) {
        var $toggleButton = $parent.find('.CategoryTreeToggle').first();
        if ($toggleButton.length && !$parent.hasClass('expanded')) {
            $toggleButton.click();

            setTimeout(function() {
                if (scrollToCategory(mw.config.get('wgTitle'))) {
                    callback(true);
                } else {
                    callback(false);
                }
            }, 1000);
        } else {
            callback(false);
        }
    }

    function recursiveSearchForCategory() {
        // Убираем очистку localStorage, т.к. больше не используем lastOpenedPageTitle
        var currentPageTitle = mw.config.get('wgTitle');
        if (!currentPageTitle) {
            console.log("Не удалось определить текущую страницу.");
            return;
        }

        console.log("Начинаем поиск категории для текущей страницы:", currentPageTitle);

        if (scrollToCategory(currentPageTitle)) {
            return;
        }

        var $categoryItems = $('#p-categorytree-portlet .CategoryTreeItem');
        var index = 0;

        function processNext() {
            if (index >= $categoryItems.length) {
                console.log("Категория для текущей страницы не найдена.");
                return;
            }

            var $item = $($categoryItems[index]);
            expandAndFindCategory($item, function(found) {
                if (!found) {
                    index++;
                    processNext();
                }
            });
        }

        processNext();
    }

    setTimeout(function() {
        recursiveSearchForCategory();
    }, 500);

    $(window).on('beforeunload', saveTreeHTML);
});