6 this.targetElem = document.getElementById('header');
8 this.breakPoint = 1200;
10 if (document.body.classList.contains('flexbox')) {
11 this.elem.style.display = 'none';
15 this.elem.addEventListener('click', this.scrollToTop.bind(this));
16 window.addEventListener('scroll', this.onPageScroll.bind(this));
20 let scrollTopPos = document.documentElement.scrollTop || document.body.scrollTop || 0;
21 if (!this.showing && scrollTopPos > this.breakPoint) {
22 this.elem.style.display = 'block';
25 this.elem.style.opacity = 0.4;
27 } else if (this.showing && scrollTopPos < this.breakPoint) {
28 this.elem.style.opacity = 0;
31 this.elem.style.display = 'none';
37 let targetTop = this.targetElem.getBoundingClientRect().top;
38 let scrollElem = document.documentElement.scrollTop ? document.documentElement : document.body;
40 let start = Date.now();
41 let scrollStart = this.targetElem.getBoundingClientRect().top;
44 let percentComplete = (1-((Date.now() - start) / duration));
45 let target = Math.abs(percentComplete * scrollStart);
46 if (percentComplete > 0) {
47 scrollElem.scrollTop = target;
48 requestAnimationFrame(setPos.bind(this));
50 scrollElem.scrollTop = targetTop;
54 requestAnimationFrame(setPos.bind(this));
59 export default BackToTop;