MediaWiki:Common.js: Difference between revisions

mNo edit summary
mNo edit summary
 
(2 intermediate revisions by the same user not shown)
Line 116: Line 116:
mw.hook('wikipage.content').add(function () {
mw.hook('wikipage.content').add(function () {


   if (!location.hash) return;   // IMPORTANT: do nothing without anchor
   if (!location.hash) return;


   const id = location.hash.slice(1);
   const id = location.hash.slice(1);
Line 124: Line 124:
     const item  = document.querySelector('.ooo-browser__item[data-target="'+id+'"]');
     const item  = document.querySelector('.ooo-browser__item[data-target="'+id+'"]');
     const panel = document.getElementById(id);
     const panel = document.getElementById(id);
     if (!item || !panel) return;
     if (!item || !panel) return;


Line 138: Line 139:
     panel.classList.add('is-active');
     panel.classList.add('is-active');


     panel.scrollIntoView({block:'start'});
  },150);
 
});
 
/* =========================================================
  OOO Browser controller (click switching)
  ========================================================= */
 
document.addEventListener("click", function (e) {
 
  const item = e.target.closest(".ooo-browser__item");
  if (!item) return;
 
  const browser = item.closest(".ooo-browser");
  if (!browser) return;
 
  const target = item.getAttribute("data-target");
  if (!target) return;
 
  e.preventDefault();
 
  browser.querySelectorAll(".ooo-browser__item")
     .forEach(el => el.classList.remove("is-active"));


   },150);
   browser.querySelectorAll(".ooo-browser__info")
    .forEach(el => el.classList.remove("is-active"));
 
  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);


});
});