aboutsummaryrefslogtreecommitdiff
path: root/plugins/base/src/main/resources/dokka/scripts
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/base/src/main/resources/dokka/scripts')
-rw-r--r--plugins/base/src/main/resources/dokka/scripts/navigation-loader.js44
-rw-r--r--plugins/base/src/main/resources/dokka/scripts/platform-content-handler.js45
2 files changed, 50 insertions, 39 deletions
diff --git a/plugins/base/src/main/resources/dokka/scripts/navigation-loader.js b/plugins/base/src/main/resources/dokka/scripts/navigation-loader.js
index 0d9948ad..7b6aeb1f 100644
--- a/plugins/base/src/main/resources/dokka/scripts/navigation-loader.js
+++ b/plugins/base/src/main/resources/dokka/scripts/navigation-loader.js
@@ -1,31 +1,29 @@
-window.addEventListener('load', () => {
- fetch(pathToRoot + "navigation.html")
- .then(response => response.text())
- .then(data => {
- document.getElementById("sideMenu").innerHTML = data;
- }).then(() => {
+navigationPageText = fetch(pathToRoot + "navigation.html").then(response => response.text())
+
+displayNavigationFromPage = () => {
+ navigationPageText.then(data => {
+ document.getElementById("sideMenu").innerHTML = data;
+ }).then(() => {
document.querySelectorAll(".overview > a").forEach(link => {
link.setAttribute("href", pathToRoot + link.getAttribute("href"));
})
}).then(() => {
document.querySelectorAll(".sideMenuPart").forEach(nav => {
- if (!nav.classList.contains("hidden")) nav.classList.add("hidden")
+ if (!nav.classList.contains("hidden"))
+ nav.classList.add("hidden")
})
}).then(() => {
revealNavigationForCurrentPage()
})
-
- /* Smooth scrolling support for going to the top of the page */
document.querySelectorAll('.footer a[href^="#"]').forEach(anchor => {
anchor.addEventListener('click', function (e) {
e.preventDefault();
-
document.querySelector(this.getAttribute('href')).scrollIntoView({
behavior: 'smooth'
});
});
});
-})
+}
revealNavigationForCurrentPage = () => {
let pageId = document.getElementById("content").attributes["pageIds"].value.toString();
@@ -35,9 +33,9 @@ revealNavigationForCurrentPage = () => {
parts.forEach(part => {
if (part.attributes['pageId'].value.indexOf(pageId) !== -1 && found === 0) {
found = 1;
- if (part.classList.contains("hidden")){
- part.classList.remove("hidden");
- part.setAttribute('data-active',"");
+ if (part.classList.contains("hidden")) {
+ part.classList.remove("hidden");
+ part.setAttribute('data-active', "");
}
revealParents(part)
}
@@ -45,10 +43,22 @@ revealNavigationForCurrentPage = () => {
pageId = pageId.substring(0, pageId.lastIndexOf("/"))
} while (pageId.indexOf("/") !== -1 && found === 0)
};
-
revealParents = (part) => {
if (part.classList.contains("sideMenuPart")) {
- if (part.classList.contains("hidden")) part.classList.remove("hidden");
+ if (part.classList.contains("hidden"))
+ part.classList.remove("hidden");
revealParents(part.parentNode)
}
-}; \ No newline at end of file
+};
+
+/*
+ This is a work-around for safari being IE of our times.
+ It doesn't fire a DOMContentLoaded, presumabely because eventListener is added after it wants to do it
+*/
+if (document.readyState == 'loading') {
+ window.addEventListener('DOMContentLoaded', () => {
+ displayNavigationFromPage()
+ })
+} else {
+ displayNavigationFromPage()
+} \ No newline at end of file
diff --git a/plugins/base/src/main/resources/dokka/scripts/platform-content-handler.js b/plugins/base/src/main/resources/dokka/scripts/platform-content-handler.js
index 07a6642b..4595fdec 100644
--- a/plugins/base/src/main/resources/dokka/scripts/platform-content-handler.js
+++ b/plugins/base/src/main/resources/dokka/scripts/platform-content-handler.js
@@ -5,7 +5,6 @@ filteringContext = {
}
let highlightedAnchor;
let topNavbarOffset;
-var scrollNavbarBreakPoint = 300
window.addEventListener('load', () => {
document.querySelectorAll("div[data-platform-hinted]")
@@ -22,9 +21,7 @@ window.addEventListener('load', () => {
initHidingLeftNavigation()
document.getElementById('main').addEventListener("scroll", (e) => {
- const element = document.getElementsByClassName("navigation-wrapper")[0]
- const additionalOffset = element.classList.contains("sticky-navigation") ? 14 : 0
- element.classList.toggle("sticky-navigation", e.target.scrollTop + additionalOffset > scrollNavbarBreakPoint)
+ document.getElementsByClassName("navigation-wrapper")[0].classList.toggle("sticky-navigation", e.target.scrollTop > 0)
})
topNavbarOffset = document.getElementById('navigation-wrapper')
})
@@ -47,6 +44,27 @@ const initHidingLeftNavigation = () => {
// If this is not present user is forced to refresh the site in order to use an anchor
window.onhashchange = handleAnchor
+function scrollToElementInContent(element){
+ const scrollToElement = () => document.getElementById('main').scrollTo({ top: element.offsetTop - topNavbarOffset.offsetHeight, behavior: "smooth"})
+
+ const waitAndScroll = () => {
+ setTimeout(() => {
+ if(topNavbarOffset){
+ scrollToElement()
+ } else {
+ waitForScroll()
+ }
+ }, 50)
+ }
+
+ if(topNavbarOffset){
+ scrollToElement()
+ } else {
+ waitAndScroll()
+ }
+}
+
+
function handleAnchor() {
if(highlightedAnchor){
highlightedAnchor.classList.remove('anchor-highlight')
@@ -74,23 +92,7 @@ function handleAnchor() {
highlightedAnchor = content
}
- const scrollToElement = () => document.getElementById('main').scrollTo({ top: element.offsetTop - topNavbarOffset.offsetHeight, behavior: "smooth"})
-
- const waitAndScroll = () => {
- setTimeout(() => {
- if(topNavbarOffset){
- scrollToElement()
- } else {
- waitForScroll()
- }
- }, 100)
- }
-
- if(topNavbarOffset){
- scrollToElement()
- } else {
- waitAndScroll()
- }
+ scrollToElementInContent(element)
}
}
}
@@ -286,4 +288,3 @@ function refreshFilterButtons() {
}
})
}
-