Browse Source

[matrix] Add scroll to top button

pull/6304/head
Josh 4 years ago
committed by GitHub
parent
commit
f78f135505
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 12
      docs/_static/custom.js
  2. 33
      docs/_static/style.css
  3. 4
      docs/_templates/layout.html

12
docs/_static/custom.js

@ -5,6 +5,7 @@ let bottomHeightThreshold, sections;
let hamburgerToggle; let hamburgerToggle;
let mobileSearch; let mobileSearch;
let sidebar; let sidebar;
let toTop;
class Modal { class Modal {
constructor(element) { constructor(element) {
@ -49,12 +50,19 @@ class SearchBar {
} }
function scrollToTop() {
window.scrollTo({ top: 0, behavior: 'smooth' });
}
document.addEventListener('DOMContentLoaded', () => { document.addEventListener('DOMContentLoaded', () => {
mobileSearch = new SearchBar(); mobileSearch = new SearchBar();
bottomHeightThreshold = document.documentElement.scrollHeight - 30; bottomHeightThreshold = document.documentElement.scrollHeight - 30;
sections = document.querySelectorAll('section'); sections = document.querySelectorAll('section');
hamburgerToggle = document.getElementById('hamburger-toggle'); hamburgerToggle = document.getElementById('hamburger-toggle');
toTop = document.getElementById('to-top');
toTop.hidden = !(window.scrollY > 0);
if (hamburgerToggle) { if (hamburgerToggle) {
hamburgerToggle.addEventListener('click', (e) => { hamburgerToggle.addEventListener('click', (e) => {
@ -76,6 +84,10 @@ document.addEventListener('DOMContentLoaded', () => {
// insert ourselves after the element // insert ourselves after the element
parent.insertBefore(table, element.nextSibling); parent.insertBefore(table, element.nextSibling);
}); });
window.addEventListener('scroll', () => {
toTop.hidden = !(window.scrollY > 0);
});
}); });
document.addEventListener('keydown', (event) => { document.addEventListener('keydown', (event) => {

33
docs/_static/style.css

@ -97,6 +97,8 @@ Historically however, thanks to:
--rtd-ad-background: var(--grey-2); --rtd-ad-background: var(--grey-2);
--rtd-ad-main-text: var(--grey-6); --rtd-ad-main-text: var(--grey-6);
--rtd-ad-small-text: var(--grey-4); --rtd-ad-small-text: var(--grey-4);
--rtd-version-background: #272525;
--rtd-version-main-text: #fcfcfc;
--attribute-table-title: var(--grey-6); --attribute-table-title: var(--grey-6);
--attribute-table-entry-border: var(--grey-3); --attribute-table-entry-border: var(--grey-3);
--attribute-table-entry-text: var(--grey-5); --attribute-table-entry-text: var(--grey-5);
@ -576,6 +578,37 @@ div.modal input {
cursor: pointer; cursor: pointer;
} }
/* scroll to top button */
#to-top {
position: fixed;
bottom: 50px;
right: 20px;
cursor: pointer;
}
#to-top.is-rtd {
bottom: 90px;
}
#to-top > span {
display: block;
width: auto;
height: 30px;
padding: 0 6px;
background-color: var(--rtd-version-background);
color: var(--rtd-version-main-text);
}
#to-top span {
line-height: 30px;
font-size: 90%;
text-align: center;
}
/* copy button */ /* copy button */
.relative-copy { .relative-copy {

4
docs/_templates/layout.html

@ -190,5 +190,9 @@
</div> </div>
</div> </div>
<div id="to-top" onclick="scrollToTop()"{%- if READTHEDOCS %} class="is-rtd"{%- endif %} hidden>
<span><span class="material-icons">arrow_upward</span> to top</span>
</div>
</body> </body>
</html> </html>

Loading…
Cancel
Save