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

Нет описания правки
Нет описания правки
 
(не показано 48 промежуточных версий этого же участника)
Строка 1: Строка 1:
$(document).ready(function () {
  document.querySelectorAll(".ext-link a").forEach(function(el) {
    el.setAttribute("target", "_blank");
    console.log("Скрипт открывания ссылок в новой вкладке загружен", highlightedCategory);
  });
});
$(document).ready(function () {
    // Если текущая страница — главная, сбрасываем localStorage
    if (mw.config.get('wgIsMainPage')) {
        console.log("Находимся на главной, сбрасываем сохранённое дерево");
        localStorage.removeItem('categoryTreeHTML');
        localStorage.removeItem('lastOpenedPageTitle');
        localStorage.removeItem('highlightedCategory');
    }
});
var highlightedCategory = localStorage.getItem('highlightedCategory');
if (highlightedCategory) {
    $('#p-categorytree-portlet').addClass('category-hidden');
    console.log("Скрыли при восстановлении по цели:", highlightedCategory);
}
//добавление кнопки вверх
$(document).ready(function () {
    // Создаём кнопку
    var $button = $('<div id="back-to-top">Вверх</div>').appendTo('body');
    // Показывать кнопку при прокрутке вниз
    $(window).scroll(function () {
        if ($(this).scrollTop() > 300) {
            $button.fadeIn();
        } else {
            $button.fadeOut();
        }
    });
    // Обработчик клика для плавного скролла вверх
    $button.click(function () {
        $('html, body').animate({ scrollTop: 0 }, 500);
        return false;
    });
});
//скрытие разделов и страниц если пусто
$(document).ready(function() {
$(document).ready(function() {
    console.log("JS скрипт для скрытия пустых разделов загружен.");
    function hideEmptySection(sectionId, listId) {
        var section = document.getElementById(sectionId);
        var list = document.getElementById(listId);
        if (!section || !list) {
            console.log(`Не найден элемент: ${section ? "список" : "заголовок"} для ${sectionId}`);
            return;
        }
        console.log(`Проверяем ${sectionId}: `, list.children.length, "элементов найдено.");
        if (list.children.length === 0) {
            section.style.display = "none";
            console.log(`Скрываем заголовок: ${sectionId}`);
        } else {
            console.log(`Оставляем заголовок: ${sectionId}`);
        }
    }
    // Проверяем и скрываем, если пустые
    hideEmptySection("section-header", "sections-list");
    hideEmptySection("pages-header", "page-list");
});
$(document).ready(function() {
     console.log("Скрипт дерева категорий загружен.");
     console.log("Скрипт дерева категорий загружен.");
    // Проверяем, авторизован ли пользователь
    var isUserLoggedIn = mw.config.get('wgUserName') !== null;


     function saveTreeHTML() {
     function saveTreeHTML() {
Строка 6: Строка 95:
         var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').prop('outerHTML');
         var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').prop('outerHTML');
         localStorage.setItem('categoryTreeHTML', treeHTML);
         localStorage.setItem('categoryTreeHTML', treeHTML);
     }
     }


     function restoreTreeHTML() {
     function restoreTreeHTML() {
Строка 14: Строка 107:
         if (treeHTML && treeHTML !== "undefined") {
         if (treeHTML && treeHTML !== "undefined") {
             $('#p-categorytree-portlet .CategoryTreeTag').replaceWith(treeHTML);
             $('#p-categorytree-portlet .CategoryTreeTag').replaceWith(treeHTML);
           
           
         } else {
         } else {
             console.log("Ошибка: Дерево категорий повреждено, сбрасываем...");
             console.log("Ошибка: Дерево категорий повреждено, сбрасываем...");
Строка 20: Строка 116:


         attachCategoryEvents();
         attachCategoryEvents();
     }
     }


Строка 52: Строка 149:


     function scrollToCategory(categoryTitle, callback) {
     function scrollToCategory(categoryTitle, callback) {
         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;
         });
         });


        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);
if ($categoryItem.length) {
            return true;
    console.log("Категория найдена, прокручиваем без анимации...");
        }
 
    var $portlet = $('#p-categorytree-portlet');
$portlet.addClass('category-hidden');
    // Выполняем прокрутку
    $portlet.scrollTop($categoryItem.position().top - 50);
 
    // Подсветка
    $('.CategoryTreeItem').removeClass('highlighted');
    $categoryItem.addClass('highlighted');
 
    // Показываем дерево
    setTimeout(function() {
        $portlet.removeClass('category-hidden');
        if (callback) callback(true);
    }, 0); // можно увеличить задержку при необходимости
 
    localStorage.setItem('highlightedCategory', categoryTitle);
    return true;
}
 
 
 


         if (callback) callback(false);
         if (callback) callback(false);
Строка 77: Строка 191:
         if (attempts > 1) {
         if (attempts > 1) {
             console.log("Категория не найдена даже после подмены, прекращаем попытки.");
             console.log("Категория не найдена даже после подмены, прекращаем попытки.");
       
        var $portlet = $('#p-categorytree-portlet');   
           
       
    localStorage.removeItem('categoryTreeHTML');
    localStorage.removeItem('lastOpenedPageTitle');
        localStorage.removeItem('highlightedCategory');
        console.log("Очистили всё");
        $portlet.removeClass('category-hidden');
             return;
             return;
         }
         }
Строка 99: Строка 223:
     }
     }


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


     $(window).on('beforeunload', saveTreeHTML);
     $(window).on('beforeunload', saveTreeHTML);
Строка 135: Строка 258:
});
});


//скрытие разделов и страниц если пусто
// Обработчик Ctrl+F5 для очистки localStorage
document.addEventListener("DOMContentLoaded", function() {
$(document).keydown(function(event) {
     console.log("JS скрипт для скрытия пустых разделов загружен.");
     if (event.ctrlKey && event.key === 'F2') {
 
        console.log("Ctrl+F2 нажато, очищаем localStorage...");
    function hideEmptySection(sectionId, listId) {
         localStorage.removeItem('categoryTreeHTML');
         var section = document.getElementById(sectionId);
         localStorage.removeItem('lastOpenedPageTitle');
         var list = document.getElementById(listId);
         localStorage.removeItem('highlightedCategory');
 
         $('#p-categorytree-portlet .CategoryTreeTag').remove(); // Удаляем дерево с страницы
         if (!section || !list) {
         location.reload();
            console.log(`Не найден элемент: ${section ? "список" : "заголовок"} для ${sectionId}`);
            return;
         }
 
        console.log(`Проверяем ${sectionId}: `, list.children.length, "элементов найдено.");
 
        if (list.children.length === 0) {
            section.style.display = "none";
            console.log(`Скрываем заголовок: ${sectionId}`);
         } else {
            console.log(`Оставляем заголовок: ${sectionId}`);
        }
     }
     }
    // Проверяем и скрываем, если пустые
    hideEmptySection("section-header", "sections-list");
    hideEmptySection("pages-header", "page-list");
});
});