* add npm dependencies used in this theme * implement helper to configure JS and ESBuild * migrate jquery popper.js bootstrap fontawesome to js bundle * refactor main.js into smaller pieces, and moved navbar.js to assets * remove list.js. It adjusts post card height to be the same, but is actually not needed. * refactored notes.js, search.js, single.js into application.js * move ityped to js asset, implement experiences horizontal vertical line in css * align recent post height via css * migrated home.js and refactored into various sections * migrated darkMode feature to js bundle * moved mermaid feature to js bundle * migrate syntax highlight to js bundle * migrate katex ( js portion ) to js bundle * migrate pdf-js to js bundle by delegating to cdn * set explicit comparisions for feature envvars so js can properly optimize * removed goat-counter * more fixes for broken achievements and small bugs * more bug fixes * allow configuration of hightlight.js, fix video-player shortcode * remove jquery all together * add null handling and fix merge conflicts Co-authored-by: Aaron Qian <aaron@yeet.io>
60 lines
1.8 KiB
JavaScript
60 lines
1.8 KiB
JavaScript
window.addEventListener('DOMContentLoaded', () => {
|
|
// =========== Add anchor to the headers ================
|
|
function addAnchor (element) {
|
|
element.innerHTML = `<a href="#${element.id}" class="header-anchor">${element.innerHTML}<sup><i class="fas fa-link fa-sm"></i></sup></a>`
|
|
}
|
|
|
|
const postContent = document.getElementById('post-content')
|
|
if (postContent != null) {
|
|
const headerTypes = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6']
|
|
for (let i = 0; i < headerTypes.length; i++) {
|
|
const headers = postContent.querySelectorAll(headerTypes[i])
|
|
if (headers) {
|
|
headers.forEach(addAnchor)
|
|
}
|
|
}
|
|
}
|
|
|
|
// =============== Make TOC Compatible wit Bootstrap Scroll Spy ========
|
|
// add "navbar" class to the "nav" element
|
|
const toc = document.getElementById('TableOfContents')
|
|
if (toc) {
|
|
toc.classList.add('navbar')
|
|
// add "nav-pills" class to the "ul" elements
|
|
let elems = toc.getElementsByTagName('ul')
|
|
for (let i = 0; i < elems.length; i++) {
|
|
elems[i].classList.add('nav-pills')
|
|
}
|
|
// add "nav-item" class to the "li" elements
|
|
elems = toc.getElementsByTagName('li')
|
|
for (let i = 0; i < elems.length; i++) {
|
|
elems[i].classList.add('nav-item')
|
|
}
|
|
// add "nav-link" class to the "a" elements
|
|
elems = toc.getElementsByTagName('a')
|
|
for (let i = 0; i < elems.length; i++) {
|
|
elems[i].classList.add('nav-link')
|
|
}
|
|
}
|
|
|
|
// add scroll to top button
|
|
const btn = document.getElementById('scroll-to-top')
|
|
|
|
if(btn) {
|
|
window.addEventListener('scroll', function () {
|
|
if (window.scrollY > 300) {
|
|
btn.classList.add('show')
|
|
} else {
|
|
btn.classList.remove('show')
|
|
}
|
|
})
|
|
|
|
btn.addEventListener('click', function (e) {
|
|
e.preventDefault()
|
|
window.scrollTo({
|
|
top: 0,
|
|
behavior: 'smooth'
|
|
})
|
|
})
|
|
}
|
|
})
|