1 import {Component} from "./component";
3 export class BackToTop extends Component {
6 this.button = this.$el;
7 this.targetElem = document.getElementById('header');
9 this.breakPoint = 1200;
11 if (document.body.classList.contains('flexbox')) {
12 this.button.style.display = 'none';
16 this.button.addEventListener('click', this.scrollToTop.bind(this));
17 window.addEventListener('scroll', this.onPageScroll.bind(this));
21 let scrollTopPos = document.documentElement.scrollTop || document.body.scrollTop || 0;
22 if (!this.showing && scrollTopPos > this.breakPoint) {
23 this.button.style.display = 'block';
26 this.button.style.opacity = 0.4;
28 } else if (this.showing && scrollTopPos < this.breakPoint) {
29 this.button.style.opacity = 0;
32 this.button.style.display = 'none';
38 let targetTop = this.targetElem.getBoundingClientRect().top;
39 let scrollElem = document.documentElement.scrollTop ? document.documentElement : document.body;
41 let start = Date.now();
42 let scrollStart = this.targetElem.getBoundingClientRect().top;
45 let percentComplete = (1-((Date.now() - start) / duration));
46 let target = Math.abs(percentComplete * scrollStart);
47 if (percentComplete > 0) {
48 scrollElem.scrollTop = target;
49 requestAnimationFrame(setPos.bind(this));
51 scrollElem.scrollTop = targetTop;
55 requestAnimationFrame(setPos.bind(this));
60 export default BackToTop;