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