Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix scrolling in docs #7982

Merged
merged 4 commits into from
Feb 8, 2022
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fix lint
  • Loading branch information
Falke-Design committed Feb 7, 2022
commit d04a59a5c72f086fed5403fb344169a3812607c5
59 changes: 30 additions & 29 deletions docs/docs/js/docs.js
Original file line number Diff line number Diff line change
Expand Up @@ -71,46 +71,47 @@ if (toc) {
scrollPos();
});

window.addEventListener("load", function (e) {
window.addEventListener('load', function () {
var currentHash = window.location.hash;
var elem = document.querySelector(currentHash);

if(elem.tagName === 'H2' || elem.tagName === 'H4'){
if (elem.tagName === 'H2' || elem.tagName === 'H4') {
setTimeout(()=>{
scrollToHeader(elem, true)
},10);
scrollToHeader(elem, true);
}, 10);
}
}, false);
}

function clickOnAnchor(e){
// if the parent element of <a> is clicked we ignore it
if(e.target.tagName !== 'A'){
return;
}

var anchor = '#'+ e.target.href.split('#')[1];
var elemHeader = document.querySelector(anchor);
function clickOnAnchor(e) {
// if the parent element of <a> is clicked we ignore it
if (e.target.tagName !== 'A') {
return;
}

scrollToHeader(elemHeader, '#'+elemHeader.id === currentAnchor);
var anchor = '#' + e.target.href.split('#')[1];
var elemHeader = document.querySelector(anchor);

// prevent default browser anchor scroll
e.preventDefault();
}
scrollToHeader(elemHeader, '#' + elemHeader.id === currentAnchor);

function scrollToHeader(elemHeader, sameAnchor){
var scrollBy = elemHeader.nextSibling.offsetTop;
// prevent default browser anchor scroll
e.preventDefault();
}

if(L.Browser.chrome && sameAnchor){
// chromium remove the anchor element from the scroll-position
// we check with sameAnchor if the User has clicked on the same anchor link again
scrollBy = scrollBy - elemHeader.offsetHeight;
}else{
// we scroll a little bit more down to get the element already sticky
scrollBy += 5;
}
// scroll to the anchor
window.scrollTo(0,scrollBy);
// apply the new anchor to the location url
currentAnchor = window.location.hash = '#'+elemHeader.id;
function scrollToHeader(elemHeader, sameAnchor) {
var scrollBy = elemHeader.nextSibling.offsetTop;

if (L.Browser.chrome && sameAnchor) {
// chromium remove the anchor element from the scroll-position
// we check with sameAnchor if the User has clicked on the same anchor link again
scrollBy = scrollBy - elemHeader.offsetHeight;
} else {
// we scroll a little bit more down to get the element already sticky
scrollBy += 5;
}
// scroll to the anchor
window.scrollTo(0, scrollBy);
// apply the new anchor to the location url
currentAnchor = window.location.hash = '#' + elemHeader.id;
}