Merge pull request #2473 from notriddle/notriddle/folding

Fix inadvertently broken folding behavior
This commit is contained in:
Eric Huss 2024-11-07 14:39:31 +00:00 committed by GitHub
commit c6236ead67
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 66 additions and 61 deletions

View file

@ -463,17 +463,6 @@ function playground_text(playground, hidden = true) {
try { localStorage.setItem('mdbook-sidebar', 'visible'); } catch (e) { } try { localStorage.setItem('mdbook-sidebar', 'visible'); } catch (e) { }
} }
var sidebarAnchorToggles = document.querySelectorAll('#sidebar a.toggle');
function toggleSection(ev) {
ev.currentTarget.parentElement.classList.toggle('expanded');
}
Array.from(sidebarAnchorToggles).forEach(function (el) {
el.addEventListener('click', toggleSection);
});
function hideSidebar() { function hideSidebar() {
body.classList.remove('sidebar-visible') body.classList.remove('sidebar-visible')
body.classList.add('sidebar-hidden'); body.classList.add('sidebar-hidden');

View file

@ -52,15 +52,17 @@
<!-- MathJax --> <!-- MathJax -->
<script async src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-AMS-MML_HTMLorMML"></script> <script async src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-AMS-MML_HTMLorMML"></script>
{{/if}} {{/if}}
</head>
<body>
<div id="body-container">
<!-- Provide site root to javascript --> <!-- Provide site root to javascript -->
<script> <script>
var path_to_root = "{{ path_to_root }}"; var path_to_root = "{{ path_to_root }}";
var default_theme = window.matchMedia("(prefers-color-scheme: dark)").matches ? "{{ preferred_dark_theme }}" : "{{ default_theme }}"; var default_theme = window.matchMedia("(prefers-color-scheme: dark)").matches ? "{{ preferred_dark_theme }}" : "{{ default_theme }}";
</script> </script>
<!-- Start loading toc.js asap -->
<script src="{{ path_to_root }}toc.js"></script>
</head>
<body>
<div id="body-container">
<!-- Work around some values being stored in localStorage wrapped in quotes --> <!-- Work around some values being stored in localStorage wrapped in quotes -->
<script> <script>
try { try {
@ -107,7 +109,7 @@
<nav id="sidebar" class="sidebar" aria-label="Table of contents"> <nav id="sidebar" class="sidebar" aria-label="Table of contents">
<!-- populated by js --> <!-- populated by js -->
<div class="sidebar-scrollbox"></div> <mdbook-sidebar-scrollbox class="sidebar-scrollbox"></mdbook-sidebar-scrollbox>
<noscript> <noscript>
<iframe class="sidebar-iframe-outer" src="{{ path_to_root }}toc.html"></iframe> <iframe class="sidebar-iframe-outer" src="{{ path_to_root }}toc.html"></iframe>
</noscript> </noscript>
@ -116,8 +118,6 @@
</div> </div>
</nav> </nav>
<script async src="{{ path_to_root }}toc.js"></script>
<div id="page-wrapper" class="page-wrapper"> <div id="page-wrapper" class="page-wrapper">
<div class="page"> <div class="page">

View file

@ -3,52 +3,68 @@
// This is a script, and not included directly in the page, to control the total size of the book. // This is a script, and not included directly in the page, to control the total size of the book.
// The TOC contains an entry for each page, so if each page includes a copy of the TOC, // The TOC contains an entry for each page, so if each page includes a copy of the TOC,
// the total size of the page becomes O(n**2). // the total size of the page becomes O(n**2).
var sidebarScrollbox = document.querySelector("#sidebar .sidebar-scrollbox"); class MDBookSidebarScrollbox extends HTMLElement {
sidebarScrollbox.innerHTML = '{{#toc}}{{/toc}}'; constructor() {
(function() { super();
let current_page = document.location.href.toString();
if (current_page.endsWith("/")) {
current_page += "index.html";
} }
var links = sidebarScrollbox.querySelectorAll("a"); connectedCallback() {
var l = links.length; this.innerHTML = '{{#toc}}{{/toc}}';
for (var i = 0; i < l; ++i) { // Set the current, active page, and reveal it if it's hidden
var link = links[i]; let current_page = document.location.href.toString();
var href = link.getAttribute("href"); if (current_page.endsWith("/")) {
if (href && !href.startsWith("#") && !/^(?:[a-z+]+:)?\/\//.test(href)) { current_page += "index.html";
link.href = path_to_root + href;
} }
// The "index" page is supposed to alias the first chapter in the book. var links = Array.prototype.slice.call(this.querySelectorAll("a"));
if (link.href === current_page || (i === 0 && path_to_root === "" && current_page.endsWith("/index.html"))) { var l = links.length;
link.classList.add("active"); for (var i = 0; i < l; ++i) {
var parent = link.parentElement; var link = links[i];
while (parent) { var href = link.getAttribute("href");
if (parent.tagName === "LI" && parent.previousElementSibling) { if (href && !href.startsWith("#") && !/^(?:[a-z+]+:)?\/\//.test(href)) {
if (parent.previousElementSibling.classList.contains("chapter-item")) { link.href = path_to_root + href;
parent.previousElementSibling.classList.add("expanded"); }
} // The "index" page is supposed to alias the first chapter in the book.
if (link.href === current_page || (i === 0 && path_to_root === "" && current_page.endsWith("/index.html"))) {
link.classList.add("active");
var parent = link.parentElement;
if (parent && parent.classList.contains("chapter-item")) {
parent.classList.add("expanded");
}
while (parent) {
if (parent.tagName === "LI" && parent.previousElementSibling) {
if (parent.previousElementSibling.classList.contains("chapter-item")) {
parent.previousElementSibling.classList.add("expanded");
}
}
parent = parent.parentElement;
} }
parent = parent.parentElement;
} }
} }
} // Track and set sidebar scroll position
})(); this.addEventListener('click', function(e) {
if (e.target.tagName === 'A') {
// Track and set sidebar scroll position sessionStorage.setItem('sidebar-scroll', this.scrollTop);
sidebarScrollbox.addEventListener('click', function(e) { }
if (e.target.tagName === 'A') { }, { passive: true });
sessionStorage.setItem('sidebar-scroll', sidebarScrollbox.scrollTop); var sidebarScrollTop = sessionStorage.getItem('sidebar-scroll');
} sessionStorage.removeItem('sidebar-scroll');
}, { passive: true }); if (sidebarScrollTop) {
var sidebarScrollTop = sessionStorage.getItem('sidebar-scroll'); // preserve sidebar scroll position when navigating via links within sidebar
sessionStorage.removeItem('sidebar-scroll'); this.scrollTop = sidebarScrollTop;
if (sidebarScrollTop) { } else {
// preserve sidebar scroll position when navigating via links within sidebar // scroll sidebar to current active section when navigating via "next/previous chapter" buttons
sidebarScrollbox.scrollTop = sidebarScrollTop; var activeSection = document.querySelector('#sidebar .active');
} else { if (activeSection) {
// scroll sidebar to current active section when navigating via "next/previous chapter" buttons activeSection.scrollIntoView({ block: 'center' });
var activeSection = document.querySelector('#sidebar .active'); }
if (activeSection) { }
activeSection.scrollIntoView({ block: 'center' }); // Toggle buttons
var sidebarAnchorToggles = document.querySelectorAll('#sidebar a.toggle');
function toggleSection(ev) {
ev.currentTarget.parentElement.classList.toggle('expanded');
}
Array.from(sidebarAnchorToggles).forEach(function (el) {
el.addEventListener('click', toggleSection);
});
} }
} }
window.customElements.define("mdbook-sidebar-scrollbox", MDBookSidebarScrollbox);

View file

@ -243,7 +243,7 @@ fn toc_js_html() -> Result<Document> {
let toc_path = temp.path().join("book").join("toc.js"); let toc_path = temp.path().join("book").join("toc.js");
let html = fs::read_to_string(toc_path).with_context(|| "Unable to read index.html")?; let html = fs::read_to_string(toc_path).with_context(|| "Unable to read index.html")?;
for line in html.lines() { for line in html.lines() {
if let Some(left) = line.strip_prefix("sidebarScrollbox.innerHTML = '") { if let Some(left) = line.strip_prefix(" this.innerHTML = '") {
if let Some(html) = left.strip_suffix("';") { if let Some(html) = left.strip_suffix("';") {
return Ok(Document::from(html)); return Ok(Document::from(html));
} }