UNPKG

react-breadcrumbs-dynamic

Version:

React dynamic breadcrumbs extremely flexible and easy to use

279 lines (278 loc) 7.96 kB
<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/throughContainer.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> throughContainer.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>31/31</span> </div> <div class='fl pad1y space-right2'> <span class="strong">58.33% </span> <span class="quiet">Branches</span> <span class='fraction'>7/12</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>8/8</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>30/30</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">22x</span> <span class="cline-any cline-yes">22x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">66x</span> <span class="cline-any cline-yes">66x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">66x</span> <span class="cline-any cline-yes">42x</span> <span class="cline-any cline-yes">42x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">42x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-yes">24x</span> <span class="cline-any cline-yes">11x</span> <span class="cline-any cline-yes">11x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">11x</span> <span class="cline-any cline-yes">11x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">11x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">79x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import React, { Children } from 'react' import PropTypes from 'prop-types' &nbsp; const MAX_DATA_NUM = 1000000 &nbsp; const throughContainer = (area) =&gt; (ThroughComponent) =&gt; { class ThroughContainer extends React.Component { static contextTypes = { through: PropTypes.object, } &nbsp; constructor(props, context) { super(props, context) this.state = { dataNum: MAX_DATA_NUM } this.dataNum = MAX_DATA_NUM this.data = {} this.timer = undefined this.mounted = false this.canSetState = false } &nbsp; componentDidMount() { this.unsubscribe = this.context.through.subscribe(area, this.doUpdate) this.canSetState = true <span class="missing-if-branch" title="else path not taken" >E</span>if(this.state.dataNum != this.dataNum) { this.doUpdate(this.data, true) } } &nbsp; componentWillUnmount() { this.unsubscribe() this.canSetState = false } &nbsp; doUpdate = (data, syncUpdate) =&gt; { this.data = data ++this.dataNum &nbsp; if( syncUpdate ) { <span class="missing-if-branch" title="else path not taken" >E</span>if(this.canSetState) { this.setState({dataNum: this.dataNum}) } return } &nbsp; <span class="missing-if-branch" title="else path not taken" >E</span>if( !this.timer ) { this.timer = setTimeout(() =&gt; { <span class="missing-if-branch" title="else path not taken" >E</span>if(this.dataNum &gt; MAX_DATA_NUM ) { this.dataNum = 0 } <span class="missing-if-branch" title="else path not taken" >E</span>if(this.canSetState) { this.setState({dataNum: this.dataNum}) } this.timer = undefined }, 0) } } &nbsp; render() { return ( &lt;ThroughComponent {...this.props} {...{[area]: this.data}} /&gt; ) } } &nbsp; return ThroughContainer } &nbsp; export default throughContainer &nbsp;</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="https://istanbul.js.org/" target="_blank">istanbul</a> at Thu Dec 14 2017 12:56:28 GMT+0300 (Московское время (зима)) </div> </div> <script src="..\prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="..\sorter.js"></script> </body> </html>