aboutsummaryrefslogtreecommitdiffstats
path: root/web_src/js/markup/anchors.js
diff options
context:
space:
mode:
Diffstat (limited to 'web_src/js/markup/anchors.js')
-rw-r--r--web_src/js/markup/anchors.js32
1 files changed, 32 insertions, 0 deletions
diff --git a/web_src/js/markup/anchors.js b/web_src/js/markup/anchors.js
new file mode 100644
index 0000000000..cc2ed5db78
--- /dev/null
+++ b/web_src/js/markup/anchors.js
@@ -0,0 +1,32 @@
+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));
+ const el = document.getElementById(`user-content-${id}`);
+ if (el) {
+ el.scrollIntoView();
+ } else if (id.startsWith('user-content-')) { // compat for links with old 'user-content-' prefixed hashes
+ const el = document.getElementById(id);
+ if (el) el.scrollIntoView();
+ }
+}
+
+export function initMarkupAnchors() {
+ if (!document.querySelector('.markup')) return;
+
+ for (const heading of document.querySelectorAll(headingSelector)) {
+ const originalId = heading.id.replace(/^user-content-/, '');
+ const a = document.createElement('a');
+ a.classList.add('anchor');
+ a.setAttribute('href', `#${encodeURIComponent(originalId)}`);
+ a.innerHTML = svg('octicon-link');
+ heading.prepend(a);
+ }
+
+ scrollToAnchor();
+ window.addEventListener('hashchange', scrollToAnchor);
+}