MediaWiki:Common.js: различия между версиями
Shihov (обсуждение | вклад) Нет описания правки |
Shihov (обсуждение | вклад) Нет описания правки |
||
| Строка 2: | Строка 2: | ||
console.log("Скрипт дерева категорий загружен."); | console.log("Скрипт дерева категорий загружен."); | ||
// Функция для сохранения | // Функция для сохранения HTML дерева в localStorage | ||
function | function saveTreeHTML() { | ||
console.log("Сохраняем | console.log("Сохраняем HTML дерева..."); | ||
var | var treeHTML = $('.CategoryTreeTag').html(); | ||
localStorage.setItem('categoryTreeHTML', treeHTML); | |||
console.log("HTML дерева сохранен:", treeHTML); | |||
localStorage.setItem(' | |||
console.log(" | |||
} | } | ||
// Функция для восстановления | // Функция для восстановления HTML дерева из localStorage | ||
function | function restoreTreeHTML() { | ||
console.log("Восстанавливаем | console.log("Восстанавливаем HTML дерева..."); | ||
var | var treeHTML = localStorage.getItem('categoryTreeHTML'); | ||
if ( | if (treeHTML) { | ||
console.log("HTML дерева из localStorage:", treeHTML); | |||
console.log(" | $('.CategoryTreeTag').html(treeHTML); | ||
$('. | console.log("HTML дерева восстановлен."); | ||
} else { | } else { | ||
console.log(" | console.log("HTML дерева в localStorage не найден."); | ||
} | } | ||
} | } | ||
// Восстанавливаем | // Восстанавливаем HTML дерева при загрузке страницы | ||
restoreTreeHTML(); | |||
// Делегируем обработку кликов на body | // Делегируем обработку кликов на body | ||
| Строка 70: | Строка 46: | ||
// Переключаем состояние категории (раскрываем или сворачиваем) | // Переключаем состояние категории (раскрываем или сворачиваем) | ||
console.log("Клик по ссылке категории, переключаем состояние:", $target.attr('href')); | console.log("Клик по ссылке категории, переключаем состояние:", $target.attr('href')); | ||
$toggleButton.click(); | |||
} | } | ||
// 3. Если клик по элементу категории (не ссылке и не странице) | // 3. Если клик по элементу категории (не ссылке и не странице) | ||
| Строка 82: | Строка 52: | ||
// Переключаем состояние категории (раскрываем или сворачиваем) | // Переключаем состояние категории (раскрываем или сворачиваем) | ||
console.log("Клик по элементу категории (не ссылка), переключаем состояние:", $item.text().trim()); | console.log("Клик по элементу категории (не ссылка), переключаем состояние:", $item.text().trim()); | ||
$toggleButton.click(); | |||
} | } | ||
// 4. Если клик по ссылке страницы или на элемент страницы | // 4. Если клик по ссылке страницы или на элемент страницы | ||
| Строка 97: | Строка 61: | ||
if (link) { | if (link) { | ||
console.log("Клик по элементу страницы, переходим:", link); | console.log("Клик по элементу страницы, переходим:", link); | ||
// Сохраняем | // Сохраняем HTML дерева перед переходом | ||
saveTreeHTML(); | |||
window.location.href = link; | window.location.href = link; | ||
} | } | ||
} | } | ||
// Сохраняем | // Сохраняем HTML дерева после каждого клика | ||
saveTreeHTML(); | |||
}); | }); | ||
// Сохраняем | |||
$(window).on('beforeunload', | // Сохраняем HTML дерева при выгрузке страницы (например, при закрытии вкладки) | ||
$(window).on('beforeunload', saveTreeHTML); | |||
}); | }); | ||