react-spy-scroll
Version:
Scrollspy components for react
304 lines (303 loc) • 10.8 kB
HTML
<html lang="en">
<head>
<title>Code coverage report for src/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> / <a href="index.html">src/</a> scroll-spy.js
</h1>
<div class='clearfix'>
<div class='fl pad1y space-right2'>
<span class="strong">89.61% </span>
<span class="quiet">Statements</span>
<span class='fraction'>138/154</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">78.79% </span>
<span class="quiet">Branches</span>
<span class='fraction'>52/66</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">78.38% </span>
<span class="quiet">Functions</span>
<span class='fraction'>29/37</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">51.52% </span>
<span class="quiet">Lines</span>
<span class='fraction'>17/33</span>
</div>
<div class='fl pad1y'>
<span class="strong">48 statements, 14 functions, 29 branches</span>
<span class="quiet">Ignored</span>
</div>
</div>
</div>
<div class='status-line high'></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">1×</span>
<span class="cline-any cline-yes">1×</span>
<span class="cline-any cline-yes">1×</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1×</span>
<span class="cline-any cline-yes">1×</span>
<span class="cline-any cline-yes">1×</span>
<span class="cline-any cline-yes">1×</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1×</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">1×</span>
<span class="cline-any cline-yes">1×</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">1×</span>
<span class="cline-any cline-yes">1×</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1×</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">1×</span>
<span class="cline-any cline-yes">1×</span>
<span class="cline-any cline-neutral"> </span>
<span class="cline-any cline-yes">1×</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" > i</span>f (!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" > i</span>f (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" >(</span>el) => el.component === component);</span>
<span class="cstat-no" title="statement not covered" > i</span>f (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" >(</span>link) => ({ link, href: link.props.href }))
.map(<span class="fstat-no" title="function not covered" >(</span>{ link, href }) => ({
link, href,
panelComp: Scroller.getElementPanel(href),
panel: ReactDOM.findDOMNode(Scroller.getElementPanel(href))
}))
.filter(<span class="fstat-no" title="function not covered" >(</span>{ panel }) => scrolledIn.contains(panel))
.map(<span class="fstat-no" title="function not covered" >(</span>{ link, panelComp, panel }) => link._handleScroll(scrollOffset, scrolledIn, { panel, panelComp }));
const newActive = elements.find(<span class="fstat-no" title="function not covered" >(</span>{ isInside, hasActive }) => isInside && !hasActive);
const oldActive = elements.find(<span class="fstat-no" title="function not covered" >(</span>{ isInside, hasActive }) => !isInside && hasActive);
<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" > i</span>f (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 Sat Mar 26 2016 15:12:56 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>