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

Материал из База знаний АО АСП
Перейти к навигации Перейти к поиску
Нет описания правки
Метка: отменено
Нет описания правки
Метки: ручная отмена отменено
Строка 4: Строка 4:
     function saveTreeHTML() {
     function saveTreeHTML() {
         console.log("Сохраняем HTML дерева...");
         console.log("Сохраняем HTML дерева...");
         var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').html();
         var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').prop('outerHTML');
         localStorage.setItem('categoryTreeHTML', treeHTML);
         localStorage.setItem('categoryTreeHTML', treeHTML);
        // Сохраняем только ОТКРЫТЫЕ категории
        var expandedCategories = [];
        $('#p-categorytree-portlet .CategoryTreeItem.expanded').each(function() {
            expandedCategories.push($(this).text().trim());
        });
        localStorage.setItem('expandedCategories', JSON.stringify(expandedCategories));
     }
     }


Строка 20: Строка 13:
         var treeHTML = localStorage.getItem('categoryTreeHTML');
         var treeHTML = localStorage.getItem('categoryTreeHTML');
         if (treeHTML) {
         if (treeHTML) {
             $('#p-categorytree-portlet .CategoryTreeTag').html(treeHTML);
             $('#p-categorytree-portlet .CategoryTreeTag').replaceWith(treeHTML);
         }
         }


         // Восстанавливаем ТОЛЬКО верхние уровни категорий
         // Повторно навешиваем обработчики событий после восстановления
         var expandedCategories = JSON.parse(localStorage.getItem('expandedCategories')) || [];
         attachCategoryEvents();
        $('#p-categorytree-portlet .CategoryTreeItem').each(function() {
            var categoryName = $(this).text().trim();
            if (expandedCategories.includes(categoryName)) {
                $(this).find('.CategoryTreeToggle').first().click();
            }
        });
     }
     }


     restoreTreeHTML();
     function attachCategoryEvents() {
        console.log("Навешиваем обработчики событий...");


    $('body').on('click', '#p-categorytree-portlet .CategoryTreeItem', function(event) {
        $('body').off('click', '#p-categorytree-portlet .CategoryTreeItem').on('click', '#p-categorytree-portlet .CategoryTreeItem', function(event) {
        var $target = $(event.target);
            var $target = $(event.target);
        var $item = $(this);
            var $item = $(this);
        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;
            if ($target.hasClass('CategoryTreeToggle')) return;


        if ($target.is('a') && isCategory) {
            if ($target.is('a') && isCategory) {
            event.preventDefault();
                event.preventDefault();
            $toggleButton.click();
                $toggleButton.click();
        } else if (isCategory) {
            } else if (isCategory) {
            $toggleButton.click();
                $toggleButton.click();
        } else {
            } else {
            var link = $item.find('a').attr('href');
                var link = $item.find('a').attr('href');
            if (link) {
                if (link) {
                saveTreeHTML();
                    saveTreeHTML();
                localStorage.setItem('lastOpenedPageTitle', $item.text().trim());
                    localStorage.setItem('lastOpenedPageTitle', $item.text().trim());
                window.location.href = link;
                    window.location.href = link;
                }
             }
             }
         }
            saveTreeHTML();
        saveTreeHTML();
         });
     });
     }
 
    restoreTreeHTML();


     function scrollToCategory(categoryTitle, callback) {
     function scrollToCategory(categoryTitle, callback) {
Строка 74: Строка 65:
             });
             });


            localStorage.setItem('highlightedCategory', categoryTitle);
             return true;
             return true;
         }
         }
Строка 82: Строка 72:
     }
     }


     function expandAndFindCategory($parent, callback) {
     function expandParentCategories($categoryItem, callback) {
         var $toggleButton = $parent.find('.CategoryTreeToggle').first();
         var $parentCategory = $categoryItem.closest('.CategoryTreeChildren').prev('.CategoryTreeItem');
        if ($toggleButton.length && !$parent.hasClass('expanded')) {
        if ($parentCategory.length) {
            console.log("Раскрываем:", $parent.text().trim());
            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(false);
             callback();
         }
         }
    }
    function resetCategoryTree() {
        console.log("Категория не найдена. Очищаем данные и сбрасываем дерево.");
        localStorage.removeItem('categoryTreeHTML');
        localStorage.removeItem('lastOpenedPageTitle');
        localStorage.removeItem('highlightedCategory');
        localStorage.removeItem('expandedCategories');
        // Оставляем верхний уровень категорий открытым
        $('#p-categorytree-portlet .CategoryTreeItem').each(function() {
            if ($(this).parents('.CategoryTreeChildren').length === 0) {
                $(this).find('.CategoryTreeToggle').first().click();
            }
        });
     }
     }


Строка 118: Строка 93:
         console.log("Очищаем `localStorage` перед поиском...");
         console.log("Очищаем `localStorage` перед поиском...");
         localStorage.removeItem('lastOpenedPageTitle');
         localStorage.removeItem('lastOpenedPageTitle');
        localStorage.removeItem('highlightedCategory');


         var currentPageTitle = mw.config.get('wgTitle');
         var currentPageTitle = mw.config.get('wgTitle');
Строка 126: Строка 100:
         }
         }


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


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


         var $categoryItems = $('#p-categorytree-portlet .CategoryTreeItem');
         console.log("Категория не найдена, привязываемся к `Начало`...");
        if ($categoryItems.length === 0) {
            resetCategoryTree();
            return;
        }


         var index = 0;
         var $startCategory = $('#p-categorytree-portlet .CategoryTreeItem').filter(function() {
        function processNext() {
             return $(this).text().trim().toLowerCase() === 'начало';
             if (index >= $categoryItems.length) {
        });
                console.log("Категория не найдена. Сбрасываем дерево.");
                resetCategoryTree();
                return;
            }


            var $item = $($categoryItems[index]);
        if ($startCategory.length) {
             expandAndFindCategory($item, function(found) {
             expandParentCategories($startCategory, function() {
                 if (!found) {
                 scrollToCategory('Начало');
                    index++;
                    processNext();
                }
             });
             });
        } else {
            console.log("Категория `Начало` тоже не найдена, ничего не делаем.");
         }
         }
        processNext();
     }
     }


Строка 163: Строка 133:


     $(window).on('beforeunload', saveTreeHTML);
     $(window).on('beforeunload', saveTreeHTML);
    // Первичная инициализация обработчиков событий
    attachCategoryEvents();
});
});

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

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

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

    function restoreTreeHTML() {
        console.log("Восстанавливаем HTML дерева...");

        var treeHTML = localStorage.getItem('categoryTreeHTML');
        if (treeHTML) {
            $('#p-categorytree-portlet .CategoryTreeTag').replaceWith(treeHTML);
        }

        // Повторно навешиваем обработчики событий после восстановления
        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);
            });

            return true;
        }

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

    function expandParentCategories($categoryItem, callback) {
        var $parentCategory = $categoryItem.closest('.CategoryTreeChildren').prev('.CategoryTreeItem');
        if ($parentCategory.length) {
            var $toggleButton = $parentCategory.find('.CategoryTreeToggle').first();
            if ($toggleButton.length && !$parentCategory.hasClass('expanded')) {
                console.log("Раскрываем родителя:", $parentCategory.text().trim());
                $toggleButton.click();
                setTimeout(function() {
                    expandParentCategories($parentCategory, callback);
                }, 800);
            } else {
                callback();
            }
        } else {
            callback();
        }
    }

    function recursiveSearchForCategory() {
        console.log("Очищаем `localStorage` перед поиском...");
        localStorage.removeItem('lastOpenedPageTitle');

        var currentPageTitle = mw.config.get('wgTitle');
        if (!currentPageTitle) {
            console.log("Не удалось определить текущую страницу.");
            return;
        }

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

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

        if ($categoryItem.length) {
            expandParentCategories($categoryItem, function() {
                scrollToCategory(currentPageTitle);
            });
            return;
        }

        console.log("Категория не найдена, привязываемся к `Начало`...");

        var $startCategory = $('#p-categorytree-portlet .CategoryTreeItem').filter(function() {
            return $(this).text().trim().toLowerCase() === 'начало';
        });

        if ($startCategory.length) {
            expandParentCategories($startCategory, function() {
                scrollToCategory('Начало');
            });
        } else {
            console.log("Категория `Начало` тоже не найдена, ничего не делаем.");
        }
    }

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

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

    // Первичная инициализация обработчиков событий
    attachCategoryEvents();
});