MediaWiki:Common.js: Difference between revisions
mNo edit summary Tag: Manual revert |
mNo edit summary |
||
| (8 intermediate revisions by the same user not shown) | |||
| Line 111: | Line 111: | ||
/* ========================================================= | /* ========================================================= | ||
OOO Browser controller | OOO Anchor navigation (tabs + browser) | ||
========================================================= */ | |||
mw.hook('wikipage.content').add(function () { | |||
if (!location.hash) return; | |||
const id = location.hash.slice(1); | |||
setTimeout(function(){ | |||
const item = document.querySelector('.ooo-browser__item[data-target="'+id+'"]'); | |||
const panel = document.getElementById(id); | |||
if (!item || !panel) return; | |||
const browser = item.closest('.ooo-browser'); | |||
if (!browser) return; | |||
browser.querySelectorAll('.ooo-browser__item') | |||
.forEach(el => el.classList.remove('is-active')); | |||
browser.querySelectorAll('.ooo-browser__info') | |||
.forEach(el => el.classList.remove('is-active')); | |||
item.classList.add('is-active'); | |||
panel.classList.add('is-active'); | |||
},150); | |||
}); | |||
/* ========================================================= | |||
OOO Browser controller (click switching) | |||
========================================================= */ | ========================================================= */ | ||
| Line 127: | Line 160: | ||
e.preventDefault(); | e.preventDefault(); | ||
browser.querySelectorAll(".ooo-browser__item") | browser.querySelectorAll(".ooo-browser__item") | ||
.forEach(el => el.classList.remove("is-active")); | .forEach(el => el.classList.remove("is-active")); | ||
browser.querySelectorAll(".ooo-browser__info") | browser.querySelectorAll(".ooo-browser__info") | ||
.forEach(el => el.classList.remove("is-active")); | .forEach(el => el.classList.remove("is-active")); | ||
const panel = browser.querySelector("#" + CSS.escape(target)); | item.classList.add("is-active"); | ||
const panel = browser.querySelector("#" + CSS.escape(target)); | |||
if (panel) panel.classList.add("is-active"); | |||
/* update browser URL */ | |||
history.replaceState(null, null, "#" + target); | |||
}); | }); | ||