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)); | |||
} | } | ||
} | } | ||
}); | }); |
Revision as of 14:57, 25 April 2025
/* All JavaScript here will be loaded for users of the Citizen skin */ mw.hook('wikipage.content').add(function($content) { if (window.innerWidth >= 768) { // Desktop only const idsToCollapse = [ 'Muling', 'Misc', 'Anti-ban', 'Anti-PK', 'Trip_Settings', 'Skills_Settings', 'Equipment' ]; idsToCollapse.forEach(function(rawId) { var id = rawId.replace(/ /g, "_"); var heading = document.getElementById(id); if (!heading) return; var sectionHeading = heading.closest('.citizen-section-heading'); var content = sectionHeading?.nextElementSibling; if (content && content.classList.contains('citizen-section')) { content.hidden = 'until-found'; // ✅ collapse it using Citizen’s native system } }); } }); function expandSectionIfCollapsed(headerElement) { const sectionHeading = headerElement.closest('.citizen-section-heading'); const content = sectionHeading?.nextElementSibling; if (content && content.hidden) { 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(() => { target.scrollIntoView({ behavior: 'smooth', block: 'start' }); }, 50); } // Expand if hash exists on page load mw.hook('wikipage.content').add(function() { if (window.innerWidth >= 768) { const hash = window.location.hash; if (hash && hash.length > 1) { scrollToTargetId(hash.substring(1)); } } }); // Expand and scroll when clicking Contents (TOC) window.addEventListener('hashchange', function() { if (window.innerWidth >= 768) { const hash = window.location.hash; if (hash && hash.length > 1) { scrollToTargetId(hash.substring(1)); } } });