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

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


     // Делегируем обработку кликов на body
     // Делегируем обработку кликов на body
     $('body').on('click', '.CategoryTreeItem', function(event) {
     $('body').on('click', '#p-categorytree-portlet .CategoryTreeItem', function(event) {
         var $target = $(event.target);
         var $target = $(event.target);
         var $item = $(this); // Текущий элемент CategoryTreeItem
         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; // Является ли элементом категорией
Строка 41: Строка 41:
         // 2. Если клик по ссылке категории
         // 2. Если клик по ссылке категории
         if ($target.is('a') && isCategory) {
         if ($target.is('a') && isCategory) {
            // Предотвращаем переход по ссылке
             event.preventDefault();
             event.preventDefault();
            // Переключаем состояние категории (раскрываем или сворачиваем)
             console.log("Клик по ссылке категории, переключаем состояние:", $target.attr('href'));
             console.log("Клик по ссылке категории, переключаем состояние:", $target.attr('href'));
             $toggleButton.click();
             $toggleButton.click();
         }
         }
        // 3. Если клик по элементу категории (не ссылке и не странице)
        // 3. Если клик по элементу категории (не ссылке и не странице)
         else if (isCategory) {
         else if (isCategory) {
            // Переключаем состояние категории (раскрываем или сворачиваем)
             console.log("Клик по категории (не ссылка), переключаем:", $item.text().trim());
             console.log("Клик по элементу категории (не ссылка), переключаем состояние:", $item.text().trim());
             $toggleButton.click();
             $toggleButton.click();
         }
         }
            // 4. Если клик по ссылке страницы или на элемент страницы
        // 4. Если клик по ссылке страницы
         else {
         else {
              // Получаем ссылку страницы
            var link = $item.find('a').attr('href');
                var link = $item.find('a').attr('href');
            if (link) {
              // Переходим по ссылке страницы
                console.log("Клик по элементу страницы, переходим:", link);
                if (link) {
                saveTreeHTML();
                    console.log("Клик по элементу страницы, переходим:", link);
                localStorage.setItem('lastOpenedPageTitle', $item.text().trim());
                    // Сохраняем HTML дерева перед переходом
                window.location.href = link;
                    saveTreeHTML();
            }
                    // Сохраняем заголовок страницы в localStorage
                      localStorage.setItem('lastOpenedPageTitle', $item.text().trim());
                    window.location.href = link;
                  }
         }
         }
         // Сохраняем HTML дерева после каждого клика
         // Сохраняем HTML дерева после каждого клика
Строка 72: Строка 64:
     });
     });


     // Сохраняем HTML дерева при выгрузке страницы (например, при закрытии вкладки)
     // Прокручиваем ТОЛЬКО дерево категорий, а не всю страницу
    $(window).on('beforeunload', saveTreeHTML);
});
 
$(document).ready(function() {
    // После загрузки страницы
     setTimeout(function() {
     setTimeout(function() {
        // Получаем заголовок последней открытой страницы из localStorage
         var lastOpenedPageTitle = localStorage.getItem('lastOpenedPageTitle');
         var lastOpenedPageTitle = localStorage.getItem('lastOpenedPageTitle');
        // Если заголовок есть в localStorage
         if (lastOpenedPageTitle) {
         if (lastOpenedPageTitle) {
             console.log("Последняя открытая страница:", lastOpenedPageTitle);
             console.log("Последняя открытая страница:", lastOpenedPageTitle);


            // Ищем элемент дерева категорий с таким заголовком
             var $lastOpenedItem = $('#p-categorytree-portlet .CategoryTreeItem').filter(function() {
             var $lastOpenedItem = $('.CategoryTreeItem').filter(function() {
                 return $(this).text().trim() === lastOpenedPageTitle;
                 return $(this).text().trim() === lastOpenedPageTitle;
             });
             });


            // Если элемент найден
             if ($lastOpenedItem.length) {
             if ($lastOpenedItem.length) {
                 console.log("Элемент найден, прокручиваем к нему.");
                 console.log("Элемент найден, прокручиваем только дерево категорий.");


                 // Прокручиваем страницу к элементу
                 // Прокручиваем ТОЛЬКО контейнер категорий, а не всю страницу
                 $('html, body').animate({
                 $('#p-categorytree-portlet').animate({
                     scrollTop: $lastOpenedItem.offset().top - 100 // Вычитаем 100px, чтобы элемент не прилипал к верху страницы
                     scrollTop: $lastOpenedItem.position().top - 50
                 }, 500);
                 }, 500);


                // Удаляем заголовок из localStorage, чтобы больше не прокручивать
                 localStorage.removeItem('lastOpenedPageTitle');
                 localStorage.removeItem('lastOpenedPageTitle');
             } else {
             } else {
Строка 108: Строка 89:
             console.log("Заголовок последней открытой страницы не найден.");
             console.log("Заголовок последней открытой страницы не найден.");
         }
         }
     }, 500); // Задержка в 500 миллисекунд
     }, 500);
 
    // Сохраняем HTML дерева при выгрузке страницы (например, при закрытии вкладки)
    $(window).on('beforeunload', saveTreeHTML);
});
});

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

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

    // Функция для сохранения HTML дерева в localStorage
    function saveTreeHTML() {
        console.log("Сохраняем HTML дерева...");
        var treeHTML = $('#p-categorytree-portlet .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);
            $('#p-categorytree-portlet .CategoryTreeTag').html(treeHTML);
            console.log("HTML дерева восстановлен.");
        } else {
            console.log("HTML дерева в localStorage не найден.");
        }
    }

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

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

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

    // Прокручиваем ТОЛЬКО дерево категорий, а не всю страницу
    setTimeout(function() {
        var lastOpenedPageTitle = localStorage.getItem('lastOpenedPageTitle');
        if (lastOpenedPageTitle) {
            console.log("Последняя открытая страница:", lastOpenedPageTitle);

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

            if ($lastOpenedItem.length) {
                console.log("Элемент найден, прокручиваем только дерево категорий.");

                // Прокручиваем ТОЛЬКО контейнер категорий, а не всю страницу
                $('#p-categorytree-portlet').animate({
                    scrollTop: $lastOpenedItem.position().top - 50
                }, 500);

                localStorage.removeItem('lastOpenedPageTitle');
            } else {
                console.log("Элемент не найден.");
            }
        } else {
            console.log("Заголовок последней открытой страницы не найден.");
        }
    }, 500);

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