* 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>
33 lines
1 KiB
JavaScript
33 lines
1 KiB
JavaScript
// Show more rows in the taken courses table
|
|
function toggleCourseVisibility (elem) {
|
|
// find the courses
|
|
const courses = elem.parentNode.getElementsByClassName('course')
|
|
if (courses == null) {
|
|
return
|
|
}
|
|
|
|
// toggle hidden-course class from the third elements
|
|
for (const course of courses) {
|
|
if (course.classList.contains('hidden-course') || course.classList.contains('toggled-hidden-course')) {
|
|
course.classList.toggle('hidden-course')
|
|
course.classList.add('toggled-hidden-course')
|
|
}
|
|
}
|
|
|
|
// toggle the buttons visibility
|
|
const buttonsToToggle = elem.parentNode.getElementsByClassName('show-more-btn')
|
|
for (const buttonToToggle of buttonsToToggle) {
|
|
buttonToToggle.classList.toggle('hidden')
|
|
}
|
|
}
|
|
|
|
window.addEventListener('DOMContentLoaded', () => {
|
|
const els = [
|
|
document.getElementById('show-more-btn'),
|
|
document.getElementById('show-less-btn')
|
|
]
|
|
|
|
els.filter((el) => el != null).forEach((el) =>
|
|
el.addEventListener('click', ({ target }) =>
|
|
toggleCourseVisibility(target)))
|
|
})
|