MediaWiki:Common.js: различия между версиями
Перейти к навигации
Перейти к поиску
Shihov (обсуждение | вклад) Нет описания правки Метка: отменено |
Shihov (обсуждение | вклад) Нет описания правки Метка: отменено |
||
Строка 5: | Строка 5: | ||
function saveTreeHTML() { | function saveTreeHTML() { | ||
console.log("Сохраняем HTML дерева..."); | console.log("Сохраняем HTML дерева..."); | ||
var treeHTML = $(' | var treeHTML = $('.CategoryTreeTag').html(); | ||
localStorage.setItem('categoryTreeHTML', treeHTML); | localStorage.setItem('categoryTreeHTML', treeHTML); | ||
console.log("HTML дерева сохранен:", treeHTML); | |||
} | } | ||
Строка 14: | Строка 15: | ||
var treeHTML = localStorage.getItem('categoryTreeHTML'); | var treeHTML = localStorage.getItem('categoryTreeHTML'); | ||
if (treeHTML) { | if (treeHTML) { | ||
console.log("HTML дерева | console.log("HTML дерева из localStorage:", treeHTML); | ||
$(' | $('.CategoryTreeTag').html(treeHTML); | ||
console.log("HTML дерева восстановлен."); | |||
} else { | } else { | ||
console.log("HTML дерева в localStorage не найден."); | console.log("HTML дерева в localStorage не найден."); | ||
} | } | ||
} | } | ||
// | // Восстанавливаем HTML дерева при загрузке страницы | ||
restoreTreeHTML(); | |||
// Делегируем обработку кликов на body | |||
$('body').on('click', '.CategoryTreeItem', function(event) { | |||
$('body').on('click', ' | |||
var $target = $(event.target); | var $target = $(event.target); | ||
var $item = $(this); | var $item = $(this); // Текущий элемент CategoryTreeItem | ||
var $toggleButton = $item.find('.CategoryTreeToggle').first(); | var $toggleButton = $item.find('.CategoryTreeToggle').first(); | ||
var isCategory = !$item.find('.CategoryTreePageBullet').length; | var isCategory = !$item.find('.CategoryTreePageBullet').length; // Является ли элементом категорией | ||
if ($target.hasClass('CategoryTreeToggle')) return; | // 1. Если клик был на toggle-кнопке, ничего не делаем | ||
if ($target.hasClass('CategoryTreeToggle')) { | |||
console.log("Клик на кнопке раскрытия, ничего не делаем."); | |||
return; | |||
} | |||
// 2. Если клик по ссылке категории | |||
if ($target.is('a') && isCategory) { | if ($target.is('a') && isCategory) { | ||
// Предотвращаем переход по ссылке | |||
event.preventDefault(); | event.preventDefault(); | ||
// Переключаем состояние категории (раскрываем или сворачиваем) | |||
console.log("Клик по ссылке категории, переключаем состояние:", $target.attr('href')); | |||
$toggleButton.click(); | $toggleButton.click(); | ||
} else if (isCategory) { | } | ||
// 3. Если клик по элементу категории (не ссылке и не странице) | |||
else if (isCategory) { | |||
// Переключаем состояние категории (раскрываем или сворачиваем) | |||
console.log("Клик по элементу категории (не ссылка), переключаем состояние:", $item.text().trim()); | |||
$toggleButton.click(); | $toggleButton.click(); | ||
} | } | ||
// 4. Если клик по ссылке страницы или на элемент страницы | |||
else { | |||
// Получаем ссылку страницы | |||
var link = $item.find('a').attr('href'); | |||
// Переходим по ссылке страницы | |||
if (link) { | |||
console.log("Клик по элементу страницы, переходим:", link); | |||
// Сохраняем HTML дерева перед переходом | |||
saveTreeHTML(); | |||
window.location.href = link; | |||
} | |||
} | |||
// Сохраняем HTML дерева после каждого клика | |||
saveTreeHTML(); | |||
}); | }); | ||
// Сохраняем HTML дерева при выгрузке страницы (например, при закрытии вкладки) | |||
$(window).on('beforeunload', saveTreeHTML); | |||
// | |||
$( | |||
}); | }); |
Версия от 09:51, 27 февраля 2025
$(document).ready(function() {
console.log("Скрипт дерева категорий загружен.");
// Функция для сохранения HTML дерева в localStorage
function saveTreeHTML() {
console.log("Сохраняем HTML дерева...");
var treeHTML = $('.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);
$('.CategoryTreeTag').html(treeHTML);
console.log("HTML дерева восстановлен.");
} else {
console.log("HTML дерева в localStorage не найден.");
}
}
// Восстанавливаем HTML дерева при загрузке страницы
restoreTreeHTML();
// Делегируем обработку кликов на body
$('body').on('click', '.CategoryTreeItem', function(event) {
var $target = $(event.target);
var $item = $(this); // Текущий элемент CategoryTreeItem
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);
// Сохраняем HTML дерева перед переходом
saveTreeHTML();
window.location.href = link;
}
}
// Сохраняем HTML дерева после каждого клика
saveTreeHTML();
});
// Сохраняем HTML дерева при выгрузке страницы (например, при закрытии вкладки)
$(window).on('beforeunload', saveTreeHTML);
});