MediaWiki:Common.js: различия между версиями
Перейти к навигации
Перейти к поиску
Shihov (обсуждение | вклад) Нет описания правки Метки: ручная отмена отменено |
Shihov (обсуждение | вклад) Нет описания правки Метка: отменено |
||
Строка 3: | Строка 3: | ||
function saveTreeHTML() { | function saveTreeHTML() { | ||
console.log("Сохраняем | console.log("Сохраняем текущее состояние дерева..."); | ||
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 saveInitialTreeState() { | |||
if (!localStorage.getItem('initialCategoryTree')) { | |||
console.log("Сохраняем начальное состояние дерева..."); | |||
var initialTreeHTML = $('#p-categorytree-portlet .CategoryTreeTag').prop('outerHTML'); | |||
localStorage.setItem('initialCategoryTree', initialTreeHTML); | |||
} | |||
} | } | ||
function restoreTreeHTML() { | function restoreTreeHTML() { | ||
console.log("Восстанавливаем | console.log("Восстанавливаем последнее сохраненное состояние дерева..."); | ||
var treeHTML = localStorage.getItem('categoryTreeHTML'); | var treeHTML = localStorage.getItem('categoryTreeHTML'); | ||
if (treeHTML) { | if (treeHTML) { | ||
Строка 16: | Строка 23: | ||
} | } | ||
attachCategoryEvents(); | attachCategoryEvents(); | ||
} | |||
function restoreInitialTreeState() { | |||
console.log("Восстанавливаем ИЗНАЧАЛЬНОЕ состояние дерева..."); | |||
var initialTreeHTML = localStorage.getItem('initialCategoryTree'); | |||
if (initialTreeHTML) { | |||
$('#p-categorytree-portlet .CategoryTreeTag').replaceWith(initialTreeHTML); | |||
attachCategoryEvents(); | |||
} else { | |||
console.log("Изначальное состояние дерева отсутствует в `localStorage`."); | |||
} | |||
} | } | ||
Строка 48: | Строка 65: | ||
} | } | ||
saveInitialTreeState(); | |||
restoreTreeHTML(); | restoreTreeHTML(); | ||
Строка 113: | Строка 131: | ||
} | } | ||
console.log("Категория не найдена, | console.log("Категория не найдена, восстанавливаем начальное состояние..."); | ||
restoreInitialTreeState(); | |||
} | } | ||
Строка 134: | Строка 141: | ||
$(window).on('beforeunload', saveTreeHTML); | $(window).on('beforeunload', saveTreeHTML); | ||
attachCategoryEvents(); | attachCategoryEvents(); | ||
}); | }); |
Версия от 14:09, 27 февраля 2025
$(document).ready(function() {
console.log("Скрипт дерева категорий загружен.");
function saveTreeHTML() {
console.log("Сохраняем текущее состояние дерева...");
var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').prop('outerHTML');
localStorage.setItem('categoryTreeHTML', treeHTML);
}
function saveInitialTreeState() {
if (!localStorage.getItem('initialCategoryTree')) {
console.log("Сохраняем начальное состояние дерева...");
var initialTreeHTML = $('#p-categorytree-portlet .CategoryTreeTag').prop('outerHTML');
localStorage.setItem('initialCategoryTree', initialTreeHTML);
}
}
function restoreTreeHTML() {
console.log("Восстанавливаем последнее сохраненное состояние дерева...");
var treeHTML = localStorage.getItem('categoryTreeHTML');
if (treeHTML) {
$('#p-categorytree-portlet .CategoryTreeTag').replaceWith(treeHTML);
}
attachCategoryEvents();
}
function restoreInitialTreeState() {
console.log("Восстанавливаем ИЗНАЧАЛЬНОЕ состояние дерева...");
var initialTreeHTML = localStorage.getItem('initialCategoryTree');
if (initialTreeHTML) {
$('#p-categorytree-portlet .CategoryTreeTag').replaceWith(initialTreeHTML);
attachCategoryEvents();
} else {
console.log("Изначальное состояние дерева отсутствует в `localStorage`.");
}
}
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();
});
}
saveInitialTreeState();
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("Категория не найдена, восстанавливаем начальное состояние...");
restoreInitialTreeState();
}
setTimeout(function() {
recursiveSearchForCategory();
}, 500);
$(window).on('beforeunload', saveTreeHTML);
attachCategoryEvents();
});