From 173ec240d2ed5b25f18ef42823334ae800b3527d Mon Sep 17 00:00:00 2001
From: Jacky Zhao <j.zhao2k19@gmail.com>
Date: Mon, 21 Aug 2023 00:50:56 +0000
Subject: [PATCH] fix: jump to anchor on deployed site triggering spa refresh
---
quartz/components/scripts/spa.inline.ts | 5 ++++-
1 files changed, 4 insertions(+), 1 deletions(-)
diff --git a/quartz/components/scripts/spa.inline.ts b/quartz/components/scripts/spa.inline.ts
index 0a57a9d..32c2bf2 100644
--- a/quartz/components/scripts/spa.inline.ts
+++ b/quartz/components/scripts/spa.inline.ts
@@ -66,7 +66,6 @@
// scroll into place and add history
if (!isBack) {
- history.pushState({}, "", url)
if (url.hash) {
const el = document.getElementById(url.hash.substring(1))
el?.scrollIntoView()
@@ -81,6 +80,9 @@
const elementsToAdd = html.head.querySelectorAll(":not([spa-preserve])")
elementsToAdd.forEach((el) => document.head.appendChild(el))
+ // delay setting the url until now
+ // at this point everything is loaded so changing the url should resolve to the correct addresses
+ history.pushState({}, "", url)
notifyNav(getFullSlug(window))
delete announcer.dataset.persist
}
@@ -92,6 +94,7 @@
window.addEventListener("click", async (event) => {
const { url } = getOpts(event) ?? {}
if (!url) return
+ if (url.pathname === window.location.pathname) return
event.preventDefault()
try {
navigate(url, false)
--
Gitblit v1.10.0