Add smooth scrolling to TOC

This commit is contained in:
2025-11-18 12:33:23 +13:00
parent 7972acb40f
commit 1f499739fb
2 changed files with 30 additions and 13 deletions

View File

@@ -16,6 +16,20 @@
lnk.className = 'b1-no-underline' lnk.className = 'b1-no-underline'
lnk.innerHTML = `<span class="mr-1">${"#".repeat(depth)}</span>${tag.innerHTML}` lnk.innerHTML = `<span class="mr-1">${"#".repeat(depth)}</span>${tag.innerHTML}`
// Add smooth scroll with offset
lnk.addEventListener('click', (e) => {
e.preventDefault()
const target = document.getElementById(tag.id)
if (target) {
const offset = 20 // pixels from top
const targetPosition = target.getBoundingClientRect().top + window.pageYOffset - offset
window.scrollTo({
top: targetPosition,
behavior: 'smooth'
})
}
})
let li = document.createElement('li') let li = document.createElement('li')
li.className = 'line-clamp-1' li.className = 'line-clamp-1'
li.appendChild(lnk) li.appendChild(lnk)

View File

@@ -23,9 +23,8 @@ const readTime = calcReadTime(wordCount);
<Base> <Base>
<div slot="sidebar" class="text-left"> <div slot="sidebar" class="text-left">
<img src={headerImage}/> <img src={headerImage}/>
<p class="text-2xl pt-2">{title}</p> <p class="text-2xl pt-2">{title}</p>
<p class="italic">{description}</p> <p class="italic">{description}</p>
<PostInfo <PostInfo
@@ -39,11 +38,15 @@ const readTime = calcReadTime(wordCount);
</div> </div>
<div id="post-content" slot="content" class="md:py-12"> <div id="post-content" slot="content" class="md:py-12 border-t border-gray-200 md:border-0">
<Fragment set:html={content} /> <Fragment set:html={content} />
</div> </div>
<style is:global> <style is:global>
html {
scroll-behavior: smooth;
}
#post-content img { #post-content img {
width: 90%; width: 90%;
margin-inline: auto; margin-inline: auto;