More actions
No edit summary Tag: Reverted |
No edit summary Tag: Reverted |
||
| Line 23: | Line 23: | ||
}); | }); | ||
function | function expandSectionIfCollapsed(headerElement) { | ||
const sectionHeading = headerElement.closest('.citizen-section-heading'); | |||
const sectionHeading = | |||
const content = sectionHeading?.nextElementSibling; | const content = sectionHeading?.nextElementSibling; | ||
if (content && content.hidden) { | if (content && content.hidden) { | ||
content.hidden = false; // Expand | content.hidden = false; // Expand the parent section | ||
} | } | ||
} | |||
function scrollToTargetId(id) { | |||
const target = document.getElementById(id); | |||
if (!target) return; | |||
expandSectionIfCollapsed(target); // Always expand parent first | |||
// After expanding, scroll to the real target | |||
setTimeout(() => { | setTimeout(() => { | ||
target.scrollIntoView({ behavior: 'smooth', block: 'start' }); | |||
}, 50); | }, 50); | ||
} | } | ||
// Expand if | // Expand if hash exists on page load | ||
mw.hook('wikipage.content').add(function() { | mw.hook('wikipage.content').add(function() { | ||
if (window.innerWidth >= 768) { | if (window.innerWidth >= 768) { | ||
const hash = window.location.hash; | const hash = window.location.hash; | ||
if (hash && hash.length > 1) { | if (hash && hash.length > 1) { | ||
scrollToTargetId(hash.substring(1)); | |||
} | } | ||
} | } | ||
}); | }); | ||
// Expand | // Expand and scroll when clicking Contents (TOC) | ||
window.addEventListener('hashchange', function() { | window.addEventListener('hashchange', function() { | ||
if (window.innerWidth >= 768) { | if (window.innerWidth >= 768) { | ||
const hash = window.location.hash; | const hash = window.location.hash; | ||
if (hash && hash.length > 1) { | if (hash && hash.length > 1) { | ||
scrollToTargetId(hash.substring(1)); | |||
} | } | ||
} | } | ||
}); | }); | ||