MediaWiki:Common.js: различия между версиями
Shihov (обсуждение | вклад) Нет описания правки Метка: ручная отмена |
Shihov (обсуждение | вклад) Нет описания правки |
||
| Строка 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); | 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. Если клик по элементу категории (не ссылке и не странице) | |||
else if (isCategory) { | else if (isCategory) { | ||
console.log("Клик по категории (не ссылка), переключаем:", $item.text().trim()); | |||
console.log("Клик по | |||
$toggleButton.click(); | $toggleButton.click(); | ||
} | } | ||
// 4. Если клик по ссылке страницы | |||
else | 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 дерева после каждого клика | // Сохраняем HTML дерева после каждого клика | ||
| Строка 72: | Строка 64: | ||
}); | }); | ||
// | // Прокручиваем ТОЛЬКО дерево категорий, а не всю страницу | ||
setTimeout(function() { | setTimeout(function() { | ||
var lastOpenedPageTitle = localStorage.getItem('lastOpenedPageTitle'); | var lastOpenedPageTitle = localStorage.getItem('lastOpenedPageTitle'); | ||
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("Элемент найден, прокручиваем только дерево категорий."); | ||
// Прокручиваем страницу | // Прокручиваем ТОЛЬКО контейнер категорий, а не всю страницу | ||
$(' | $('#p-categorytree-portlet').animate({ | ||
scrollTop: $lastOpenedItem. | scrollTop: $lastOpenedItem.position().top - 50 | ||
}, 500); | }, 500); | ||
localStorage.removeItem('lastOpenedPageTitle'); | localStorage.removeItem('lastOpenedPageTitle'); | ||
} else { | } else { | ||
| Строка 108: | Строка 89: | ||
console.log("Заголовок последней открытой страницы не найден."); | console.log("Заголовок последней открытой страницы не найден."); | ||
} | } | ||
}, 500); // | }, 500); | ||
// Сохраняем HTML дерева при выгрузке страницы (например, при закрытии вкладки) | |||
$(window).on('beforeunload', saveTreeHTML); | |||
}); | }); | ||