mirror of
https://github.com/rust-lang/mdBook
synced 2024-12-13 14:22:35 +00:00
Merge pull request #2473 from notriddle/notriddle/folding
Fix inadvertently broken folding behavior
This commit is contained in:
commit
c6236ead67
4 changed files with 66 additions and 61 deletions
|
@ -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');
|
||||||
|
|
|
@ -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">
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue