UNPKG

i-react-utils

Version:
384 lines (383 loc) 12.9 kB
<!doctype html> <html lang="en"> <head> <title>Code coverage report for List.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> List.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">74.29% </span> <span class="quiet">Statements</span> <span class='fraction'>26/35</span> </div> <div class='fl pad1y space-right2'> <span class="strong">61.11% </span> <span class="quiet">Branches</span> <span class='fraction'>11/18</span> </div> <div class='fl pad1y space-right2'> <span class="strong">88.89% </span> <span class="quiet">Functions</span> <span class='fraction'>8/9</span> </div> <div class='fl pad1y space-right2'> <span class="strong">74.29% </span> <span class="quiet">Lines</span> <span class='fraction'>26/35</span> </div> </div> </div> <div class='status-line medium'></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 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107</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-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">6x</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-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-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-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">7x</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">6x</span> <span class="cline-any cline-yes">6x</span> <span class="cline-any cline-yes">6x</span> <span class="cline-any cline-yes">6x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">6x</span> <span class="cline-any cline-yes">6x</span> <span class="cline-any cline-yes">6x</span> <span class="cline-any cline-yes">6x</span> <span class="cline-any cline-yes">6x</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-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&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">6x</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">7x</span> <span class="cline-any cline-yes">6x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">7x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">7x</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">7x</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">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</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">13x</span> <span class="cline-any cline-yes">13x</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">13x</span> <span class="cline-any cline-yes">7x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">6x</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-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import React, { PropTypes } from 'react'; import {SimpleListTable, ListPagination} from './ListComponents'; import {devOnly, isEquivalent, shallowCopyExcept} from './utils'; import {_buildElement} from './utils-internal'; &nbsp; &nbsp; function copyProps(props) { return shallowCopyExcept({}, props, ['data', 'count', 'renderRow', 'showPagination', 'onPageChanged', 'prepareDataForPage', 'noDataComponent', 'headerAlwaysOn']); } &nbsp; &nbsp; export default class List extends React.Component { static propTypes = { id : React.PropTypes.string, // list id data : React.PropTypes.array, // data array (all available data) renderRow : React.PropTypes.func.isRequired, // function(item,index,key) : tr element count : React.PropTypes.number, // number of items per page onPageChanged : React.PropTypes.func, // callback function(page) : void (page is 1-indexed) prepareDataForPage : React.PropTypes.func, // function(data,page,count) : array of data (page is 1-indexed) showPagination : React.PropTypes.bool, // Default: true headerAlwaysOn : React.PropTypes.bool, // if show header and footer when no data is available. Default: true noDataComponent : React.PropTypes.oneOfType([ React.PropTypes.func, React.PropTypes.element ]) // component function or element }; &nbsp; static defaultProps = { showPagination : true, headerAlwaysOn : true, count : 10, id : "list-" + Math.floor(Math.random() * 1000000).toString(22), prepareDataForPage : function(data,page,count) { return data.slice((page -1)*count, page*count); } }; &nbsp; constructor(props) { super(); this.state = { }; this.page = 1; <span class="missing-if-branch" title="if path not taken" >I</span>if (props.renderRow == undefined) { <span class="cstat-no" title="statement not covered" > throw new Error('Missing function renderRow(item,index,key):component');</span> } this._handlePageChange = this._handlePageChange.bind(this); this._data = this._data.bind(this); this.props = props; this.htmlProps = copyProps(props); this.noDataElement = _buildElement(props.noDataComponent, this.htmlProps, []); } &nbsp; <span class="fstat-no" title="function not covered" > co</span>mponentWillReceiveProps(nextProps) { const updateData = <span class="cstat-no" title="statement not covered" >! isEquivalent(this.props.data, nextProps.data);</span> <span class="cstat-no" title="statement not covered" > this.htmlProps = copyProps(nextProps);</span> <span class="cstat-no" title="statement not covered" > if (this.props.noDataComponent != nextProps.noDataComponent) {</span> <span class="cstat-no" title="statement not covered" > this.noDataElement = _buildElement(nextProps.noDataComponent, this.htmlProps, []);</span> } <span class="cstat-no" title="statement not covered" > this.props = nextProps;</span> <span class="cstat-no" title="statement not covered" > if (updateData) {</span> <span class="cstat-no" title="statement not covered" > this._data(nextProps.data, true);</span> } } &nbsp; componentDidMount() { this._data(this.props.data, true); } &nbsp; _data(data, resetPage) { if (resetPage) { this.page = 1; } <span class="missing-if-branch" title="if path not taken" >I</span>if (data == null || data == undefined) { <span class="cstat-no" title="statement not covered" > data = [];</span> } const update = { items: this.props.prepareDataForPage(data, this.page, this.props.count), total: data.length, page: this.page }; this.setState(update); } &nbsp; _handlePageChange(pg) { <span class="missing-if-branch" title="else path not taken" >E</span>if (this.props.onPageChanged != undefined) { this.props.onPageChanged(pg); } this.page = pg; this._data(this.props.data, false); } &nbsp; render() { const {items, total, page} = this.state; return ( &lt;div {...this.htmlProps} key={this.id}&gt; &lt;SimpleListTable className={this.props.className} id={this.props.id} renderRow={this.props.renderRow} data={items} indexOffset={(page -1) * this.props.count} headerAlwaysOn={this.props.headerAlwaysOn} noDataElement={this.noDataElement}&gt; {this.props.children} &lt;/SimpleListTable&gt; {(() =&gt; { if (items &amp;&amp; this.props.showPagination) { return (&lt;ListPagination className={this.props.className} onPageChanged={this._handlePageChange} id={this.props.id} total={total} count={this.props.count} page={page}/&gt;); } else { return null; } })()} &lt;/div&gt; ); } } &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 Sun Dec 17 2017 22:40:08 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>