MediaWiki:Common.js
Замечание: Возможно, после публикации вам придётся очистить кэш своего браузера, чтобы увидеть изменения.
- Firefox / Safari: Удерживая клавишу Shift, нажмите на панели инструментов Обновить либо нажмите Ctrl+F5 или Ctrl+R (⌘+R на Mac)
- Google Chrome: Нажмите Ctrl+Shift+R (⌘+Shift+R на Mac)
- Edge: Удерживая Ctrl, нажмите Обновить либо нажмите Ctrl+F5
- Opera: Нажмите Ctrl+F5.
$(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);
});