summaryrefslogtreecommitdiffstats
path: root/web_src
diff options
context:
space:
mode:
authorsilverwind <me@silverwind.io>2022-11-26 12:15:44 +0100
committerGitHub <noreply@github.com>2022-11-26 19:15:44 +0800
commit5f38acd9a08958024e8bbf47bcc482c79d844e44 (patch)
tree7b352a293f560a9a2e150e7650b26d680f217375 /web_src
parentd7f12af805e33e327ec0c7a250ad8ed09a88e8fd (diff)
downloadgitea-5f38acd9a08958024e8bbf47bcc482c79d844e44.tar.gz
gitea-5f38acd9a08958024e8bbf47bcc482c79d844e44.zip
Fix markdown anchor re-clicking (#21931)
The hashchange event did not fire on re-click of a active anchor. Instead, use the click event which always fires. Fixes: https://github.com/go-gitea/gitea/issues/21680 Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: zeripath <art27@cantab.net>
Diffstat (limited to 'web_src')
-rw-r--r--web_src/js/markup/anchors.js15
1 files changed, 9 insertions, 6 deletions
diff --git a/web_src/js/markup/anchors.js b/web_src/js/markup/anchors.js
index cc2ed5db78..53dfa2980c 100644
--- a/web_src/js/markup/anchors.js
+++ b/web_src/js/markup/anchors.js
@@ -2,10 +2,11 @@ import {svg} from '../svg.js';
const headingSelector = '.markup h1, .markup h2, .markup h3, .markup h4, .markup h5, .markup h6';
-function scrollToAnchor() {
- if (document.querySelector(':target')) return;
- if (!window.location.hash || window.location.hash.length <= 1) return;
- const id = decodeURIComponent(window.location.hash.substring(1));
+function scrollToAnchor(hash, initial) {
+ // abort if the browser has already scrolled to another anchor during page load
+ if (initial && document.querySelector(':target')) return;
+ if (hash?.length <= 1) return;
+ const id = decodeURIComponent(hash.substring(1));
const el = document.getElementById(`user-content-${id}`);
if (el) {
el.scrollIntoView();
@@ -24,9 +25,11 @@ export function initMarkupAnchors() {
a.classList.add('anchor');
a.setAttribute('href', `#${encodeURIComponent(originalId)}`);
a.innerHTML = svg('octicon-link');
+ a.addEventListener('click', (e) => {
+ scrollToAnchor(e.currentTarget.getAttribute('href'), false);
+ });
heading.prepend(a);
}
- scrollToAnchor();
- window.addEventListener('hashchange', scrollToAnchor);
+ scrollToAnchor(window.location.hash, true);
}