react-spy-scroll
Version:
Scrollspy components for react
300 lines (299 loc) • 10.6 kB
HTML
<html lang="en">
<head>
<title>Code coverage report for scroll-spy.js</title>
<meta charset="utf-8" />
<link rel="stylesheet" href="prettify.css" />
<link rel="stylesheet" href="base.css" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<style type='text/css'>
.coverage-summary .sorter {
background-image: url(sort-arrow-sprite.png);
}
</style>
</head>
<body>
<div class='wrapper'>
<div class='pad1'>
<h1>
<a href="index.html">All files</a> scroll-spy.js
</h1>
<div class='clearfix'>
<div class='fl pad1y space-right2'>
<span class="strong">48.39% </span>
<span class="quiet">Statements</span>
<span class='fraction'>15/31</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">12.5% </span>
<span class="quiet">Branches</span>
<span class='fraction'>2/16</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">11.11% </span>
<span class="quiet">Functions</span>
<span class='fraction'>1/9</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">48.39% </span>
<span class="quiet">Lines</span>
<span class='fraction'>15/31</span>
</div>
</div>
</div>
<div class='status-line low'></div>
<pre><table class="coverage">
<tr><td class="line-count quiet">1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1x</span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-no"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/**
* The class responsible for keeping track of scrolling
*/
import ReactDOM from 'react-dom';
import { throttle } from './utils';
import Scroller from './scroller';
class ScrollSpy {
constructor() {
this._linksRegister = [];
this._scrollPanelRegister = [];
window.addEventListener('scroll', throttle(<span class="fstat-no" title="function not covered" >() =></span>
this._handleScroll({ target: document.body }))
);
this._handleScroll({ target: document.body });
}
registerLink(component) {
<span class="missing-if-branch" title="else path not taken" >E</span>if (!this._linksRegister.includes(component)) {
this._linksRegister.push(component);
}
}
registerScrollpanel(component) {
<span class="cstat-no" title="statement not covered" ></span> if (!this._scrollPanelRegister.includes(component)) {
<span class="cstat-no" title="statement not covered" > const listener = throttle(this._handleScroll.bind(this));</span>
<span class="cstat-no" title="statement not covered" > component.addEventListener('scroll', listener);</span>
<span class="cstat-no" title="statement not covered" > this._handleScroll({ target: component });</span>
<span class="cstat-no" title="statement not covered" > this._scrollPanelRegister.push({ component, listener });</span>
}
}
unregisterLink(component) {
<span class="cstat-no" title="statement not covered" > const index = this._linksRegister.indexOf(component);</span>
<span class="cstat-no" title="statement not covered" ></span> if (index >= 0) {
<span class="cstat-no" title="statement not covered" > this._linksRegister.splice(index, 1);</span>
}
}
unregisterScrollpanel(component) {
<span class="cstat-no" title="statement not covered" > const index = this._scrollPanelRegister.findIndex(<span class="fstat-no" title="function not covered" >(el) => el.component === component);</span></span>
<span class="cstat-no" title="statement not covered" ></span> if (index >= 0) {
<span class="cstat-no" title="statement not covered" > const el = this._scrollPanelRegister[index];</span>
<span class="cstat-no" title="statement not covered" > el.component.removeEventListener('scroll', el.listener);</span>
<span class="cstat-no" title="statement not covered" > this._scrollPanelRegister.splice(index, 1);</span>
}
}
_handleScroll(e) {
const scrolledIn = e.target;
const scrollOffset = scrolledIn.scrollTop;
const elements = this._linksRegister
.map(<span class="fstat-no" title="function not covered" >(link) => ({ link, href: link.props.href }))</span>
.map(<span class="fstat-no" title="function not covered" >({ link, href }) => ({</span>
link, href,
panelComp: Scroller.getElementPanel(href),
panel: ReactDOM.findDOMNode(Scroller.getElementPanel(href))
}))
.filter(<span class="fstat-no" title="function not covered" >({ panel }) => scrolledIn.contains(panel))</span>
.map(<span class="fstat-no" title="function not covered" >({ link, panelComp, panel }) => link._handleScroll(scrollOffset, scrolledIn, { panel, panelComp }));</span>
const newActive = elements.find(<span class="fstat-no" title="function not covered" >({ isInside, hasActive }) => isInside && !hasActive);</span>
const oldActive = elements.find(<span class="fstat-no" title="function not covered" >({ isInside, hasActive }) => !isInside && hasActive);</span>
<span class="missing-if-branch" title="if path not taken" >I</span>if (newActive) {
<span class="cstat-no" title="statement not covered" > newActive.link.classList.add(newActive.activeClass);</span>
<span class="cstat-no" title="statement not covered" ></span> if (oldActive) {
<span class="cstat-no" title="statement not covered" > oldActive.link.classList.remove(oldActive.activeClass);</span>
}
}
}
}
export default new ScrollSpy();
</pre></td></tr>
</table></pre>
<div class='push'></div><!-- for sticky footer -->
</div><!-- /wrapper -->
<div class='footer quiet pad2 space-top1 center small'>
Code coverage
generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Fri Mar 25 2016 16:26:53 GMT+0100 (CET)
</div>
</div>
<script src="prettify.js"></script>
<script>
window.onload = function () {
if (typeof prettyPrint === 'function') {
prettyPrint();
}
};
</script>
<script src="sorter.js"></script>
</body>
</html>