|
|
|
|
@@ -1478,6 +1478,33 @@ const WHOAMI_FORCE_LOCALHOST = (import.meta.env.PUBLIC_WHOAMI_FORCE_LOCALHOST ??
|
|
|
|
|
|
|
|
|
|
const h1 = reading.querySelector("h1");
|
|
|
|
|
|
|
|
|
|
const topChapterLabel =
|
|
|
|
|
isGlossaryEntryMode
|
|
|
|
|
? "Haut de la fiche"
|
|
|
|
|
: isGlossaryEdition
|
|
|
|
|
? "Haut de la page"
|
|
|
|
|
: "Haut du chapitre";
|
|
|
|
|
|
|
|
|
|
if (btnTopChapter) {
|
|
|
|
|
btnTopChapter.setAttribute("aria-label", topChapterLabel);
|
|
|
|
|
btnTopChapter.setAttribute("title", topChapterLabel);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function scrollToTopChapter(behavior = "smooth") {
|
|
|
|
|
if (isGlossaryEdition) {
|
|
|
|
|
window.scrollTo({ top: 0, behavior });
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (h1) {
|
|
|
|
|
scrollToElWithOffset(h1, 12, behavior);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getH2ScrollTarget(item) {
|
|
|
|
|
return item?.h2 || item?.anchor || item?.marker || null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const h2Anchors = Array.from(reading.querySelectorAll(".details-anchor[id]"))
|
|
|
|
|
.map((s) => {
|
|
|
|
|
const d = (s.nextElementSibling && s.nextElementSibling.tagName === "DETAILS")
|
|
|
|
|
@@ -1500,6 +1527,7 @@ const WHOAMI_FORCE_LOCALHOST = (import.meta.env.PUBLIC_WHOAMI_FORCE_LOCALHOST ??
|
|
|
|
|
.filter(Boolean);
|
|
|
|
|
|
|
|
|
|
const h2Plain = Array.from(reading.querySelectorAll("h2[id]"))
|
|
|
|
|
.filter((h2) => !h2.closest("details.details-section"))
|
|
|
|
|
.map((h2) => ({
|
|
|
|
|
id: h2.id,
|
|
|
|
|
anchor: h2,
|
|
|
|
|
@@ -1508,7 +1536,7 @@ const WHOAMI_FORCE_LOCALHOST = (import.meta.env.PUBLIC_WHOAMI_FORCE_LOCALHOST ??
|
|
|
|
|
h2,
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
const H2 = (h2Anchors.length ? h2Anchors : h2Plain)
|
|
|
|
|
const H2 = [...h2Anchors, ...h2Plain]
|
|
|
|
|
.slice()
|
|
|
|
|
.sort((a, b) => absTop(a.marker) - absTop(b.marker));
|
|
|
|
|
|
|
|
|
|
@@ -1700,7 +1728,12 @@ const WHOAMI_FORCE_LOCALHOST = (import.meta.env.PUBLIC_WHOAMI_FORCE_LOCALHOST ??
|
|
|
|
|
syncGlossaryFollowState(followEl.classList.contains("is-on") && followH > 0);
|
|
|
|
|
|
|
|
|
|
if (btnTopChapter) {
|
|
|
|
|
btnTopChapter.hidden = !(rfH1 && !rfH1.hidden);
|
|
|
|
|
const showTopChapter =
|
|
|
|
|
isGlossaryEdition
|
|
|
|
|
? Boolean(followEl.classList.contains("is-on"))
|
|
|
|
|
: Boolean(rfH1 && !rfH1.hidden);
|
|
|
|
|
|
|
|
|
|
btnTopChapter.hidden = !showTopChapter;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (btnTopSection) {
|
|
|
|
|
@@ -1736,8 +1769,11 @@ const WHOAMI_FORCE_LOCALHOST = (import.meta.env.PUBLIC_WHOAMI_FORCE_LOCALHOST ??
|
|
|
|
|
if (rfH2) {
|
|
|
|
|
rfH2.addEventListener("click", () => {
|
|
|
|
|
if (!curH2) return;
|
|
|
|
|
openDetailsIfNeeded(curH2.anchor || curH2.h2 || curH2.marker);
|
|
|
|
|
scrollToElWithOffset(curH2.marker, 12, "smooth");
|
|
|
|
|
const target = getH2ScrollTarget(curH2);
|
|
|
|
|
if (!target) return;
|
|
|
|
|
|
|
|
|
|
openDetailsIfNeeded(target);
|
|
|
|
|
scrollToElWithOffset(target, 12, "smooth");
|
|
|
|
|
history.replaceState(null, "", `${window.location.pathname}#${curH2.id}`);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
@@ -1753,15 +1789,18 @@ const WHOAMI_FORCE_LOCALHOST = (import.meta.env.PUBLIC_WHOAMI_FORCE_LOCALHOST ??
|
|
|
|
|
|
|
|
|
|
if (btnTopChapter) {
|
|
|
|
|
btnTopChapter.addEventListener("click", () => {
|
|
|
|
|
if (h1) scrollToElWithOffset(h1, 12, "smooth");
|
|
|
|
|
scrollToTopChapter("smooth");
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (btnTopSection) {
|
|
|
|
|
btnTopSection.addEventListener("click", () => {
|
|
|
|
|
if (!curH2) return;
|
|
|
|
|
openDetailsIfNeeded(curH2.anchor || curH2.h2 || curH2.marker);
|
|
|
|
|
scrollToElWithOffset(curH2.marker, 12, "smooth");
|
|
|
|
|
const target = getH2ScrollTarget(curH2);
|
|
|
|
|
if (!target) return;
|
|
|
|
|
|
|
|
|
|
openDetailsIfNeeded(target);
|
|
|
|
|
scrollToElWithOffset(target, 12, "smooth");
|
|
|
|
|
history.replaceState(null, "", `${window.location.pathname}#${curH2.id}`);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|