MediaWiki:Common.js: различия между версиями
Перейти к навигации
Перейти к поиску
Shihov (обсуждение | вклад) Нет описания правки Метка: отменено |
Shihov (обсуждение | вклад) Нет описания правки Метка: отменено |
||
Строка 2: | Строка 2: | ||
console.log("Скрипт дерева категорий загружен."); | console.log("Скрипт дерева категорий загружен."); | ||
function scrollToCategory(categoryTitle | function saveTreeHTML() { | ||
console.log("Сохраняем HTML дерева..."); | |||
var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').html(); | |||
localStorage.setItem('categoryTreeHTML', treeHTML); | |||
} | |||
function restoreTreeHTML() { | |||
console.log("Восстанавливаем HTML дерева..."); | |||
var treeHTML = localStorage.getItem('categoryTreeHTML'); | |||
if (treeHTML) { | |||
$('#p-categorytree-portlet .CategoryTreeTag').html(treeHTML); | |||
} | |||
} | |||
restoreTreeHTML(); | |||
$('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; | |||
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(); | |||
// Переходим по ссылке без сохранения заголовка страницы | |||
window.location.href = link; | |||
} | |||
} | |||
//Сохраняем дерево после каждого клика уберём, чтоб не дёргало | |||
//saveTreeHTML(); | |||
}); | |||
function scrollToCategory(categoryTitle) { | |||
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; | ||
Строка 12: | Строка 54: | ||
scrollTop: $categoryItem.position().top - 50 | scrollTop: $categoryItem.position().top - 50 | ||
}, 500, function() { | }, 500, function() { | ||
$('.CategoryTreeItem').removeClass('highlighted'); | // Убираем подсветку со всех элементов и добавляем только к текущему | ||
$('#p-categorytree-portlet .CategoryTreeItem').removeClass('highlighted'); | |||
$categoryItem.addClass('highlighted'); | $categoryItem.addClass('highlighted'); | ||
}); | }); | ||
return true; | return true; | ||
} | } | ||
return false; | return false; | ||
} | } | ||
function | function expandAndFindCategory($parent, callback) { | ||
var $toggleButton = $parent.find('.CategoryTreeToggle').first(); | |||
if ($toggleButton.length && !$parent.hasClass('expanded')) { | |||
$toggleButton.click(); | |||
setTimeout(function() { | |||
if (scrollToCategory(mw.config.get('wgTitle'))) { | |||
callback(true); | |||
} else { | |||
callback(false); | |||
} | |||
}, 1000); | |||
} | |||
} else { | } else { | ||
callback(); | callback(false); | ||
} | } | ||
} | } | ||
function recursiveSearchForCategory() { | function recursiveSearchForCategory() { | ||
// Убираем очистку localStorage, т.к. больше не используем lastOpenedPageTitle | |||
var currentPageTitle = mw.config.get('wgTitle'); | var currentPageTitle = mw.config.get('wgTitle'); | ||
if (!currentPageTitle) { | if (!currentPageTitle) { | ||
Строка 51: | Строка 91: | ||
console.log("Начинаем поиск категории для текущей страницы:", currentPageTitle); | console.log("Начинаем поиск категории для текущей страницы:", currentPageTitle); | ||
if (scrollToCategory(currentPageTitle)) { | |||
if ( | |||
return; | return; | ||
} | } | ||
var $categoryItems = $('#p-categorytree-portlet .CategoryTreeItem'); | var $categoryItems = $('#p-categorytree-portlet .CategoryTreeItem'); | ||
var index = 0; | var index = 0; | ||
Строка 73: | Строка 105: | ||
var $item = $($categoryItems[index]); | var $item = $($categoryItems[index]); | ||
expandAndFindCategory($item, function(found) { | |||
if (! | if (!found) { | ||
index++; | index++; | ||
processNext(); | processNext(); | ||
Строка 87: | Строка 119: | ||
recursiveSearchForCategory(); | recursiveSearchForCategory(); | ||
}, 500); | }, 500); | ||
$(window).on('beforeunload', saveTreeHTML); | |||
}); | }); |
Версия от 08:48, 27 февраля 2025
$(document).ready(function() {
console.log("Скрипт дерева категорий загружен.");
function saveTreeHTML() {
console.log("Сохраняем HTML дерева...");
var treeHTML = $('#p-categorytree-portlet .CategoryTreeTag').html();
localStorage.setItem('categoryTreeHTML', treeHTML);
}
function restoreTreeHTML() {
console.log("Восстанавливаем HTML дерева...");
var treeHTML = localStorage.getItem('categoryTreeHTML');
if (treeHTML) {
$('#p-categorytree-portlet .CategoryTreeTag').html(treeHTML);
}
}
restoreTreeHTML();
$('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;
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();
// Переходим по ссылке без сохранения заголовка страницы
window.location.href = link;
}
}
//Сохраняем дерево после каждого клика уберём, чтоб не дёргало
//saveTreeHTML();
});
function scrollToCategory(categoryTitle) {
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() {
// Убираем подсветку со всех элементов и добавляем только к текущему
$('#p-categorytree-portlet .CategoryTreeItem').removeClass('highlighted');
$categoryItem.addClass('highlighted');
});
return true;
}
return false;
}
function expandAndFindCategory($parent, callback) {
var $toggleButton = $parent.find('.CategoryTreeToggle').first();
if ($toggleButton.length && !$parent.hasClass('expanded')) {
$toggleButton.click();
setTimeout(function() {
if (scrollToCategory(mw.config.get('wgTitle'))) {
callback(true);
} else {
callback(false);
}
}, 1000);
} else {
callback(false);
}
}
function recursiveSearchForCategory() {
// Убираем очистку localStorage, т.к. больше не используем lastOpenedPageTitle
var currentPageTitle = mw.config.get('wgTitle');
if (!currentPageTitle) {
console.log("Не удалось определить текущую страницу.");
return;
}
console.log("Начинаем поиск категории для текущей страницы:", currentPageTitle);
if (scrollToCategory(currentPageTitle)) {
return;
}
var $categoryItems = $('#p-categorytree-portlet .CategoryTreeItem');
var index = 0;
function processNext() {
if (index >= $categoryItems.length) {
console.log("Категория для текущей страницы не найдена.");
return;
}
var $item = $($categoryItems[index]);
expandAndFindCategory($item, function(found) {
if (!found) {
index++;
processNext();
}
});
}
processNext();
}
setTimeout(function() {
recursiveSearchForCategory();
}, 500);
$(window).on('beforeunload', saveTreeHTML);
});