1
0
Fork 0
mirror of https://git.sr.ht/~ashkeel/strimertul-website synced 2024-11-19 21:12:20 +00:00
This commit is contained in:
Ash Keel 2023-03-01 14:17:50 +01:00
parent cde6792584
commit 3ec4a8df68
No known key found for this signature in database
GPG key ID: BAD8D93E7314ED3E
3 changed files with 89 additions and 0 deletions

View file

@ -5,5 +5,10 @@
<header><h1>{{ .Title }}</h1></header>
<section class="copy">{{ .Content }}</section>
</div>
<div class="toc">
<header>In this page:</header>
{{ .TableOfContents }}
</div>
</main>
<script async defer src="/script/toc.js"></script>
{{ end }}

34
static/script/toc.js Normal file
View file

@ -0,0 +1,34 @@
const toc = document.getElementById("TableOfContents");
const getId = (el) => {
do {
const id = el.getAttribute("id");
if (id) {
return id;
}
el = el.previousElementSibling;
} while (el);
};
if (toc) {
if (toc.children.length < 1) {
toc.parentElement.remove();
} else {
const observer = new IntersectionObserver((entries) => {
const filtered = entries.filter((i) => getId(i.target));
filtered.forEach((entry) => {
const id = getId(entry.target);
if (id && entry.intersectionRatio > 0) {
toc.querySelector(`li.active`)?.classList.remove("active");
toc
.querySelector(`li a[href="#${id}"]`)
.parentElement.classList.add("active");
}
});
});
// Track all sections that have an `id` applied
document.querySelectorAll(".copy *").forEach((section) => {
observer.observe(section);
});
}
}

View file

@ -175,3 +175,53 @@
}
}
}
.toc {
@media only screen and (max-width: 1400px) {
display: none;
}
padding: 0;
position: fixed;
right: 0;
top: 60px;
header {
font-weight: bold;
padding: 0.6rem 0.9rem;
margin-top: 0.5rem;
}
ul {
list-style-type: none;
margin: 0;
padding: 0;
li {
display: flex;
align-items: stretch;
justify-content: stretch;
transition: all 100ms;
font-size: 14px;
border-left: 5px solid $gray3;
&.active {
pointer-events: none;
border-left-color: $teal8;
a {
color: $teal11;
}
}
&:hover {
background-color: rgba(255, 255, 255, 0.05);
}
a {
flex: 1;
padding: 0.6rem 1rem;
color: $teal12;
text-decoration: none;
&:first-of-type {
padding-top: 0.8rem;
}
}
a:hover {
color: $teal11;
}
}
}
}