* 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>
30 lines
1.1 KiB
JavaScript
30 lines
1.1 KiB
JavaScript
import imagesLoaded from 'imagesloaded'
|
|
|
|
document.addEventListener('DOMContentLoaded', function () {
|
|
function resizeGridItem (item) {
|
|
const grid = document.getElementsByClassName('note-card-holder')[0]
|
|
const rowHeight = parseInt(window.getComputedStyle(grid).getPropertyValue('grid-auto-rows'))
|
|
const rowGap = parseInt(window.getComputedStyle(grid).getPropertyValue('grid-row-gap'))
|
|
const rowSpan = Math.ceil((item.querySelector('.item').getBoundingClientRect().height + rowGap) / (rowHeight + rowGap))
|
|
item.style.gridRowEnd = 'span ' + rowSpan
|
|
}
|
|
|
|
function resizeAllGridItems () {
|
|
const allItems = document.getElementsByClassName('note-card')
|
|
for (let x = 0; x < allItems.length; x++) {
|
|
resizeGridItem(allItems[x])
|
|
}
|
|
}
|
|
|
|
function resizeInstance (instance) {
|
|
const item = instance.elements[0]
|
|
resizeGridItem(item)
|
|
}
|
|
|
|
window.addEventListener('resize', resizeAllGridItems)
|
|
|
|
const allItems = document.getElementsByClassName('note-card')
|
|
for (let x = 0; x < allItems.length; x++) {
|
|
imagesLoaded(allItems[x], resizeInstance)
|
|
}
|
|
})
|