uawdijnntqw1x1x1
IP : 216.73.216.110
Hostname : 6.87.74.97.host.secureserver.net
Kernel : Linux 6.87.74.97.host.secureserver.net 4.18.0-553.83.1.el8_10.x86_64 #1 SMP Mon Nov 10 04:22:44 EST 2025 x86_64
Disable Function : None :)
OS : Linux
PATH:
/
home
/
emeraadmin
/
www
/
node_modules
/
liftup
/
..
/
map-cache
/
..
/
..
/
4d695
/
coverage.tar
/
/
PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/editing/History.js.html000064400000027201151677271550020427 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/editing/History.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/js/base/editing/</a> History.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">76.19% </span> <span class="quiet">Statements</span> <span class='fraction'>32/42</span> </div> <div class='fl pad1y space-right2'> <span class="strong">43.75% </span> <span class="quiet">Branches</span> <span class='fraction'>7/16</span> </div> <div class='fl pad1y space-right2'> <span class="strong">77.78% </span> <span class="quiet">Functions</span> <span class='fraction'>7/9</span> </div> <div class='fl pad1y space-right2'> <span class="strong">76.19% </span> <span class="quiet">Lines</span> <span class='fraction'>32/42</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</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">126×</span> <span class="cline-any cline-yes">126×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">126×</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">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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-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-no"> </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-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-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-no"> </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-neutral"> </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-neutral"> </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-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-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-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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">126×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">126×</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-yes">126×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import range from '../core/range'; export default class History { constructor($editable) { this.stack = []; this.stackOffset = -1; this.$editable = $editable; this.editable = $editable[0]; } makeSnapshot() { const rng = range.create(this.editable); const emptyBookmark = {s: {path: [], offset: 0}, e: {path: [], offset: 0}}; return { contents: this.$editable.html(), bookmark: (rng ? rng.bookmark(this.editable) : <span class="branch-1 cbranch-no" title="branch not covered" >emptyBookmark)</span> }; } applySnapshot(snapshot) { <span class="missing-if-branch" title="else path not taken" >E</span>if (snapshot.contents !== null) { this.$editable.html(snapshot.contents); } <span class="missing-if-branch" title="else path not taken" >E</span>if (snapshot.bookmark !== null) { range.createFromBookmark(this.editable, snapshot.bookmark).select(); } } /** * @method rewind * Rewinds the history stack back to the first snapshot taken. * Leaves the stack intact, so that "Redo" can still be used. */ <span class="fstat-no" title="function not covered" > rewind() {</span> // Create snap shot if not yet recorded <span class="cstat-no" title="statement not covered" > if (this.$editable.html() !== this.stack[this.stackOffset].contents) {</span> <span class="cstat-no" title="statement not covered" > this.recordUndo();</span> } // Return to the first available snapshot. <span class="cstat-no" title="statement not covered" > this.stackOffset = 0;</span> // Apply that snapshot. <span class="cstat-no" title="statement not covered" > this.applySnapshot(this.stack[this.stackOffset]);</span> } /** * @method reset * Resets the history stack completely; reverting to an empty editor. */ <span class="fstat-no" title="function not covered" > reset() {</span> // Clear the stack. <span class="cstat-no" title="statement not covered" > this.stack = [];</span> // Restore stackOffset to its original value. <span class="cstat-no" title="statement not covered" > this.stackOffset = -1;</span> // Clear the editable area. <span class="cstat-no" title="statement not covered" > this.$editable.html('');</span> // Record our first snapshot (of nothing). <span class="cstat-no" title="statement not covered" > this.recordUndo();</span> } /** * undo */ undo() { // Create snap shot if not yet recorded <span class="missing-if-branch" title="if path not taken" >I</span>if (this.$editable.html() !== this.stack[this.stackOffset].contents) { <span class="cstat-no" title="statement not covered" > this.recordUndo();</span> } <span class="missing-if-branch" title="else path not taken" >E</span>if (this.stackOffset > 0) { this.stackOffset--; this.applySnapshot(this.stack[this.stackOffset]); } } /** * redo */ redo() { <span class="missing-if-branch" title="else path not taken" >E</span>if (this.stack.length - 1 > this.stackOffset) { this.stackOffset++; this.applySnapshot(this.stack[this.stackOffset]); } } /** * recorded undo */ recordUndo() { this.stackOffset++; // Wash out stack after stackOffset <span class="missing-if-branch" title="if path not taken" >I</span>if (this.stack.length > this.stackOffset) { <span class="cstat-no" title="statement not covered" > this.stack = this.stack.slice(0, this.stackOffset);</span> } // Create new snapshot and push it to the end this.stack.push(this.makeSnapshot()); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/editing/index.html000064400000014621151677271550017464 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/editing/</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> src/js/base/editing/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">88.13% </span> <span class="quiet">Statements</span> <span class='fraction'>453/514</span> </div> <div class='fl pad1y space-right2'> <span class="strong">76.09% </span> <span class="quiet">Branches</span> <span class='fraction'>210/276</span> </div> <div class='fl pad1y space-right2'> <span class="strong">90% </span> <span class="quiet">Functions</span> <span class='fraction'>63/70</span> </div> <div class='fl pad1y space-right2'> <span class="strong">88.8% </span> <span class="quiet">Lines</span> <span class='fraction'>452/509</span> </div> </div> </div> <div class='status-line high'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file high" data-value="Bullet.js"><a href="Bullet.js.html">Bullet.js</a></td> <td data-value="97.73" class="pic high"><div class="chart"><div class="cover-fill" style="width: 97%;"></div><div class="cover-empty" style="width:3%;"></div></div></td> <td data-value="97.73" class="pct high">97.73%</td> <td data-value="88" class="abs high">86/88</td> <td data-value="78.95" class="pct medium">78.95%</td> <td data-value="38" class="abs medium">30/38</td> <td data-value="100" class="pct high">100%</td> <td data-value="23" class="abs high">23/23</td> <td data-value="97.73" class="pct high">97.73%</td> <td data-value="88" class="abs high">86/88</td> </tr> <tr> <td class="file medium" data-value="History.js"><a href="History.js.html">History.js</a></td> <td data-value="76.19" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 76%;"></div><div class="cover-empty" style="width:24%;"></div></div></td> <td data-value="76.19" class="pct medium">76.19%</td> <td data-value="42" class="abs medium">32/42</td> <td data-value="43.75" class="pct low">43.75%</td> <td data-value="16" class="abs low">7/16</td> <td data-value="77.78" class="pct medium">77.78%</td> <td data-value="9" class="abs medium">7/9</td> <td data-value="76.19" class="pct medium">76.19%</td> <td data-value="42" class="abs medium">32/42</td> </tr> <tr> <td class="file high" data-value="Style.js"><a href="Style.js.html">Style.js</a></td> <td data-value="84.62" class="pic high"><div class="chart"><div class="cover-fill" style="width: 84%;"></div><div class="cover-empty" style="width:16%;"></div></div></td> <td data-value="84.62" class="pct high">84.62%</td> <td data-value="65" class="abs high">55/65</td> <td data-value="82.22" class="pct high">82.22%</td> <td data-value="45" class="abs high">37/45</td> <td data-value="75" class="pct medium">75%</td> <td data-value="12" class="abs medium">9/12</td> <td data-value="84.62" class="pct high">84.62%</td> <td data-value="65" class="abs high">55/65</td> </tr> <tr> <td class="file high" data-value="Table.js"><a href="Table.js.html">Table.js</a></td> <td data-value="89.96" class="pic high"><div class="chart"><div class="cover-fill" style="width: 89%;"></div><div class="cover-empty" style="width:11%;"></div></div></td> <td data-value="89.96" class="pct high">89.96%</td> <td data-value="279" class="abs high">251/279</td> <td data-value="78.48" class="pct medium">78.48%</td> <td data-value="158" class="abs medium">124/158</td> <td data-value="95.24" class="pct high">95.24%</td> <td data-value="21" class="abs high">20/21</td> <td data-value="91.24" class="pct high">91.24%</td> <td data-value="274" class="abs high">250/274</td> </tr> <tr> <td class="file medium" data-value="Typing.js"><a href="Typing.js.html">Typing.js</a></td> <td data-value="72.5" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 72%;"></div><div class="cover-empty" style="width:28%;"></div></div></td> <td data-value="72.5" class="pct medium">72.5%</td> <td data-value="40" class="abs medium">29/40</td> <td data-value="63.16" class="pct medium">63.16%</td> <td data-value="19" class="abs medium">12/19</td> <td data-value="80" class="pct high">80%</td> <td data-value="5" class="abs high">4/5</td> <td data-value="72.5" class="pct medium">72.5%</td> <td data-value="40" class="abs medium">29/40</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/editing/Bullet.js.html000064400000046530151677271550020223 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/editing/Bullet.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/js/base/editing/</a> Bullet.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">97.73% </span> <span class="quiet">Statements</span> <span class='fraction'>86/88</span> </div> <div class='fl pad1y space-right2'> <span class="strong">78.95% </span> <span class="quiet">Branches</span> <span class='fraction'>30/38</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>23/23</span> </div> <div class='fl pad1y space-right2'> <span class="strong">97.73% </span> <span class="quiet">Lines</span> <span class='fraction'>86/88</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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">2×</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">2×</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">3×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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-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-neutral"> </span> <span class="cline-any cline-yes">2×</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">3×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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-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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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">5×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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">4×</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">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</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">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</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-yes">3×</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">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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">2×</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">2×</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">2×</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-yes">2×</span> <span class="cline-any cline-yes">2×</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">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</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">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import lists from '../core/lists'; import func from '../core/func'; import dom from '../core/dom'; import range from '../core/range'; export default class Bullet { /** * toggle ordered list */ insertOrderedList(editable) { this.toggleList('OL', editable); } /** * toggle unordered list */ insertUnorderedList(editable) { this.toggleList('UL', editable); } /** * indent */ indent(editable) { const rng = range.create(editable).wrapBodyInlineWithPara(); const paras = rng.nodes(dom.isPara, { includeAncestor: true }); const clustereds = lists.clusterBy(paras, func.peq2('parentNode')); $.each(clustereds, (idx, paras) => { const head = lists.head(paras); if (dom.isLi(head)) { this.wrapList(paras, head.parentNode.nodeName); } else { $.each(paras, (idx, para) => { $(para).css('marginLeft', (idx, val) => { return (parseInt(val, 10) || 0) + 25; }); }); } }); rng.select(); } /** * outdent */ outdent(editable) { const rng = range.create(editable).wrapBodyInlineWithPara(); const paras = rng.nodes(dom.isPara, { includeAncestor: true }); const clustereds = lists.clusterBy(paras, func.peq2('parentNode')); $.each(clustereds, (idx, paras) => { const head = lists.head(paras); if (dom.isLi(head)) { this.releaseList([paras]); } else { $.each(paras, (idx, para) => { $(para).css('marginLeft', (idx, val) => { val = (parseInt(val, 10) || <span class="branch-1 cbranch-no" title="branch not covered" >0)</span>; return val > 25 ? <span class="branch-0 cbranch-no" title="branch not covered" >val - 25 </span>: ''; }); }); } }); rng.select(); } /** * toggle list * * @param {String} listName - OL or UL */ toggleList(listName, editable) { const rng = range.create(editable).wrapBodyInlineWithPara(); let paras = rng.nodes(dom.isPara, { includeAncestor: true }); const bookmark = rng.paraBookmark(paras); const clustereds = lists.clusterBy(paras, func.peq2('parentNode')); // paragraph to list if (lists.find(paras, dom.isPurePara)) { let wrappedParas = []; $.each(clustereds, (idx, paras) => { wrappedParas = wrappedParas.concat(this.wrapList(paras, listName)); }); paras = wrappedParas; // list to paragraph or change list style } else { const diffLists = rng.nodes(dom.isList, { includeAncestor: true }).filter((listNode) => { return !$.nodeName(listNode, listName); }); if (diffLists.length) { $.each(diffLists, (idx, listNode) => { dom.replace(listNode, listName); }); } else { paras = this.releaseList(clustereds, true); } } range.createFromParaBookmark(bookmark, paras).select(); } /** * @param {Node[]} paras * @param {String} listName * @return {Node[]} */ wrapList(paras, listName) { const head = lists.head(paras); const last = lists.last(paras); const prevList = dom.isList(head.previousSibling) && <span class="branch-1 cbranch-no" title="branch not covered" >head.previousSibling;</span> const nextList = dom.isList(last.nextSibling) && <span class="branch-1 cbranch-no" title="branch not covered" >last.nextSibling;</span> const listNode = prevList || dom.insertAfter(dom.create(listName || <span class="branch-1 cbranch-no" title="branch not covered" >'UL')</span>, last); // P to LI paras = paras.map((para) => { return dom.isPurePara(para) ? dom.replace(para, 'LI') : para; }); // append to list(<ul>, <ol>) dom.appendChildNodes(listNode, paras); <span class="missing-if-branch" title="if path not taken" >I</span>if (nextList) { <span class="cstat-no" title="statement not covered" > dom.appendChildNodes(listNode, lists.from(nextList.childNodes));</span> <span class="cstat-no" title="statement not covered" > dom.remove(nextList);</span> } return paras; } /** * @method releaseList * * @param {Array[]} clustereds * @param {Boolean} isEscapseToBody * @return {Node[]} */ releaseList(clustereds, isEscapseToBody) { let releasedParas = []; $.each(clustereds, (idx, paras) => { const head = lists.head(paras); const last = lists.last(paras); const headList = isEscapseToBody ? dom.lastAncestor(head, dom.isList) : head.parentNode; const lastList = headList.childNodes.length > 1 ? <span class="branch-0 cbranch-no" title="branch not covered" >dom.splitTree(headList, {</span> node: last.parentNode, offset: dom.position(last) + 1 }, { isSkipPaddingBlankHTML: true }) : null; const middleList = dom.splitTree(headList, { node: head.parentNode, offset: dom.position(head) }, { isSkipPaddingBlankHTML: true }); paras = isEscapseToBody ? dom.listDescendant(middleList, dom.isLi) : lists.from(middleList.childNodes).filter(dom.isLi); // LI to P if (isEscapseToBody || !dom.isList(headList.parentNode)) { paras = paras.map((para) => { return dom.replace(para, 'P'); }); } $.each(lists.from(paras).reverse(), (idx, para) => { dom.insertAfter(para, headList); }); // remove empty lists const rootLists = lists.compact([headList, middleList, lastList]); $.each(rootLists, (idx, rootList) => { const listNodes = [rootList].concat(dom.listDescendant(rootList, dom.isList)); $.each(listNodes.reverse(), (idx, listNode) => { <span class="missing-if-branch" title="else path not taken" >E</span>if (!dom.nodeLength(listNode)) { dom.remove(listNode, true); } }); }); releasedParas = releasedParas.concat(paras); }); return releasedParas; } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/editing/Table.js.html000064400000157722151677271550020031 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/editing/Table.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/js/base/editing/</a> Table.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">89.96% </span> <span class="quiet">Statements</span> <span class='fraction'>251/279</span> </div> <div class='fl pad1y space-right2'> <span class="strong">78.48% </span> <span class="quiet">Branches</span> <span class='fraction'>124/158</span> </div> <div class='fl pad1y space-right2'> <span class="strong">95.24% </span> <span class="quiet">Functions</span> <span class='fraction'>20/21</span> </div> <div class='fl pad1y space-right2'> <span class="strong">91.24% </span> <span class="quiet">Lines</span> <span class='fraction'>250/274</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575</td><td class="line-coverage quiet"><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-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">24×</span> <span class="cline-any cline-yes">24×</span> <span class="cline-any cline-yes">24×</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">24×</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-yes">24×</span> <span class="cline-any cline-yes">24×</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-yes">24×</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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">112×</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">112×</span> <span class="cline-any cline-yes">52×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">112×</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">42×</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-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">102×</span> <span class="cline-any cline-yes">42×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">60×</span> <span class="cline-any cline-yes">45×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">15×</span> <span class="cline-any cline-yes">15×</span> <span class="cline-any cline-yes">16×</span> <span class="cline-any cline-yes">16×</span> <span class="cline-any cline-yes">15×</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">94×</span> <span class="cline-any cline-yes">94×</span> <span class="cline-any cline-yes">94×</span> <span class="cline-any cline-yes">94×</span> <span class="cline-any cline-yes">94×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">94×</span> <span class="cline-any cline-yes">94×</span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-yes">10×</span> <span class="cline-any cline-yes">10×</span> <span class="cline-any cline-yes">10×</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">94×</span> <span class="cline-any cline-yes">94×</span> <span class="cline-any cline-yes">7×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">4×</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">24×</span> <span class="cline-any cline-yes">24×</span> <span class="cline-any cline-yes">52×</span> <span class="cline-any cline-yes">52×</span> <span class="cline-any cline-yes">94×</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">22×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">17×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">17×</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">20×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">7×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">12×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">14×</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">24×</span> <span class="cline-any cline-yes">24×</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">24×</span> <span class="cline-any cline-yes">24×</span> <span class="cline-any cline-yes">24×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">24×</span> <span class="cline-any cline-yes">24×</span> <span class="cline-any cline-yes">24×</span> <span class="cline-any cline-yes">66×</span> <span class="cline-any cline-yes">66×</span> <span class="cline-any cline-yes">66×</span> <span class="cline-any cline-yes">66×</span> <span class="cline-any cline-yes">13×</span> <span class="cline-any cline-yes">13×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">53×</span> <span class="cline-any cline-yes">53×</span> <span class="cline-any cline-yes">11×</span> <span class="cline-any cline-yes">11×</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">42×</span> <span class="cline-any cline-yes">42×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">20×</span> <span class="cline-any cline-yes">20×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">22×</span> <span class="cline-any cline-yes">22×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">42×</span> <span class="cline-any cline-yes">42×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">24×</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-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-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-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">2×</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-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-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> <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">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">12×</span> <span class="cline-any cline-yes">12×</span> <span class="cline-any cline-yes">12×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</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-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">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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">8×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</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-yes">4×</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">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6×</span> <span class="cline-any cline-yes">5×</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-yes">6×</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-no"> </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">28×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">28×</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-yes">28×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">28×</span> <span class="cline-any cline-yes">26×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</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">28×</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">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">5×</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-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</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-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-yes">1×</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-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-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-yes">1×</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-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</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">8×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">17×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">17×</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-yes">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</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">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-yes">14×</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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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">2×</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-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></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import dom from '../core/dom'; import range from '../core/range'; import lists from '../core/lists'; /** * @class Create a virtual table to create what actions to do in change. * @param {object} startPoint Cell selected to apply change. * @param {enum} where Where change will be applied Row or Col. Use enum: TableResultAction.where * @param {enum} action Action to be applied. Use enum: TableResultAction.requestAction * @param {object} domTable Dom element of table to make changes. */ const TableResultAction = function(startPoint, where, action, domTable) { const _startPoint = { 'colPos': 0, 'rowPos': 0 }; const _virtualTable = []; const _actionCellList = []; /// /////////////////////////////////////////// // Private functions /// /////////////////////////////////////////// /** * Set the startPoint of action. */ function setStartPoint() { <span class="missing-if-branch" title="if path not taken" >I</span>if (!startPoint || !startPoint.tagName || (startPoint.tagName.toLowerCase() !== 'td' && <span class="branch-3 cbranch-no" title="branch not covered" >startPoint.tagName.toLowerCase() !== 'th')</span>) { <span class="cstat-no" title="statement not covered" > console.error('Impossible to identify start Cell point.', startPoint);</span> <span class="cstat-no" title="statement not covered" > return;</span> } _startPoint.colPos = startPoint.cellIndex; <span class="missing-if-branch" title="if path not taken" >I</span>if (!startPoint.parentElement || !startPoint.parentElement.tagName || startPoint.parentElement.tagName.toLowerCase() !== 'tr') { <span class="cstat-no" title="statement not covered" > console.error('Impossible to identify start Row point.', startPoint);</span> <span class="cstat-no" title="statement not covered" > return;</span> } _startPoint.rowPos = startPoint.parentElement.rowIndex; } /** * Define virtual table position info object. * * @param {int} rowIndex Index position in line of virtual table. * @param {int} cellIndex Index position in column of virtual table. * @param {object} baseRow Row affected by this position. * @param {object} baseCell Cell affected by this position. * @param {bool} isSpan Inform if it is an span cell/row. */ function setVirtualTablePosition(rowIndex, cellIndex, baseRow, baseCell, isRowSpan, isColSpan, isVirtualCell) { const objPosition = { 'baseRow': baseRow, 'baseCell': baseCell, 'isRowSpan': isRowSpan, 'isColSpan': isColSpan, 'isVirtual': isVirtualCell }; if (!_virtualTable[rowIndex]) { _virtualTable[rowIndex] = []; } _virtualTable[rowIndex][cellIndex] = objPosition; } /** * Create action cell object. * * @param {object} virtualTableCellObj Object of specific position on virtual table. * @param {enum} resultAction Action to be applied in that item. */ function getActionCell(virtualTableCellObj, resultAction, virtualRowPosition, virtualColPosition) { return { 'baseCell': virtualTableCellObj.baseCell, 'action': resultAction, 'virtualTable': { 'rowIndex': virtualRowPosition, 'cellIndex': virtualColPosition } }; } /** * Recover free index of row to append Cell. * * @param {int} rowIndex Index of row to find free space. * @param {int} cellIndex Index of cell to find free space in table. */ function recoverCellIndex(rowIndex, cellIndex) { if (!_virtualTable[rowIndex]) { return cellIndex; } if (!_virtualTable[rowIndex][cellIndex]) { return cellIndex; } let newCellIndex = cellIndex; while (_virtualTable[rowIndex][newCellIndex]) { newCellIndex++; if (!_virtualTable[rowIndex][newCellIndex]) { return newCellIndex; } } } /** * Recover info about row and cell and add information to virtual table. * * @param {object} row Row to recover information. * @param {object} cell Cell to recover information. */ function addCellInfoToVirtual(row, cell) { const cellIndex = recoverCellIndex(row.rowIndex, cell.cellIndex); const cellHasColspan = (cell.colSpan > 1); const cellHasRowspan = (cell.rowSpan > 1); const isThisSelectedCell = (row.rowIndex === _startPoint.rowPos && cell.cellIndex === _startPoint.colPos); setVirtualTablePosition(row.rowIndex, cellIndex, row, cell, cellHasRowspan, cellHasColspan, false); // Add span rows to virtual Table. const rowspanNumber = cell.attributes.rowSpan ? parseInt(cell.attributes.rowSpan.value, 10) : 0; if (rowspanNumber > 1) { for (let rp = 1; rp < rowspanNumber; rp++) { const rowspanIndex = row.rowIndex + rp; adjustStartPoint(rowspanIndex, cellIndex, cell, isThisSelectedCell); setVirtualTablePosition(rowspanIndex, cellIndex, row, cell, true, cellHasColspan, true); } } // Add span cols to virtual table. const colspanNumber = cell.attributes.colSpan ? parseInt(cell.attributes.colSpan.value, 10) : 0; if (colspanNumber > 1) { for (let cp = 1; cp < colspanNumber; cp++) { const cellspanIndex = recoverCellIndex(row.rowIndex, (cellIndex + cp)); adjustStartPoint(row.rowIndex, cellspanIndex, cell, isThisSelectedCell); setVirtualTablePosition(row.rowIndex, cellspanIndex, row, cell, cellHasRowspan, true, true); } } } /** * Process validation and adjust of start point if needed * * @param {int} rowIndex * @param {int} cellIndex * @param {object} cell * @param {bool} isSelectedCell */ function adjustStartPoint(rowIndex, cellIndex, cell, isSelectedCell) { if (rowIndex === _startPoint.rowPos && _startPoint.colPos >= cell.cellIndex && cell.cellIndex <= cellIndex && !isSelectedCell) { _startPoint.colPos++; } } /** * Create virtual table of cells with all cells, including span cells. */ function createVirtualTable() { const rows = domTable.rows; for (let rowIndex = 0; rowIndex < rows.length; rowIndex++) { const cells = rows[rowIndex].cells; for (let cellIndex = 0; cellIndex < cells.length; cellIndex++) { addCellInfoToVirtual(rows[rowIndex], cells[cellIndex]); } } } /** * Get action to be applied on the cell. * * @param {object} cell virtual table cell to apply action */ function getDeleteResultActionToCell(cell) { switch (where) { case TableResultAction.where.Column: if (cell.isColSpan) { return TableResultAction.resultAction.SubtractSpanCount; } break; case TableResultAction.where.Row: if (!cell.isVirtual && cell.isRowSpan) { return TableResultAction.resultAction.AddCell; } else if (cell.isRowSpan) { return TableResultAction.resultAction.SubtractSpanCount; } break; } return TableResultAction.resultAction.RemoveCell; } /** * Get action to be applied on the cell. * * @param {object} cell virtual table cell to apply action */ function getAddResultActionToCell(cell) { switch (where) { case TableResultAction.where.Column: if (cell.isColSpan) { return TableResultAction.resultAction.SumSpanCount; } else if (cell.isRowSpan && cell.isVirtual) { return TableResultAction.resultAction.Ignore; } break; case TableResultAction.where.Row: if (cell.isRowSpan) { return TableResultAction.resultAction.SumSpanCount; } else if (cell.isColSpan && cell.isVirtual) { return TableResultAction.resultAction.Ignore; } break; } return TableResultAction.resultAction.AddCell; } function init() { setStartPoint(); createVirtualTable(); } /// /////////////////////////////////////////// // Public functions /// /////////////////////////////////////////// /** * Recover array os what to do in table. */ this.getActionList = function() { const fixedRow = (where === TableResultAction.where.Row) ? _startPoint.rowPos : -1; const fixedCol = (where === TableResultAction.where.Column) ? _startPoint.colPos : -1; let actualPosition = 0; let canContinue = true; while (canContinue) { const rowPosition = (fixedRow >= 0) ? fixedRow : actualPosition; const colPosition = (fixedCol >= 0) ? fixedCol : actualPosition; const row = _virtualTable[rowPosition]; if (!row) { canContinue = false; return _actionCellList; } const cell = row[colPosition]; if (!cell) { canContinue = false; return _actionCellList; } // Define action to be applied in this cell let resultAction = TableResultAction.resultAction.Ignore; switch (action) { case TableResultAction.requestAction.Add: resultAction = getAddResultActionToCell(cell); break; case TableResultAction.requestAction.Delete: resultAction = getDeleteResultActionToCell(cell); break; } _actionCellList.push(getActionCell(cell, resultAction, rowPosition, colPosition)); actualPosition++; } <span class="cstat-no" title="statement not covered" > return _actionCellList;</span> }; init(); }; /** * * Where action occours enum. */ TableResultAction.where = { 'Row': 0, 'Column': 1 }; /** * * Requested action to apply enum. */ TableResultAction.requestAction = { 'Add': 0, 'Delete': 1 }; /** * * Result action to be executed enum. */ TableResultAction.resultAction = { 'Ignore': 0, 'SubtractSpanCount': 1, 'RemoveCell': 2, 'AddCell': 3, 'SumSpanCount': 4 }; /** * * @class editing.Table * * Table * */ export default class Table { /** * handle tab key * * @param {WrappedRange} rng * @param {Boolean} isShift */ <span class="fstat-no" title="function not covered" > tab(rng, isShift)</span> { <span class="cstat-no" title="statement not covered" > const cell = dom.ancestor(rng.commonAncestor(), dom.isCell);</span> <span class="cstat-no" title="statement not covered" > const table = dom.ancestor(cell, dom.isTable);</span> <span class="cstat-no" title="statement not covered" > const cells = dom.listDescendant(table, dom.isCell);</span> <span class="cstat-no" title="statement not covered" > const nextCell = lists[isShift ? 'prev' : 'next'](cells, cell);</span> <span class="cstat-no" title="statement not covered" > if (nextCell) {</span> <span class="cstat-no" title="statement not covered" > range.create(nextCell, 0).select();</span> } } /** * Add a new row * * @param {WrappedRange} rng * @param {String} position (top/bottom) * @return {Node} */ addRow(rng, position) { const cell = dom.ancestor(rng.commonAncestor(), dom.isCell); const currentTr = $(cell).closest('tr'); const trAttributes = this.recoverAttributes(currentTr); const html = $('<tr' + trAttributes + '></tr>'); const vTable = new TableResultAction(cell, TableResultAction.where.Row, TableResultAction.requestAction.Add, $(currentTr).closest('table')[0]); const actions = vTable.getActionList(); for (let idCell = 0; idCell < actions.length; idCell++) { const currentCell = actions[idCell]; const tdAttributes = this.recoverAttributes(currentCell.baseCell); switch (currentCell.action) { case TableResultAction.resultAction.AddCell: html.append('<td' + tdAttributes + '>' + dom.blank + '</td>'); break; case TableResultAction.resultAction.SumSpanCount: if (position === 'top') { const baseCellTr = currentCell.baseCell.parent; const isTopFromRowSpan = (!baseCellTr ? 0 : <span class="branch-1 cbranch-no" title="branch not covered" >currentCell.baseCell.closest('tr').rowIndex)</span> <= currentTr[0].rowIndex; <span class="missing-if-branch" title="else path not taken" >E</span>if (isTopFromRowSpan) { const newTd = $('<div></div>').append($('<td' + tdAttributes + '>' + dom.blank + '</td>').removeAttr('rowspan')).html(); html.append(newTd); break; } } let rowspanNumber = parseInt(currentCell.baseCell.rowSpan, 10); rowspanNumber++; currentCell.baseCell.setAttribute('rowSpan', rowspanNumber); break; } } if (position === 'top') { currentTr.before(html); } else { const cellHasRowspan = (cell.rowSpan > 1); if (cellHasRowspan) { const lastTrIndex = currentTr[0].rowIndex + (cell.rowSpan - 2); $($(currentTr).parent().find('tr')[lastTrIndex]).after($(html)); return; } currentTr.after(html); } } /** * Add a new col * * @param {WrappedRange} rng * @param {String} position (left/right) * @return {Node} */ addCol(rng, position) { const cell = dom.ancestor(rng.commonAncestor(), dom.isCell); const row = $(cell).closest('tr'); const rowsGroup = $(row).siblings(); rowsGroup.push(row); const vTable = new TableResultAction(cell, TableResultAction.where.Column, TableResultAction.requestAction.Add, $(row).closest('table')[0]); const actions = vTable.getActionList(); for (let actionIndex = 0; actionIndex < actions.length; actionIndex++) { const currentCell = actions[actionIndex]; const tdAttributes = this.recoverAttributes(currentCell.baseCell); switch (currentCell.action) { case TableResultAction.resultAction.AddCell: if (position === 'right') { $(currentCell.baseCell).after('<td' + tdAttributes + '>' + dom.blank + '</td>'); } else { $(currentCell.baseCell).before('<td' + tdAttributes + '>' + dom.blank + '</td>'); } break; case TableResultAction.resultAction.SumSpanCount: <span class="missing-if-branch" title="else path not taken" >E</span>if (position === 'right') { let colspanNumber = parseInt(currentCell.baseCell.colSpan, 10); colspanNumber++; currentCell.baseCell.setAttribute('colSpan', colspanNumber); } else { <span class="cstat-no" title="statement not covered" > $(currentCell.baseCell).before('<td' + tdAttributes + '>' + dom.blank + '</td>');</span> } break; } } } /* * Copy attributes from element. * * @param {object} Element to recover attributes. * @return {string} Copied string elements. */ recoverAttributes(el) { let resultStr = ''; <span class="missing-if-branch" title="if path not taken" >I</span>if (!el) { <span class="cstat-no" title="statement not covered" > return resultStr;</span> } const attrList = el.attributes || []; for (let i = 0; i < attrList.length; i++) { if (attrList[i].name.toLowerCase() === 'id') { continue; } <span class="missing-if-branch" title="else path not taken" >E</span>if (attrList[i].specified) { resultStr += ' ' + attrList[i].name + '=\'' + attrList[i].value + '\''; } } return resultStr; } /** * Delete current row * * @param {WrappedRange} rng * @return {Node} */ deleteRow(rng) { const cell = dom.ancestor(rng.commonAncestor(), dom.isCell); const row = $(cell).closest('tr'); const cellPos = row.children('td, th').index($(cell)); const rowPos = row[0].rowIndex; const vTable = new TableResultAction(cell, TableResultAction.where.Row, TableResultAction.requestAction.Delete, $(row).closest('table')[0]); const actions = vTable.getActionList(); for (let actionIndex = 0; actionIndex < actions.length; actionIndex++) { <span class="missing-if-branch" title="if path not taken" >I</span>if (!actions[actionIndex]) { <span class="cstat-no" title="statement not covered" > continue;</span> } const baseCell = actions[actionIndex].baseCell; const virtualPosition = actions[actionIndex].virtualTable; const hasRowspan = (baseCell.rowSpan && baseCell.rowSpan > 1); let rowspanNumber = (hasRowspan) ? parseInt(baseCell.rowSpan, 10) : 0; switch (actions[actionIndex].action) { <span class="branch-0 cbranch-no" title="branch not covered" > case TableResultAction.resultAction.Ignore:</span> <span class="cstat-no" title="statement not covered" > continue;</span> case TableResultAction.resultAction.AddCell: const nextRow = row.next('tr')[0]; <span class="missing-if-branch" title="if path not taken" >I</span>if (!nextRow) { <span class="cstat-no" title="statement not covered" >continue; </span>} const cloneRow = row[0].cells[cellPos]; <span class="missing-if-branch" title="else path not taken" >E</span>if (hasRowspan) { <span class="missing-if-branch" title="if path not taken" >I</span>if (rowspanNumber > 2) { <span class="cstat-no" title="statement not covered" > rowspanNumber--;</span> <span class="cstat-no" title="statement not covered" > nextRow.insertBefore(cloneRow, nextRow.cells[cellPos]);</span> <span class="cstat-no" title="statement not covered" > nextRow.cells[cellPos].setAttribute('rowSpan', rowspanNumber);</span> <span class="cstat-no" title="statement not covered" > nextRow.cells[cellPos].innerHTML = '';</span> } else <span class="missing-if-branch" title="else path not taken" >E</span>if (rowspanNumber === 2) { nextRow.insertBefore(cloneRow, nextRow.cells[cellPos]); nextRow.cells[cellPos].removeAttribute('rowSpan'); nextRow.cells[cellPos].innerHTML = ''; } } continue; case TableResultAction.resultAction.SubtractSpanCount: <span class="missing-if-branch" title="else path not taken" >E</span>if (hasRowspan) { <span class="missing-if-branch" title="else path not taken" >E</span>if (rowspanNumber > 2) { rowspanNumber--; baseCell.setAttribute('rowSpan', rowspanNumber); <span class="missing-if-branch" title="if path not taken" >I</span>if (virtualPosition.rowIndex !== rowPos && <span class="branch-1 cbranch-no" title="branch not covered" >baseCell.cellIndex === cellPos)</span> { <span class="cstat-no" title="statement not covered" >baseCell.innerHTML = ''; </span>} } else <span class="cstat-no" title="statement not covered" >if (rowspanNumber === 2) {</span> <span class="cstat-no" title="statement not covered" > baseCell.removeAttribute('rowSpan');</span> <span class="cstat-no" title="statement not covered" > if (virtualPosition.rowIndex !== rowPos && baseCell.cellIndex === cellPos) { <span class="cstat-no" title="statement not covered" >baseCell.innerHTML = ''; </span>}</span> } } continue; case TableResultAction.resultAction.RemoveCell: // Do not need remove cell because row will be deleted. continue; } } row.remove(); } /** * Delete current col * * @param {WrappedRange} rng * @return {Node} */ deleteCol(rng) { const cell = dom.ancestor(rng.commonAncestor(), dom.isCell); const row = $(cell).closest('tr'); const cellPos = row.children('td, th').index($(cell)); const vTable = new TableResultAction(cell, TableResultAction.where.Column, TableResultAction.requestAction.Delete, $(row).closest('table')[0]); const actions = vTable.getActionList(); for (let actionIndex = 0; actionIndex < actions.length; actionIndex++) { <span class="missing-if-branch" title="if path not taken" >I</span>if (!actions[actionIndex]) { <span class="cstat-no" title="statement not covered" > continue;</span> } switch (actions[actionIndex].action) { <span class="branch-0 cbranch-no" title="branch not covered" > case TableResultAction.resultAction.Ignore:</span> <span class="cstat-no" title="statement not covered" > continue;</span> case TableResultAction.resultAction.SubtractSpanCount: const baseCell = actions[actionIndex].baseCell; const hasColspan = (baseCell.colSpan && baseCell.colSpan > 1); <span class="missing-if-branch" title="else path not taken" >E</span>if (hasColspan) { let colspanNumber = (baseCell.colSpan) ? parseInt(baseCell.colSpan, 10) : <span class="branch-1 cbranch-no" title="branch not covered" >0;</span> if (colspanNumber > 2) { colspanNumber--; baseCell.setAttribute('colSpan', colspanNumber); <span class="missing-if-branch" title="if path not taken" >I</span>if (baseCell.cellIndex === cellPos) { <span class="cstat-no" title="statement not covered" >baseCell.innerHTML = ''; </span>} } else <span class="missing-if-branch" title="else path not taken" >E</span>if (colspanNumber === 2) { baseCell.removeAttribute('colSpan'); if (baseCell.cellIndex === cellPos) { baseCell.innerHTML = ''; } } } continue; case TableResultAction.resultAction.RemoveCell: dom.remove(actions[actionIndex].baseCell, true); continue; } } } /** * create empty table element * * @param {Number} rowCount * @param {Number} colCount * @return {Node} */ createTable(colCount, rowCount, options) { const tds = []; let tdHTML; for (let idxCol = 0; idxCol < colCount; idxCol++) { tds.push('<td>' + dom.blank + '</td>'); } tdHTML = tds.join(''); const trs = []; let trHTML; for (let idxRow = 0; idxRow < rowCount; idxRow++) { trs.push('<tr>' + tdHTML + '</tr>'); } trHTML = trs.join(''); const $table = $('<table>' + trHTML + '</table>'); if (options && options.tableClassName) { $table.addClass(options.tableClassName); } return $table[0]; } /** * Delete current table * * @param {WrappedRange} rng * @return {Node} */ deleteTable(rng) { const cell = dom.ancestor(rng.commonAncestor(), dom.isCell); $(cell).closest('table').remove(); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/editing/Style.js.html000064400000042403151677271550020067 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/editing/Style.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/js/base/editing/</a> Style.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">84.62% </span> <span class="quiet">Statements</span> <span class='fraction'>55/65</span> </div> <div class='fl pad1y space-right2'> <span class="strong">82.22% </span> <span class="quiet">Branches</span> <span class='fraction'>37/45</span> </div> <div class='fl pad1y space-right2'> <span class="strong">75% </span> <span class="quiet">Functions</span> <span class='fraction'>9/12</span> </div> <div class='fl pad1y space-right2'> <span class="strong">84.62% </span> <span class="quiet">Lines</span> <span class='fraction'>55/65</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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-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">215×</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-yes">215×</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">215×</span> <span class="cline-any cline-yes">215×</span> <span class="cline-any cline-yes">215×</span> <span class="cline-any cline-yes">215×</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-no"> </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-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-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">9×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">7×</span> <span class="cline-any cline-yes">7×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">7×</span> <span class="cline-any cline-yes">2×</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-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">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</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">38×</span> <span class="cline-any cline-yes">38×</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">38×</span> <span class="cline-any cline-yes">38×</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-neutral"> </span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-yes">38×</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-yes">38×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import env from '../core/env'; import func from '../core/func'; import lists from '../core/lists'; import dom from '../core/dom'; export default class Style { /** * @method jQueryCSS * * [workaround] for old jQuery * passing an array of style properties to .css() * will result in an object of property-value pairs. * (compability with version < 1.9) * * @private * @param {jQuery} $obj * @param {Array} propertyNames - An array of one or more CSS properties. * @return {Object} */ jQueryCSS($obj, propertyNames) { <span class="missing-if-branch" title="if path not taken" >I</span>if (env.jqueryVersion < 1.9) { <span class="cstat-no" title="statement not covered" > const result = {};</span> <span class="cstat-no" title="statement not covered" > $.each(propertyNames, <span class="fstat-no" title="function not covered" >(idx, propertyName)</span> => {</span> <span class="cstat-no" title="statement not covered" > result[propertyName] = $obj.css(propertyName);</span> }); <span class="cstat-no" title="statement not covered" > return result;</span> } return $obj.css(propertyNames); } /** * returns style object from node * * @param {jQuery} $node * @return {Object} */ fromNode($node) { const properties = ['font-family', 'font-size', 'text-align', 'list-style-type', 'line-height']; const styleInfo = this.jQueryCSS($node, properties) || <span class="branch-1 cbranch-no" title="branch not covered" >{};</span> styleInfo['font-size'] = parseInt(styleInfo['font-size'], 10); return styleInfo; } /** * paragraph level style * * @param {WrappedRange} rng * @param {Object} styleInfo */ <span class="fstat-no" title="function not covered" > stylePara(rng, styleInfo)</span> { <span class="cstat-no" title="statement not covered" > $.each(rng.nodes(dom.isPara, {</span> includeAncestor: true }), <span class="fstat-no" title="function not covered" >(idx, para)</span> => { <span class="cstat-no" title="statement not covered" > $(para).css(styleInfo);</span> }); } /** * insert and returns styleNodes on range. * * @param {WrappedRange} rng * @param {Object} [options] - options for styleNodes * @param {String} [options.nodeName] - default: `SPAN` * @param {Boolean} [options.expandClosestSibling] - default: `false` * @param {Boolean} [options.onlyPartialContains] - default: `false` * @return {Node[]} */ styleNodes(rng, options) { rng = rng.splitText(); const nodeName = (options && options.nodeName) || 'SPAN'; const expandClosestSibling = !!(options && options.expandClosestSibling); const onlyPartialContains = !!(options && options.onlyPartialContains); if (rng.isCollapsed()) { return [rng.insertNode(dom.create(nodeName))]; } let pred = dom.makePredByNodeName(nodeName); const nodes = rng.nodes(dom.isText, { fullyContains: true }).map((text) => { return dom.singleChildAncestor(text, pred) || dom.wrap(text, nodeName); }); if (expandClosestSibling) { if (onlyPartialContains) { const nodesInRange = rng.nodes(); // compose with partial contains predication pred = func.and(pred, (node) => { return lists.contains(nodesInRange, node); }); } return nodes.map((node) => { const siblings = dom.withClosestSiblings(node, pred); const head = lists.head(siblings); const tails = lists.tail(siblings); $.each(tails, (idx, elem) => { dom.appendChildNodes(head, elem.childNodes); dom.remove(elem); }); return lists.head(siblings); }); } else { return nodes; } } /** * get current style on cursor * * @param {WrappedRange} rng * @return {Object} - object contains style properties. */ current(rng) { const $cont = $(!dom.isElement(rng.sc) ? rng.sc.parentNode : <span class="branch-1 cbranch-no" title="branch not covered" >rng.sc)</span>; let styleInfo = this.fromNode($cont); // document.queryCommandState for toggle state // [workaround] prevent Firefox nsresult: "0x80004005 (NS_ERROR_FAILURE)" try { styleInfo = $.extend(styleInfo, { 'font-bold': document.queryCommandState('bold') ? 'bold' : 'normal', 'font-italic': document.queryCommandState('italic') ? 'italic' : 'normal', 'font-underline': document.queryCommandState('underline') ? 'underline' : 'normal', 'font-subscript': document.queryCommandState('subscript') ? 'subscript' : 'normal', 'font-superscript': document.queryCommandState('superscript') ? 'superscript' : 'normal', 'font-strikethrough': document.queryCommandState('strikethrough') ? 'strikethrough' : 'normal', 'font-family': document.queryCommandValue('fontname') || <span class="branch-1 cbranch-no" title="branch not covered" >styleInfo['font-family']</span> }); } catch (e) {} // list-style-type to list-style(unordered, ordered) <span class="missing-if-branch" title="else path not taken" >E</span>if (!rng.isOnList()) { styleInfo['list-style'] = 'none'; } else { <span class="cstat-no" title="statement not covered" > const orderedTypes = ['circle', 'disc', 'disc-leading-zero', 'square'];</span> <span class="cstat-no" title="statement not covered" > const isUnordered = $.inArray(styleInfo['list-style-type'], orderedTypes) > -1;</span> <span class="cstat-no" title="statement not covered" > styleInfo['list-style'] = isUnordered ? 'unordered' : 'ordered';</span> } const para = dom.ancestor(rng.sc, dom.isPara); <span class="missing-if-branch" title="if path not taken" >I</span>if (para && para.style['line-height']) { <span class="cstat-no" title="statement not covered" > styleInfo['line-height'] = para.style.lineHeight;</span> } else { const lineHeight = parseInt(styleInfo['line-height'], 10) / parseInt(styleInfo['font-size'], 10); styleInfo['line-height'] = lineHeight.toFixed(1); } styleInfo.anchor = rng.isOnAnchor() && dom.ancestor(rng.sc, dom.isAnchor); styleInfo.ancestors = dom.listAncestor(rng.sc, dom.isEditable); styleInfo.range = rng; return styleInfo; } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/editing/Typing.js.html000064400000025450151677271550020244 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/editing/Typing.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/js/base/editing/</a> Typing.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">72.5% </span> <span class="quiet">Statements</span> <span class='fraction'>29/40</span> </div> <div class='fl pad1y space-right2'> <span class="strong">63.16% </span> <span class="quiet">Branches</span> <span class='fraction'>12/19</span> </div> <div class='fl pad1y space-right2'> <span class="strong">80% </span> <span class="quiet">Functions</span> <span class='fraction'>4/5</span> </div> <div class='fl pad1y space-right2'> <span class="strong">72.5% </span> <span class="quiet">Lines</span> <span class='fraction'>29/40</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</td><td class="line-coverage quiet"><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-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">77×</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-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-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-yes">1×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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-yes">2×</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-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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-yes">2×</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-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import dom from '../core/dom'; import range from '../core/range'; import Bullet from '../editing/Bullet'; /** * @class editing.Typing * * Typing * */ export default class Typing { constructor() { // a Bullet instance to toggle lists off this.bullet = new Bullet(); } /** * insert tab * * @param {WrappedRange} rng * @param {Number} tabsize */ insertTab(rng, tabsize) { const tab = dom.createText(new Array(tabsize + 1).join(dom.NBSP_CHAR)); rng = rng.deleteContents(); rng.insertNode(tab, true); rng = range.create(tab, tabsize); rng.select(); } /** * insert paragraph */ insertParagraph(editable) { let rng = range.create(editable); // deleteContents on range. rng = rng.deleteContents(); // Wrap range if it needs to be wrapped by paragraph rng = rng.wrapBodyInlineWithPara(); // finding paragraph const splitRoot = dom.ancestor(rng.sc, dom.isPara); let nextPara; // on paragraph: split paragraph <span class="missing-if-branch" title="else path not taken" >E</span>if (splitRoot) { // if it is an empty line with li <span class="missing-if-branch" title="if path not taken" >I</span>if (dom.isEmpty(splitRoot) && dom.isLi(splitRoot)) { // toogle UL/OL and escape <span class="cstat-no" title="statement not covered" > this.bullet.toggleList(splitRoot.parentNode.nodeName);</span> <span class="cstat-no" title="statement not covered" > return;</span> // if it is an empty line with para on blockquote } else <span class="missing-if-branch" title="if path not taken" >I</span>if (dom.isEmpty(splitRoot) && dom.isPara(splitRoot) && dom.isBlockquote(splitRoot.parentNode)) { // escape blockquote <span class="cstat-no" title="statement not covered" > dom.insertAfter(splitRoot, splitRoot.parentNode);</span> <span class="cstat-no" title="statement not covered" > nextPara = splitRoot;</span> // if new line has content (not a line break) } else { nextPara = dom.splitTree(splitRoot, rng.getStartPoint()); let emptyAnchors = dom.listDescendant(splitRoot, dom.isEmptyAnchor); emptyAnchors = emptyAnchors.concat(dom.listDescendant(nextPara, dom.isEmptyAnchor)); $.each(emptyAnchors, <span class="fstat-no" title="function not covered" >(idx, anchor)</span> => { <span class="cstat-no" title="statement not covered" > dom.remove(anchor);</span> }); // replace empty heading, pre or custom-made styleTag with P tag <span class="missing-if-branch" title="if path not taken" >I</span>if ((dom.isHeading(nextPara) || dom.isPre(nextPara) || dom.isCustomStyleTag(nextPara)) && <span class="branch-3 cbranch-no" title="branch not covered" >dom.isEmpty(nextPara))</span> { <span class="cstat-no" title="statement not covered" > nextPara = dom.replace(nextPara, 'p');</span> } } // no paragraph: insert empty paragraph } else { <span class="cstat-no" title="statement not covered" > const next = rng.sc.childNodes[rng.so];</span> <span class="cstat-no" title="statement not covered" > nextPara = $(dom.emptyPara)[0];</span> <span class="cstat-no" title="statement not covered" > if (next) {</span> <span class="cstat-no" title="statement not covered" > rng.sc.insertBefore(nextPara, next);</span> } else { <span class="cstat-no" title="statement not covered" > rng.sc.appendChild(nextPara);</span> } } range.create(nextPara, 0).normalize().select().scrollIntoView(editable); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/core/range.js.html000064400000222276151677271550017400 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/core/range.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/js/base/core/</a> range.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">74.28% </span> <span class="quiet">Statements</span> <span class='fraction'>231/311</span> </div> <div class='fl pad1y space-right2'> <span class="strong">69.89% </span> <span class="quiet">Branches</span> <span class='fraction'>123/176</span> </div> <div class='fl pad1y space-right2'> <span class="strong">86.67% </span> <span class="quiet">Functions</span> <span class='fraction'>39/45</span> </div> <div class='fl pad1y space-right2'> <span class="strong">74.28% </span> <span class="quiet">Lines</span> <span class='fraction'>231/311</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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793</td><td class="line-coverage quiet"><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-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-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-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-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-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-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-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-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-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-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-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-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> <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-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-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-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-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-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-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-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-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-yes">596×</span> <span class="cline-any cline-yes">596×</span> <span class="cline-any cline-yes">596×</span> <span class="cline-any cline-yes">596×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">596×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">596×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">596×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">596×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">596×</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">42×</span> <span class="cline-any cline-yes">42×</span> <span class="cline-any cline-yes">42×</span> <span class="cline-any cline-yes">42×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">42×</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-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-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">15×</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">102×</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">187×</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">38×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-yes">11×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">38×</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-yes">38×</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">2×</span> <span class="cline-any cline-yes">2×</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-yes">2×</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-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">138×</span> <span class="cline-any cline-yes">162×</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">61×</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">101×</span> <span class="cline-any cline-yes">101×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">23×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">83×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">83×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">138×</span> <span class="cline-any cline-yes">138×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">138×</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-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">28×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">28×</span> <span class="cline-any cline-yes">28×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">28×</span> <span class="cline-any cline-yes">28×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">28×</span> <span class="cline-any cline-yes">28×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">28×</span> <span class="cline-any cline-yes">120×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">118×</span> <span class="cline-any cline-yes">118×</span> <span class="cline-any cline-yes">67×</span> <span class="cline-any cline-yes">17×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">67×</span> <span class="cline-any cline-yes">15×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">51×</span> <span class="cline-any cline-yes">46×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">118×</span> <span class="cline-any cline-yes">65×</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">28×</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">27×</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-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-neutral"> </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-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-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-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">133×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">129×</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">14×</span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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">14×</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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">41×</span> <span class="cline-any cline-yes">36×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</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">5×</span> <span class="cline-any cline-yes">10×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6×</span> <span class="cline-any cline-yes">6×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6×</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">5×</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">5×</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">2980×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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-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-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-yes">1×</span> <span class="cline-any cline-yes">190×</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">47×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">46×</span> <span class="cline-any cline-yes">46×</span> <span class="cline-any cline-yes">19×</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">27×</span> <span class="cline-any cline-yes">27×</span> <span class="cline-any cline-yes">26×</span> <span class="cline-any cline-yes">26×</span> <span class="cline-any cline-yes">26×</span> <span class="cline-any cline-yes">21×</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">27×</span> <span class="cline-any cline-yes">27×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">27×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">27×</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">26×</span> <span class="cline-any cline-yes">26×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">26×</span> <span class="cline-any cline-yes">13×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">13×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">26×</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">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">8×</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">4×</span> <span class="cline-any cline-yes">4×</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">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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">3×</span> <span class="cline-any cline-yes">17×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</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-yes">3×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">126×</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-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">4×</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-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-no"> </span> <span class="cline-any cline-no"> </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-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">591×</span> <span class="cline-any cline-yes">180×</span> <span class="cline-any cline-yes">411×</span> <span class="cline-any cline-yes">46×</span> <span class="cline-any cline-yes">46×</span> <span class="cline-any cline-yes">46×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">365×</span> <span class="cline-any cline-yes">365×</span> <span class="cline-any cline-yes">119×</span> <span class="cline-any cline-yes">119×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">246×</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">365×</span> <span class="cline-any cline-yes">365×</span> <span class="cline-any cline-yes">365×</span> <span class="cline-any cline-yes">365×</span> <span class="cline-any cline-yes">194×</span> <span class="cline-any cline-yes">171×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">102×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">69×</span> <span class="cline-any cline-yes">69×</span> <span class="cline-any cline-yes">69×</span> <span class="cline-any cline-yes">69×</span> <span class="cline-any cline-yes">69×</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-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-no"> </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-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-neutral"> </span> <span class="cline-any cline-yes">69×</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-neutral"> </span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">142×</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">142×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-yes">142×</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">142×</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">4×</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">9×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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">import $ from 'jquery'; import env from './env'; import func from './func'; import lists from './lists'; import dom from './dom'; /** * return boundaryPoint from TextRange, inspired by Andy Na's HuskyRange.js * * @param {TextRange} textRange * @param {Boolean} isStart * @return {BoundaryPoint} * * @see http://msdn.microsoft.com/en-us/library/ie/ms535872(v=vs.85).aspx */ <span class="fstat-no" title="function not covered" >function textRangeToPoint(textRange, isStart)</span> { <span class="cstat-no" title="statement not covered" > let container = textRange.parentElement();</span> <span class="cstat-no" title="statement not covered" > let offset;</span> <span class="cstat-no" title="statement not covered" > const tester = document.body.createTextRange();</span> <span class="cstat-no" title="statement not covered" > let prevContainer;</span> <span class="cstat-no" title="statement not covered" > const childNodes = lists.from(container.childNodes);</span> <span class="cstat-no" title="statement not covered" > for (offset = 0; offset < childNodes.length; offset++) {</span> <span class="cstat-no" title="statement not covered" > if (dom.isText(childNodes[offset])) {</span> <span class="cstat-no" title="statement not covered" > continue;</span> } <span class="cstat-no" title="statement not covered" > tester.moveToElementText(childNodes[offset]);</span> <span class="cstat-no" title="statement not covered" > if (tester.compareEndPoints('StartToStart', textRange) >= 0) {</span> <span class="cstat-no" title="statement not covered" > break;</span> } <span class="cstat-no" title="statement not covered" > prevContainer = childNodes[offset];</span> } <span class="cstat-no" title="statement not covered" > if (offset !== 0 && dom.isText(childNodes[offset - 1])) {</span> <span class="cstat-no" title="statement not covered" > const textRangeStart = document.body.createTextRange();</span> <span class="cstat-no" title="statement not covered" > let curTextNode = null;</span> <span class="cstat-no" title="statement not covered" > textRangeStart.moveToElementText(prevContainer || container);</span> <span class="cstat-no" title="statement not covered" > textRangeStart.collapse(!prevContainer);</span> <span class="cstat-no" title="statement not covered" > curTextNode = prevContainer ? prevContainer.nextSibling : container.firstChild;</span> <span class="cstat-no" title="statement not covered" > const pointTester = textRange.duplicate();</span> <span class="cstat-no" title="statement not covered" > pointTester.setEndPoint('StartToStart', textRangeStart);</span> <span class="cstat-no" title="statement not covered" > let textCount = pointTester.text.replace(/[\r\n]/g, '').length;</span> <span class="cstat-no" title="statement not covered" > while (textCount > curTextNode.nodeValue.length && curTextNode.nextSibling) {</span> <span class="cstat-no" title="statement not covered" > textCount -= curTextNode.nodeValue.length;</span> <span class="cstat-no" title="statement not covered" > curTextNode = curTextNode.nextSibling;</span> } // [workaround] enforce IE to re-reference curTextNode, hack <span class="cstat-no" title="statement not covered" > const dummy = curTextNode.nodeValue; </span>// eslint-disable-line <span class="cstat-no" title="statement not covered" > if (isStart && curTextNode.nextSibling && dom.isText(curTextNode.nextSibling) &&</span> textCount === curTextNode.nodeValue.length) { <span class="cstat-no" title="statement not covered" > textCount -= curTextNode.nodeValue.length;</span> <span class="cstat-no" title="statement not covered" > curTextNode = curTextNode.nextSibling;</span> } <span class="cstat-no" title="statement not covered" > container = curTextNode;</span> <span class="cstat-no" title="statement not covered" > offset = textCount;</span> } <span class="cstat-no" title="statement not covered" > return {</span> cont: container, offset: offset }; } /** * return TextRange from boundary point (inspired by google closure-library) * @param {BoundaryPoint} point * @return {TextRange} */ <span class="fstat-no" title="function not covered" >function pointToTextRange(point)</span> { <span class="cstat-no" title="statement not covered" > const textRangeInfo = <span class="fstat-no" title="function not covered" >function(container, offset)</span> {</span> <span class="cstat-no" title="statement not covered" > let node, isCollapseToStart;</span> <span class="cstat-no" title="statement not covered" > if (dom.isText(container)) {</span> <span class="cstat-no" title="statement not covered" > const prevTextNodes = dom.listPrev(container, func.not(dom.isText));</span> <span class="cstat-no" title="statement not covered" > const prevContainer = lists.last(prevTextNodes).previousSibling;</span> <span class="cstat-no" title="statement not covered" > node = prevContainer || container.parentNode;</span> <span class="cstat-no" title="statement not covered" > offset += lists.sum(lists.tail(prevTextNodes), dom.nodeLength);</span> <span class="cstat-no" title="statement not covered" > isCollapseToStart = !prevContainer;</span> } else { <span class="cstat-no" title="statement not covered" > node = container.childNodes[offset] || container;</span> <span class="cstat-no" title="statement not covered" > if (dom.isText(node)) {</span> <span class="cstat-no" title="statement not covered" > return textRangeInfo(node, 0);</span> } <span class="cstat-no" title="statement not covered" > offset = 0;</span> <span class="cstat-no" title="statement not covered" > isCollapseToStart = false;</span> } <span class="cstat-no" title="statement not covered" > return {</span> node: node, collapseToStart: isCollapseToStart, offset: offset }; }; <span class="cstat-no" title="statement not covered" > const textRange = document.body.createTextRange();</span> <span class="cstat-no" title="statement not covered" > const info = textRangeInfo(point.node, point.offset);</span> <span class="cstat-no" title="statement not covered" > textRange.moveToElementText(info.node);</span> <span class="cstat-no" title="statement not covered" > textRange.collapse(info.collapseToStart);</span> <span class="cstat-no" title="statement not covered" > textRange.moveStart('character', info.offset);</span> <span class="cstat-no" title="statement not covered" > return textRange;</span> } /** * Wrapped Range * * @constructor * @param {Node} sc - start container * @param {Number} so - start offset * @param {Node} ec - end container * @param {Number} eo - end offset */ class WrappedRange { constructor(sc, so, ec, eo) { this.sc = sc; this.so = so; this.ec = ec; this.eo = eo; // isOnEditable: judge whether range is on editable or not this.isOnEditable = this.makeIsOn(dom.isEditable); // isOnList: judge whether range is on list node or not this.isOnList = this.makeIsOn(dom.isList); // isOnAnchor: judge whether range is on anchor node or not this.isOnAnchor = this.makeIsOn(dom.isAnchor); // isOnCell: judge whether range is on cell node or not this.isOnCell = this.makeIsOn(dom.isCell); // isOnData: judge whether range is on data node or not this.isOnData = this.makeIsOn(dom.isData); } // nativeRange: get nativeRange from sc, so, ec, eo nativeRange() { <span class="missing-if-branch" title="else path not taken" >E</span>if (env.isW3CRangeSupport) { const w3cRange = document.createRange(); w3cRange.setStart(this.sc, this.so); w3cRange.setEnd(this.ec, this.eo); return w3cRange; } else { <span class="cstat-no" title="statement not covered" > const textRange = pointToTextRange({</span> node: this.sc, offset: this.so }); <span class="cstat-no" title="statement not covered" > textRange.setEndPoint('EndToEnd', pointToTextRange({</span> node: this.ec, offset: this.eo })); <span class="cstat-no" title="statement not covered" > return textRange;</span> } } getPoints() { return { sc: this.sc, so: this.so, ec: this.ec, eo: this.eo }; } getStartPoint() { return { node: this.sc, offset: this.so }; } getEndPoint() { return { node: this.ec, offset: this.eo }; } /** * select update visible range */ select() { const nativeRng = this.nativeRange(); <span class="missing-if-branch" title="else path not taken" >E</span>if (env.isW3CRangeSupport) { const selection = document.getSelection(); if (selection.rangeCount > 0) { selection.removeAllRanges(); } selection.addRange(nativeRng); } else { <span class="cstat-no" title="statement not covered" > nativeRng.select();</span> } return this; } /** * Moves the scrollbar to start container(sc) of current range * * @return {WrappedRange} */ scrollIntoView(container) { const height = $(container).height(); <span class="missing-if-branch" title="if path not taken" >I</span>if (container.scrollTop + height < this.sc.offsetTop) { <span class="cstat-no" title="statement not covered" > container.scrollTop += Math.abs(container.scrollTop + height - this.sc.offsetTop);</span> } return this; } /** * @return {WrappedRange} */ normalize() { /** * @param {BoundaryPoint} point * @param {Boolean} isLeftToRight * @return {BoundaryPoint} */ const getVisiblePoint = function(point, isLeftToRight) { if ((dom.isVisiblePoint(point) && !dom.isEdgePoint(point)) || (dom.isVisiblePoint(point) && dom.isRightEdgePoint(point) && !isLeftToRight) || (dom.isVisiblePoint(point) && dom.isLeftEdgePoint(point) && isLeftToRight) || (dom.isVisiblePoint(point) && dom.isBlock(point.node) && dom.isEmpty(point.node))) { return point; } // point on block's edge const block = dom.ancestor(point.node, dom.isBlock); if (((dom.isLeftEdgePointOf(point, block) || dom.isVoid(dom.prevPoint(point).node)) && !isLeftToRight) || ((dom.isRightEdgePointOf(point, block) || dom.isVoid(dom.nextPoint(point).node)) && isLeftToRight)) { // returns point already on visible point if (dom.isVisiblePoint(point)) { return point; } // reverse direction isLeftToRight = !isLeftToRight; } const nextPoint = isLeftToRight ? dom.nextPointUntil(dom.nextPoint(point), dom.isVisiblePoint) : dom.prevPointUntil(dom.prevPoint(point), dom.isVisiblePoint); return nextPoint || <span class="branch-1 cbranch-no" title="branch not covered" >point;</span> }; const endPoint = getVisiblePoint(this.getEndPoint(), false); const startPoint = this.isCollapsed() ? endPoint : getVisiblePoint(this.getStartPoint(), true); return new WrappedRange( startPoint.node, startPoint.offset, endPoint.node, endPoint.offset ); } /** * returns matched nodes on range * * @param {Function} [pred] - predicate function * @param {Object} [options] * @param {Boolean} [options.includeAncestor] * @param {Boolean} [options.fullyContains] * @return {Node[]} */ nodes(pred, options) { pred = pred || func.ok; const includeAncestor = options && options.includeAncestor; const fullyContains = options && options.fullyContains; // TODO compare points and sort const startPoint = this.getStartPoint(); const endPoint = this.getEndPoint(); const nodes = []; const leftEdgeNodes = []; dom.walkPoint(startPoint, endPoint, function(point) { if (dom.isEditable(point.node)) { return; } let node; if (fullyContains) { if (dom.isLeftEdgePoint(point)) { leftEdgeNodes.push(point.node); } if (dom.isRightEdgePoint(point) && lists.contains(leftEdgeNodes, point.node)) { node = point.node; } } else if (includeAncestor) { node = dom.ancestor(point.node, pred); } else { node = point.node; } if (node && pred(node)) { nodes.push(node); } }, true); return lists.unique(nodes); } /** * returns commonAncestor of range * @return {Element} - commonAncestor */ commonAncestor() { return dom.commonAncestor(this.sc, this.ec); } /** * returns expanded range by pred * * @param {Function} pred - predicate function * @return {WrappedRange} */ expand(pred) { const startAncestor = dom.ancestor(this.sc, pred); const endAncestor = dom.ancestor(this.ec, pred); <span class="missing-if-branch" title="if path not taken" >I</span>if (!startAncestor && <span class="branch-1 cbranch-no" title="branch not covered" >!endAncestor)</span> { <span class="cstat-no" title="statement not covered" > return new WrappedRange(this.sc, this.so, this.ec, this.eo);</span> } const boundaryPoints = this.getPoints(); <span class="missing-if-branch" title="else path not taken" >E</span>if (startAncestor) { boundaryPoints.sc = startAncestor; boundaryPoints.so = 0; } <span class="missing-if-branch" title="else path not taken" >E</span>if (endAncestor) { boundaryPoints.ec = endAncestor; boundaryPoints.eo = dom.nodeLength(endAncestor); } return new WrappedRange( boundaryPoints.sc, boundaryPoints.so, boundaryPoints.ec, boundaryPoints.eo ); } /** * @param {Boolean} isCollapseToStart * @return {WrappedRange} */ collapse(isCollapseToStart) { if (isCollapseToStart) { return new WrappedRange(this.sc, this.so, this.sc, this.so); } else { return new WrappedRange(this.ec, this.eo, this.ec, this.eo); } } /** * splitText on range */ splitText() { const isSameContainer = this.sc === this.ec; const boundaryPoints = this.getPoints(); if (dom.isText(this.ec) && !dom.isEdgePoint(this.getEndPoint())) { this.ec.splitText(this.eo); } if (dom.isText(this.sc) && !dom.isEdgePoint(this.getStartPoint())) { boundaryPoints.sc = this.sc.splitText(this.so); boundaryPoints.so = 0; if (isSameContainer) { boundaryPoints.ec = boundaryPoints.sc; boundaryPoints.eo = this.eo - this.so; } } return new WrappedRange( boundaryPoints.sc, boundaryPoints.so, boundaryPoints.ec, boundaryPoints.eo ); } /** * delete contents on range * @return {WrappedRange} */ deleteContents() { if (this.isCollapsed()) { return this; } const rng = this.splitText(); const nodes = rng.nodes(null, { fullyContains: true }); // find new cursor point const point = dom.prevPointUntil(rng.getStartPoint(), function(point) { return !lists.contains(nodes, point.node); }); const emptyParents = []; $.each(nodes, function(idx, node) { // find empty parents const parent = node.parentNode; if (point.node !== parent && dom.nodeLength(parent) === 1) { emptyParents.push(parent); } dom.remove(node, false); }); // remove empty parents $.each(emptyParents, function(idx, node) { dom.remove(node, false); }); return new WrappedRange( point.node, point.offset, point.node, point.offset ).normalize(); } /** * makeIsOn: return isOn(pred) function */ makeIsOn(pred) { return function() { const ancestor = dom.ancestor(this.sc, pred); return !!ancestor && (ancestor === dom.ancestor(this.ec, pred)); }; } /** * @param {Function} pred * @return {Boolean} */ <span class="fstat-no" title="function not covered" > isLeftEdgeOf(pred)</span> { <span class="cstat-no" title="statement not covered" > if (!dom.isLeftEdgePoint(this.getStartPoint())) {</span> <span class="cstat-no" title="statement not covered" > return false;</span> } <span class="cstat-no" title="statement not covered" > const node = dom.ancestor(this.sc, pred);</span> <span class="cstat-no" title="statement not covered" > return node && dom.isLeftEdgeOf(this.sc, node);</span> } /** * returns whether range was collapsed or not */ isCollapsed() { return this.sc === this.ec && this.so === this.eo; } /** * wrap inline nodes which children of body with paragraph * * @return {WrappedRange} */ wrapBodyInlineWithPara() { if (dom.isBodyContainer(this.sc) && dom.isEmpty(this.sc)) { this.sc.innerHTML = dom.emptyPara; return new WrappedRange(this.sc.firstChild, 0, this.sc.firstChild, 0); } /** * [workaround] firefox often create range on not visible point. so normalize here. * - firefox: |<p>text</p>| * - chrome: <p>|text|</p> */ const rng = this.normalize(); if (dom.isParaInline(this.sc) || dom.isPara(this.sc)) { return rng; } // find inline top ancestor let topAncestor; if (dom.isInline(rng.sc)) { const ancestors = dom.listAncestor(rng.sc, func.not(dom.isInline)); topAncestor = lists.last(ancestors); if (!dom.isInline(topAncestor)) { topAncestor = ancestors[ancestors.length - 2] || <span class="branch-1 cbranch-no" title="branch not covered" >rng.sc.childNodes[rng.so];</span> } } else { topAncestor = rng.sc.childNodes[rng.so > 0 ? rng.so - 1 : <span class="branch-1 cbranch-no" title="branch not covered" >0]</span>; } // siblings not in paragraph let inlineSiblings = dom.listPrev(topAncestor, dom.isParaInline).reverse(); inlineSiblings = inlineSiblings.concat(dom.listNext(topAncestor.nextSibling, dom.isParaInline)); // wrap with paragraph if (inlineSiblings.length) { const para = dom.wrap(lists.head(inlineSiblings), 'p'); dom.appendChildNodes(para, lists.tail(inlineSiblings)); } return this.normalize(); } /** * insert node at current cursor * * @param {Node} node * @return {Node} */ insertNode(node) { const rng = this.wrapBodyInlineWithPara().deleteContents(); const info = dom.splitPoint(rng.getStartPoint(), dom.isInline(node)); if (info.rightNode) { info.rightNode.parentNode.insertBefore(node, info.rightNode); } else { info.container.appendChild(node); } return node; } /** * insert html at current cursor */ pasteHTML(markup) { const contentsContainer = $('<div></div>').html(markup)[0]; const childNodes = lists.from(contentsContainer.childNodes); const rng = this.wrapBodyInlineWithPara().deleteContents(); return childNodes.reverse().map(function(childNode) { return rng.insertNode(childNode); }).reverse(); } /** * returns text in range * * @return {String} */ toString() { const nativeRng = this.nativeRange(); return env.isW3CRangeSupport ? nativeRng.toString() : <span class="branch-1 cbranch-no" title="branch not covered" >nativeRng.text;</span> } /** * returns range for word before cursor * * @param {Boolean} [findAfter] - find after cursor, default: false * @return {WrappedRange} */ getWordRange(findAfter) { let endPoint = this.getEndPoint(); if (!dom.isCharPoint(endPoint)) { return this; } const startPoint = dom.prevPointUntil(endPoint, function(point) { return !dom.isCharPoint(point); }); <span class="missing-if-branch" title="if path not taken" >I</span>if (findAfter) { <span class="cstat-no" title="statement not covered" > endPoint = dom.nextPointUntil(endPoint, <span class="fstat-no" title="function not covered" >function(point)</span> {</span> <span class="cstat-no" title="statement not covered" > return !dom.isCharPoint(point);</span> }); } return new WrappedRange( startPoint.node, startPoint.offset, endPoint.node, endPoint.offset ); } /** * create offsetPath bookmark * * @param {Node} editable */ bookmark(editable) { return { s: { path: dom.makeOffsetPath(editable, this.sc), offset: this.so }, e: { path: dom.makeOffsetPath(editable, this.ec), offset: this.eo } }; } /** * create offsetPath bookmark base on paragraph * * @param {Node[]} paras */ paraBookmark(paras) { return { s: { path: lists.tail(dom.makeOffsetPath(lists.head(paras), this.sc)), offset: this.so }, e: { path: lists.tail(dom.makeOffsetPath(lists.last(paras), this.ec)), offset: this.eo } }; } /** * getClientRects * @return {Rect[]} */ <span class="fstat-no" title="function not covered" > getClientRects() {</span> <span class="cstat-no" title="statement not covered" > const nativeRng = this.nativeRange();</span> <span class="cstat-no" title="statement not covered" > return nativeRng.getClientRects();</span> } } /** * Data structure * * BoundaryPoint: a point of dom tree * * BoundaryPoints: two boundaryPoints corresponding to the start and the end of the Range * * See to http://www.w3.org/TR/DOM-Level-2-Traversal-Range/ranges.html#Level-2-Range-Position */ export default { /** * create Range Object From arguments or Browser Selection * * @param {Node} sc - start container * @param {Number} so - start offset * @param {Node} ec - end container * @param {Number} eo - end offset * @return {WrappedRange} */ create: function(sc, so, ec, eo) { if (arguments.length === 4) { return new WrappedRange(sc, so, ec, eo); } else if (arguments.length === 2) { // collapsed ec = sc; eo = so; return new WrappedRange(sc, so, ec, eo); } else { let wrappedRange = this.createFromSelection(); if (!wrappedRange && arguments.length === 1) { wrappedRange = this.createFromNode(arguments[0]); return wrappedRange.collapse(dom.emptyPara === arguments[0].innerHTML); } return wrappedRange; } }, createFromSelection: function() { let sc, so, ec, eo; <span class="missing-if-branch" title="else path not taken" >E</span>if (env.isW3CRangeSupport) { const selection = document.getSelection(); if (!selection || selection.rangeCount === 0) { return null; } else if (dom.isBody(selection.anchorNode)) { // Firefox: returns entire body as range on initialization. // We won't never need it. return null; } const nativeRng = selection.getRangeAt(0); sc = nativeRng.startContainer; so = nativeRng.startOffset; ec = nativeRng.endContainer; eo = nativeRng.endOffset; } else { // IE8: TextRange <span class="cstat-no" title="statement not covered" > const textRange = document.selection.createRange();</span> <span class="cstat-no" title="statement not covered" > const textRangeEnd = textRange.duplicate();</span> <span class="cstat-no" title="statement not covered" > textRangeEnd.collapse(false);</span> <span class="cstat-no" title="statement not covered" > const textRangeStart = textRange;</span> <span class="cstat-no" title="statement not covered" > textRangeStart.collapse(true);</span> <span class="cstat-no" title="statement not covered" > let startPoint = textRangeToPoint(textRangeStart, true);</span> <span class="cstat-no" title="statement not covered" > let endPoint = textRangeToPoint(textRangeEnd, false);</span> // same visible point case: range was collapsed. <span class="cstat-no" title="statement not covered" > if (dom.isText(startPoint.node) && dom.isLeftEdgePoint(startPoint) &&</span> dom.isTextNode(endPoint.node) && dom.isRightEdgePoint(endPoint) && endPoint.node.nextSibling === startPoint.node) { <span class="cstat-no" title="statement not covered" > startPoint = endPoint;</span> } <span class="cstat-no" title="statement not covered" > sc = startPoint.cont;</span> <span class="cstat-no" title="statement not covered" > so = startPoint.offset;</span> <span class="cstat-no" title="statement not covered" > ec = endPoint.cont;</span> <span class="cstat-no" title="statement not covered" > eo = endPoint.offset;</span> } return new WrappedRange(sc, so, ec, eo); }, /** * @method * * create WrappedRange from node * * @param {Node} node * @return {WrappedRange} */ createFromNode: function(node) { let sc = node; let so = 0; let ec = node; let eo = dom.nodeLength(ec); // browsers can't target a picture or void node if (dom.isVoid(sc)) { so = dom.listPrev(sc).length - 1; sc = sc.parentNode; } <span class="missing-if-branch" title="if path not taken" >I</span>if (dom.isBR(ec)) { <span class="cstat-no" title="statement not covered" > eo = dom.listPrev(ec).length - 1;</span> <span class="cstat-no" title="statement not covered" > ec = ec.parentNode;</span> } else if (dom.isVoid(ec)) { eo = dom.listPrev(ec).length; ec = ec.parentNode; } return this.create(sc, so, ec, eo); }, /** * create WrappedRange from node after position * * @param {Node} node * @return {WrappedRange} */ createFromNodeBefore: function(node) { return this.createFromNode(node).collapse(true); }, /** * create WrappedRange from node after position * * @param {Node} node * @return {WrappedRange} */ createFromNodeAfter: function(node) { return this.createFromNode(node).collapse(); }, /** * @method * * create WrappedRange from bookmark * * @param {Node} editable * @param {Object} bookmark * @return {WrappedRange} */ createFromBookmark: function(editable, bookmark) { const sc = dom.fromOffsetPath(editable, bookmark.s.path); const so = bookmark.s.offset; const ec = dom.fromOffsetPath(editable, bookmark.e.path); const eo = bookmark.e.offset; return new WrappedRange(sc, so, ec, eo); }, /** * @method * * create WrappedRange from paraBookmark * * @param {Object} bookmark * @param {Node[]} paras * @return {WrappedRange} */ createFromParaBookmark: function(bookmark, paras) { const so = bookmark.s.offset; const eo = bookmark.e.offset; const sc = dom.fromOffsetPath(lists.head(paras), bookmark.s.path); const ec = dom.fromOffsetPath(lists.last(paras), bookmark.e.path); return new WrappedRange(sc, so, ec, eo); } }; </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/core/async.js.html000064400000015155151677271550017415 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/core/async.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/js/base/core/</a> async.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">53.33% </span> <span class="quiet">Statements</span> <span class='fraction'>8/15</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">37.5% </span> <span class="quiet">Functions</span> <span class='fraction'>3/8</span> </div> <div class='fl pad1y space-right2'> <span class="strong">53.33% </span> <span class="quiet">Lines</span> <span class='fraction'>8/15</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</td><td class="line-coverage quiet"><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-yes">2×</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-no"> </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-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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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-yes">1×</span> <span class="cline-any cline-yes">1×</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></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; /** * @method readFileAsDataURL * * read contents of file as representing URL * * @param {File} file * @return {Promise} - then: dataUrl */ <span class="fstat-no" title="function not covered" >export function readFileAsDataURL(file)</span> { <span class="cstat-no" title="statement not covered" > return $.Deferred(<span class="fstat-no" title="function not covered" >(deferred)</span> => {</span> <span class="cstat-no" title="statement not covered" > $.extend(new FileReader(), {</span> onload: <span class="fstat-no" title="function not covered" >(e)</span> => { <span class="cstat-no" title="statement not covered" > const dataURL = e.target.result;</span> <span class="cstat-no" title="statement not covered" > deferred.resolve(dataURL);</span> }, onerror: <span class="fstat-no" title="function not covered" >(err)</span> => { <span class="cstat-no" title="statement not covered" > deferred.reject(err);</span> } }).readAsDataURL(file); }).promise(); } /** * @method createImage * * create `<image>` from url string * * @param {String} url * @return {Promise} - then: $image */ export function createImage(url) { return $.Deferred((deferred) => { const $img = $('<img>'); $img.one('load', () => { $img.off('error abort'); deferred.resolve($img); }).one('error abort', <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > $img.off('load').detach();</span> <span class="cstat-no" title="statement not covered" > deferred.reject($img);</span> }).css({ display: 'none' }).appendTo(document.body).attr('src', url); }).promise(); } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/core/key.js.html000064400000021525151677271550017066 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/core/key.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/js/base/core/</a> key.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>6/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>2/2</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>6/6</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 80 81 82 83 84 85 86 87 88 89 90 91 92 93</td><td class="line-coverage quiet"><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-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-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-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-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-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-yes">3×</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-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">2×</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-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">import lists from './lists'; import func from './func'; const KEY_MAP = { 'BACKSPACE': 8, 'TAB': 9, 'ENTER': 13, 'SPACE': 32, 'DELETE': 46, // Arrow 'LEFT': 37, 'UP': 38, 'RIGHT': 39, 'DOWN': 40, // Number: 0-9 'NUM0': 48, 'NUM1': 49, 'NUM2': 50, 'NUM3': 51, 'NUM4': 52, 'NUM5': 53, 'NUM6': 54, 'NUM7': 55, 'NUM8': 56, // Alphabet: a-z 'B': 66, 'E': 69, 'I': 73, 'J': 74, 'K': 75, 'L': 76, 'R': 82, 'S': 83, 'U': 85, 'V': 86, 'Y': 89, 'Z': 90, 'SLASH': 191, 'LEFTBRACKET': 219, 'BACKSLASH': 220, 'RIGHTBRACKET': 221 }; /** * @class core.key * * Object for keycodes. * * @singleton * @alternateClassName key */ export default { /** * @method isEdit * * @param {Number} keyCode * @return {Boolean} */ isEdit: (keyCode) => { return lists.contains([ KEY_MAP.BACKSPACE, KEY_MAP.TAB, KEY_MAP.ENTER, KEY_MAP.SPACE, KEY_MAP.DELETE ], keyCode); }, /** * @method isMove * * @param {Number} keyCode * @return {Boolean} */ isMove: (keyCode) => { return lists.contains([ KEY_MAP.LEFT, KEY_MAP.UP, KEY_MAP.RIGHT, KEY_MAP.DOWN ], keyCode); }, /** * @property {Object} nameFromCode * @property {String} nameFromCode.8 "BACKSPACE" */ nameFromCode: func.invertObject(KEY_MAP), code: KEY_MAP }; </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/core/lists.js.html000064400000044576151677271550017447 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/core/lists.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/js/base/core/</a> lists.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">87.14% </span> <span class="quiet">Statements</span> <span class='fraction'>61/70</span> </div> <div class='fl pad1y space-right2'> <span class="strong">75% </span> <span class="quiet">Branches</span> <span class='fraction'>15/20</span> </div> <div class='fl pad1y space-right2'> <span class="strong">88.89% </span> <span class="quiet">Functions</span> <span class='fraction'>16/18</span> </div> <div class='fl pad1y space-right2'> <span class="strong">90.91% </span> <span class="quiet">Lines</span> <span class='fraction'>60/66</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211</td><td class="line-coverage quiet"><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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">1958×</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">958×</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-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">1069×</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">78×</span> <span class="cline-any cline-yes">79×</span> <span class="cline-any cline-yes">79×</span> <span class="cline-any cline-yes">76×</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">441×</span> <span class="cline-any cline-yes">446×</span> <span class="cline-any cline-yes">294×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">147×</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">111×</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">111×</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">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">6×</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">1056×</span> <span class="cline-any cline-yes">1056×</span> <span class="cline-any cline-yes">1056×</span> <span class="cline-any cline-yes">1056×</span> <span class="cline-any cline-yes">1944×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1056×</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">291×</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">10×</span> <span class="cline-any cline-yes">10×</span> <span class="cline-any cline-yes">10×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</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">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">12×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</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">29×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">29×</span> <span class="cline-any cline-yes">71×</span> <span class="cline-any cline-yes">37×</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">29×</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-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-neutral"> </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-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-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-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-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">import $ from 'jquery'; import func from './func'; /** * returns the first item of an array. * * @param {Array} array */ function head(array) { return array[0]; } /** * returns the last item of an array. * * @param {Array} array */ function last(array) { return array[array.length - 1]; } /** * returns everything but the last entry of the array. * * @param {Array} array */ function initial(array) { return array.slice(0, array.length - 1); } /** * returns the rest of the items in an array. * * @param {Array} array */ function tail(array) { return array.slice(1); } /** * returns item of array */ function find(array, pred) { for (let idx = 0, len = array.length; idx < len; idx++) { const item = array[idx]; if (pred(item)) { return item; } } } /** * returns true if all of the values in the array pass the predicate truth test. */ function all(array, pred) { for (let idx = 0, len = array.length; idx < len; idx++) { if (!pred(array[idx])) { return false; } } return true; } /** * returns index of item */ function indexOf(array, item) { return $.inArray(item, array); } /** * returns true if the value is present in the list. */ function contains(array, item) { return indexOf(array, item) !== -1; } /** * get sum from a list * * @param {Array} array - array * @param {Function} fn - iterator */ function sum(array, fn) { fn = fn || func.self; return array.reduce(function(memo, v) { return memo + fn(v); }, 0); } /** * returns a copy of the collection with array type. * @param {Collection} collection - collection eg) node.childNodes, ... */ function from(collection) { const result = []; const length = collection.length; let idx = -1; while (++idx < length) { result[idx] = collection[idx]; } return result; } /** * returns whether list is empty or not */ function isEmpty(array) { return !array || !array.length; } /** * cluster elements by predicate function. * * @param {Array} array - array * @param {Function} fn - predicate function for cluster rule * @param {Array[]} */ function clusterBy(array, fn) { <span class="missing-if-branch" title="if path not taken" >I</span>if (!array.length) { <span class="cstat-no" title="statement not covered" >return []; </span>} const aTail = tail(array); return aTail.reduce(function(memo, v) { const aLast = last(memo); if (fn(last(aLast), v)) { aLast[aLast.length] = v; } else { memo[memo.length] = [v]; } return memo; }, [[head(array)]]); } /** * returns a copy of the array with all false values removed * * @param {Array} array - array * @param {Function} fn - predicate function for cluster rule */ function compact(array) { const aResult = []; for (let idx = 0, len = array.length; idx < len; idx++) { if (array[idx]) { aResult.push(array[idx]); } } return aResult; } /** * produces a duplicate-free version of the array * * @param {Array} array */ function unique(array) { const results = []; for (let idx = 0, len = array.length; idx < len; idx++) { if (!contains(results, array[idx])) { results.push(array[idx]); } } return results; } /** * returns next item. * @param {Array} array */ <span class="fstat-no" title="function not covered" >function next(array, item)</span> { <span class="cstat-no" title="statement not covered" > const idx = indexOf(array, item);</span> <span class="cstat-no" title="statement not covered" > if (idx === -1) { <span class="cstat-no" title="statement not covered" >return null; </span>}</span> <span class="cstat-no" title="statement not covered" > return array[idx + 1];</span> } /** * returns prev item. * @param {Array} array */ <span class="fstat-no" title="function not covered" >function prev(array, item)</span> { <span class="cstat-no" title="statement not covered" > const idx = indexOf(array, item);</span> <span class="cstat-no" title="statement not covered" > if (idx === -1) { <span class="cstat-no" title="statement not covered" >return null; </span>}</span> <span class="cstat-no" title="statement not covered" > return array[idx - 1];</span> } /** * @class core.list * * list utils * * @singleton * @alternateClassName list */ export default { head, last, initial, tail, prev, next, find, contains, all, sum, from, isEmpty, clusterBy, compact, unique }; </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/core/env.js.html000064400000031323151677271550017063 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/core/env.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/js/base/core/</a> env.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">52.78% </span> <span class="quiet">Statements</span> <span class='fraction'>19/36</span> </div> <div class='fl pad1y space-right2'> <span class="strong">51.35% </span> <span class="quiet">Branches</span> <span class='fraction'>19/37</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>1/1</span> </div> <div class='fl pad1y space-right2'> <span class="strong">52.78% </span> <span class="quiet">Lines</span> <span class='fraction'>19/36</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 108</td><td class="line-coverage quiet"><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-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">892×</span> <span class="cline-any cline-yes">892×</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">892×</span> <span class="cline-any cline-yes">892×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">892×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">892×</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-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-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-yes">1×</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-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-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-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-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-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-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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; const isSupportAmd = typeof define === 'function' && <span class="branch-1 cbranch-no" title="branch not covered" >define.amd;</span> // eslint-disable-line /** * returns whether font is installed or not. * * @param {String} fontName * @return {Boolean} */ function isFontInstalled(fontName) { const testFontName = fontName === 'Comic Sans MS' ? 'Courier New' : 'Comic Sans MS'; const $tester = $('<div>').css({ position: 'absolute', left: '-9999px', top: '-9999px', fontSize: '200px' }).text('mmmmmmmmmwwwwwww').appendTo(document.body); const originalWidth = $tester.css('fontFamily', testFontName).width(); const width = $tester.css('fontFamily', fontName + ',' + testFontName).width(); $tester.remove(); return originalWidth !== width; } const userAgent = navigator.userAgent; const isMSIE = /MSIE|Trident/i.test(userAgent); let browserVersion; <span class="missing-if-branch" title="if path not taken" >I</span>if (isMSIE) { <span class="cstat-no" title="statement not covered" > let matches = /MSIE (\d+[.]\d+)/.exec(userAgent);</span> <span class="cstat-no" title="statement not covered" > if (matches) {</span> <span class="cstat-no" title="statement not covered" > browserVersion = parseFloat(matches[1]);</span> } <span class="cstat-no" title="statement not covered" > matches = /Trident\/.*rv:([0-9]{1,}[.0-9]{0,})/.exec(userAgent);</span> <span class="cstat-no" title="statement not covered" > if (matches) {</span> <span class="cstat-no" title="statement not covered" > browserVersion = parseFloat(matches[1]);</span> } } const isEdge = /Edge\/\d+/.test(userAgent); let hasCodeMirror = !!window.CodeMirror; <span class="missing-if-branch" title="if path not taken" >I</span>if (!hasCodeMirror && isSupportAmd) { // Webpack <span class="cstat-no" title="statement not covered" > if (typeof __webpack_require__ === 'function') { // eslint-disable-line</span> <span class="cstat-no" title="statement not covered" > try {</span> // If CodeMirror can't be resolved, `require.resolve` will throw an // exception and `hasCodeMirror` won't be set to `true`. <span class="cstat-no" title="statement not covered" > require.resolve('codemirror');</span> <span class="cstat-no" title="statement not covered" > hasCodeMirror = true;</span> } catch (e) { // do nothing } } else <span class="cstat-no" title="statement not covered" >if (typeof require !== 'undefined') {</span> // Browserify <span class="cstat-no" title="statement not covered" > if (typeof require.resolve !== 'undefined') {</span> <span class="cstat-no" title="statement not covered" > try {</span> // If CodeMirror can't be resolved, `require.resolve` will throw an // exception and `hasCodeMirror` won't be set to `true`. <span class="cstat-no" title="statement not covered" > require.resolve('codemirror');</span> <span class="cstat-no" title="statement not covered" > hasCodeMirror = true;</span> } catch (e) { // do nothing } // Almond/Require } else <span class="cstat-no" title="statement not covered" >if (typeof require.specified !== 'undefined') {</span> <span class="cstat-no" title="statement not covered" > hasCodeMirror = require.specified('codemirror');</span> } } } const isSupportTouch = (('ontouchstart' in window) || (<span class="branch-1 cbranch-no" title="branch not covered" >navigator.MaxTouchPoints > 0)</span> || (<span class="branch-2 cbranch-no" title="branch not covered" >navigator.msMaxTouchPoints > 0)</span>); // [workaround] IE doesn't have input events for contentEditable // - see: https://goo.gl/4bfIvA const inputEventName = (isMSIE || isEdge) ? <span class="branch-0 cbranch-no" title="branch not covered" >'DOMCharacterDataModified DOMSubtreeModified DOMNodeInserted' </span>: 'input'; /** * @class core.env * * Object which check platform and agent * * @singleton * @alternateClassName env */ export default { isMac: navigator.appVersion.indexOf('Mac') > -1, isMSIE, isEdge, isFF: !isEdge && /firefox/i.test(userAgent), isPhantom: /PhantomJS/i.test(userAgent), isWebkit: !isEdge && /webkit/i.test(userAgent), isChrome: !isEdge && /chrome/i.test(userAgent), isSafari: !isEdge && /safari/i.test(userAgent), browserVersion, jqueryVersion: parseFloat($.fn.jquery), isSupportAmd, isSupportTouch, hasCodeMirror, isFontInstalled, isW3CRangeSupport: !!document.createRange, inputEventName }; </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/core/index.html000064400000017330151677271550016771 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/core/</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> src/js/base/core/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">82.09% </span> <span class="quiet">Statements</span> <span class='fraction'>706/860</span> </div> <div class='fl pad1y space-right2'> <span class="strong">75.62% </span> <span class="quiet">Branches</span> <span class='fraction'>366/484</span> </div> <div class='fl pad1y space-right2'> <span class="strong">88.1% </span> <span class="quiet">Functions</span> <span class='fraction'>148/168</span> </div> <div class='fl pad1y space-right2'> <span class="strong">82.27% </span> <span class="quiet">Lines</span> <span class='fraction'>696/846</span> </div> </div> </div> <div class='status-line high'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file medium" data-value="async.js"><a href="async.js.html">async.js</a></td> <td data-value="53.33" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 53%;"></div><div class="cover-empty" style="width:47%;"></div></div></td> <td data-value="53.33" class="pct medium">53.33%</td> <td data-value="15" class="abs medium">8/15</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="37.5" class="pct low">37.5%</td> <td data-value="8" class="abs low">3/8</td> <td data-value="53.33" class="pct medium">53.33%</td> <td data-value="15" class="abs medium">8/15</td> </tr> <tr> <td class="file high" data-value="dom.js"><a href="dom.js.html">dom.js</a></td> <td data-value="89.65" class="pic high"><div class="chart"><div class="cover-fill" style="width: 89%;"></div><div class="cover-empty" style="width:11%;"></div></div></td> <td data-value="89.65" class="pct high">89.65%</td> <td data-value="367" class="abs high">329/367</td> <td data-value="84.39" class="pct high">84.39%</td> <td data-value="237" class="abs high">200/237</td> <td data-value="91.67" class="pct high">91.67%</td> <td data-value="72" class="abs high">66/72</td> <td data-value="89.64" class="pct high">89.64%</td> <td data-value="357" class="abs high">320/357</td> </tr> <tr> <td class="file medium" data-value="env.js"><a href="env.js.html">env.js</a></td> <td data-value="52.78" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 52%;"></div><div class="cover-empty" style="width:48%;"></div></div></td> <td data-value="52.78" class="pct medium">52.78%</td> <td data-value="36" class="abs medium">19/36</td> <td data-value="51.35" class="pct medium">51.35%</td> <td data-value="37" class="abs medium">19/37</td> <td data-value="100" class="pct high">100%</td> <td data-value="1" class="abs high">1/1</td> <td data-value="52.78" class="pct medium">52.78%</td> <td data-value="36" class="abs medium">19/36</td> </tr> <tr> <td class="file high" data-value="func.js"><a href="func.js.html">func.js</a></td> <td data-value="94.55" class="pic high"><div class="chart"><div class="cover-fill" style="width: 94%;"></div><div class="cover-empty" style="width:6%;"></div></div></td> <td data-value="94.55" class="pct high">94.55%</td> <td data-value="55" class="abs high">52/55</td> <td data-value="64.29" class="pct medium">64.29%</td> <td data-value="14" class="abs medium">9/14</td> <td data-value="95.45" class="pct high">95.45%</td> <td data-value="22" class="abs high">21/22</td> <td data-value="94.55" class="pct high">94.55%</td> <td data-value="55" class="abs high">52/55</td> </tr> <tr> <td class="file high" data-value="key.js"><a href="key.js.html">key.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="6" class="abs high">6/6</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="2" class="abs high">2/2</td> <td data-value="100" class="pct high">100%</td> <td data-value="6" class="abs high">6/6</td> </tr> <tr> <td class="file high" data-value="lists.js"><a href="lists.js.html">lists.js</a></td> <td data-value="87.14" class="pic high"><div class="chart"><div class="cover-fill" style="width: 87%;"></div><div class="cover-empty" style="width:13%;"></div></div></td> <td data-value="87.14" class="pct high">87.14%</td> <td data-value="70" class="abs high">61/70</td> <td data-value="75" class="pct medium">75%</td> <td data-value="20" class="abs medium">15/20</td> <td data-value="88.89" class="pct high">88.89%</td> <td data-value="18" class="abs high">16/18</td> <td data-value="90.91" class="pct high">90.91%</td> <td data-value="66" class="abs high">60/66</td> </tr> <tr> <td class="file medium" data-value="range.js"><a href="range.js.html">range.js</a></td> <td data-value="74.28" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 74%;"></div><div class="cover-empty" style="width:26%;"></div></div></td> <td data-value="74.28" class="pct medium">74.28%</td> <td data-value="311" class="abs medium">231/311</td> <td data-value="69.89" class="pct medium">69.89%</td> <td data-value="176" class="abs medium">123/176</td> <td data-value="86.67" class="pct high">86.67%</td> <td data-value="45" class="abs high">39/45</td> <td data-value="74.28" class="pct medium">74.28%</td> <td data-value="311" class="abs medium">231/311</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/core/func.js.html000064400000035617151677271550017240 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/core/func.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/js/base/core/</a> func.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">94.55% </span> <span class="quiet">Statements</span> <span class='fraction'>52/55</span> </div> <div class='fl pad1y space-right2'> <span class="strong">64.29% </span> <span class="quiet">Branches</span> <span class='fraction'>9/14</span> </div> <div class='fl pad1y space-right2'> <span class="strong">95.45% </span> <span class="quiet">Functions</span> <span class='fraction'>21/22</span> </div> <div class='fl pad1y space-right2'> <span class="strong">94.55% </span> <span class="quiet">Lines</span> <span class='fraction'>52/55</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163</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-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">317×</span> <span class="cline-any cline-yes">514×</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">2×</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">10×</span> <span class="cline-any cline-yes">2×</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">1854×</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">220×</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">29×</span> <span class="cline-any cline-yes">210×</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">5×</span> <span class="cline-any cline-yes">8×</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">3×</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">464×</span> <span class="cline-any cline-yes">2×</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-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">3×</span> <span class="cline-any cline-yes">3×</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-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-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> <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">79×</span> <span class="cline-any cline-yes">79×</span> <span class="cline-any cline-yes">2115×</span> <span class="cline-any cline-yes">2115×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">79×</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">172×</span> <span class="cline-any cline-yes">172×</span> <span class="cline-any cline-yes">227×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">81×</span> <span class="cline-any cline-yes">80×</span> <span class="cline-any cline-yes">80×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">16×</span> <span class="cline-any cline-yes">16×</span> <span class="cline-any cline-yes">16×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">18×</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-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-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">/** * @class core.func * * func utils (for high-order func's arg) * * @singleton * @alternateClassName func */ function eq(itemA) { return function(itemB) { return itemA === itemB; }; } function eq2(itemA, itemB) { return itemA === itemB; } function peq2(propName) { return function(itemA, itemB) { return itemA[propName] === itemB[propName]; }; } function ok() { return true; } function fail() { return false; } function not(f) { return () => { return !f.apply(f, arguments); }; } function and(fA, fB) { return function(item) { return fA(item) && fB(item); }; } function self(a) { return a; } function invoke(obj, method) { return () => { return obj[method].apply(obj, arguments); }; } let idCounter = 0; /** * generate a globally-unique id * * @param {String} [prefix] */ function uniqueId(prefix) { const id = ++idCounter + ''; return prefix ? prefix + id : <span class="branch-1 cbranch-no" title="branch not covered" >id;</span> } /** * returns bnd (bounds) from rect * * - IE Compatibility Issue: http://goo.gl/sRLOAo * - Scroll Issue: http://goo.gl/sNjUc * * @param {Rect} rect * @return {Object} bounds * @return {Number} bounds.top * @return {Number} bounds.left * @return {Number} bounds.width * @return {Number} bounds.height */ <span class="fstat-no" title="function not covered" >function rect2bnd(rect)</span> { <span class="cstat-no" title="statement not covered" > const $document = $(document);</span> <span class="cstat-no" title="statement not covered" > return {</span> top: rect.top + $document.scrollTop(), left: rect.left + $document.scrollLeft(), width: rect.right - rect.left, height: rect.bottom - rect.top }; } /** * returns a copy of the object where the keys have become the values and the values the keys. * @param {Object} obj * @return {Object} */ function invertObject(obj) { const inverted = {}; for (const key in obj) { <span class="missing-if-branch" title="else path not taken" >E</span>if (obj.hasOwnProperty(key)) { inverted[obj[key]] = key; } } return inverted; } /** * @param {String} namespace * @param {String} [prefix] * @return {String} */ function namespaceToCamel(namespace, prefix) { prefix = prefix || ''; return prefix + namespace.split('.').map(function(name) { return name.substring(0, 1).toUpperCase() + name.substring(1); }).join(''); } /** * Returns a function, that, as long as it continues to be invoked, will not * be triggered. The function will be called after it stops being called for * N milliseconds. If `immediate` is passed, trigger the function on the * leading edge, instead of the trailing. * @param {Function} func * @param {Number} wait * @param {Boolean} immediate * @return {Function} */ function debounce(func, wait, immediate) { let timeout; return () => { const context = this; const args = arguments; const later = () => { timeout = null; <span class="missing-if-branch" title="else path not taken" >E</span>if (!immediate) { func.apply(context, args); } }; const callNow = immediate && <span class="branch-1 cbranch-no" title="branch not covered" >!timeout;</span> clearTimeout(timeout); timeout = setTimeout(later, wait); <span class="missing-if-branch" title="if path not taken" >I</span>if (callNow) { <span class="cstat-no" title="statement not covered" > func.apply(context, args);</span> } }; } export default { eq, eq2, peq2, ok, fail, self, not, and, invoke, uniqueId, rect2bnd, invertObject, namespaceToCamel, debounce }; </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/core/dom.js.html000064400000265416151677271550017066 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/core/dom.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/js/base/core/</a> dom.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">89.65% </span> <span class="quiet">Statements</span> <span class='fraction'>329/367</span> </div> <div class='fl pad1y space-right2'> <span class="strong">84.39% </span> <span class="quiet">Branches</span> <span class='fraction'>200/237</span> </div> <div class='fl pad1y space-right2'> <span class="strong">91.67% </span> <span class="quiet">Functions</span> <span class='fraction'>66/72</span> </div> <div class='fl pad1y space-right2'> <span class="strong">89.64% </span> <span class="quiet">Lines</span> <span class='fraction'>320/357</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089</td><td class="line-coverage quiet"><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-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-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">3458×</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-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> <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">24×</span> <span class="cline-any cline-yes">24×</span> <span class="cline-any cline-yes">2010×</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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">3125×</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">38×</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">835×</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">720×</span> <span class="cline-any cline-yes">51×</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">669×</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">2×</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-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">7×</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-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">363×</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">423×</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-yes">1×</span> <span class="cline-any cline-yes">535×</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-yes">1×</span> <span class="cline-any cline-yes">432×</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-yes">1×</span> <span class="cline-any cline-yes">76×</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-no"> </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-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-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> <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">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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-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">1368×</span> <span class="cline-any cline-yes">378×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">990×</span> <span class="cline-any cline-yes">990×</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-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">464×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">464×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">463×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">24×</span> <span class="cline-any cline-yes">439×</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-yes">439×</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">50×</span> <span class="cline-any cline-yes">11×</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">796×</span> <span class="cline-any cline-yes">1745×</span> <span class="cline-any cline-yes">1092×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">951×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">143×</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">9×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-yes">10×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">2×</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-yes">7×</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">437×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">437×</span> <span class="cline-any cline-yes">437×</span> <span class="cline-any cline-yes">942×</span> <span class="cline-any cline-yes">597×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">942×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">437×</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-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-yes">1×</span> <span class="cline-any cline-yes">29×</span> <span class="cline-any cline-yes">29×</span> <span class="cline-any cline-yes">34×</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-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">32×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">32×</span> <span class="cline-any cline-yes">32×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-yes">15×</span> <span class="cline-any cline-yes">15×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">32×</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">59×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">59×</span> <span class="cline-any cline-yes">59×</span> <span class="cline-any cline-yes">40×</span> <span class="cline-any cline-yes">39×</span> <span class="cline-any cline-yes">39×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">59×</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">11×</span> <span class="cline-any cline-yes">11×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">11×</span> <span class="cline-any cline-yes">25×</span> <span class="cline-any cline-yes">7×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">25×</span> <span class="cline-any cline-yes">14×</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">11×</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">12×</span> <span class="cline-any cline-yes">12×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">12×</span> <span class="cline-any cline-yes">12×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">12×</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">38×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-yes">11×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">27×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">38×</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">42×</span> <span class="cline-any cline-yes">43×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">42×</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">392×</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">343×</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">167×</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">33×</span> <span class="cline-any cline-yes">24×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">23×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">32×</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">63×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">63×</span> <span class="cline-any cline-yes">2×</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-yes">62×</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">101×</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">79×</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">251×</span> <span class="cline-any cline-yes">251×</span> <span class="cline-any cline-yes">63×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">251×</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">782×</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">227×</span> <span class="cline-any cline-yes">227×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">227×</span> <span class="cline-any cline-yes">8×</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-yes">8×</span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">219×</span> <span class="cline-any cline-yes">204×</span> <span class="cline-any cline-yes">204×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">15×</span> <span class="cline-any cline-yes">15×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">227×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">134×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">134×</span> <span class="cline-any cline-yes">14×</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-yes">14×</span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-yes">120×</span> <span class="cline-any cline-yes">49×</span> <span class="cline-any cline-yes">49×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">71×</span> <span class="cline-any cline-yes">71×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">134×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">120×</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">718×</span> <span class="cline-any cline-yes">307×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">411×</span> <span class="cline-any cline-yes">411×</span> <span class="cline-any cline-yes">411×</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">410×</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">75×</span> <span class="cline-any cline-yes">166×</span> <span class="cline-any cline-yes">75×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">91×</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-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">16×</span> <span class="cline-any cline-yes">25×</span> <span class="cline-any cline-yes">16×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">9×</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-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">21×</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-yes">21×</span> <span class="cline-any cline-yes">21×</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">28×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">28×</span> <span class="cline-any cline-yes">120×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">120×</span> <span class="cline-any cline-yes">28×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">92×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">92×</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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">277×</span> <span class="cline-any cline-yes">277×</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">20×</span> <span class="cline-any cline-yes">20×</span> <span class="cline-any cline-yes">20×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">20×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">20×</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-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">60×</span> <span class="cline-any cline-yes">60×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">60×</span> <span class="cline-any cline-yes">22×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">20×</span> <span class="cline-any cline-yes">20×</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">38×</span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">29×</span> <span class="cline-any cline-yes">29×</span> <span class="cline-any cline-yes">29×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">29×</span> <span class="cline-any cline-yes">25×</span> <span class="cline-any cline-yes">25×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">29×</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-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-neutral"> </span> <span class="cline-any cline-yes">37×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">37×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-yes">37×</span> <span class="cline-any cline-yes">19×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">23×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">23×</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-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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">27×</span> <span class="cline-any cline-yes">27×</span> <span class="cline-any cline-yes">27×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">27×</span> <span class="cline-any cline-yes">27×</span> <span class="cline-any cline-yes">22×</span> <span class="cline-any cline-yes">22×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</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">27×</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">27×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">27×</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">10×</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">5×</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">30×</span> <span class="cline-any cline-yes">29×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">29×</span> <span class="cline-any cline-yes">29×</span> <span class="cline-any cline-yes">11×</span> <span class="cline-any cline-yes">11×</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-yes">11×</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-yes">29×</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-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-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-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">4×</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-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">79×</span> <span class="cline-any cline-yes">79×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">79×</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">78×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">78×</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-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-yes">78×</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-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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">385×</span> <span class="cline-any cline-yes">924×</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">10×</span> <span class="cline-any cline-yes">24×</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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">2×</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-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-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-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-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-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-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-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-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-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">import $ from 'jquery'; import func from './func'; import lists from './lists'; import env from './env'; const NBSP_CHAR = String.fromCharCode(160); const ZERO_WIDTH_NBSP_CHAR = '\ufeff'; /** * @method isEditable * * returns whether node is `note-editable` or not. * * @param {Node} node * @return {Boolean} */ function isEditable(node) { return node && $(node).hasClass('note-editable'); } /** * @method isControlSizing * * returns whether node is `note-control-sizing` or not. * * @param {Node} node * @return {Boolean} */ <span class="fstat-no" title="function not covered" >function isControlSizing(node)</span> { <span class="cstat-no" title="statement not covered" > return node && $(node).hasClass('note-control-sizing');</span> } /** * @method makePredByNodeName * * returns predicate which judge whether nodeName is same * * @param {String} nodeName * @return {Function} */ function makePredByNodeName(nodeName) { nodeName = nodeName.toUpperCase(); return function(node) { return node && node.nodeName.toUpperCase() === nodeName; }; } /** * @method isText * * * * @param {Node} node * @return {Boolean} true if node's type is text(3) */ function isText(node) { return node && node.nodeType === 3; } /** * @method isElement * * * * @param {Node} node * @return {Boolean} true if node's type is element(1) */ function isElement(node) { return node && node.nodeType === 1; } /** * ex) br, col, embed, hr, img, input, ... * @see http://www.w3.org/html/wg/drafts/html/master/syntax.html#void-elements */ function isVoid(node) { return node && /^BR|^IMG|^HR|^IFRAME|^BUTTON|^INPUT/.test(node.nodeName.toUpperCase()); } function isPara(node) { if (isEditable(node)) { return false; } // Chrome(v31.0), FF(v25.0.1) use DIV for paragraph return node && /^DIV|^P|^LI|^H[1-7]/.test(node.nodeName.toUpperCase()); } function isHeading(node) { return node && /^H[1-7]/.test(node.nodeName.toUpperCase()); } const isPre = makePredByNodeName('PRE'); const isLi = makePredByNodeName('LI'); function isPurePara(node) { return isPara(node) && !isLi(node); } const isTable = makePredByNodeName('TABLE'); const isData = makePredByNodeName('DATA'); function isInline(node) { return !isBodyContainer(node) && !isList(node) && !isHr(node) && !isPara(node) && !isTable(node) && !isBlockquote(node) && !isData(node); } function isList(node) { return node && /^UL|^OL/.test(node.nodeName.toUpperCase()); } const isHr = makePredByNodeName('HR'); function isCell(node) { return node && /^TD|^TH/.test(node.nodeName.toUpperCase()); } const isBlockquote = makePredByNodeName('BLOCKQUOTE'); function isBodyContainer(node) { return isCell(node) || isBlockquote(node) || isEditable(node); } const isAnchor = makePredByNodeName('A'); function isParaInline(node) { return isInline(node) && !!ancestor(node, isPara); } <span class="fstat-no" title="function not covered" >function isBodyInline(node)</span> { <span class="cstat-no" title="statement not covered" > return isInline(node) && !ancestor(node, isPara);</span> } const isBody = makePredByNodeName('BODY'); /** * returns whether nodeB is closest sibling of nodeA * * @param {Node} nodeA * @param {Node} nodeB * @return {Boolean} */ <span class="fstat-no" title="function not covered" >function isClosestSibling(nodeA, nodeB)</span> { <span class="cstat-no" title="statement not covered" > return nodeA.nextSibling === nodeB ||</span> nodeA.previousSibling === nodeB; } /** * returns array of closest siblings with node * * @param {Node} node * @param {function} [pred] - predicate function * @return {Node[]} */ function withClosestSiblings(node, pred) { pred = pred || <span class="branch-1 cbranch-no" title="branch not covered" >func.ok;</span> const siblings = []; <span class="missing-if-branch" title="if path not taken" >I</span>if (node.previousSibling && <span class="branch-1 cbranch-no" title="branch not covered" >pred(node.previousSibling))</span> { <span class="cstat-no" title="statement not covered" > siblings.push(node.previousSibling);</span> } siblings.push(node); if (node.nextSibling && pred(node.nextSibling)) { siblings.push(node.nextSibling); } return siblings; } /** * blank HTML for cursor position * - [workaround] old IE only works with &nbsp; * - [workaround] IE11 and other browser works with bogus br */ const blankHTML = env.isMSIE && <span class="branch-1 cbranch-no" title="branch not covered" >env.browserVersion < 11 </span>? <span class="branch-0 cbranch-no" title="branch not covered" >'&nbsp;' </span>: '<br>'; /** * @method nodeLength * * returns #text's text size or element's childNodes size * * @param {Node} node */ function nodeLength(node) { if (isText(node)) { return node.nodeValue.length; } <span class="missing-if-branch" title="else path not taken" >E</span>if (node) { return node.childNodes.length; } <span class="cstat-no" title="statement not covered" > return 0;</span> } /** * returns whether node is empty or not. * * @param {Node} node * @return {Boolean} */ function isEmpty(node) { const len = nodeLength(node); if (len === 0) { return true; } else if (!isText(node) && len === 1 && node.innerHTML === blankHTML) { // ex) <p><br></p>, <span><br></span> return true; } else <span class="missing-if-branch" title="if path not taken" >I</span>if (lists.all(node.childNodes, isText) && node.innerHTML === '') { // ex) <p></p>, <span></span> <span class="cstat-no" title="statement not covered" > return true;</span> } return false; } /** * padding blankHTML if node is empty (for cursor position) */ function paddingBlankHTML(node) { if (!isVoid(node) && !nodeLength(node)) { node.innerHTML = blankHTML; } } /** * find nearest ancestor predicate hit * * @param {Node} node * @param {Function} pred - predicate function */ function ancestor(node, pred) { while (node) { if (pred(node)) { return node; } if (isEditable(node)) { break; } node = node.parentNode; } return null; } /** * find nearest ancestor only single child blood line and predicate hit * * @param {Node} node * @param {Function} pred - predicate function */ function singleChildAncestor(node, pred) { node = node.parentNode; while (node) { if (nodeLength(node) !== 1) { break; } if (pred(node)) { return node; } if (isEditable(node)) { break; } node = node.parentNode; } return null; } /** * returns new array of ancestor nodes (until predicate hit). * * @param {Node} node * @param {Function} [optional] pred - predicate function */ function listAncestor(node, pred) { pred = pred || func.fail; const ancestors = []; ancestor(node, function(el) { if (!isEditable(el)) { ancestors.push(el); } return pred(el); }); return ancestors; } /** * find farthest ancestor predicate hit */ function lastAncestor(node, pred) { const ancestors = listAncestor(node); return lists.last(ancestors.filter(pred)); } /** * returns common ancestor node between two nodes. * * @param {Node} nodeA * @param {Node} nodeB */ function commonAncestor(nodeA, nodeB) { const ancestors = listAncestor(nodeA); for (let n = nodeB; n; n = n.parentNode) { if ($.inArray(n, ancestors) > -1) { return n; } } <span class="cstat-no" title="statement not covered" > return null; </span>// difference document area } /** * listing all previous siblings (until predicate hit). * * @param {Node} node * @param {Function} [optional] pred - predicate function */ function listPrev(node, pred) { pred = pred || func.fail; const nodes = []; while (node) { if (pred(node)) { break; } nodes.push(node); node = node.previousSibling; } return nodes; } /** * listing next siblings (until predicate hit). * * @param {Node} node * @param {Function} [pred] - predicate function */ function listNext(node, pred) { pred = pred || func.fail; const nodes = []; while (node) { if (pred(node)) { break; } nodes.push(node); node = node.nextSibling; } return nodes; } /** * listing descendant nodes * * @param {Node} node * @param {Function} [pred] - predicate function */ function listDescendant(node, pred) { const descendants = []; pred = pred || func.ok; // start DFS(depth first search) with node (function fnWalk(current) { if (node !== current && pred(current)) { descendants.push(current); } for (let idx = 0, len = current.childNodes.length; idx < len; idx++) { fnWalk(current.childNodes[idx]); } })(node); return descendants; } /** * wrap node with new tag. * * @param {Node} node * @param {Node} tagName of wrapper * @return {Node} - wrapper */ function wrap(node, wrapperName) { const parent = node.parentNode; const wrapper = $('<' + wrapperName + '>')[0]; parent.insertBefore(wrapper, node); wrapper.appendChild(node); return wrapper; } /** * insert node after preceding * * @param {Node} node * @param {Node} preceding - predicate function */ function insertAfter(node, preceding) { const next = preceding.nextSibling; let parent = preceding.parentNode; if (next) { parent.insertBefore(node, next); } else { parent.appendChild(node); } return node; } /** * append elements. * * @param {Node} node * @param {Collection} aChild */ function appendChildNodes(node, aChild) { $.each(aChild, function(idx, child) { node.appendChild(child); }); return node; } /** * returns whether boundaryPoint is left edge or not. * * @param {BoundaryPoint} point * @return {Boolean} */ function isLeftEdgePoint(point) { return point.offset === 0; } /** * returns whether boundaryPoint is right edge or not. * * @param {BoundaryPoint} point * @return {Boolean} */ function isRightEdgePoint(point) { return point.offset === nodeLength(point.node); } /** * returns whether boundaryPoint is edge or not. * * @param {BoundaryPoint} point * @return {Boolean} */ function isEdgePoint(point) { return isLeftEdgePoint(point) || isRightEdgePoint(point); } /** * returns whether node is left edge of ancestor or not. * * @param {Node} node * @param {Node} ancestor * @return {Boolean} */ function isLeftEdgeOf(node, ancestor) { while (node && node !== ancestor) { if (position(node) !== 0) { return false; } node = node.parentNode; } return true; } /** * returns whether node is right edge of ancestor or not. * * @param {Node} node * @param {Node} ancestor * @return {Boolean} */ function isRightEdgeOf(node, ancestor) { <span class="missing-if-branch" title="if path not taken" >I</span>if (!ancestor) { <span class="cstat-no" title="statement not covered" > return false;</span> } while (node && node !== ancestor) { if (position(node) !== nodeLength(node.parentNode) - 1) { return false; } node = node.parentNode; } return true; } /** * returns whether point is left edge of ancestor or not. * @param {BoundaryPoint} point * @param {Node} ancestor * @return {Boolean} */ function isLeftEdgePointOf(point, ancestor) { return isLeftEdgePoint(point) && isLeftEdgeOf(point.node, ancestor); } /** * returns whether point is right edge of ancestor or not. * @param {BoundaryPoint} point * @param {Node} ancestor * @return {Boolean} */ function isRightEdgePointOf(point, ancestor) { return isRightEdgePoint(point) && isRightEdgeOf(point.node, ancestor); } /** * returns offset from parent. * * @param {Node} node */ function position(node) { let offset = 0; while ((node = node.previousSibling)) { offset += 1; } return offset; } function hasChildren(node) { return !!(node && node.childNodes && node.childNodes.length); } /** * returns previous boundaryPoint * * @param {BoundaryPoint} point * @param {Boolean} isSkipInnerOffset * @return {BoundaryPoint} */ function prevPoint(point, isSkipInnerOffset) { let node; let offset; if (point.offset === 0) { <span class="missing-if-branch" title="if path not taken" >I</span>if (isEditable(point.node)) { <span class="cstat-no" title="statement not covered" > return null;</span> } node = point.node.parentNode; offset = position(point.node); } else if (hasChildren(point.node)) { node = point.node.childNodes[point.offset - 1]; offset = nodeLength(node); } else { node = point.node; offset = isSkipInnerOffset ? <span class="branch-0 cbranch-no" title="branch not covered" >0 </span>: point.offset - 1; } return { node: node, offset: offset }; } /** * returns next boundaryPoint * * @param {BoundaryPoint} point * @param {Boolean} isSkipInnerOffset * @return {BoundaryPoint} */ function nextPoint(point, isSkipInnerOffset) { let node, offset; if (nodeLength(point.node) === point.offset) { <span class="missing-if-branch" title="if path not taken" >I</span>if (isEditable(point.node)) { <span class="cstat-no" title="statement not covered" > return null;</span> } node = point.node.parentNode; offset = position(point.node) + 1; } else if (hasChildren(point.node)) { node = point.node.childNodes[point.offset]; offset = 0; } else { node = point.node; offset = isSkipInnerOffset ? nodeLength(point.node) : point.offset + 1; } return { node: node, offset: offset }; } /** * returns whether pointA and pointB is same or not. * * @param {BoundaryPoint} pointA * @param {BoundaryPoint} pointB * @return {Boolean} */ function isSamePoint(pointA, pointB) { return pointA.node === pointB.node && pointA.offset === pointB.offset; } /** * returns whether point is visible (can set cursor) or not. * * @param {BoundaryPoint} point * @return {Boolean} */ function isVisiblePoint(point) { if (isText(point.node) || !hasChildren(point.node) || isEmpty(point.node)) { return true; } const leftNode = point.node.childNodes[point.offset - 1]; const rightNode = point.node.childNodes[point.offset]; if ((!leftNode || isVoid(leftNode)) && (!rightNode || isVoid(rightNode))) { return true; } return false; } /** * @method prevPointUtil * * @param {BoundaryPoint} point * @param {Function} pred * @return {BoundaryPoint} */ function prevPointUntil(point, pred) { while (point) { if (pred(point)) { return point; } point = prevPoint(point); } <span class="cstat-no" title="statement not covered" > return null;</span> } /** * @method nextPointUntil * * @param {BoundaryPoint} point * @param {Function} pred * @return {BoundaryPoint} */ function nextPointUntil(point, pred) { while (point) { if (pred(point)) { return point; } point = nextPoint(point); } <span class="cstat-no" title="statement not covered" > return null;</span> } /** * returns whether point has character or not. * * @param {Point} point * @return {Boolean} */ function isCharPoint(point) { <span class="missing-if-branch" title="if path not taken" >I</span>if (!isText(point.node)) { <span class="cstat-no" title="statement not covered" > return false;</span> } const ch = point.node.nodeValue.charAt(point.offset - 1); return ch && (ch !== ' ' && ch !== NBSP_CHAR); } /** * @method walkPoint * * @param {BoundaryPoint} startPoint * @param {BoundaryPoint} endPoint * @param {Function} handler * @param {Boolean} isSkipInnerOffset */ function walkPoint(startPoint, endPoint, handler, isSkipInnerOffset) { let point = startPoint; while (point) { handler(point); if (isSamePoint(point, endPoint)) { break; } const isSkipOffset = isSkipInnerOffset && startPoint.node !== point.node && endPoint.node !== point.node; point = nextPoint(point, isSkipOffset); } } /** * @method makeOffsetPath * * return offsetPath(array of offset) from ancestor * * @param {Node} ancestor - ancestor node * @param {Node} node */ function makeOffsetPath(ancestor, node) { const ancestors = listAncestor(node, func.eq(ancestor)); return ancestors.map(position).reverse(); } /** * @method fromOffsetPath * * return element from offsetPath(array of offset) * * @param {Node} ancestor - ancestor node * @param {array} offsets - offsetPath */ function fromOffsetPath(ancestor, offsets) { let current = ancestor; for (let i = 0, len = offsets.length; i < len; i++) { <span class="missing-if-branch" title="if path not taken" >I</span>if (current.childNodes.length <= offsets[i]) { <span class="cstat-no" title="statement not covered" > current = current.childNodes[current.childNodes.length - 1];</span> } else { current = current.childNodes[offsets[i]]; } } return current; } /** * @method splitNode * * split element or #text * * @param {BoundaryPoint} point * @param {Object} [options] * @param {Boolean} [options.isSkipPaddingBlankHTML] - default: false * @param {Boolean} [options.isNotSplitEdgePoint] - default: false * @return {Node} right node of boundaryPoint */ function splitNode(point, options) { const isSkipPaddingBlankHTML = options && options.isSkipPaddingBlankHTML; const isNotSplitEdgePoint = options && options.isNotSplitEdgePoint; // edge case if (isEdgePoint(point) && (isText(point.node) || isNotSplitEdgePoint)) { if (isLeftEdgePoint(point)) { return point.node; } else <span class="missing-if-branch" title="else path not taken" >E</span>if (isRightEdgePoint(point)) { return point.node.nextSibling; } } // split #text if (isText(point.node)) { return point.node.splitText(point.offset); } else { const childNode = point.node.childNodes[point.offset]; const clone = insertAfter(point.node.cloneNode(false), point.node); appendChildNodes(clone, listNext(childNode)); if (!isSkipPaddingBlankHTML) { paddingBlankHTML(point.node); paddingBlankHTML(clone); } return clone; } } /** * @method splitTree * * split tree by point * * @param {Node} root - split root * @param {BoundaryPoint} point * @param {Object} [options] * @param {Boolean} [options.isSkipPaddingBlankHTML] - default: false * @param {Boolean} [options.isNotSplitEdgePoint] - default: false * @return {Node} right node of boundaryPoint */ function splitTree(root, point, options) { // ex) [#text, <span>, <p>] const ancestors = listAncestor(point.node, func.eq(root)); <span class="missing-if-branch" title="if path not taken" >I</span>if (!ancestors.length) { <span class="cstat-no" title="statement not covered" > return null;</span> } else if (ancestors.length === 1) { return splitNode(point, options); } return ancestors.reduce(function(node, parent) { if (node === point.node) { node = splitNode(point, options); } return splitNode({ node: parent, offset: node ? position(node) : nodeLength(parent) }, options); }); } /** * split point * * @param {Point} point * @param {Boolean} isInline * @return {Object} */ function splitPoint(point, isInline) { // find splitRoot, container // - inline: splitRoot is a child of paragraph // - block: splitRoot is a child of bodyContainer const pred = isInline ? isPara : isBodyContainer; const ancestors = listAncestor(point.node, pred); const topAncestor = lists.last(ancestors) || <span class="branch-1 cbranch-no" title="branch not covered" >point.node;</span> let splitRoot, container; if (pred(topAncestor)) { splitRoot = ancestors[ancestors.length - 2]; container = topAncestor; } else { splitRoot = topAncestor; container = splitRoot.parentNode; } // if splitRoot is exists, split with splitTree let pivot = splitRoot && splitTree(splitRoot, point, { isSkipPaddingBlankHTML: isInline, isNotSplitEdgePoint: isInline }); // if container is point.node, find pivot with point.offset if (!pivot && container === point.node) { pivot = point.node.childNodes[point.offset]; } return { rightNode: pivot, container: container }; } function create(nodeName) { return document.createElement(nodeName); } function createText(text) { return document.createTextNode(text); } /** * @method remove * * remove node, (isRemoveChild: remove child or not) * * @param {Node} node * @param {Boolean} isRemoveChild */ function remove(node, isRemoveChild) { if (!node || !node.parentNode) { return; } <span class="missing-if-branch" title="if path not taken" >I</span>if (node.removeNode) { <span class="cstat-no" title="statement not covered" >return node.removeNode(isRemoveChild); </span>} const parent = node.parentNode; if (!isRemoveChild) { const nodes = []; for (let i = 0, len = node.childNodes.length; i < len; i++) { <span class="cstat-no" title="statement not covered" > nodes.push(node.childNodes[i]);</span> } for (let i = 0, len = nodes.length; i < len; i++) { <span class="cstat-no" title="statement not covered" > parent.insertBefore(nodes[i], node);</span> } } parent.removeChild(node); } /** * @method removeWhile * * @param {Node} node * @param {Function} pred */ <span class="fstat-no" title="function not covered" >function removeWhile(node, pred)</span> { <span class="cstat-no" title="statement not covered" > while (node) {</span> <span class="cstat-no" title="statement not covered" > if (isEditable(node) || !pred(node)) {</span> <span class="cstat-no" title="statement not covered" > break;</span> } <span class="cstat-no" title="statement not covered" > const parent = node.parentNode;</span> <span class="cstat-no" title="statement not covered" > remove(node);</span> <span class="cstat-no" title="statement not covered" > node = parent;</span> } } /** * @method replace * * replace node with provided nodeName * * @param {Node} node * @param {String} nodeName * @return {Node} - new node */ function replace(node, nodeName) { <span class="missing-if-branch" title="if path not taken" >I</span>if (node.nodeName.toUpperCase() === nodeName.toUpperCase()) { <span class="cstat-no" title="statement not covered" > return node;</span> } const newNode = create(nodeName); <span class="missing-if-branch" title="if path not taken" >I</span>if (node.style.cssText) { <span class="cstat-no" title="statement not covered" > newNode.style.cssText = node.style.cssText;</span> } appendChildNodes(newNode, lists.from(node.childNodes)); insertAfter(newNode, node); remove(node); return newNode; } const isTextarea = makePredByNodeName('TEXTAREA'); /** * @param {jQuery} $node * @param {Boolean} [stripLinebreaks] - default: false */ function value($node, stripLinebreaks) { const val = isTextarea($node[0]) ? $node.val() : $node.html(); <span class="missing-if-branch" title="if path not taken" >I</span>if (stripLinebreaks) { <span class="cstat-no" title="statement not covered" > return val.replace(/[\n\r]/g, '');</span> } return val; } /** * @method html * * get the HTML contents of node * * @param {jQuery} $node * @param {Boolean} [isNewlineOnBlock] */ function html($node, isNewlineOnBlock) { let markup = value($node); <span class="missing-if-branch" title="if path not taken" >I</span>if (isNewlineOnBlock) { <span class="cstat-no" title="statement not covered" > const regexTag = /<(\/?)(\b(?!!)[^>\s]*)(.*?)(\s*\/?>)/g;</span> <span class="cstat-no" title="statement not covered" > markup = markup.replace(regexTag, <span class="fstat-no" title="function not covered" >function(match, endSlash, name)</span> {</span> <span class="cstat-no" title="statement not covered" > name = name.toUpperCase();</span> <span class="cstat-no" title="statement not covered" > const isEndOfInlineContainer = /^DIV|^TD|^TH|^P|^LI|^H[1-7]/.test(name) &&</span> !!endSlash; <span class="cstat-no" title="statement not covered" > const isBlockNode = /^BLOCKQUOTE|^TABLE|^TBODY|^TR|^HR|^UL|^OL/.test(name);</span> <span class="cstat-no" title="statement not covered" > return match + ((isEndOfInlineContainer || isBlockNode) ? '\n' : '');</span> }); <span class="cstat-no" title="statement not covered" > markup = $.trim(markup);</span> } return markup; } <span class="fstat-no" title="function not covered" >function posFromPlaceholder(placeholder)</span> { <span class="cstat-no" title="statement not covered" > const $placeholder = $(placeholder);</span> <span class="cstat-no" title="statement not covered" > const pos = $placeholder.offset();</span> <span class="cstat-no" title="statement not covered" > const height = $placeholder.outerHeight(true); </span>// include margin <span class="cstat-no" title="statement not covered" > return {</span> left: pos.left, top: pos.top + height }; } function attachEvents($node, events) { Object.keys(events).forEach(function(key) { $node.on(key, events[key]); }); } function detachEvents($node, events) { Object.keys(events).forEach(function(key) { $node.off(key, events[key]); }); } /** * @method isCustomStyleTag * * assert if a node contains a "note-styletag" class, * which implies that's a custom-made style tag node * * @param {Node} an HTML DOM node */ function isCustomStyleTag(node) { return node && !isText(node) && lists.contains(node.classList, 'note-styletag'); } export default { /** @property {String} NBSP_CHAR */ NBSP_CHAR, /** @property {String} ZERO_WIDTH_NBSP_CHAR */ ZERO_WIDTH_NBSP_CHAR, /** @property {String} blank */ blank: blankHTML, /** @property {String} emptyPara */ emptyPara: `<p>${blankHTML}</p>`, makePredByNodeName, isEditable, isControlSizing, isText, isElement, isVoid, isPara, isPurePara, isHeading, isInline, isBlock: func.not(isInline), isBodyInline, isBody, isParaInline, isPre, isList, isTable, isData, isCell, isBlockquote, isBodyContainer, isAnchor, isDiv: makePredByNodeName('DIV'), isLi, isBR: makePredByNodeName('BR'), isSpan: makePredByNodeName('SPAN'), isB: makePredByNodeName('B'), isU: makePredByNodeName('U'), isS: makePredByNodeName('S'), isI: makePredByNodeName('I'), isImg: makePredByNodeName('IMG'), isTextarea, isEmpty, isEmptyAnchor: func.and(isAnchor, isEmpty), isClosestSibling, withClosestSiblings, nodeLength, isLeftEdgePoint, isRightEdgePoint, isEdgePoint, isLeftEdgeOf, isRightEdgeOf, isLeftEdgePointOf, isRightEdgePointOf, prevPoint, nextPoint, isSamePoint, isVisiblePoint, prevPointUntil, nextPointUntil, isCharPoint, walkPoint, ancestor, singleChildAncestor, listAncestor, lastAncestor, listNext, listPrev, listDescendant, commonAncestor, wrap, insertAfter, appendChildNodes, position, hasChildren, makeOffsetPath, fromOffsetPath, splitTree, splitPoint, create, createText, remove, removeWhile, replace, html, value, posFromPlaceholder, attachEvents, detachEvents, isCustomStyleTag }; </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/Codeview.js.html000064400000034120151677271550020373 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/Codeview.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/js/base/module/</a> Codeview.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">66.67% </span> <span class="quiet">Statements</span> <span class='fraction'>42/63</span> </div> <div class='fl pad1y space-right2'> <span class="strong">45.83% </span> <span class="quiet">Branches</span> <span class='fraction'>11/24</span> </div> <div class='fl pad1y space-right2'> <span class="strong">66.67% </span> <span class="quiet">Functions</span> <span class='fraction'>8/12</span> </div> <div class='fl pad1y space-right2'> <span class="strong">66.67% </span> <span class="quiet">Lines</span> <span class='fraction'>42/63</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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124</td><td class="line-coverage quiet"><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-yes">1×</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-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-yes">1×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">78×</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">2×</span> <span class="cline-any cline-yes">2×</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-yes">1×</span> <span class="cline-any cline-yes">20×</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">2×</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-yes">2×</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">2×</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-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-no"> </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-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-no"> </span> <span class="cline-any cline-no"> </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-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-neutral"> </span> <span class="cline-any cline-yes">1×</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-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-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-neutral"> </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-yes">1×</span> <span class="cline-any cline-yes">2×</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-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import env from '../core/env'; import dom from '../core/dom'; let CodeMirror; <span class="missing-if-branch" title="if path not taken" >I</span>if (env.hasCodeMirror) { <span class="cstat-no" title="statement not covered" > if (env.isSupportAmd) {</span> <span class="cstat-no" title="statement not covered" > require(['codemirror'], <span class="fstat-no" title="function not covered" >function(cm)</span> {</span> <span class="cstat-no" title="statement not covered" > CodeMirror = cm;</span> }); } else { <span class="cstat-no" title="statement not covered" > CodeMirror = window.CodeMirror;</span> } } /** * @class Codeview */ export default class CodeView { constructor(context) { this.context = context; this.$editor = context.layoutInfo.editor; this.$editable = context.layoutInfo.editable; this.$codable = context.layoutInfo.codable; this.options = context.options; } sync() { const isCodeview = this.isActivated(); <span class="missing-if-branch" title="if path not taken" >I</span>if (isCodeview && <span class="branch-1 cbranch-no" title="branch not covered" >env.hasCodeMirror)</span> { <span class="cstat-no" title="statement not covered" > this.$codable.data('cmEditor').save();</span> } } /** * @return {Boolean} */ isActivated() { return this.$editor.hasClass('codeview'); } /** * toggle codeview */ toggle() { if (this.isActivated()) { this.deactivate(); } else { this.activate(); } this.context.triggerEvent('codeview.toggled'); } /** * activate code view */ activate() { this.$codable.val(dom.html(this.$editable, this.options.prettifyHtml)); this.$codable.height(this.$editable.height()); this.context.invoke('toolbar.updateCodeview', true); this.$editor.addClass('codeview'); this.$codable.focus(); // activate CodeMirror as codable <span class="missing-if-branch" title="if path not taken" >I</span>if (env.hasCodeMirror) { <span class="cstat-no" title="statement not covered" > const cmEditor = CodeMirror.fromTextArea(this.$codable[0], this.options.codemirror);</span> // CodeMirror TernServer <span class="cstat-no" title="statement not covered" > if (this.options.codemirror.tern) {</span> <span class="cstat-no" title="statement not covered" > const server = new CodeMirror.TernServer(this.options.codemirror.tern);</span> <span class="cstat-no" title="statement not covered" > cmEditor.ternServer = server;</span> <span class="cstat-no" title="statement not covered" > cmEditor.on('cursorActivity', <span class="fstat-no" title="function not covered" >(cm)</span> => {</span> <span class="cstat-no" title="statement not covered" > server.updateArgHints(cm);</span> }); } <span class="cstat-no" title="statement not covered" > cmEditor.on('blur', <span class="fstat-no" title="function not covered" >(event)</span> => {</span> <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('blur.codeview', cmEditor.getValue(), event);</span> }); // CodeMirror hasn't Padding. <span class="cstat-no" title="statement not covered" > cmEditor.setSize(null, this.$editable.outerHeight());</span> <span class="cstat-no" title="statement not covered" > this.$codable.data('cmEditor', cmEditor);</span> } else { this.$codable.on('blur', <span class="fstat-no" title="function not covered" >(event)</span> => { <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('blur.codeview', this.$codable.val(), event);</span> }); } } /** * deactivate code view */ deactivate() { // deactivate CodeMirror as codable <span class="missing-if-branch" title="if path not taken" >I</span>if (env.hasCodeMirror) { <span class="cstat-no" title="statement not covered" > const cmEditor = this.$codable.data('cmEditor');</span> <span class="cstat-no" title="statement not covered" > this.$codable.val(cmEditor.getValue());</span> <span class="cstat-no" title="statement not covered" > cmEditor.toTextArea();</span> } const value = dom.value(this.$codable, this.options.prettifyHtml) || <span class="branch-1 cbranch-no" title="branch not covered" >dom.emptyPara;</span> const isChange = this.$editable.html() !== value; this.$editable.html(value); this.$editable.height(this.options.height ? <span class="branch-0 cbranch-no" title="branch not covered" >this.$codable.height() </span>: 'auto'); this.$editor.removeClass('codeview'); <span class="missing-if-branch" title="if path not taken" >I</span>if (isChange) { <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('change', this.$editable.html(), this.$editable);</span> } this.$editable.focus(); this.context.invoke('toolbar.updateCodeview', false); } destroy() { <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isActivated()) { <span class="cstat-no" title="statement not covered" > this.deactivate();</span> } } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/TablePopover.js.html000064400000020022151677271550021224 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/TablePopover.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/js/base/module/</a> TablePopover.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">91.43% </span> <span class="quiet">Statements</span> <span class='fraction'>32/35</span> </div> <div class='fl pad1y space-right2'> <span class="strong">66.67% </span> <span class="quiet">Branches</span> <span class='fraction'>4/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>10/10</span> </div> <div class='fl pad1y space-right2'> <span class="strong">91.43% </span> <span class="quiet">Lines</span> <span class='fraction'>32/35</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-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-yes">1×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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-yes">52×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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">79×</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">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-yes">1×</span> <span class="cline-any cline-yes">2×</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">53×</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">52×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">52×</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-yes">52×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">52×</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">56×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import env from '../core/env'; import lists from '../core/lists'; import dom from '../core/dom'; export default class TablePopover { constructor(context) { this.context = context; this.ui = $.summernote.ui; this.options = context.options; this.events = { 'summernote.mousedown': (we, e) => { this.update(e.target); }, 'summernote.keyup summernote.scroll summernote.change': () => { this.update(); }, 'summernote.disable': () => { this.hide(); } }; } shouldInitialize() { return !lists.isEmpty(this.options.popover.table); } initialize() { this.$popover = this.ui.popover({ className: 'note-table-popover' }).render().appendTo(this.options.container); const $content = this.$popover.find('.popover-content,.note-popover-content'); this.context.invoke('buttons.build', $content, this.options.popover.table); // [workaround] Disable Firefox's default table editor <span class="missing-if-branch" title="if path not taken" >I</span>if (env.isFF) { <span class="cstat-no" title="statement not covered" > document.execCommand('enableInlineTableEditing', false, false);</span> } } destroy() { this.$popover.remove(); } update(target) { if (this.context.isDisabled()) { return false; } const isCell = dom.isCell(target); <span class="missing-if-branch" title="if path not taken" >I</span>if (isCell) { <span class="cstat-no" title="statement not covered" > const pos = dom.posFromPlaceholder(target);</span> <span class="cstat-no" title="statement not covered" > this.$popover.css({</span> display: 'block', left: pos.left, top: pos.top }); } else { this.hide(); } return isCell; } hide() { this.$popover.hide(); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/ImageDialog.js.html000064400000041606151677271550020777 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/ImageDialog.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/js/base/module/</a> ImageDialog.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">40% </span> <span class="quiet">Statements</span> <span class='fraction'>26/65</span> </div> <div class='fl pad1y space-right2'> <span class="strong">14.29% </span> <span class="quiet">Branches</span> <span class='fraction'>2/14</span> </div> <div class='fl pad1y space-right2'> <span class="strong">25% </span> <span class="quiet">Functions</span> <span class='fraction'>4/16</span> </div> <div class='fl pad1y space-right2'> <span class="strong">40% </span> <span class="quiet">Lines</span> <span class='fraction'>26/65</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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-yes">77×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">2×</span> <span class="cline-any cline-yes">2×</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-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-yes">1×</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-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-no"> </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-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-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-no"> </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-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-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-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-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-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-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-no"> </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></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import env from '../core/env'; import key from '../core/key'; export default class ImageDialog { constructor(context) { this.context = context; this.ui = $.summernote.ui; this.$body = $(document.body); this.$editor = context.layoutInfo.editor; this.options = context.options; this.lang = this.options.langInfo; } initialize() { const $container = this.options.dialogsInBody ? <span class="branch-0 cbranch-no" title="branch not covered" >this.$body </span>: this.$editor; let imageLimitation = ''; <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.maximumImageFileSize) { <span class="cstat-no" title="statement not covered" > const unit = Math.floor(Math.log(this.options.maximumImageFileSize) / Math.log(1024));</span> <span class="cstat-no" title="statement not covered" > const readableSize = (this.options.maximumImageFileSize / Math.pow(1024, unit)).toFixed(2) * 1 +</span> ' ' + ' KMGTP'[unit] + 'B'; <span class="cstat-no" title="statement not covered" > imageLimitation = `<small>${this.lang.image.maximumFileSize + ' : ' + readableSize}</small>`;</span> } const body = [ '<div class="form-group note-form-group note-group-select-from-files">', '<label class="note-form-label">' + this.lang.image.selectFromFiles + '</label>', '<input class="note-image-input note-form-control note-input" ', ' type="file" name="files" accept="image/*" multiple="multiple" />', imageLimitation, '</div>', '<div class="form-group note-group-image-url" style="overflow:auto;">', '<label class="note-form-label">' + this.lang.image.url + '</label>', '<input class="note-image-url form-control note-form-control note-input ', ' col-md-12" type="text" />', '</div>' ].join(''); const buttonClass = 'btn btn-primary note-btn note-btn-primary note-image-btn'; const footer = `<button type="submit" href="#" class="${buttonClass}" disabled>${this.lang.image.insert}</button>`; this.$dialog = this.ui.dialog({ title: this.lang.image.insert, fade: this.options.dialogsFade, body: body, footer: footer }).render().appendTo($container); } destroy() { this.ui.hideDialog(this.$dialog); this.$dialog.remove(); } <span class="fstat-no" title="function not covered" > bindEnterKey($input, $btn)</span> { <span class="cstat-no" title="statement not covered" > $input.on('keypress', <span class="fstat-no" title="function not covered" >(event)</span> => {</span> <span class="cstat-no" title="statement not covered" > if (event.keyCode === key.code.ENTER) {</span> <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> <span class="cstat-no" title="statement not covered" > $btn.trigger('click');</span> } }); } <span class="fstat-no" title="function not covered" > show() {</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.saveRange');</span> <span class="cstat-no" title="statement not covered" > this.showImageDialog().then(<span class="fstat-no" title="function not covered" >(data)</span> => {</span> // [workaround] hide dialog before restore range for IE range focus <span class="cstat-no" title="statement not covered" > this.ui.hideDialog(this.$dialog);</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.restoreRange');</span> <span class="cstat-no" title="statement not covered" > if (typeof data === 'string') { // image url</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.insertImage', data);</span> } else { // array of files <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.insertImagesOrCallback', data);</span> } }).fail(<span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.restoreRange');</span> }); } /** * show image dialog * * @param {jQuery} $dialog * @return {Promise} */ <span class="fstat-no" title="function not covered" > showImageDialog() {</span> <span class="cstat-no" title="statement not covered" > return $.Deferred(<span class="fstat-no" title="function not covered" >(deferred)</span> => {</span> <span class="cstat-no" title="statement not covered" > const $imageInput = this.$dialog.find('.note-image-input');</span> <span class="cstat-no" title="statement not covered" > const $imageUrl = this.$dialog.find('.note-image-url');</span> <span class="cstat-no" title="statement not covered" > const $imageBtn = this.$dialog.find('.note-image-btn');</span> <span class="cstat-no" title="statement not covered" > this.ui.onDialogShown(this.$dialog, <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('dialog.shown');</span> // Cloning imageInput to clear element. <span class="cstat-no" title="statement not covered" > $imageInput.replaceWith($imageInput.clone().on('change', <span class="fstat-no" title="function not covered" >(event)</span> => {</span> <span class="cstat-no" title="statement not covered" > deferred.resolve(event.target.files || event.target.value);</span> }).val('')); <span class="cstat-no" title="statement not covered" > $imageBtn.click(<span class="fstat-no" title="function not covered" >(event)</span> => {</span> <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> <span class="cstat-no" title="statement not covered" > deferred.resolve($imageUrl.val());</span> }); <span class="cstat-no" title="statement not covered" > $imageUrl.on('keyup paste', <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > const url = $imageUrl.val();</span> <span class="cstat-no" title="statement not covered" > this.ui.toggleBtn($imageBtn, url);</span> }).val(''); <span class="cstat-no" title="statement not covered" > if (!env.isSupportTouch) {</span> <span class="cstat-no" title="statement not covered" > $imageUrl.trigger('focus');</span> } <span class="cstat-no" title="statement not covered" > this.bindEnterKey($imageUrl, $imageBtn);</span> }); <span class="cstat-no" title="statement not covered" > this.ui.onDialogHidden(this.$dialog, <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > $imageInput.off('change');</span> <span class="cstat-no" title="statement not covered" > $imageUrl.off('keyup paste keypress');</span> <span class="cstat-no" title="statement not covered" > $imageBtn.off('click');</span> <span class="cstat-no" title="statement not covered" > if (deferred.state() === 'pending') {</span> <span class="cstat-no" title="statement not covered" > deferred.reject();</span> } }); <span class="cstat-no" title="statement not covered" > this.ui.showDialog(this.$dialog);</span> }); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/Buttons.js.html000064400000241103151677271550020265 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/Buttons.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/js/base/module/</a> Buttons.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">88.48% </span> <span class="quiet">Statements</span> <span class='fraction'>215/243</span> </div> <div class='fl pad1y space-right2'> <span class="strong">54.93% </span> <span class="quiet">Branches</span> <span class='fraction'>39/71</span> </div> <div class='fl pad1y space-right2'> <span class="strong">91.03% </span> <span class="quiet">Functions</span> <span class='fraction'>71/78</span> </div> <div class='fl pad1y space-right2'> <span class="strong">88.48% </span> <span class="quiet">Lines</span> <span class='fraction'>215/243</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">972×</span> <span class="cline-any cline-yes">972×</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-yes">972×</span> <span class="cline-any cline-yes">972×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">972×</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">972×</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">3119×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3119×</span> <span class="cline-any cline-yes">3119×</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">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">2×</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">960×</span> <span class="cline-any cline-yes">892×</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">960×</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">73×</span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">73×</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-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">657×</span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">657×</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">77×</span> <span class="cline-any cline-yes">693×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">693×</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> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">73×</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">77×</span> <span class="cline-any cline-yes">36×</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">77×</span> <span class="cline-any cline-yes">73×</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">77×</span> <span class="cline-any cline-yes">73×</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">77×</span> <span class="cline-any cline-yes">36×</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">77×</span> <span class="cline-any cline-yes">36×</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">77×</span> <span class="cline-any cline-yes">36×</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">77×</span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">40×</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-yes">73×</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-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">847×</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">77×</span> <span class="cline-any cline-yes">36×</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-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">77×</span> <span class="cline-any cline-yes">73×</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-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">73×</span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">73×</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-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-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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">146×</span> <span class="cline-any cline-yes">146×</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">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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">77×</span> <span class="cline-any cline-yes">73×</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">77×</span> <span class="cline-any cline-yes">73×</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">77×</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">77×</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">77×</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">77×</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">77×</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">77×</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">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">73×</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-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-neutral"> </span> <span class="cline-any cline-yes">77×</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> <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-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">73×</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-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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">73×</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">77×</span> <span class="cline-any cline-yes">73×</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">77×</span> <span class="cline-any cline-yes">73×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</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-yes">77×</span> <span class="cline-any cline-yes">73×</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">77×</span> <span class="cline-any cline-yes">73×</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">77×</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-yes">77×</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-yes">77×</span> <span class="cline-any cline-yes">73×</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-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">78×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</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">308×</span> <span class="cline-any cline-yes">1050×</span> <span class="cline-any cline-yes">1050×</span> <span class="cline-any cline-yes">1050×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1050×</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">1050×</span> <span class="cline-any cline-yes">2584×</span> <span class="cline-any cline-yes">2584×</span> <span class="cline-any cline-yes">2584×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1050×</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">143×</span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">142×</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">142×</span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">73×</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">73×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">826×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">826×</span> <span class="cline-any cline-yes">826×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">495×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">495×</span> <span class="cline-any cline-yes">495×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-yes">73×</span> <span class="cline-any cline-yes">73×</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-yes">143×</span> <span class="cline-any cline-yes">142×</span> <span class="cline-any cline-yes">852×</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-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-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-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-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-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-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-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-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import func from '../core/func'; import lists from '../core/lists'; import env from '../core/env'; export default class Buttons { constructor(context) { this.ui = $.summernote.ui; this.context = context; this.$toolbar = context.layoutInfo.toolbar; this.options = context.options; this.lang = this.options.langInfo; this.invertedKeyMap = func.invertObject( this.options.keyMap[env.isMac ? 'mac' : <span class="branch-1 cbranch-no" title="branch not covered" >'pc']</span> ); } representShortcut(editorMethod) { let shortcut = this.invertedKeyMap[editorMethod]; <span class="missing-if-branch" title="if path not taken" >I</span>if (!this.options.shortcuts || !shortcut) { <span class="cstat-no" title="statement not covered" > return '';</span> } <span class="missing-if-branch" title="else path not taken" >E</span>if (env.isMac) { shortcut = shortcut.replace('CMD', '⌘').replace('SHIFT', '⇧'); } shortcut = shortcut.replace('BACKSLASH', '\\') .replace('SLASH', '/') .replace('LEFTBRACKET', '[') .replace('RIGHTBRACKET', ']'); return ' (' + shortcut + ')'; } button(o) { <span class="missing-if-branch" title="if path not taken" >I</span>if (!this.options.tooltip && <span class="branch-1 cbranch-no" title="branch not covered" >o.tooltip)</span> { <span class="cstat-no" title="statement not covered" > delete o.tooltip;</span> } o.container = this.options.container; return this.ui.button(o); } initialize() { this.addToolbarButtons(); this.addImagePopoverButtons(); this.addLinkPopoverButtons(); this.addTablePopoverButtons(); this.fontInstalledMap = {}; } destroy() { delete this.fontInstalledMap; } isFontInstalled(name) { if (!this.fontInstalledMap.hasOwnProperty(name)) { this.fontInstalledMap[name] = env.isFontInstalled(name) || <span class="branch-1 cbranch-no" title="branch not covered" > lists.contains(this.options.fontNamesIgnoreCheck, name);</span> } return this.fontInstalledMap[name]; } isFontDeservedToAdd(name) { const genericFamilies = ['sans-serif', 'serif', 'monospace', 'cursive', 'fantasy']; name = name.toLowerCase(); return ((name !== '') && this.isFontInstalled(name) && ($.inArray(name, genericFamilies) === -1)); } addToolbarButtons() { this.context.memo('button.style', () => { return this.ui.buttonGroup([ this.button({ className: 'dropdown-toggle', contents: this.ui.dropdownButtonContents( this.ui.icon(this.options.icons.magic), this.options ), tooltip: this.lang.style.style, data: { toggle: 'dropdown' } }), this.ui.dropdown({ className: 'dropdown-style', items: this.options.styleTags, title: this.lang.style.style, template: (item) => { <span class="missing-if-branch" title="else path not taken" >E</span>if (typeof item === 'string') { item = { tag: item, title: (this.lang.style.hasOwnProperty(item) ? this.lang.style[item] : <span class="branch-1 cbranch-no" title="branch not covered" >item)</span> }; } const tag = item.tag; const title = item.title; const style = item.style ? <span class="branch-0 cbranch-no" title="branch not covered" >' style="' + item.style + '" ' </span>: ''; const className = item.className ? <span class="branch-0 cbranch-no" title="branch not covered" >' class="' + item.className + '"' </span>: ''; return '<' + tag + style + className + '>' + title + '</' + tag + '>'; }, click: this.context.createInvokeHandler('editor.formatBlock') }) ]).render(); }); for (let styleIdx = 0, styleLen = this.options.styleTags.length; styleIdx < styleLen; styleIdx++) { const item = this.options.styleTags[styleIdx]; this.context.memo('button.style.' + item, <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > return this.button({</span> className: 'note-btn-style-' + item, contents: '<div data-value="' + item + '">' + item.toUpperCase() + '</div>', tooltip: this.lang.style[item], click: this.context.createInvokeHandler('editor.formatBlock') }).render(); }); } this.context.memo('button.bold', () => { return this.button({ className: 'note-btn-bold', contents: this.ui.icon(this.options.icons.bold), tooltip: this.lang.font.bold + this.representShortcut('bold'), click: this.context.createInvokeHandlerAndUpdateState('editor.bold') }).render(); }); this.context.memo('button.italic', () => { return this.button({ className: 'note-btn-italic', contents: this.ui.icon(this.options.icons.italic), tooltip: this.lang.font.italic + this.representShortcut('italic'), click: this.context.createInvokeHandlerAndUpdateState('editor.italic') }).render(); }); this.context.memo('button.underline', () => { return this.button({ className: 'note-btn-underline', contents: this.ui.icon(this.options.icons.underline), tooltip: this.lang.font.underline + this.representShortcut('underline'), click: this.context.createInvokeHandlerAndUpdateState('editor.underline') }).render(); }); this.context.memo('button.clear', () => { return this.button({ contents: this.ui.icon(this.options.icons.eraser), tooltip: this.lang.font.clear + this.representShortcut('removeFormat'), click: this.context.createInvokeHandler('editor.removeFormat') }).render(); }); this.context.memo('button.strikethrough', () => { return this.button({ className: 'note-btn-strikethrough', contents: this.ui.icon(this.options.icons.strikethrough), tooltip: this.lang.font.strikethrough + this.representShortcut('strikethrough'), click: this.context.createInvokeHandlerAndUpdateState('editor.strikethrough') }).render(); }); this.context.memo('button.superscript', () => { return this.button({ className: 'note-btn-superscript', contents: this.ui.icon(this.options.icons.superscript), tooltip: this.lang.font.superscript, click: this.context.createInvokeHandlerAndUpdateState('editor.superscript') }).render(); }); this.context.memo('button.subscript', () => { return this.button({ className: 'note-btn-subscript', contents: this.ui.icon(this.options.icons.subscript), tooltip: this.lang.font.subscript, click: this.context.createInvokeHandlerAndUpdateState('editor.subscript') }).render(); }); this.context.memo('button.fontname', () => { const styleInfo = this.context.invoke('editor.currentStyle'); // Add 'default' fonts into the fontnames array if not exist $.each(styleInfo['font-family'].split(','), (idx, fontname) => { fontname = fontname.trim().replace(/['"]+/g, ''); if (this.isFontDeservedToAdd(fontname)) { if ($.inArray(fontname, this.options.fontNames) === -1) { this.options.fontNames.push(fontname); } } }); return this.ui.buttonGroup([ this.button({ className: 'dropdown-toggle', contents: this.ui.dropdownButtonContents( '<span class="note-current-fontname"/>', this.options ), tooltip: this.lang.font.name, data: { toggle: 'dropdown' } }), this.ui.dropdownCheck({ className: 'dropdown-fontname', checkClassName: this.options.icons.menuCheck, items: this.options.fontNames.filter(this.isFontInstalled.bind(this)), title: this.lang.font.name, template: (item) => { return '<span style="font-family: \'' + item + '\'">' + item + '</span>'; }, click: this.context.createInvokeHandlerAndUpdateState('editor.fontName') }) ]).render(); }); this.context.memo('button.fontsize', () => { return this.ui.buttonGroup([ this.button({ className: 'dropdown-toggle', contents: this.ui.dropdownButtonContents('<span class="note-current-fontsize"/>', this.options), tooltip: this.lang.font.size, data: { toggle: 'dropdown' } }), this.ui.dropdownCheck({ className: 'dropdown-fontsize', checkClassName: this.options.icons.menuCheck, items: this.options.fontSizes, title: this.lang.font.size, click: this.context.createInvokeHandlerAndUpdateState('editor.fontSize') }) ]).render(); }); this.context.memo('button.color', () => { return this.ui.buttonGroup({ className: 'note-color', children: [ this.button({ className: 'note-current-color-button', contents: this.ui.icon(this.options.icons.font + ' note-recent-color'), tooltip: this.lang.color.recent, click: (e) => { const $button = $(e.currentTarget); this.context.invoke('editor.color', { backColor: $button.attr('data-backColor'), foreColor: $button.attr('data-foreColor') }); }, callback: ($button) => { const $recentColor = $button.find('.note-recent-color'); $recentColor.css('background-color', '#FFFF00'); $button.attr('data-backColor', '#FFFF00'); } }), this.button({ className: 'dropdown-toggle', contents: this.ui.dropdownButtonContents('', this.options), tooltip: this.lang.color.more, data: { toggle: 'dropdown' } }), this.ui.dropdown({ items: [ '<div class="note-palette">', ' <div class="note-palette-title">' + this.lang.color.background + '</div>', ' <div>', ' <button type="button" class="note-color-reset btn btn-light" data-event="backColor" data-value="inherit">', this.lang.color.transparent, ' </button>', ' </div>', ' <div class="note-holder" data-event="backColor"/>', '</div>', '<div class="note-palette">', ' <div class="note-palette-title">' + this.lang.color.foreground + '</div>', ' <div>', ' <button type="button" class="note-color-reset btn btn-light" data-event="removeFormat" data-value="foreColor">', this.lang.color.resetToDefault, ' </button>', ' </div>', ' <div class="note-holder" data-event="foreColor"/>', '</div>' ].join(''), callback: ($dropdown) => { $dropdown.find('.note-holder').each((idx, item) => { const $holder = $(item); $holder.append(this.ui.palette({ colors: this.options.colors, colorsName: this.options.colorsName, eventName: $holder.data('event'), container: this.options.container, tooltip: this.options.tooltip }).render()); }); }, click: (event) => { const $button = $(event.target); const eventName = $button.data('event'); const value = $button.data('value'); <span class="missing-if-branch" title="else path not taken" >E</span>if (eventName && value) { const key = eventName === 'backColor' ? 'background-color' : 'color'; const $color = $button.closest('.note-color').find('.note-recent-color'); const $currentButton = $button.closest('.note-color').find('.note-current-color-button'); $color.css(key, value); $currentButton.attr('data-' + eventName, value); this.context.invoke('editor.' + eventName, value); } } }) ] }).render(); }); this.context.memo('button.ul', () => { return this.button({ contents: this.ui.icon(this.options.icons.unorderedlist), tooltip: this.lang.lists.unordered + this.representShortcut('insertUnorderedList'), click: this.context.createInvokeHandler('editor.insertUnorderedList') }).render(); }); this.context.memo('button.ol', () => { return this.button({ contents: this.ui.icon(this.options.icons.orderedlist), tooltip: this.lang.lists.ordered + this.representShortcut('insertOrderedList'), click: this.context.createInvokeHandler('editor.insertOrderedList') }).render(); }); const justifyLeft = this.button({ contents: this.ui.icon(this.options.icons.alignLeft), tooltip: this.lang.paragraph.left + this.representShortcut('justifyLeft'), click: this.context.createInvokeHandler('editor.justifyLeft') }); const justifyCenter = this.button({ contents: this.ui.icon(this.options.icons.alignCenter), tooltip: this.lang.paragraph.center + this.representShortcut('justifyCenter'), click: this.context.createInvokeHandler('editor.justifyCenter') }); const justifyRight = this.button({ contents: this.ui.icon(this.options.icons.alignRight), tooltip: this.lang.paragraph.right + this.representShortcut('justifyRight'), click: this.context.createInvokeHandler('editor.justifyRight') }); const justifyFull = this.button({ contents: this.ui.icon(this.options.icons.alignJustify), tooltip: this.lang.paragraph.justify + this.representShortcut('justifyFull'), click: this.context.createInvokeHandler('editor.justifyFull') }); const outdent = this.button({ contents: this.ui.icon(this.options.icons.outdent), tooltip: this.lang.paragraph.outdent + this.representShortcut('outdent'), click: this.context.createInvokeHandler('editor.outdent') }); const indent = this.button({ contents: this.ui.icon(this.options.icons.indent), tooltip: this.lang.paragraph.indent + this.representShortcut('indent'), click: this.context.createInvokeHandler('editor.indent') }); this.context.memo('button.justifyLeft', func.invoke(justifyLeft, 'render')); this.context.memo('button.justifyCenter', func.invoke(justifyCenter, 'render')); this.context.memo('button.justifyRight', func.invoke(justifyRight, 'render')); this.context.memo('button.justifyFull', func.invoke(justifyFull, 'render')); this.context.memo('button.outdent', func.invoke(outdent, 'render')); this.context.memo('button.indent', func.invoke(indent, 'render')); this.context.memo('button.paragraph', () => { return this.ui.buttonGroup([ this.button({ className: 'dropdown-toggle', contents: this.ui.dropdownButtonContents(this.ui.icon(this.options.icons.alignLeft), this.options), tooltip: this.lang.paragraph.paragraph, data: { toggle: 'dropdown' } }), this.ui.dropdown([ this.ui.buttonGroup({ className: 'note-align', children: [justifyLeft, justifyCenter, justifyRight, justifyFull] }), this.ui.buttonGroup({ className: 'note-list', children: [outdent, indent] }) ]) ]).render(); }); this.context.memo('button.height', <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > return this.ui.buttonGroup([</span> this.button({ className: 'dropdown-toggle', contents: this.ui.dropdownButtonContents(this.ui.icon(this.options.icons.textHeight), this.options), tooltip: this.lang.font.height, data: { toggle: 'dropdown' } }), this.ui.dropdownCheck({ items: this.options.lineHeights, checkClassName: this.options.icons.menuCheck, className: 'dropdown-line-height', title: this.lang.font.height, click: this.context.createInvokeHandler('editor.lineHeight') }) ]).render(); }); this.context.memo('button.table', () => { return this.ui.buttonGroup([ this.button({ className: 'dropdown-toggle', contents: this.ui.dropdownButtonContents(this.ui.icon(this.options.icons.table), this.options), tooltip: this.lang.table.table, data: { toggle: 'dropdown' } }), this.ui.dropdown({ title: this.lang.table.table, className: 'note-table', items: [ '<div class="note-dimension-picker">', ' <div class="note-dimension-picker-mousecatcher" data-event="insertTable" data-value="1x1"/>', ' <div class="note-dimension-picker-highlighted"/>', ' <div class="note-dimension-picker-unhighlighted"/>', '</div>', '<div class="note-dimension-display">1 x 1</div>' ].join('') }) ], { callback: ($node) => { const $catcher = $node.find('.note-dimension-picker-mousecatcher'); $catcher.css({ width: this.options.insertTableMaxSize.col + 'em', height: this.options.insertTableMaxSize.row + 'em' }).mousedown(this.context.createInvokeHandler('editor.insertTable')) .on('mousemove', this.tableMoveHandler.bind(this)); } }).render(); }); this.context.memo('button.link', () => { return this.button({ contents: this.ui.icon(this.options.icons.link), tooltip: this.lang.link.link + this.representShortcut('linkDialog.show'), click: this.context.createInvokeHandler('linkDialog.show') }).render(); }); this.context.memo('button.picture', () => { return this.button({ contents: this.ui.icon(this.options.icons.picture), tooltip: this.lang.image.image, click: this.context.createInvokeHandler('imageDialog.show') }).render(); }); this.context.memo('button.video', () => { return this.button({ contents: this.ui.icon(this.options.icons.video), tooltip: this.lang.video.video, click: this.context.createInvokeHandler('videoDialog.show') }).render(); }); this.context.memo('button.hr', <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > return this.button({</span> contents: this.ui.icon(this.options.icons.minus), tooltip: this.lang.hr.insert + this.representShortcut('insertHorizontalRule'), click: this.context.createInvokeHandler('editor.insertHorizontalRule') }).render(); }); this.context.memo('button.fullscreen', () => { return this.button({ className: 'btn-fullscreen', contents: this.ui.icon(this.options.icons.arrowsAlt), tooltip: this.lang.options.fullscreen, click: this.context.createInvokeHandler('fullscreen.toggle') }).render(); }); this.context.memo('button.codeview', () => { return this.button({ className: 'btn-codeview', contents: this.ui.icon(this.options.icons.code), tooltip: this.lang.options.codeview, click: this.context.createInvokeHandler('codeview.toggle') }).render(); }); this.context.memo('button.redo', <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > return this.button({</span> contents: this.ui.icon(this.options.icons.redo), tooltip: this.lang.history.redo + this.representShortcut('redo'), click: this.context.createInvokeHandler('editor.redo') }).render(); }); this.context.memo('button.undo', <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > return this.button({</span> contents: this.ui.icon(this.options.icons.undo), tooltip: this.lang.history.undo + this.representShortcut('undo'), click: this.context.createInvokeHandler('editor.undo') }).render(); }); this.context.memo('button.help', () => { return this.button({ contents: this.ui.icon(this.options.icons.question), tooltip: this.lang.options.help, click: this.context.createInvokeHandler('helpDialog.show') }).render(); }); } /** * image : [ * ['imagesize', ['imageSize100', 'imageSize50', 'imageSize25']], * ['float', ['floatLeft', 'floatRight', 'floatNone' ]], * ['remove', ['removeMedia']] * ], */ addImagePopoverButtons() { // Image Size Buttons this.context.memo('button.imageSize100', () => { return this.button({ contents: '<span class="note-fontsize-10">100%</span>', tooltip: this.lang.image.resizeFull, click: this.context.createInvokeHandler('editor.resize', '1') }).render(); }); this.context.memo('button.imageSize50', () => { return this.button({ contents: '<span class="note-fontsize-10">50%</span>', tooltip: this.lang.image.resizeHalf, click: this.context.createInvokeHandler('editor.resize', '0.5') }).render(); }); this.context.memo('button.imageSize25', () => { return this.button({ contents: '<span class="note-fontsize-10">25%</span>', tooltip: this.lang.image.resizeQuarter, click: this.context.createInvokeHandler('editor.resize', '0.25') }).render(); }); // Float Buttons this.context.memo('button.floatLeft', () => { return this.button({ contents: this.ui.icon(this.options.icons.alignLeft), tooltip: this.lang.image.floatLeft, click: this.context.createInvokeHandler('editor.floatMe', 'left') }).render(); }); this.context.memo('button.floatRight', () => { return this.button({ contents: this.ui.icon(this.options.icons.alignRight), tooltip: this.lang.image.floatRight, click: this.context.createInvokeHandler('editor.floatMe', 'right') }).render(); }); this.context.memo('button.floatNone', () => { return this.button({ contents: this.ui.icon(this.options.icons.alignJustify), tooltip: this.lang.image.floatNone, click: this.context.createInvokeHandler('editor.floatMe', 'none') }).render(); }); // Remove Buttons this.context.memo('button.removeMedia', () => { return this.button({ contents: this.ui.icon(this.options.icons.trash), tooltip: this.lang.image.remove, click: this.context.createInvokeHandler('editor.removeMedia') }).render(); }); } addLinkPopoverButtons() { this.context.memo('button.linkDialogShow', () => { return this.button({ contents: this.ui.icon(this.options.icons.link), tooltip: this.lang.link.edit, click: this.context.createInvokeHandler('linkDialog.show') }).render(); }); this.context.memo('button.unlink', () => { return this.button({ contents: this.ui.icon(this.options.icons.unlink), tooltip: this.lang.link.unlink, click: this.context.createInvokeHandler('editor.unlink') }).render(); }); } /** * table : [ * ['add', ['addRowDown', 'addRowUp', 'addColLeft', 'addColRight']], * ['delete', ['deleteRow', 'deleteCol', 'deleteTable']] * ], */ addTablePopoverButtons() { this.context.memo('button.addRowUp', () => { return this.button({ className: 'btn-md', contents: this.ui.icon(this.options.icons.rowAbove), tooltip: this.lang.table.addRowAbove, click: this.context.createInvokeHandler('editor.addRow', 'top') }).render(); }); this.context.memo('button.addRowDown', () => { return this.button({ className: 'btn-md', contents: this.ui.icon(this.options.icons.rowBelow), tooltip: this.lang.table.addRowBelow, click: this.context.createInvokeHandler('editor.addRow', 'bottom') }).render(); }); this.context.memo('button.addColLeft', () => { return this.button({ className: 'btn-md', contents: this.ui.icon(this.options.icons.colBefore), tooltip: this.lang.table.addColLeft, click: this.context.createInvokeHandler('editor.addCol', 'left') }).render(); }); this.context.memo('button.addColRight', () => { return this.button({ className: 'btn-md', contents: this.ui.icon(this.options.icons.colAfter), tooltip: this.lang.table.addColRight, click: this.context.createInvokeHandler('editor.addCol', 'right') }).render(); }); this.context.memo('button.deleteRow', () => { return this.button({ className: 'btn-md', contents: this.ui.icon(this.options.icons.rowRemove), tooltip: this.lang.table.delRow, click: this.context.createInvokeHandler('editor.deleteRow') }).render(); }); this.context.memo('button.deleteCol', () => { return this.button({ className: 'btn-md', contents: this.ui.icon(this.options.icons.colRemove), tooltip: this.lang.table.delCol, click: this.context.createInvokeHandler('editor.deleteCol') }).render(); }); this.context.memo('button.deleteTable', () => { return this.button({ className: 'btn-md', contents: this.ui.icon(this.options.icons.trash), tooltip: this.lang.table.delTable, click: this.context.createInvokeHandler('editor.deleteTable') }).render(); }); } build($container, groups) { for (let groupIdx = 0, groupLen = groups.length; groupIdx < groupLen; groupIdx++) { const group = groups[groupIdx]; const groupName = $.isArray(group) ? group[0] : <span class="branch-1 cbranch-no" title="branch not covered" >group;</span> const buttons = $.isArray(group) ? ((group.length === 1) ? <span class="branch-0 cbranch-no" title="branch not covered" >[group[0]] </span>: group[1]) : <span class="branch-1 cbranch-no" title="branch not covered" >[group];</span> const $group = this.ui.buttonGroup({ className: 'note-' + groupName }).render(); for (let idx = 0, len = buttons.length; idx < len; idx++) { const btn = this.context.memo('button.' + buttons[idx]); <span class="missing-if-branch" title="else path not taken" >E</span>if (btn) { $group.append(typeof btn === 'function' ? btn(this.context) : <span class="branch-1 cbranch-no" title="branch not covered" >btn)</span>; } } $group.appendTo($container); } } /** * @param {jQuery} [$container] */ updateCurrentStyle($container) { const $cont = $container || this.$toolbar; const styleInfo = this.context.invoke('editor.currentStyle'); this.updateBtnStates($cont, { '.note-btn-bold': () => { return styleInfo['font-bold'] === 'bold'; }, '.note-btn-italic': () => { return styleInfo['font-italic'] === 'italic'; }, '.note-btn-underline': () => { return styleInfo['font-underline'] === 'underline'; }, '.note-btn-subscript': () => { return styleInfo['font-subscript'] === 'subscript'; }, '.note-btn-superscript': () => { return styleInfo['font-superscript'] === 'superscript'; }, '.note-btn-strikethrough': () => { return styleInfo['font-strikethrough'] === 'strikethrough'; } }); if (styleInfo['font-family']) { const fontNames = styleInfo['font-family'].split(',').map((name) => { return name.replace(/[\'\"]/g, '') .replace(/\s+$/, '') .replace(/^\s+/, ''); }); const fontName = lists.find(fontNames, this.isFontInstalled.bind(this)); $cont.find('.dropdown-fontname a').each((idx, item) => { const $item = $(item); // always compare string to avoid creating another func. const isChecked = ($item.data('value') + '') === (fontName + ''); $item.toggleClass('checked', isChecked); }); $cont.find('.note-current-fontname').text(fontName).css('font-family', fontName); } if (styleInfo['font-size']) { const fontSize = styleInfo['font-size']; $cont.find('.dropdown-fontsize a').each((idx, item) => { const $item = $(item); // always compare with string to avoid creating another func. const isChecked = ($item.data('value') + '') === (fontSize + ''); $item.toggleClass('checked', isChecked); }); $cont.find('.note-current-fontsize').text(fontSize); } if (styleInfo['line-height']) { const lineHeight = styleInfo['line-height']; $cont.find('.dropdown-line-height li a').each(<span class="fstat-no" title="function not covered" >(idx, item)</span> => { // always compare with string to avoid creating another func. <span class="cstat-no" title="statement not covered" > const isChecked = ($(item).data('value') + '') === (lineHeight + '');</span> <span class="cstat-no" title="statement not covered" > this.className = isChecked ? 'checked' : '';</span> }); } } updateBtnStates($container, infos) { $.each(infos, (selector, pred) => { this.ui.toggleBtnActive($container.find(selector), pred()); }); } <span class="fstat-no" title="function not covered" > tableMoveHandler(event)</span> { <span class="cstat-no" title="statement not covered" > const PX_PER_EM = 18;</span> <span class="cstat-no" title="statement not covered" > const $picker = $(event.target.parentNode); </span>// target is mousecatcher <span class="cstat-no" title="statement not covered" > const $dimensionDisplay = $picker.next();</span> <span class="cstat-no" title="statement not covered" > const $catcher = $picker.find('.note-dimension-picker-mousecatcher');</span> <span class="cstat-no" title="statement not covered" > const $highlighted = $picker.find('.note-dimension-picker-highlighted');</span> <span class="cstat-no" title="statement not covered" > const $unhighlighted = $picker.find('.note-dimension-picker-unhighlighted');</span> <span class="cstat-no" title="statement not covered" > let posOffset;</span> // HTML5 with jQuery - e.offsetX is undefined in Firefox <span class="cstat-no" title="statement not covered" > if (event.offsetX === undefined) {</span> <span class="cstat-no" title="statement not covered" > const posCatcher = $(event.target).offset();</span> <span class="cstat-no" title="statement not covered" > posOffset = {</span> x: event.pageX - posCatcher.left, y: event.pageY - posCatcher.top }; } else { <span class="cstat-no" title="statement not covered" > posOffset = {</span> x: event.offsetX, y: event.offsetY }; } <span class="cstat-no" title="statement not covered" > const dim = {</span> c: Math.ceil(posOffset.x / PX_PER_EM) || 1, r: Math.ceil(posOffset.y / PX_PER_EM) || 1 }; <span class="cstat-no" title="statement not covered" > $highlighted.css({ width: dim.c + 'em', height: dim.r + 'em' });</span> <span class="cstat-no" title="statement not covered" > $catcher.data('value', dim.c + 'x' + dim.r);</span> <span class="cstat-no" title="statement not covered" > if (dim.c > 3 && dim.c < this.options.insertTableMaxSize.col) {</span> <span class="cstat-no" title="statement not covered" > $unhighlighted.css({ width: dim.c + 1 + 'em' });</span> } <span class="cstat-no" title="statement not covered" > if (dim.r > 3 && dim.r < this.options.insertTableMaxSize.row) {</span> <span class="cstat-no" title="statement not covered" > $unhighlighted.css({ height: dim.r + 1 + 'em' });</span> } <span class="cstat-no" title="statement not covered" > $dimensionDisplay.html(dim.c + ' x ' + dim.r);</span> } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/AutoLink.js.html000064400000020117151677271550020355 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/AutoLink.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/js/base/module/</a> AutoLink.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">62.86% </span> <span class="quiet">Statements</span> <span class='fraction'>22/35</span> </div> <div class='fl pad1y space-right2'> <span class="strong">20% </span> <span class="quiet">Branches</span> <span class='fraction'>3/15</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">62.86% </span> <span class="quiet">Lines</span> <span class='fraction'>22/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</td><td class="line-coverage quiet"><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-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-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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-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-yes">1×</span> <span class="cline-any cline-yes">77×</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">2×</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-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-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-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-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-yes">1×</span> <span class="cline-any cline-yes">1×</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-yes">1×</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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import lists from '../core/lists'; import key from '../core/key'; const defaultScheme = 'http://'; const linkPattern = /^([A-Za-z][A-Za-z0-9+-.]*\:[\/\/]?|mailto:[A-Z0-9._%+-]+@)?(www\.)?(.+)$/i; export default class AutoLink { constructor(context) { this.context = context; this.events = { 'summernote.keyup': (we, e) => { <span class="missing-if-branch" title="else path not taken" >E</span>if (!e.isDefaultPrevented()) { this.handleKeyup(e); } }, 'summernote.keydown': (we, e) => { this.handleKeydown(e); } }; } initialize() { this.lastWordRange = null; } destroy() { this.lastWordRange = null; } <span class="fstat-no" title="function not covered" > replace() {</span> <span class="cstat-no" title="statement not covered" > if (!this.lastWordRange) {</span> <span class="cstat-no" title="statement not covered" > return;</span> } <span class="cstat-no" title="statement not covered" > const keyword = this.lastWordRange.toString();</span> <span class="cstat-no" title="statement not covered" > const match = keyword.match(linkPattern);</span> <span class="cstat-no" title="statement not covered" > if (match && (match[1] || match[2])) {</span> <span class="cstat-no" title="statement not covered" > const link = match[1] ? keyword : defaultScheme + keyword;</span> <span class="cstat-no" title="statement not covered" > const node = $('<a />').html(keyword).attr('href', link)[0];</span> <span class="cstat-no" title="statement not covered" > this.lastWordRange.insertNode(node);</span> <span class="cstat-no" title="statement not covered" > this.lastWordRange = null;</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.focus');</span> } } handleKeydown(e) { <span class="missing-if-branch" title="if path not taken" >I</span>if (lists.contains([key.code.ENTER, key.code.SPACE], e.keyCode)) { <span class="cstat-no" title="statement not covered" > const wordRange = this.context.invoke('editor.createRange').getWordRange();</span> <span class="cstat-no" title="statement not covered" > this.lastWordRange = wordRange;</span> } } handleKeyup(e) { <span class="missing-if-branch" title="if path not taken" >I</span>if (lists.contains([key.code.ENTER, key.code.SPACE], e.keyCode)) { <span class="cstat-no" title="statement not covered" > this.replace();</span> } } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/AirPopover.js.html000064400000023546151677271550020726 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/AirPopover.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/js/base/module/</a> AirPopover.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">50% </span> <span class="quiet">Statements</span> <span class='fraction'>19/38</span> </div> <div class='fl pad1y space-right2'> <span class="strong">7.14% </span> <span class="quiet">Branches</span> <span class='fraction'>1/14</span> </div> <div class='fl pad1y space-right2'> <span class="strong">30% </span> <span class="quiet">Functions</span> <span class='fraction'>3/10</span> </div> <div class='fl pad1y space-right2'> <span class="strong">50% </span> <span class="quiet">Lines</span> <span class='fraction'>19/38</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</td><td class="line-coverage quiet"><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-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-yes">1×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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-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-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-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">79×</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-no"> </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-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-yes">1×</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-yes">1×</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-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-neutral"> </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-yes">1×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import env from '../core/env'; import func from '../core/func'; import lists from '../core/lists'; import dom from '../core/dom'; const AIR_MODE_POPOVER_X_OFFSET = 20; export default class AirPopover { constructor(context) { this.context = context; this.ui = $.summernote.ui; this.options = context.options; this.events = { 'summernote.keyup summernote.mouseup summernote.scroll': <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.update();</span> }, 'summernote.disable summernote.change summernote.dialog.shown': <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.hide();</span> }, 'summernote.focusout': <span class="fstat-no" title="function not covered" >(we, e)</span> => { // [workaround] Firefox doesn't support relatedTarget on focusout // - Ignore hide action on focus out in FF. <span class="cstat-no" title="statement not covered" > if (env.isFF) {</span> <span class="cstat-no" title="statement not covered" > return;</span> } <span class="cstat-no" title="statement not covered" > if (!e.relatedTarget || !dom.ancestor(e.relatedTarget, func.eq(this.$popover[0]))) {</span> <span class="cstat-no" title="statement not covered" > this.hide();</span> } } }; } shouldInitialize() { return this.options.airMode && <span class="branch-1 cbranch-no" title="branch not covered" >!lists.isEmpty(this.options.popover.air);</span> } <span class="fstat-no" title="function not covered" > initialize() {</span> <span class="cstat-no" title="statement not covered" > this.$popover = this.ui.popover({</span> className: 'note-air-popover' }).render().appendTo(this.options.container); <span class="cstat-no" title="statement not covered" > const $content = this.$popover.find('.popover-content');</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('buttons.build', $content, this.options.popover.air);</span> } <span class="fstat-no" title="function not covered" > destroy() {</span> <span class="cstat-no" title="statement not covered" > this.$popover.remove();</span> } <span class="fstat-no" title="function not covered" > update() {</span> <span class="cstat-no" title="statement not covered" > const styleInfo = this.context.invoke('editor.currentStyle');</span> <span class="cstat-no" title="statement not covered" > if (styleInfo.range && !styleInfo.range.isCollapsed()) {</span> <span class="cstat-no" title="statement not covered" > const rect = lists.last(styleInfo.range.getClientRects());</span> <span class="cstat-no" title="statement not covered" > if (rect) {</span> <span class="cstat-no" title="statement not covered" > const bnd = func.rect2bnd(rect);</span> <span class="cstat-no" title="statement not covered" > this.$popover.css({</span> display: 'block', left: Math.max(bnd.left + bnd.width / 2, 0) - AIR_MODE_POPOVER_X_OFFSET, top: bnd.top + bnd.height }); <span class="cstat-no" title="statement not covered" > this.context.invoke('buttons.updateCurrentStyle', this.$popover);</span> } } else { <span class="cstat-no" title="statement not covered" > this.hide();</span> } } <span class="fstat-no" title="function not covered" > hide() {</span> <span class="cstat-no" title="statement not covered" > this.$popover.hide();</span> } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/Clipboard.js.html000064400000011765151677271550020537 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/Clipboard.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/js/base/module/</a> Clipboard.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">60% </span> <span class="quiet">Statements</span> <span class='fraction'>9/15</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/9</span> </div> <div class='fl pad1y space-right2'> <span class="strong">75% </span> <span class="quiet">Functions</span> <span class='fraction'>3/4</span> </div> <div class='fl pad1y space-right2'> <span class="strong">60% </span> <span class="quiet">Lines</span> <span class='fraction'>9/15</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</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">77×</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-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-no"> </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></td><td class="text"><pre class="prettyprint lang-js">import lists from '../core/lists'; export default class Clipboard { constructor(context) { this.context = context; this.$editable = context.layoutInfo.editable; } initialize() { this.$editable.on('paste', this.pasteByEvent.bind(this)); } /** * paste by clipboard event * * @param {Event} event */ <span class="fstat-no" title="function not covered" > pasteByEvent(event)</span> { <span class="cstat-no" title="statement not covered" > const clipboardData = event.originalEvent.clipboardData;</span> <span class="cstat-no" title="statement not covered" > if (clipboardData && clipboardData.items && clipboardData.items.length) {</span> <span class="cstat-no" title="statement not covered" > const item = lists.head(clipboardData.items);</span> <span class="cstat-no" title="statement not covered" > if (item.kind === 'file' && item.type.indexOf('image/') !== -1) {</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.insertImagesOrCallback', [item.getAsFile()]);</span> } <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.afterCommand');</span> } } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/Editor.js.html000064400000247237151677271550020073 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/Editor.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/js/base/module/</a> Editor.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">70.78% </span> <span class="quiet">Statements</span> <span class='fraction'>281/397</span> </div> <div class='fl pad1y space-right2'> <span class="strong">43.43% </span> <span class="quiet">Branches</span> <span class='fraction'>76/175</span> </div> <div class='fl pad1y space-right2'> <span class="strong">64.29% </span> <span class="quiet">Functions</span> <span class='fraction'>54/84</span> </div> <div class='fl pad1y space-right2'> <span class="strong">71.43% </span> <span class="quiet">Lines</span> <span class='fraction'>280/392</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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862</td><td class="line-coverage quiet"><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-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-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-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-yes">1×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">1001×</span> <span class="cline-any cline-yes">1001×</span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1001×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-yes">77×</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">77×</span> <span class="cline-any cline-yes">462×</span> <span class="cline-any cline-yes">462×</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-yes">462×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">2×</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">77×</span> <span class="cline-any cline-yes">2×</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-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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</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">77×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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">77×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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">77×</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-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">77×</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> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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-yes">4×</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">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</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">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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-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">77×</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-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-yes">77×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-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-yes">77×</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-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> <span class="cline-any cline-yes">77×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-yes">78×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-yes">1×</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-no"> </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-no"> </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-yes">23×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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-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-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-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">13×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">20×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-yes">77×</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">2×</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-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-yes">1×</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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">1×</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-yes">1×</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-yes">1×</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-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-yes">1×</span> <span class="cline-any cline-yes">12×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">12×</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-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-yes">12×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">9×</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">13×</span> <span class="cline-any cline-yes">13×</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-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-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-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-yes">1×</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-yes">1×</span> <span class="cline-any cline-yes">58×</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-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> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">215×</span> <span class="cline-any cline-yes">215×</span> <span class="cline-any cline-yes">38×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">215×</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-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-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-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-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-yes">1×</span> <span class="cline-any cline-yes">49×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">49×</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">49×</span> <span class="cline-any cline-yes">49×</span> <span class="cline-any cline-yes">49×</span> <span class="cline-any cline-yes">35×</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-yes">1×</span> <span class="cline-any cline-no"> </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-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-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-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-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> <span class="cline-any cline-yes">1541×</span> <span class="cline-any cline-yes">1540×</span> <span class="cline-any cline-yes">33×</span> <span class="cline-any cline-yes">33×</span> <span class="cline-any cline-yes">33×</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">2×</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-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-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-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> <span class="cline-any cline-yes">1×</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-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-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-no"> </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-neutral"> </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-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-no"> </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-neutral"> </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-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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-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-yes">1×</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-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-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-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-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-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-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-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-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-no"> </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-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-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-no"> </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-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-yes">1×</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-yes">1×</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-yes">1×</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-yes">1×</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-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-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-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-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-yes">1×</span> <span class="cline-any cline-yes">115×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">62×</span> <span class="cline-any cline-yes">62×</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-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-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">49×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import env from '../core/env'; import key from '../core/key'; import func from '../core/func'; import lists from '../core/lists'; import dom from '../core/dom'; import range from '../core/range'; import { readFileAsDataURL, createImage } from '../core/async'; import History from '../editing/History'; import Style from '../editing/Style'; import Typing from '../editing/Typing'; import Table from '../editing/Table'; import Bullet from '../editing/Bullet'; const KEY_BOGUS = 'bogus'; /** * @class Editor */ export default class Editor { constructor(context) { this.context = context; this.$note = context.layoutInfo.note; this.$editor = context.layoutInfo.editor; this.$editable = context.layoutInfo.editable; this.options = context.options; this.lang = this.options.langInfo; this.editable = this.$editable[0]; this.lastRange = null; this.style = new Style(); this.table = new Table(); this.typing = new Typing(); this.bullet = new Bullet(); this.history = new History(this.$editable); this.context.memo('help.undo', this.lang.help.undo); this.context.memo('help.redo', this.lang.help.redo); this.context.memo('help.tab', this.lang.help.tab); this.context.memo('help.untab', this.lang.help.untab); this.context.memo('help.insertParagraph', this.lang.help.insertParagraph); this.context.memo('help.insertOrderedList', this.lang.help.insertOrderedList); this.context.memo('help.insertUnorderedList', this.lang.help.insertUnorderedList); this.context.memo('help.indent', this.lang.help.indent); this.context.memo('help.outdent', this.lang.help.outdent); this.context.memo('help.formatPara', this.lang.help.formatPara); this.context.memo('help.insertHorizontalRule', this.lang.help.insertHorizontalRule); this.context.memo('help.fontName', this.lang.help.fontName); // native commands(with execCommand), generate function for execCommand const commands = [ 'bold', 'italic', 'underline', 'strikethrough', 'superscript', 'subscript', 'justifyLeft', 'justifyCenter', 'justifyRight', 'justifyFull', 'formatBlock', 'removeFormat', 'backColor' ]; for (let idx = 0, len = commands.length; idx < len; idx++) { this[commands[idx]] = ((sCmd) => { return (value) => { this.beforeCommand(); document.execCommand(sCmd, false, value); this.afterCommand(true); }; })(commands[idx]); this.context.memo('help.' + commands[idx], this.lang.help[commands[idx]]); } this.fontName = this.wrapCommand(<span class="fstat-no" title="function not covered" >(value)</span> => { <span class="cstat-no" title="statement not covered" > return this.fontStyling('font-family', "\'" + value + "\'");</span> }); this.fontSize = this.wrapCommand((value) => { return this.fontStyling('font-size', value + 'px'); }); for (let idx = 1; idx <= 6; idx++) { this['formatH' + idx] = ((idx) => { return <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.formatBlock('H' + idx);</span> }; })(idx); this.context.memo('help.formatH' + idx, this.lang.help['formatH' + idx]); }; this.insertParagraph = this.wrapCommand(() => { this.typing.insertParagraph(this.editable); }); this.insertOrderedList = this.wrapCommand(() => { this.bullet.insertOrderedList(this.editable); }); this.insertUnorderedList = this.wrapCommand(() => { this.bullet.insertUnorderedList(this.editable); }); this.indent = this.wrapCommand(() => { this.bullet.indent(this.editable); }); this.outdent = this.wrapCommand(() => { this.bullet.outdent(this.editable); }); /** * insertNode * insert node * @param {Node} node */ this.insertNode = this.wrapCommand((node) => { if (this.isLimited($(node).text().length)) { return; } const rng = this.createRange(); rng.insertNode(node); range.createFromNodeAfter(node).select(); }); /** * insert text * @param {String} text */ this.insertText = this.wrapCommand((text) => { if (this.isLimited(text.length)) { return; } const rng = this.createRange(); const textNode = rng.insertNode(dom.createText(text)); range.create(textNode, dom.nodeLength(textNode)).select(); }); /** * paste HTML * @param {String} markup */ this.pasteHTML = this.wrapCommand((markup) => { if (this.isLimited(markup.length)) { return; } const contents = this.createRange().pasteHTML(markup); range.createFromNodeAfter(lists.last(contents)).select(); }); /** * formatBlock * * @param {String} tagName */ this.formatBlock = this.wrapCommand((tagName, $target) => { const onApplyCustomStyle = this.options.callbacks.onApplyCustomStyle; <span class="missing-if-branch" title="if path not taken" >I</span>if (onApplyCustomStyle) { <span class="cstat-no" title="statement not covered" > onApplyCustomStyle.call(this, $target, this.context, this.onFormatBlock);</span> } else { this.onFormatBlock(tagName, $target); } }); /** * insert horizontal rule */ this.insertHorizontalRule = this.wrapCommand(() => { const hrNode = this.createRange().insertNode(dom.create('HR')); <span class="missing-if-branch" title="else path not taken" >E</span>if (hrNode.nextSibling) { range.create(hrNode.nextSibling, 0).normalize().select(); } }); /** * lineHeight * @param {String} value */ this.lineHeight = this.wrapCommand(<span class="fstat-no" title="function not covered" >(value)</span> => { <span class="cstat-no" title="statement not covered" > this.style.stylePara(this.createRange(), {</span> lineHeight: value }); }); /** * create link (command) * * @param {Object} linkInfo */ this.createLink = this.wrapCommand((linkInfo) => { let linkUrl = linkInfo.url; const linkText = linkInfo.text; const isNewWindow = linkInfo.isNewWindow; let rng = linkInfo.range || this.createRange(); const isTextChanged = rng.toString() !== linkText; // handle spaced urls from input <span class="missing-if-branch" title="else path not taken" >E</span>if (typeof linkUrl === 'string') { linkUrl = linkUrl.trim(); } <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.onCreateLink) { <span class="cstat-no" title="statement not covered" > linkUrl = this.options.onCreateLink(linkUrl);</span> } else { // if url doesn't match an URL schema, set http:// as default linkUrl = /^[A-Za-z][A-Za-z0-9+-.]*\:[\/\/]?/.test(linkUrl) ? linkUrl : <span class="branch-1 cbranch-no" title="branch not covered" >'http://' + linkUrl;</span> } let anchors = []; <span class="missing-if-branch" title="else path not taken" >E</span>if (isTextChanged) { rng = rng.deleteContents(); const anchor = rng.insertNode($('<A>' + linkText + '</A>')[0]); anchors.push(anchor); } else { <span class="cstat-no" title="statement not covered" > anchors = this.style.styleNodes(rng, {</span> nodeName: 'A', expandClosestSibling: true, onlyPartialContains: true }); } $.each(anchors, (idx, anchor) => { $(anchor).attr('href', linkUrl); if (isNewWindow) { $(anchor).attr('target', '_blank'); } else { $(anchor).removeAttr('target'); } }); const startRange = range.createFromNodeBefore(lists.head(anchors)); const startPoint = startRange.getStartPoint(); const endRange = range.createFromNodeAfter(lists.last(anchors)); const endPoint = endRange.getEndPoint(); range.create( startPoint.node, startPoint.offset, endPoint.node, endPoint.offset ).select(); }); /** * setting color * * @param {Object} sObjColor color code * @param {String} sObjColor.foreColor foreground color * @param {String} sObjColor.backColor background color */ this.color = this.wrapCommand((colorInfo) => { const foreColor = colorInfo.foreColor; const backColor = colorInfo.backColor; <span class="missing-if-branch" title="if path not taken" >I</span>if (foreColor) { <span class="cstat-no" title="statement not covered" >document.execCommand('foreColor', false, foreColor); </span>} <span class="missing-if-branch" title="else path not taken" >E</span>if (backColor) { document.execCommand('backColor', false, backColor); } }); /** * Set foreground color * * @param {String} colorCode foreground color code */ this.foreColor = this.wrapCommand((colorInfo) => { document.execCommand('styleWithCSS', false, true); document.execCommand('foreColor', false, colorInfo); }); /** * insert Table * * @param {String} dimension of table (ex : "5x5") */ this.insertTable = this.wrapCommand((dim) => { const dimension = dim.split('x'); const rng = this.createRange().deleteContents(); rng.insertNode(this.table.createTable(dimension[0], dimension[1], this.options)); }); /** * remove media object and Figure Elements if media object is img with Figure. */ this.removeMedia = this.wrapCommand(<span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > let $target = $(this.restoreTarget()).parent();</span> <span class="cstat-no" title="statement not covered" > if ($target.parent('figure').length) {</span> <span class="cstat-no" title="statement not covered" > $target.parent('figure').remove();</span> } else { <span class="cstat-no" title="statement not covered" > $target = $(this.restoreTarget()).detach();</span> } <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('media.delete', $target, this.$editable);</span> }); /** * float me * * @param {String} value */ this.floatMe = this.wrapCommand(<span class="fstat-no" title="function not covered" >(value)</span> => { <span class="cstat-no" title="statement not covered" > const $target = $(this.restoreTarget());</span> <span class="cstat-no" title="statement not covered" > $target.toggleClass('note-float-left', value === 'left');</span> <span class="cstat-no" title="statement not covered" > $target.toggleClass('note-float-right', value === 'right');</span> <span class="cstat-no" title="statement not covered" > $target.css('float', value);</span> }); /** * resize overlay element * @param {String} value */ this.resize = this.wrapCommand(<span class="fstat-no" title="function not covered" >(value)</span> => { <span class="cstat-no" title="statement not covered" > const $target = $(this.restoreTarget());</span> <span class="cstat-no" title="statement not covered" > $target.css({</span> width: value * 100 + '%', height: '' }); }); } initialize() { // bind custom events this.$editable.on('keydown', (event) => { <span class="missing-if-branch" title="if path not taken" >I</span>if (event.keyCode === key.code.ENTER) { <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('enter', event);</span> } this.context.triggerEvent('keydown', event); <span class="missing-if-branch" title="else path not taken" >E</span>if (!event.isDefaultPrevented()) { <span class="missing-if-branch" title="else path not taken" >E</span>if (this.options.shortcuts) { this.handleKeyMap(event); } else { <span class="cstat-no" title="statement not covered" > this.preventDefaultEditableShortCuts(event);</span> } } <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isLimited(1, event)) { <span class="cstat-no" title="statement not covered" > return false;</span> } }).on('keyup', (event) => { this.context.triggerEvent('keyup', event); }).on('focus', (event) => { this.context.triggerEvent('focus', event); }).on('blur', (event) => { this.context.triggerEvent('blur', event); }).on('mousedown', (event) => { this.context.triggerEvent('mousedown', event); }).on('mouseup', (event) => { this.context.triggerEvent('mouseup', event); }).on('scroll', (event) => { this.context.triggerEvent('scroll', event); }).on('paste', <span class="fstat-no" title="function not covered" >(event)</span> => { <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('paste', event);</span> }); // init content before set event this.$editable.html(dom.html(this.$note) || dom.emptyPara); this.$editable.on(env.inputEventName, func.debounce(() => { this.context.triggerEvent('change', this.$editable.html()); }, 100)); this.$editor.on('focusin', (event) => { this.context.triggerEvent('focusin', event); }).on('focusout', (event) => { this.context.triggerEvent('focusout', event); }); <span class="missing-if-branch" title="else path not taken" >E</span>if (!this.options.airMode) { <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.width) { <span class="cstat-no" title="statement not covered" > this.$editor.outerWidth(this.options.width);</span> } <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.height) { <span class="cstat-no" title="statement not covered" > this.$editable.outerHeight(this.options.height);</span> } <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.maxHeight) { <span class="cstat-no" title="statement not covered" > this.$editable.css('max-height', this.options.maxHeight);</span> } <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.minHeight) { <span class="cstat-no" title="statement not covered" > this.$editable.css('min-height', this.options.minHeight);</span> } } this.history.recordUndo(); } destroy() { this.$editable.off(); } handleKeyMap(event) { const keyMap = this.options.keyMap[env.isMac ? 'mac' : <span class="branch-1 cbranch-no" title="branch not covered" >'pc']</span>; const keys = []; <span class="missing-if-branch" title="if path not taken" >I</span>if (event.metaKey) { <span class="cstat-no" title="statement not covered" >keys.push('CMD'); </span>} <span class="missing-if-branch" title="if path not taken" >I</span>if (event.ctrlKey && <span class="branch-1 cbranch-no" title="branch not covered" >!event.altKey)</span> { <span class="cstat-no" title="statement not covered" >keys.push('CTRL'); </span>} <span class="missing-if-branch" title="if path not taken" >I</span>if (event.shiftKey) { <span class="cstat-no" title="statement not covered" >keys.push('SHIFT'); </span>} const keyName = key.nameFromCode[event.keyCode]; <span class="missing-if-branch" title="if path not taken" >I</span>if (keyName) { <span class="cstat-no" title="statement not covered" > keys.push(keyName);</span> } const eventName = keyMap[keys.join('+')]; <span class="missing-if-branch" title="if path not taken" >I</span>if (eventName) { <span class="cstat-no" title="statement not covered" > if (this.context.invoke(eventName) !== false) {</span> <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> } } else <span class="missing-if-branch" title="if path not taken" >I</span>if (key.isEdit(event.keyCode)) { <span class="cstat-no" title="statement not covered" > this.afterCommand();</span> } } <span class="fstat-no" title="function not covered" > preventDefaultEditableShortCuts(event)</span> { // B(Bold, 66) / I(Italic, 73) / U(Underline, 85) <span class="cstat-no" title="statement not covered" > if ((event.ctrlKey || event.metaKey) &&</span> lists.contains([66, 73, 85], event.keyCode)) { <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> } } isLimited(pad, event) { pad = pad || <span class="branch-1 cbranch-no" title="branch not covered" >0;</span> if (typeof event !== 'undefined') { <span class="missing-if-branch" title="if path not taken" >I</span>if (key.isMove(event.keyCode) || (event.ctrlKey || event.metaKey) || lists.contains([key.code.BACKSPACE, key.code.DELETE], event.keyCode)) { <span class="cstat-no" title="statement not covered" > return false;</span> } } if (this.options.maxTextLength > 0) { <span class="missing-if-branch" title="else path not taken" >E</span>if ((this.$editable.text().length + pad) >= this.options.maxTextLength) { return true; } } return false; } /** * create range * @return {WrappedRange} */ createRange() { this.focus(); return range.create(this.editable); } /** * saveRange * * save current range * * @param {Boolean} [thenCollapse=false] */ <span class="fstat-no" title="function not covered" > saveRange(thenCollapse)</span> { <span class="cstat-no" title="statement not covered" > this.lastRange = this.createRange();</span> <span class="cstat-no" title="statement not covered" > if (thenCollapse) {</span> <span class="cstat-no" title="statement not covered" > this.lastRange.collapse().select();</span> } } /** * restoreRange * * restore lately range */ <span class="fstat-no" title="function not covered" > restoreRange() {</span> <span class="cstat-no" title="statement not covered" > if (this.lastRange) {</span> <span class="cstat-no" title="statement not covered" > this.lastRange.select();</span> <span class="cstat-no" title="statement not covered" > this.focus();</span> } } <span class="fstat-no" title="function not covered" > saveTarget(node)</span> { <span class="cstat-no" title="statement not covered" > this.$editable.data('target', node);</span> } clearTarget() { this.$editable.removeData('target'); } <span class="fstat-no" title="function not covered" > restoreTarget() {</span> <span class="cstat-no" title="statement not covered" > return this.$editable.data('target');</span> } /** * currentStyle * * current style * @return {Object|Boolean} unfocus */ currentStyle() { let rng = range.create(); if (rng) { rng = rng.normalize(); } return rng ? this.style.current(rng) : this.style.fromNode(this.$editable); } /** * style from node * * @param {jQuery} $node * @return {Object} */ <span class="fstat-no" title="function not covered" > styleFromNode($node)</span> { <span class="cstat-no" title="statement not covered" > return this.style.fromNode($node);</span> } /** * undo */ undo() { this.context.triggerEvent('before.command', this.$editable.html()); this.history.undo(); this.context.triggerEvent('change', this.$editable.html()); } /** * redo */ redo() { this.context.triggerEvent('before.command', this.$editable.html()); this.history.redo(); this.context.triggerEvent('change', this.$editable.html()); } /** * before command */ beforeCommand() { this.context.triggerEvent('before.command', this.$editable.html()); // keep focus on editable before command execution this.focus(); } /** * after command * @param {Boolean} isPreventTrigger */ afterCommand(isPreventTrigger) { this.normalizeContent(); this.history.recordUndo(); if (!isPreventTrigger) { this.context.triggerEvent('change', this.$editable.html()); } } /** * handle tab key */ tab() { const rng = this.createRange(); <span class="missing-if-branch" title="if path not taken" >I</span>if (rng.isCollapsed() && rng.isOnCell()) { <span class="cstat-no" title="statement not covered" > this.table.tab(rng);</span> } else { <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.tabSize === 0) { <span class="cstat-no" title="statement not covered" > return false;</span> } <span class="missing-if-branch" title="else path not taken" >E</span>if (!this.isLimited(this.options.tabSize)) { this.beforeCommand(); this.typing.insertTab(rng, this.options.tabSize); this.afterCommand(); } } } /** * handle shift+tab key */ <span class="fstat-no" title="function not covered" > untab() {</span> <span class="cstat-no" title="statement not covered" > const rng = this.createRange();</span> <span class="cstat-no" title="statement not covered" > if (rng.isCollapsed() && rng.isOnCell()) {</span> <span class="cstat-no" title="statement not covered" > this.table.tab(rng, true);</span> } else { <span class="cstat-no" title="statement not covered" > if (this.options.tabSize === 0) {</span> <span class="cstat-no" title="statement not covered" > return false;</span> } } } /** * run given function between beforeCommand and afterCommand */ wrapCommand(fn) { return () => { this.beforeCommand(); fn.apply(this, arguments); this.afterCommand(); }; } /** * insert image * * @param {String} src * @param {String|Function} param * @return {Promise} */ insertImage(src, param) { return createImage(src, param).then(($image) => { this.beforeCommand(); <span class="missing-if-branch" title="if path not taken" >I</span>if (typeof param === 'function') { <span class="cstat-no" title="statement not covered" > param($image);</span> } else { <span class="missing-if-branch" title="else path not taken" >E</span>if (typeof param === 'string') { $image.attr('data-filename', param); } $image.css('width', Math.min(this.$editable.width(), $image.width())); } $image.show(); range.create(this.editable).insertNode($image[0]); range.createFromNodeAfter($image[0]).select(); this.afterCommand(); }).fail(<span class="fstat-no" title="function not covered" >(e)</span> => { <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('image.upload.error', e);</span> }); } /** * insertImages * @param {File[]} files */ <span class="fstat-no" title="function not covered" > insertImages(files)</span> { <span class="cstat-no" title="statement not covered" > $.each(files, <span class="fstat-no" title="function not covered" >(idx, file)</span> => {</span> <span class="cstat-no" title="statement not covered" > const filename = file.name;</span> <span class="cstat-no" title="statement not covered" > if (this.options.maximumImageFileSize && this.options.maximumImageFileSize < file.size) {</span> <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('image.upload.error', this.lang.image.maximumFileSizeError);</span> } else { <span class="cstat-no" title="statement not covered" > readFileAsDataURL(file).then(<span class="fstat-no" title="function not covered" >(dataURL)</span> => {</span> <span class="cstat-no" title="statement not covered" > return this.insertImage(dataURL, filename);</span> }).fail(<span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('image.upload.error');</span> }); } }); } /** * insertImagesOrCallback * @param {File[]} files */ <span class="fstat-no" title="function not covered" > insertImagesOrCallback(files)</span> { <span class="cstat-no" title="statement not covered" > const callbacks = this.options.callbacks;</span> // If onImageUpload this.options setted <span class="cstat-no" title="statement not covered" > if (callbacks.onImageUpload) {</span> <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('image.upload', files);</span> // else insert Image as dataURL } else { <span class="cstat-no" title="statement not covered" > this.insertImages(files);</span> } } /** * return selected plain text * @return {String} text */ <span class="fstat-no" title="function not covered" > getSelectedText() {</span> <span class="cstat-no" title="statement not covered" > let rng = this.createRange();</span> // if range on anchor, expand range with anchor <span class="cstat-no" title="statement not covered" > if (rng.isOnAnchor()) {</span> <span class="cstat-no" title="statement not covered" > rng = range.createFromNode(dom.ancestor(rng.sc, dom.isAnchor));</span> } <span class="cstat-no" title="statement not covered" > return rng.toString();</span> } onFormatBlock(tagName, $target) { // [workaround] for MSIE, IE need `<` tagName = env.isMSIE ? <span class="branch-0 cbranch-no" title="branch not covered" >'<' + tagName + '>' </span>: tagName; document.execCommand('FormatBlock', false, tagName); // support custom class if ($target && $target.length) { const className = $target[0].className || <span class="branch-1 cbranch-no" title="branch not covered" >'';</span> <span class="missing-if-branch" title="else path not taken" >E</span>if (className) { const currentRange = this.createRange(); const $parent = $([currentRange.sc, currentRange.ec]).closest(tagName); $parent.addClass(className); } } } <span class="fstat-no" title="function not covered" > formatPara() {</span> <span class="cstat-no" title="statement not covered" > this.formatBlock('P');</span> } fontStyling(target, value) { const rng = this.createRange(); <span class="missing-if-branch" title="else path not taken" >E</span>if (rng) { const spans = this.style.styleNodes(rng); $(spans).css(target, value); // [workaround] added styled bogus span for style // - also bogus character needed for cursor position <span class="missing-if-branch" title="else path not taken" >E</span>if (rng.isCollapsed()) { const firstSpan = lists.head(spans); <span class="missing-if-branch" title="else path not taken" >E</span>if (firstSpan && !dom.nodeLength(firstSpan)) { firstSpan.innerHTML = dom.ZERO_WIDTH_NBSP_CHAR; range.createFromNodeAfter(firstSpan.firstChild).select(); this.$editable.data(KEY_BOGUS, firstSpan); } } } } /** * unlink * * @type command */ <span class="fstat-no" title="function not covered" > unlink() {</span> <span class="cstat-no" title="statement not covered" > let rng = this.createRange();</span> <span class="cstat-no" title="statement not covered" > if (rng.isOnAnchor()) {</span> <span class="cstat-no" title="statement not covered" > const anchor = dom.ancestor(rng.sc, dom.isAnchor);</span> <span class="cstat-no" title="statement not covered" > rng = range.createFromNode(anchor);</span> <span class="cstat-no" title="statement not covered" > rng.select();</span> <span class="cstat-no" title="statement not covered" > this.beforeCommand();</span> <span class="cstat-no" title="statement not covered" > document.execCommand('unlink');</span> <span class="cstat-no" title="statement not covered" > this.afterCommand();</span> } } /** * returns link info * * @return {Object} * @return {WrappedRange} return.range * @return {String} return.text * @return {Boolean} [return.isNewWindow=true] * @return {String} [return.url=""] */ <span class="fstat-no" title="function not covered" > getLinkInfo() {</span> <span class="cstat-no" title="statement not covered" > const rng = this.createRange().expand(dom.isAnchor);</span> // Get the first anchor on range(for edit). <span class="cstat-no" title="statement not covered" > const $anchor = $(lists.head(rng.nodes(dom.isAnchor)));</span> <span class="cstat-no" title="statement not covered" > const linkInfo = {</span> range: rng, text: rng.toString(), url: $anchor.length ? $anchor.attr('href') : '' }; // Define isNewWindow when anchor exists. <span class="cstat-no" title="statement not covered" > if ($anchor.length) {</span> <span class="cstat-no" title="statement not covered" > linkInfo.isNewWindow = $anchor.attr('target') === '_blank';</span> } <span class="cstat-no" title="statement not covered" > return linkInfo;</span> } <span class="fstat-no" title="function not covered" > addRow(position)</span> { <span class="cstat-no" title="statement not covered" > const rng = this.createRange(this.$editable);</span> <span class="cstat-no" title="statement not covered" > if (rng.isCollapsed() && rng.isOnCell()) {</span> <span class="cstat-no" title="statement not covered" > this.beforeCommand();</span> <span class="cstat-no" title="statement not covered" > this.table.addRow(rng, position);</span> <span class="cstat-no" title="statement not covered" > this.afterCommand();</span> } } <span class="fstat-no" title="function not covered" > addCol(position)</span> { <span class="cstat-no" title="statement not covered" > const rng = this.createRange(this.$editable);</span> <span class="cstat-no" title="statement not covered" > if (rng.isCollapsed() && rng.isOnCell()) {</span> <span class="cstat-no" title="statement not covered" > this.beforeCommand();</span> <span class="cstat-no" title="statement not covered" > this.table.addCol(rng, position);</span> <span class="cstat-no" title="statement not covered" > this.afterCommand();</span> } } <span class="fstat-no" title="function not covered" > deleteRow() {</span> <span class="cstat-no" title="statement not covered" > const rng = this.createRange(this.$editable);</span> <span class="cstat-no" title="statement not covered" > if (rng.isCollapsed() && rng.isOnCell()) {</span> <span class="cstat-no" title="statement not covered" > this.beforeCommand();</span> <span class="cstat-no" title="statement not covered" > this.table.deleteRow(rng);</span> <span class="cstat-no" title="statement not covered" > this.afterCommand();</span> } } <span class="fstat-no" title="function not covered" > deleteCol() {</span> <span class="cstat-no" title="statement not covered" > const rng = this.createRange(this.$editable);</span> <span class="cstat-no" title="statement not covered" > if (rng.isCollapsed() && rng.isOnCell()) {</span> <span class="cstat-no" title="statement not covered" > this.beforeCommand();</span> <span class="cstat-no" title="statement not covered" > this.table.deleteCol(rng);</span> <span class="cstat-no" title="statement not covered" > this.afterCommand();</span> } } <span class="fstat-no" title="function not covered" > deleteTable() {</span> <span class="cstat-no" title="statement not covered" > const rng = this.createRange(this.$editable);</span> <span class="cstat-no" title="statement not covered" > if (rng.isCollapsed() && rng.isOnCell()) {</span> <span class="cstat-no" title="statement not covered" > this.beforeCommand();</span> <span class="cstat-no" title="statement not covered" > this.table.deleteTable(rng);</span> <span class="cstat-no" title="statement not covered" > this.afterCommand();</span> } } /** * @param {Position} pos * @param {jQuery} $target - target element * @param {Boolean} [bKeepRatio] - keep ratio */ <span class="fstat-no" title="function not covered" > resizeTo(pos, $target, bKeepRatio)</span> { <span class="cstat-no" title="statement not covered" > let imageSize;</span> <span class="cstat-no" title="statement not covered" > if (bKeepRatio) {</span> <span class="cstat-no" title="statement not covered" > const newRatio = pos.y / pos.x;</span> <span class="cstat-no" title="statement not covered" > const ratio = $target.data('ratio');</span> <span class="cstat-no" title="statement not covered" > imageSize = {</span> width: ratio > newRatio ? pos.x : pos.y / ratio, height: ratio > newRatio ? pos.x * ratio : pos.y }; } else { <span class="cstat-no" title="statement not covered" > imageSize = {</span> width: pos.x, height: pos.y }; } <span class="cstat-no" title="statement not covered" > $target.css(imageSize);</span> } /** * returns whether editable area has focus or not. */ hasFocus() { return this.$editable.is(':focus'); } /** * set focus */ focus() { // [workaround] Screen will move when page is scolled in IE. // - do focus when not focused <span class="missing-if-branch" title="else path not taken" >E</span>if (!this.hasFocus()) { this.$editable.focus(); } } /** * returns whether contents is empty or not. * @return {Boolean} */ isEmpty() { return dom.isEmpty(this.$editable[0]) || dom.emptyPara === this.$editable.html(); } /** * Removes all contents and restores the editable instance to an _emptyPara_. */ empty() { this.context.invoke('code', dom.emptyPara); } /** * normalize content */ normalizeContent() { this.$editable[0].normalize(); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/index.html000064400000042577151677271550017341 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/</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> src/js/base/module/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">66.01% </span> <span class="quiet">Statements</span> <span class='fraction'>1043/1580</span> </div> <div class='fl pad1y space-right2'> <span class="strong">38.15% </span> <span class="quiet">Branches</span> <span class='fraction'>206/540</span> </div> <div class='fl pad1y space-right2'> <span class="strong">63.85% </span> <span class="quiet">Functions</span> <span class='fraction'>242/379</span> </div> <div class='fl pad1y space-right2'> <span class="strong">66.16% </span> <span class="quiet">Lines</span> <span class='fraction'>1042/1575</span> </div> </div> </div> <div class='status-line medium'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file medium" data-value="AirPopover.js"><a href="AirPopover.js.html">AirPopover.js</a></td> <td data-value="50" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 50%;"></div><div class="cover-empty" style="width:50%;"></div></div></td> <td data-value="50" class="pct medium">50%</td> <td data-value="38" class="abs medium">19/38</td> <td data-value="7.14" class="pct low">7.14%</td> <td data-value="14" class="abs low">1/14</td> <td data-value="30" class="pct low">30%</td> <td data-value="10" class="abs low">3/10</td> <td data-value="50" class="pct medium">50%</td> <td data-value="38" class="abs medium">19/38</td> </tr> <tr> <td class="file medium" data-value="AutoLink.js"><a href="AutoLink.js.html">AutoLink.js</a></td> <td data-value="62.86" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 62%;"></div><div class="cover-empty" style="width:38%;"></div></div></td> <td data-value="62.86" class="pct medium">62.86%</td> <td data-value="35" class="abs medium">22/35</td> <td data-value="20" class="pct low">20%</td> <td data-value="15" class="abs low">3/15</td> <td data-value="88.89" class="pct high">88.89%</td> <td data-value="9" class="abs high">8/9</td> <td data-value="62.86" class="pct medium">62.86%</td> <td data-value="35" class="abs medium">22/35</td> </tr> <tr> <td class="file high" data-value="AutoSync.js"><a href="AutoSync.js.html">AutoSync.js</a></td> <td data-value="88.89" class="pic high"><div class="chart"><div class="cover-fill" style="width: 88%;"></div><div class="cover-empty" style="width:12%;"></div></div></td> <td data-value="88.89" class="pct high">88.89%</td> <td data-value="9" class="abs high">8/9</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="75" class="pct medium">75%</td> <td data-value="4" class="abs medium">3/4</td> <td data-value="88.89" class="pct high">88.89%</td> <td data-value="9" class="abs high">8/9</td> </tr> <tr> <td class="file high" data-value="Buttons.js"><a href="Buttons.js.html">Buttons.js</a></td> <td data-value="88.48" class="pic high"><div class="chart"><div class="cover-fill" style="width: 88%;"></div><div class="cover-empty" style="width:12%;"></div></div></td> <td data-value="88.48" class="pct high">88.48%</td> <td data-value="243" class="abs high">215/243</td> <td data-value="54.93" class="pct medium">54.93%</td> <td data-value="71" class="abs medium">39/71</td> <td data-value="91.03" class="pct high">91.03%</td> <td data-value="78" class="abs high">71/78</td> <td data-value="88.48" class="pct high">88.48%</td> <td data-value="243" class="abs high">215/243</td> </tr> <tr> <td class="file medium" data-value="Clipboard.js"><a href="Clipboard.js.html">Clipboard.js</a></td> <td data-value="60" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 60%;"></div><div class="cover-empty" style="width:40%;"></div></div></td> <td data-value="60" class="pct medium">60%</td> <td data-value="15" class="abs medium">9/15</td> <td data-value="0" class="pct low">0%</td> <td data-value="9" class="abs low">0/9</td> <td data-value="75" class="pct medium">75%</td> <td data-value="4" class="abs medium">3/4</td> <td data-value="60" class="pct medium">60%</td> <td data-value="15" class="abs medium">9/15</td> </tr> <tr> <td class="file medium" data-value="Codeview.js"><a href="Codeview.js.html">Codeview.js</a></td> <td data-value="66.67" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 66%;"></div><div class="cover-empty" style="width:34%;"></div></div></td> <td data-value="66.67" class="pct medium">66.67%</td> <td data-value="63" class="abs medium">42/63</td> <td data-value="45.83" class="pct low">45.83%</td> <td data-value="24" class="abs low">11/24</td> <td data-value="66.67" class="pct medium">66.67%</td> <td data-value="12" class="abs medium">8/12</td> <td data-value="66.67" class="pct medium">66.67%</td> <td data-value="63" class="abs medium">42/63</td> </tr> <tr> <td class="file low" data-value="Dropzone.js"><a href="Dropzone.js.html">Dropzone.js</a></td> <td data-value="46.67" class="pic low"><div class="chart"><div class="cover-fill" style="width: 46%;"></div><div class="cover-empty" style="width:54%;"></div></div></td> <td data-value="46.67" class="pct low">46.67%</td> <td data-value="60" class="abs low">28/60</td> <td data-value="5.56" class="pct low">5.56%</td> <td data-value="18" class="abs low">1/18</td> <td data-value="40" class="pct low">40%</td> <td data-value="15" class="abs low">6/15</td> <td data-value="46.67" class="pct low">46.67%</td> <td data-value="60" class="abs low">28/60</td> </tr> <tr> <td class="file medium" data-value="Editor.js"><a href="Editor.js.html">Editor.js</a></td> <td data-value="70.78" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 70%;"></div><div class="cover-empty" style="width:30%;"></div></div></td> <td data-value="70.78" class="pct medium">70.78%</td> <td data-value="397" class="abs medium">281/397</td> <td data-value="43.43" class="pct low">43.43%</td> <td data-value="175" class="abs low">76/175</td> <td data-value="64.29" class="pct medium">64.29%</td> <td data-value="84" class="abs medium">54/84</td> <td data-value="71.43" class="pct medium">71.43%</td> <td data-value="392" class="abs medium">280/392</td> </tr> <tr> <td class="file high" data-value="Fullscreen.js"><a href="Fullscreen.js.html">Fullscreen.js</a></td> <td data-value="96.67" class="pic high"><div class="chart"><div class="cover-fill" style="width: 96%;"></div><div class="cover-empty" style="width:4%;"></div></div></td> <td data-value="96.67" class="pct high">96.67%</td> <td data-value="30" class="abs high">29/30</td> <td data-value="75" class="pct medium">75%</td> <td data-value="4" class="abs medium">3/4</td> <td data-value="100" class="pct high">100%</td> <td data-value="6" class="abs high">6/6</td> <td data-value="96.67" class="pct high">96.67%</td> <td data-value="30" class="abs high">29/30</td> </tr> <tr> <td class="file medium" data-value="Handle.js"><a href="Handle.js.html">Handle.js</a></td> <td data-value="54.1" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 54%;"></div><div class="cover-empty" style="width:46%;"></div></div></td> <td data-value="54.1" class="pct medium">54.1%</td> <td data-value="61" class="abs medium">33/61</td> <td data-value="42.86" class="pct low">42.86%</td> <td data-value="14" class="abs low">6/14</td> <td data-value="71.43" class="pct medium">71.43%</td> <td data-value="14" class="abs medium">10/14</td> <td data-value="54.1" class="pct medium">54.1%</td> <td data-value="61" class="abs medium">33/61</td> </tr> <tr> <td class="file medium" data-value="HelpDialog.js"><a href="HelpDialog.js.html">HelpDialog.js</a></td> <td data-value="77.78" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 77%;"></div><div class="cover-empty" style="width:23%;"></div></div></td> <td data-value="77.78" class="pct medium">77.78%</td> <td data-value="36" class="abs medium">28/36</td> <td data-value="50" class="pct medium">50%</td> <td data-value="6" class="abs medium">3/6</td> <td data-value="58.33" class="pct medium">58.33%</td> <td data-value="12" class="abs medium">7/12</td> <td data-value="77.78" class="pct medium">77.78%</td> <td data-value="36" class="abs medium">28/36</td> </tr> <tr> <td class="file low" data-value="HintPopover.js"><a href="HintPopover.js.html">HintPopover.js</a></td> <td data-value="26.36" class="pic low"><div class="chart"><div class="cover-fill" style="width: 26%;"></div><div class="cover-empty" style="width:74%;"></div></div></td> <td data-value="26.36" class="pct low">26.36%</td> <td data-value="129" class="abs low">34/129</td> <td data-value="7.55" class="pct low">7.55%</td> <td data-value="53" class="abs low">4/53</td> <td data-value="12.5" class="pct low">12.5%</td> <td data-value="24" class="abs low">3/24</td> <td data-value="26.36" class="pct low">26.36%</td> <td data-value="129" class="abs low">34/129</td> </tr> <tr> <td class="file low" data-value="ImageDialog.js"><a href="ImageDialog.js.html">ImageDialog.js</a></td> <td data-value="40" class="pic low"><div class="chart"><div class="cover-fill" style="width: 40%;"></div><div class="cover-empty" style="width:60%;"></div></div></td> <td data-value="40" class="pct low">40%</td> <td data-value="65" class="abs low">26/65</td> <td data-value="14.29" class="pct low">14.29%</td> <td data-value="14" class="abs low">2/14</td> <td data-value="25" class="pct low">25%</td> <td data-value="16" class="abs low">4/16</td> <td data-value="40" class="pct low">40%</td> <td data-value="65" class="abs low">26/65</td> </tr> <tr> <td class="file high" data-value="ImagePopover.js"><a href="ImagePopover.js.html">ImagePopover.js</a></td> <td data-value="89.29" class="pic high"><div class="chart"><div class="cover-fill" style="width: 89%;"></div><div class="cover-empty" style="width:11%;"></div></div></td> <td data-value="89.29" class="pct high">89.29%</td> <td data-value="28" class="abs high">25/28</td> <td data-value="16.67" class="pct low">16.67%</td> <td data-value="6" class="abs low">1/6</td> <td data-value="100" class="pct high">100%</td> <td data-value="8" class="abs high">8/8</td> <td data-value="89.29" class="pct high">89.29%</td> <td data-value="28" class="abs high">25/28</td> </tr> <tr> <td class="file low" data-value="LinkDialog.js"><a href="LinkDialog.js.html">LinkDialog.js</a></td> <td data-value="34.21" class="pic low"><div class="chart"><div class="cover-fill" style="width: 34%;"></div><div class="cover-empty" style="width:66%;"></div></div></td> <td data-value="34.21" class="pct low">34.21%</td> <td data-value="76" class="abs low">26/76</td> <td data-value="11.11" class="pct low">11.11%</td> <td data-value="18" class="abs low">2/18</td> <td data-value="21.05" class="pct low">21.05%</td> <td data-value="19" class="abs low">4/19</td> <td data-value="34.21" class="pct low">34.21%</td> <td data-value="76" class="abs low">26/76</td> </tr> <tr> <td class="file medium" data-value="LinkPopover.js"><a href="LinkPopover.js.html">LinkPopover.js</a></td> <td data-value="77.78" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 77%;"></div><div class="cover-empty" style="width:23%;"></div></div></td> <td data-value="77.78" class="pct medium">77.78%</td> <td data-value="36" class="abs medium">28/36</td> <td data-value="16.67" class="pct low">16.67%</td> <td data-value="6" class="abs low">1/6</td> <td data-value="100" class="pct high">100%</td> <td data-value="10" class="abs high">10/10</td> <td data-value="77.78" class="pct medium">77.78%</td> <td data-value="36" class="abs medium">28/36</td> </tr> <tr> <td class="file medium" data-value="Placeholder.js"><a href="Placeholder.js.html">Placeholder.js</a></td> <td data-value="59.09" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 59%;"></div><div class="cover-empty" style="width:41%;"></div></div></td> <td data-value="59.09" class="pct medium">59.09%</td> <td data-value="22" class="abs medium">13/22</td> <td data-value="0" class="pct low">0%</td> <td data-value="2" class="abs low">0/2</td> <td data-value="33.33" class="pct low">33.33%</td> <td data-value="9" class="abs low">3/9</td> <td data-value="59.09" class="pct medium">59.09%</td> <td data-value="22" class="abs medium">13/22</td> </tr> <tr> <td class="file medium" data-value="Statusbar.js"><a href="Statusbar.js.html">Statusbar.js</a></td> <td data-value="55.56" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 55%;"></div><div class="cover-empty" style="width:45%;"></div></div></td> <td data-value="55.56" class="pct medium">55.56%</td> <td data-value="27" class="abs medium">15/27</td> <td data-value="37.5" class="pct low">37.5%</td> <td data-value="8" class="abs low">3/8</td> <td data-value="57.14" class="pct medium">57.14%</td> <td data-value="7" class="abs medium">4/7</td> <td data-value="55.56" class="pct medium">55.56%</td> <td data-value="27" class="abs medium">15/27</td> </tr> <tr> <td class="file high" data-value="TablePopover.js"><a href="TablePopover.js.html">TablePopover.js</a></td> <td data-value="91.43" class="pic high"><div class="chart"><div class="cover-fill" style="width: 91%;"></div><div class="cover-empty" style="width:9%;"></div></div></td> <td data-value="91.43" class="pct high">91.43%</td> <td data-value="35" class="abs high">32/35</td> <td data-value="66.67" class="pct medium">66.67%</td> <td data-value="6" class="abs medium">4/6</td> <td data-value="100" class="pct high">100%</td> <td data-value="10" class="abs high">10/10</td> <td data-value="91.43" class="pct high">91.43%</td> <td data-value="35" class="abs high">32/35</td> </tr> <tr> <td class="file high" data-value="Toolbar.js"><a href="Toolbar.js.html">Toolbar.js</a></td> <td data-value="93.24" class="pic high"><div class="chart"><div class="cover-fill" style="width: 93%;"></div><div class="cover-empty" style="width:7%;"></div></div></td> <td data-value="93.24" class="pct high">93.24%</td> <td data-value="74" class="abs high">69/74</td> <td data-value="67.86" class="pct medium">67.86%</td> <td data-value="28" class="abs medium">19/28</td> <td data-value="100" class="pct high">100%</td> <td data-value="12" class="abs high">12/12</td> <td data-value="93.24" class="pct high">93.24%</td> <td data-value="74" class="abs high">69/74</td> </tr> <tr> <td class="file medium" data-value="VideoDialog.js"><a href="VideoDialog.js.html">VideoDialog.js</a></td> <td data-value="60.4" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 60%;"></div><div class="cover-empty" style="width:40%;"></div></div></td> <td data-value="60.4" class="pct medium">60.4%</td> <td data-value="101" class="abs medium">61/101</td> <td data-value="55.1" class="pct medium">55.1%</td> <td data-value="49" class="abs medium">27/49</td> <td data-value="31.25" class="pct low">31.25%</td> <td data-value="16" class="abs low">5/16</td> <td data-value="60.4" class="pct medium">60.4%</td> <td data-value="101" class="abs medium">61/101</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/Statusbar.js.html000064400000015334151677271550020604 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/Statusbar.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/js/base/module/</a> Statusbar.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">55.56% </span> <span class="quiet">Statements</span> <span class='fraction'>15/27</span> </div> <div class='fl pad1y space-right2'> <span class="strong">37.5% </span> <span class="quiet">Branches</span> <span class='fraction'>3/8</span> </div> <div class='fl pad1y space-right2'> <span class="strong">57.14% </span> <span class="quiet">Functions</span> <span class='fraction'>4/7</span> </div> <div class='fl pad1y space-right2'> <span class="strong">55.56% </span> <span class="quiet">Lines</span> <span class='fraction'>15/27</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</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</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-yes">77×</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-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-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-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-yes">1×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; const EDITABLE_PADDING = 24; export default class Statusbar { constructor(context) { this.$document = $(document); this.$statusbar = context.layoutInfo.statusbar; this.$editable = context.layoutInfo.editable; this.options = context.options; } initialize() { <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.airMode || this.options.disableResizeEditor) { <span class="cstat-no" title="statement not covered" > this.destroy();</span> <span class="cstat-no" title="statement not covered" > return;</span> } this.$statusbar.on('mousedown', <span class="fstat-no" title="function not covered" >(event)</span> => { <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> <span class="cstat-no" title="statement not covered" > event.stopPropagation();</span> <span class="cstat-no" title="statement not covered" > const editableTop = this.$editable.offset().top - this.$document.scrollTop();</span> <span class="cstat-no" title="statement not covered" > const onMouseMove = <span class="fstat-no" title="function not covered" >(event)</span> => {</span> <span class="cstat-no" title="statement not covered" > let height = event.clientY - (editableTop + EDITABLE_PADDING);</span> <span class="cstat-no" title="statement not covered" > height = (this.options.minheight > 0) ? Math.max(height, this.options.minheight) : height;</span> <span class="cstat-no" title="statement not covered" > height = (this.options.maxHeight > 0) ? Math.min(height, this.options.maxHeight) : height;</span> <span class="cstat-no" title="statement not covered" > this.$editable.height(height);</span> }; <span class="cstat-no" title="statement not covered" > this.$document.on('mousemove', onMouseMove).one('mouseup', <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.$document.off('mousemove', onMouseMove);</span> }); }); } destroy() { this.$statusbar.off(); this.$statusbar.addClass('locked'); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/LinkDialog.js.html000064400000052427151677271550020655 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/LinkDialog.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/js/base/module/</a> LinkDialog.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">34.21% </span> <span class="quiet">Statements</span> <span class='fraction'>26/76</span> </div> <div class='fl pad1y space-right2'> <span class="strong">11.11% </span> <span class="quiet">Branches</span> <span class='fraction'>2/18</span> </div> <div class='fl pad1y space-right2'> <span class="strong">21.05% </span> <span class="quiet">Functions</span> <span class='fraction'>4/19</span> </div> <div class='fl pad1y space-right2'> <span class="strong">34.21% </span> <span class="quiet">Lines</span> <span class='fraction'>26/76</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-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">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">2×</span> <span class="cline-any cline-yes">2×</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-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-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-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> <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-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-no"> </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-neutral"> </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-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-no"> </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-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-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-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-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-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-no"> </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-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-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-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-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-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-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-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-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-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import env from '../core/env'; import key from '../core/key'; export default class LinkDialog { constructor(context) { this.context = context; this.ui = $.summernote.ui; this.$body = $(document.body); this.$editor = context.layoutInfo.editor; this.options = context.options; this.lang = this.options.langInfo; context.memo('help.linkDialog.show', this.options.langInfo.help['linkDialog.show']); } initialize() { const $container = this.options.dialogsInBody ? <span class="branch-0 cbranch-no" title="branch not covered" >this.$body </span>: this.$editor; const body = [ '<div class="form-group note-form-group">', `<label class="note-form-label">${this.lang.link.textToDisplay}</label>`, '<input class="note-link-text form-control note-form-control note-input" type="text" />', '</div>', '<div class="form-group note-form-group">', `<label class="note-form-label">${this.lang.link.url}</label>`, '<input class="note-link-url form-control note-form-control note-input" type="text" value="http://" />', '</div>', !this.options.disableLinkTarget ? $('<div/>').append(this.ui.checkbox({ id: 'sn-checkbox-open-in-new-window', text: this.lang.link.openInNewWindow, checked: true }).render()).html() : <span class="branch-1 cbranch-no" title="branch not covered" >''</span> ].join(''); const buttonClass = 'btn btn-primary note-btn note-btn-primary note-link-btn'; const footer = `<button type="submit" href="#" class="${buttonClass}" disabled>${this.lang.link.insert}</button>`; this.$dialog = this.ui.dialog({ className: 'link-dialog', title: this.lang.link.insert, fade: this.options.dialogsFade, body: body, footer: footer }).render().appendTo($container); } destroy() { this.ui.hideDialog(this.$dialog); this.$dialog.remove(); } <span class="fstat-no" title="function not covered" > bindEnterKey($input, $btn)</span> { <span class="cstat-no" title="statement not covered" > $input.on('keypress', <span class="fstat-no" title="function not covered" >(event)</span> => {</span> <span class="cstat-no" title="statement not covered" > if (event.keyCode === key.code.ENTER) {</span> <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> <span class="cstat-no" title="statement not covered" > $btn.trigger('click');</span> } }); } /** * toggle update button */ <span class="fstat-no" title="function not covered" > toggleLinkBtn($linkBtn, $linkText, $linkUrl)</span> { <span class="cstat-no" title="statement not covered" > this.ui.toggleBtn($linkBtn, $linkText.val() && $linkUrl.val());</span> } /** * Show link dialog and set event handlers on dialog controls. * * @param {Object} linkInfo * @return {Promise} */ <span class="fstat-no" title="function not covered" > showLinkDialog(linkInfo)</span> { <span class="cstat-no" title="statement not covered" > return $.Deferred(<span class="fstat-no" title="function not covered" >(deferred)</span> => {</span> <span class="cstat-no" title="statement not covered" > const $linkText = this.$dialog.find('.note-link-text');</span> <span class="cstat-no" title="statement not covered" > const $linkUrl = this.$dialog.find('.note-link-url');</span> <span class="cstat-no" title="statement not covered" > const $linkBtn = this.$dialog.find('.note-link-btn');</span> <span class="cstat-no" title="statement not covered" > const $openInNewWindow = this.$dialog.find('input[type=checkbox]');</span> <span class="cstat-no" title="statement not covered" > this.ui.onDialogShown(this.$dialog, <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('dialog.shown');</span> // if no url was given, copy text to url <span class="cstat-no" title="statement not covered" > if (!linkInfo.url) {</span> <span class="cstat-no" title="statement not covered" > linkInfo.url = linkInfo.text;</span> } <span class="cstat-no" title="statement not covered" > $linkText.val(linkInfo.text);</span> <span class="cstat-no" title="statement not covered" > const handleLinkTextUpdate = <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.toggleLinkBtn($linkBtn, $linkText, $linkUrl);</span> // if linktext was modified by keyup, // stop cloning text from linkUrl <span class="cstat-no" title="statement not covered" > linkInfo.text = $linkText.val();</span> }; <span class="cstat-no" title="statement not covered" > $linkText.on('input', handleLinkTextUpdate).on('paste', <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > setTimeout(handleLinkTextUpdate, 0);</span> }); <span class="cstat-no" title="statement not covered" > const handleLinkUrlUpdate = <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.toggleLinkBtn($linkBtn, $linkText, $linkUrl);</span> // display same link on `Text to display` input // when create a new link <span class="cstat-no" title="statement not covered" > if (!linkInfo.text) {</span> <span class="cstat-no" title="statement not covered" > $linkText.val($linkUrl.val());</span> } }; <span class="cstat-no" title="statement not covered" > $linkUrl.on('input', handleLinkUrlUpdate).on('paste', <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > setTimeout(handleLinkUrlUpdate, 0);</span> }).val(linkInfo.url); <span class="cstat-no" title="statement not covered" > if (!env.isSupportTouch) {</span> <span class="cstat-no" title="statement not covered" > $linkUrl.trigger('focus');</span> } <span class="cstat-no" title="statement not covered" > this.toggleLinkBtn($linkBtn, $linkText, $linkUrl);</span> <span class="cstat-no" title="statement not covered" > this.bindEnterKey($linkUrl, $linkBtn);</span> <span class="cstat-no" title="statement not covered" > this.bindEnterKey($linkText, $linkBtn);</span> <span class="cstat-no" title="statement not covered" > const isChecked = linkInfo.isNewWindow !== undefined</span> ? linkInfo.isNewWindow : this.context.options.linkTargetBlank; <span class="cstat-no" title="statement not covered" > $openInNewWindow.prop('checked', isChecked);</span> <span class="cstat-no" title="statement not covered" > $linkBtn.one('click', <span class="fstat-no" title="function not covered" >(event)</span> => {</span> <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> <span class="cstat-no" title="statement not covered" > deferred.resolve({</span> range: linkInfo.range, url: $linkUrl.val(), text: $linkText.val(), isNewWindow: $openInNewWindow.is(':checked') }); <span class="cstat-no" title="statement not covered" > this.ui.hideDialog(this.$dialog);</span> }); }); <span class="cstat-no" title="statement not covered" > this.ui.onDialogHidden(this.$dialog, <span class="fstat-no" title="function not covered" >() => {</span></span> // detach events <span class="cstat-no" title="statement not covered" > $linkText.off('input paste keypress');</span> <span class="cstat-no" title="statement not covered" > $linkUrl.off('input paste keypress');</span> <span class="cstat-no" title="statement not covered" > $linkBtn.off('click');</span> <span class="cstat-no" title="statement not covered" > if (deferred.state() === 'pending') {</span> <span class="cstat-no" title="statement not covered" > deferred.reject();</span> } }); <span class="cstat-no" title="statement not covered" > this.ui.showDialog(this.$dialog);</span> }).promise(); } /** * @param {Object} layoutInfo */ <span class="fstat-no" title="function not covered" > show() {</span> <span class="cstat-no" title="statement not covered" > const linkInfo = this.context.invoke('editor.getLinkInfo');</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.saveRange');</span> <span class="cstat-no" title="statement not covered" > this.showLinkDialog(linkInfo).then(<span class="fstat-no" title="function not covered" >(linkInfo)</span> => {</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.restoreRange');</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.createLink', linkInfo);</span> }).fail(<span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.restoreRange');</span> }); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/Handle.js.html000064400000041010151677271550020015 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/Handle.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/js/base/module/</a> Handle.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">54.1% </span> <span class="quiet">Statements</span> <span class='fraction'>33/61</span> </div> <div class='fl pad1y space-right2'> <span class="strong">42.86% </span> <span class="quiet">Branches</span> <span class='fraction'>6/14</span> </div> <div class='fl pad1y space-right2'> <span class="strong">71.43% </span> <span class="quiet">Functions</span> <span class='fraction'>10/14</span> </div> <div class='fl pad1y space-right2'> <span class="strong">54.1% </span> <span class="quiet">Lines</span> <span class='fraction'>33/61</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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144</td><td class="line-coverage quiet"><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-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">52×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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">78×</span> <span class="cline-any cline-yes">77×</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-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">77×</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-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-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-neutral"> </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-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-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-yes">77×</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-yes">1×</span> <span class="cline-any cline-yes">2×</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">55×</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">54×</span> <span class="cline-any cline-yes">54×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">54×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">54×</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-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-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> <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-no"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">54×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">54×</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">58×</span> <span class="cline-any cline-yes">58×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import dom from '../core/dom'; export default class Handle { constructor(context) { this.context = context; this.$document = $(document); this.$editingArea = context.layoutInfo.editingArea; this.options = context.options; this.lang = this.options.langInfo; this.events = { 'summernote.mousedown': (we, e) => { <span class="missing-if-branch" title="if path not taken" >I</span>if (this.update(e.target)) { <span class="cstat-no" title="statement not covered" > e.preventDefault();</span> } }, 'summernote.keyup summernote.scroll summernote.change summernote.dialog.shown': () => { this.update(); }, 'summernote.disable': () => { this.hide(); }, 'summernote.codeview.toggled': () => { this.update(); } }; } initialize() { this.$handle = $([ '<div class="note-handle">', '<div class="note-control-selection">', '<div class="note-control-selection-bg"></div>', '<div class="note-control-holder note-control-nw"></div>', '<div class="note-control-holder note-control-ne"></div>', '<div class="note-control-holder note-control-sw"></div>', '<div class="', (this.options.disableResizeImage ? <span class="branch-0 cbranch-no" title="branch not covered" >'note-control-holder' </span>: 'note-control-sizing'), ' note-control-se"></div>', (this.options.disableResizeImage ? <span class="branch-0 cbranch-no" title="branch not covered" >'' </span>: '<div class="note-control-selection-info"></div>'), '</div>', '</div>' ].join('')).prependTo(this.$editingArea); this.$handle.on('mousedown', <span class="fstat-no" title="function not covered" >(event)</span> => { <span class="cstat-no" title="statement not covered" > if (dom.isControlSizing(event.target)) {</span> <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> <span class="cstat-no" title="statement not covered" > event.stopPropagation();</span> <span class="cstat-no" title="statement not covered" > const $target = this.$handle.find('.note-control-selection').data('target');</span> <span class="cstat-no" title="statement not covered" > const posStart = $target.offset();</span> <span class="cstat-no" title="statement not covered" > const scrollTop = this.$document.scrollTop();</span> <span class="cstat-no" title="statement not covered" > const onMouseMove = <span class="fstat-no" title="function not covered" >(event)</span> => {</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.resizeTo', {</span> x: event.clientX - posStart.left, y: event.clientY - (posStart.top - scrollTop) }, $target, !event.shiftKey); <span class="cstat-no" title="statement not covered" > this.update($target[0]);</span> }; <span class="cstat-no" title="statement not covered" > this.$document</span> .on('mousemove', onMouseMove) .one('mouseup', <span class="fstat-no" title="function not covered" >(e)</span> => { <span class="cstat-no" title="statement not covered" > e.preventDefault();</span> <span class="cstat-no" title="statement not covered" > this.$document.off('mousemove', onMouseMove);</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.afterCommand');</span> }); <span class="cstat-no" title="statement not covered" > if (!$target.data('ratio')) { // original ratio.</span> <span class="cstat-no" title="statement not covered" > $target.data('ratio', $target.height() / $target.width());</span> } } }); // Listen for scrolling on the handle overlay. this.$handle.on('wheel', <span class="fstat-no" title="function not covered" >(e)</span> => { <span class="cstat-no" title="statement not covered" > e.preventDefault();</span> <span class="cstat-no" title="statement not covered" > this.update();</span> }); } destroy() { this.$handle.remove(); } update(target) { if (this.context.isDisabled()) { return false; } const isImage = dom.isImg(target); const $selection = this.$handle.find('.note-control-selection'); this.context.invoke('imagePopover.update', target); <span class="missing-if-branch" title="if path not taken" >I</span>if (isImage) { <span class="cstat-no" title="statement not covered" > const $image = $(target);</span> <span class="cstat-no" title="statement not covered" > const position = $image.position();</span> <span class="cstat-no" title="statement not covered" > const pos = {</span> left: position.left + parseInt($image.css('marginLeft'), 10), top: position.top + parseInt($image.css('marginTop'), 10) }; // exclude margin <span class="cstat-no" title="statement not covered" > const imageSize = {</span> w: $image.outerWidth(false), h: $image.outerHeight(false) }; <span class="cstat-no" title="statement not covered" > $selection.css({</span> display: 'block', left: pos.left, top: pos.top, width: imageSize.w, height: imageSize.h }).data('target', $image); // save current image element. <span class="cstat-no" title="statement not covered" > const origImageObj = new Image();</span> <span class="cstat-no" title="statement not covered" > origImageObj.src = $image.attr('src');</span> <span class="cstat-no" title="statement not covered" > const sizingText = imageSize.w + 'x' + imageSize.h + ' (' + this.lang.image.original + ': ' + origImageObj.width + 'x' + origImageObj.height + ')';</span> <span class="cstat-no" title="statement not covered" > $selection.find('.note-control-selection-info').text(sizingText);</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.saveTarget', target);</span> } else { this.hide(); } return isImage; } /** * hide * * @param {jQuery} $handle */ hide() { this.context.invoke('editor.clearTarget'); this.$handle.children().hide(); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/HelpDialog.js.html000064400000023567151677271550020653 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/HelpDialog.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/js/base/module/</a> HelpDialog.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">77.78% </span> <span class="quiet">Statements</span> <span class='fraction'>28/36</span> </div> <div class='fl pad1y space-right2'> <span class="strong">50% </span> <span class="quiet">Branches</span> <span class='fraction'>3/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">58.33% </span> <span class="quiet">Functions</span> <span class='fraction'>7/12</span> </div> <div class='fl pad1y space-right2'> <span class="strong">77.78% </span> <span class="quiet">Lines</span> <span class='fraction'>28/36</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</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">77×</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">77×</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">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">2079×</span> <span class="cline-any cline-yes">2079×</span> <span class="cline-any cline-yes">2079×</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">2079×</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-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-yes">1×</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-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import env from '../core/env'; export default class HelpDialog { constructor(context) { this.context = context; this.ui = $.summernote.ui; this.$body = $(document.body); this.$editor = context.layoutInfo.editor; this.options = context.options; this.lang = this.options.langInfo; } initialize() { const $container = this.options.dialogsInBody ? <span class="branch-0 cbranch-no" title="branch not covered" >this.$body </span>: this.$editor; const body = [ '<p class="text-center">', '<a href="http://summernote.org/" target="_blank">Summernote @@VERSION@@</a> · ', '<a href="https://github.com/summernote/summernote" target="_blank">Project</a> · ', '<a href="https://github.com/summernote/summernote/issues" target="_blank">Issues</a>', '</p>' ].join(''); this.$dialog = this.ui.dialog({ title: this.lang.options.help, fade: this.options.dialogsFade, body: this.createShortcutList(), footer: body, callback: ($node) => { $node.find('.modal-body,.note-modal-body').css({ 'max-height': 300, 'overflow': 'scroll' }); } }).render().appendTo($container); } destroy() { this.ui.hideDialog(this.$dialog); this.$dialog.remove(); } createShortcutList() { const keyMap = this.options.keyMap[env.isMac ? 'mac' : <span class="branch-1 cbranch-no" title="branch not covered" >'pc']</span>; return Object.keys(keyMap).map((key) => { const command = keyMap[key]; const $row = $('<div><div class="help-list-item"/></div>'); $row.append($('<label><kbd>' + key + '</kdb></label>').css({ 'width': 180, 'margin-right': 10 })).append($('<span/>').html(this.context.memo('help.' + command) || <span class="branch-1 cbranch-no" title="branch not covered" >command)</span>); return $row.html(); }).join(''); } /** * show help dialog * * @return {Promise} */ <span class="fstat-no" title="function not covered" > showHelpDialog() {</span> <span class="cstat-no" title="statement not covered" > return $.Deferred(<span class="fstat-no" title="function not covered" >(deferred)</span> => {</span> <span class="cstat-no" title="statement not covered" > this.ui.onDialogShown(this.$dialog, <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('dialog.shown');</span> <span class="cstat-no" title="statement not covered" > deferred.resolve();</span> }); <span class="cstat-no" title="statement not covered" > this.ui.showDialog(this.$dialog);</span> }).promise(); } <span class="fstat-no" title="function not covered" > show() {</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.saveRange');</span> <span class="cstat-no" title="statement not covered" > this.showHelpDialog().then(<span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.restoreRange');</span> }); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/Toolbar.js.html000064400000034246151677271550020241 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/Toolbar.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/js/base/module/</a> Toolbar.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">93.24% </span> <span class="quiet">Statements</span> <span class='fraction'>69/74</span> </div> <div class='fl pad1y space-right2'> <span class="strong">67.86% </span> <span class="quiet">Branches</span> <span class='fraction'>19/28</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>12/12</span> </div> <div class='fl pad1y space-right2'> <span class="strong">93.24% </span> <span class="quiet">Lines</span> <span class='fraction'>69/74</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137</td><td class="line-coverage quiet"><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">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">87×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">52×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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">544×</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">543×</span> <span class="cline-any cline-yes">543×</span> <span class="cline-any cline-yes">543×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">543×</span> <span class="cline-any cline-yes">543×</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">543×</span> <span class="cline-any cline-yes">543×</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-yes">543×</span> <span class="cline-any cline-yes">543×</span> <span class="cline-any cline-yes">543×</span> <span class="cline-any cline-yes">543×</span> <span class="cline-any cline-yes">543×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">543×</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-yes">543×</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">79×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">78×</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">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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">2×</span> <span class="cline-any cline-yes">2×</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-yes">1×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; export default class Toolbar { constructor(context) { this.context = context; this.$window = $(window); this.$document = $(document); this.ui = $.summernote.ui; this.$note = context.layoutInfo.note; this.$editor = context.layoutInfo.editor; this.$toolbar = context.layoutInfo.toolbar; this.options = context.options; this.followScroll = this.followScroll.bind(this); } shouldInitialize() { return !this.options.airMode; } initialize() { this.options.toolbar = this.options.toolbar || <span class="branch-1 cbranch-no" title="branch not covered" >[];</span> <span class="missing-if-branch" title="if path not taken" >I</span>if (!this.options.toolbar.length) { <span class="cstat-no" title="statement not covered" > this.$toolbar.hide();</span> } else { this.context.invoke('buttons.build', this.$toolbar, this.options.toolbar); } <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.toolbarContainer) { <span class="cstat-no" title="statement not covered" > this.$toolbar.appendTo(this.options.toolbarContainer);</span> } this.changeContainer(false); this.$note.on('summernote.keyup summernote.mouseup summernote.change', () => { this.context.invoke('buttons.updateCurrentStyle'); }); this.context.invoke('buttons.updateCurrentStyle'); <span class="missing-if-branch" title="else path not taken" >E</span>if (this.options.followingToolbar) { this.$window.on('scroll resize', this.followScroll); } } destroy() { this.$toolbar.children().remove(); <span class="missing-if-branch" title="else path not taken" >E</span>if (this.options.followingToolbar) { this.$window.off('scroll resize', this.followScroll); } } followScroll() { if (this.$editor.hasClass('fullscreen')) { return false; } const $toolbarWrapper = this.$toolbar.parent('.note-toolbar-wrapper'); const editorHeight = this.$editor.outerHeight(); const editorWidth = this.$editor.width(); const toolbarHeight = this.$toolbar.height(); $toolbarWrapper.css({ height: toolbarHeight }); // check if the web app is currently using another static bar let otherBarHeight = 0; <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.otherStaticBar) { <span class="cstat-no" title="statement not covered" > otherBarHeight = $(this.options.otherStaticBar).outerHeight();</span> } const currentOffset = this.$document.scrollTop(); const editorOffsetTop = this.$editor.offset().top; const editorOffsetBottom = editorOffsetTop + editorHeight; const activateOffset = editorOffsetTop - otherBarHeight; const deactivateOffsetBottom = editorOffsetBottom - otherBarHeight - toolbarHeight; <span class="missing-if-branch" title="if path not taken" >I</span>if ((currentOffset > activateOffset) && (<span class="branch-1 cbranch-no" title="branch not covered" >currentOffset < deactivateOffsetBottom)</span>) { <span class="cstat-no" title="statement not covered" > this.$toolbar.css({</span> position: 'fixed', top: otherBarHeight, width: editorWidth }); } else { this.$toolbar.css({ position: 'relative', top: 0, width: '100%' }); } } changeContainer(isFullscreen) { if (isFullscreen) { this.$toolbar.prependTo(this.$editor); } else { <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.toolbarContainer) { <span class="cstat-no" title="statement not covered" > this.$toolbar.appendTo(this.options.toolbarContainer);</span> } } } updateFullscreen(isFullscreen) { this.ui.toggleBtnActive(this.$toolbar.find('.btn-fullscreen'), isFullscreen); this.changeContainer(isFullscreen); } updateCodeview(isCodeview) { this.ui.toggleBtnActive(this.$toolbar.find('.btn-codeview'), isCodeview); if (isCodeview) { this.deactivate(); } else { this.activate(); } } activate(isIncludeCodeview) { let $btn = this.$toolbar.find('button'); if (!isIncludeCodeview) { $btn = $btn.not('.btn-codeview'); } this.ui.toggleBtn($btn, true); } deactivate(isIncludeCodeview) { let $btn = this.$toolbar.find('button'); if (!isIncludeCodeview) { $btn = $btn.not('.btn-codeview'); } this.ui.toggleBtn($btn, false); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/ImagePopover.js.html000064400000016225151677271550021231 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/ImagePopover.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/js/base/module/</a> ImagePopover.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">89.29% </span> <span class="quiet">Statements</span> <span class='fraction'>25/28</span> </div> <div class='fl pad1y space-right2'> <span class="strong">16.67% </span> <span class="quiet">Branches</span> <span class='fraction'>1/6</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">89.29% </span> <span class="quiet">Lines</span> <span class='fraction'>25/28</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</td><td class="line-coverage quiet"><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-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">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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">133×</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">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">2×</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">54×</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-neutral"> </span> <span class="cline-any cline-yes">54×</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">58×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import lists from '../core/lists'; import dom from '../core/dom'; /** * Image popover module * mouse events that show/hide popover will be handled by Handle.js. * Handle.js will receive the events and invoke 'imagePopover.update'. */ export default class ImagePopover { constructor(context) { this.context = context; this.ui = $.summernote.ui; this.editable = context.layoutInfo.editable[0]; this.options = context.options; this.events = { 'summernote.disable': () => { this.hide(); } }; } shouldInitialize() { return !lists.isEmpty(this.options.popover.image); } initialize() { this.$popover = this.ui.popover({ className: 'note-image-popover' }).render().appendTo(this.options.container); const $content = this.$popover.find('.popover-content,.note-popover-content'); this.context.invoke('buttons.build', $content, this.options.popover.image); } destroy() { this.$popover.remove(); } update(target) { <span class="missing-if-branch" title="if path not taken" >I</span>if (dom.isImg(target)) { <span class="cstat-no" title="statement not covered" > const pos = dom.posFromPlaceholder(target);</span> <span class="cstat-no" title="statement not covered" > const posEditor = dom.posFromPlaceholder(this.editable);</span> <span class="cstat-no" title="statement not covered" > this.$popover.css({</span> display: 'block', left: this.options.popatmouse ? event.pageX - 20 : pos.left, top: this.options.popatmouse ? event.pageY : Math.min(pos.top, posEditor.top) }); } else { this.hide(); } } hide() { this.$popover.hide(); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/Dropzone.js.html000064400000035605151677271550020437 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/Dropzone.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/js/base/module/</a> Dropzone.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">46.67% </span> <span class="quiet">Statements</span> <span class='fraction'>28/60</span> </div> <div class='fl pad1y space-right2'> <span class="strong">5.56% </span> <span class="quiet">Branches</span> <span class='fraction'>1/18</span> </div> <div class='fl pad1y space-right2'> <span class="strong">40% </span> <span class="quiet">Functions</span> <span class='fraction'>6/15</span> </div> <div class='fl pad1y space-right2'> <span class="strong">46.67% </span> <span class="quiet">Lines</span> <span class='fraction'>28/60</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 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 108 109 110 111 112 113 114 115 116</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">77×</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-no"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-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-yes">77×</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-yes">77×</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-yes">77×</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">77×</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-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-yes">77×</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-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-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-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-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> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">6×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; export default class Dropzone { constructor(context) { this.context = context; this.$eventListener = $(document); this.$editor = context.layoutInfo.editor; this.$editable = context.layoutInfo.editable; this.options = context.options; this.lang = this.options.langInfo; this.documentEventHandlers = {}; this.$dropzone = $([ '<div class="note-dropzone">', ' <div class="note-dropzone-message"/>', '</div>' ].join('')).prependTo(this.$editor); } /** * attach Drag and Drop Events */ initialize() { <span class="missing-if-branch" title="if path not taken" >I</span>if (this.options.disableDragAndDrop) { // prevent default drop event <span class="cstat-no" title="statement not covered" > this.documentEventHandlers.onDrop = <span class="fstat-no" title="function not covered" >(e)</span> => {</span> <span class="cstat-no" title="statement not covered" > e.preventDefault();</span> }; // do not consider outside of dropzone <span class="cstat-no" title="statement not covered" > this.$eventListener = this.$dropzone;</span> <span class="cstat-no" title="statement not covered" > this.$eventListener.on('drop', this.documentEventHandlers.onDrop);</span> } else { this.attachDragAndDropEvent(); } } /** * attach Drag and Drop Events */ attachDragAndDropEvent() { let collection = $(); const $dropzoneMessage = this.$dropzone.find('.note-dropzone-message'); this.documentEventHandlers.onDragenter = <span class="fstat-no" title="function not covered" >(e)</span> => { <span class="cstat-no" title="statement not covered" > const isCodeview = this.context.invoke('codeview.isActivated');</span> <span class="cstat-no" title="statement not covered" > const hasEditorSize = this.$editor.width() > 0 && this.$editor.height() > 0;</span> <span class="cstat-no" title="statement not covered" > if (!isCodeview && !collection.length && hasEditorSize) {</span> <span class="cstat-no" title="statement not covered" > this.$editor.addClass('dragover');</span> <span class="cstat-no" title="statement not covered" > this.$dropzone.width(this.$editor.width());</span> <span class="cstat-no" title="statement not covered" > this.$dropzone.height(this.$editor.height());</span> <span class="cstat-no" title="statement not covered" > $dropzoneMessage.text(this.lang.image.dragImageHere);</span> } <span class="cstat-no" title="statement not covered" > collection = collection.add(e.target);</span> }; this.documentEventHandlers.onDragleave = <span class="fstat-no" title="function not covered" >(e)</span> => { <span class="cstat-no" title="statement not covered" > collection = collection.not(e.target);</span> <span class="cstat-no" title="statement not covered" > if (!collection.length) {</span> <span class="cstat-no" title="statement not covered" > this.$editor.removeClass('dragover');</span> } }; this.documentEventHandlers.onDrop = <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > collection = $();</span> <span class="cstat-no" title="statement not covered" > this.$editor.removeClass('dragover');</span> }; // show dropzone on dragenter when dragging a object to document // -but only if the editor is visible, i.e. has a positive width and height this.$eventListener.on('dragenter', this.documentEventHandlers.onDragenter) .on('dragleave', this.documentEventHandlers.onDragleave) .on('drop', this.documentEventHandlers.onDrop); // change dropzone's message on hover. this.$dropzone.on('dragenter', <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.$dropzone.addClass('hover');</span> <span class="cstat-no" title="statement not covered" > $dropzoneMessage.text(this.lang.image.dropImage);</span> }).on('dragleave', <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.$dropzone.removeClass('hover');</span> <span class="cstat-no" title="statement not covered" > $dropzoneMessage.text(this.lang.image.dragImageHere);</span> }); // attach dropImage this.$dropzone.on('drop', <span class="fstat-no" title="function not covered" >(event)</span> => { <span class="cstat-no" title="statement not covered" > const dataTransfer = event.originalEvent.dataTransfer;</span> // stop the browser from opening the dropped content <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> <span class="cstat-no" title="statement not covered" > if (dataTransfer && dataTransfer.files && dataTransfer.files.length) {</span> <span class="cstat-no" title="statement not covered" > this.$editable.focus();</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.insertImagesOrCallback', dataTransfer.files);</span> } else { <span class="cstat-no" title="statement not covered" > $.each(dataTransfer.types, <span class="fstat-no" title="function not covered" >(idx, type)</span> => {</span> <span class="cstat-no" title="statement not covered" > const content = dataTransfer.getData(type);</span> <span class="cstat-no" title="statement not covered" > if (type.toLowerCase().indexOf('text') > -1) {</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.pasteHTML', content);</span> } else { <span class="cstat-no" title="statement not covered" > $(content).each(<span class="fstat-no" title="function not covered" >(idx, item)</span> => {</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.insertNode', item);</span> }); } }); } }).on('dragover', false); // prevent default dragover event } destroy() { Object.keys(this.documentEventHandlers).forEach((key) => { this.$eventListener.off(key.substr(2).toLowerCase(), this.documentEventHandlers[key]); }); this.documentEventHandlers = {}; } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/Fullscreen.js.html000064400000014771151677271550020742 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/Fullscreen.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/js/base/module/</a> Fullscreen.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">96.67% </span> <span class="quiet">Statements</span> <span class='fraction'>29/30</span> </div> <div class='fl pad1y space-right2'> <span class="strong">75% </span> <span class="quiet">Branches</span> <span class='fraction'>3/4</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>6/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">96.67% </span> <span class="quiet">Lines</span> <span class='fraction'>29/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</td><td class="line-coverage quiet"><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-yes">79×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">78×</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-yes">1×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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-yes">1×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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-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">2×</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">7×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; export default class Fullscreen { constructor(context) { this.context = context; this.$editor = context.layoutInfo.editor; this.$toolbar = context.layoutInfo.toolbar; this.$editable = context.layoutInfo.editable; this.$codable = context.layoutInfo.codable; this.$window = $(window); this.$scrollbar = $('html, body'); this.onResize = () => { this.resizeTo({ h: this.$window.height() - this.$toolbar.outerHeight() }); }; } resizeTo(size) { this.$editable.css('height', size.h); this.$codable.css('height', size.h); <span class="missing-if-branch" title="if path not taken" >I</span>if (this.$codable.data('cmeditor')) { <span class="cstat-no" title="statement not covered" > this.$codable.data('cmeditor').setsize(null, size.h);</span> } } /** * toggle fullscreen */ toggle() { this.$editor.toggleClass('fullscreen'); if (this.isFullscreen()) { this.$editable.data('orgHeight', this.$editable.css('height')); this.$window.on('resize', this.onResize).trigger('resize'); this.$scrollbar.css('overflow', 'hidden'); } else { this.$window.off('resize', this.onResize); this.resizeTo({ h: this.$editable.data('orgHeight') }); this.$scrollbar.css('overflow', 'visible'); } this.context.invoke('toolbar.updateFullscreen', this.isFullscreen()); } isFullscreen() { return this.$editor.hasClass('fullscreen'); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/LinkPopover.js.html000064400000020627151677271550021105 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/LinkPopover.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/js/base/module/</a> LinkPopover.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">77.78% </span> <span class="quiet">Statements</span> <span class='fraction'>28/36</span> </div> <div class='fl pad1y space-right2'> <span class="strong">16.67% </span> <span class="quiet">Branches</span> <span class='fraction'>1/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>10/10</span> </div> <div class='fl pad1y space-right2'> <span class="strong">77.78% </span> <span class="quiet">Lines</span> <span class='fraction'>28/36</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</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">53×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">4×</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">79×</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">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">2×</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-yes">53×</span> <span class="cline-any cline-yes">53×</span> <span class="cline-any cline-yes">53×</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-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-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-yes">1×</span> <span class="cline-any cline-yes">57×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import lists from '../core/lists'; import dom from '../core/dom'; export default class LinkPopover { constructor(context) { this.context = context; this.ui = $.summernote.ui; this.options = context.options; this.events = { 'summernote.keyup summernote.mouseup summernote.change summernote.scroll': () => { this.update(); }, 'summernote.disable summernote.dialog.shown': () => { this.hide(); } }; } shouldInitialize() { return !lists.isEmpty(this.options.popover.link); } initialize() { this.$popover = this.ui.popover({ className: 'note-link-popover', callback: ($node) => { const $content = $node.find('.popover-content,.note-popover-content'); $content.prepend('<span><a target="_blank"></a>&nbsp;</span>'); } }).render().appendTo(this.options.container); const $content = this.$popover.find('.popover-content,.note-popover-content'); this.context.invoke('buttons.build', $content, this.options.popover.link); } destroy() { this.$popover.remove(); } update() { // Prevent focusing on editable when invoke('code') is executed <span class="missing-if-branch" title="else path not taken" >E</span>if (!this.context.invoke('editor.hasFocus')) { this.hide(); return; } <span class="cstat-no" title="statement not covered" > const rng = this.context.invoke('editor.createRange');</span> <span class="cstat-no" title="statement not covered" > if (rng.isCollapsed() && rng.isOnAnchor()) {</span> <span class="cstat-no" title="statement not covered" > const anchor = dom.ancestor(rng.sc, dom.isAnchor);</span> <span class="cstat-no" title="statement not covered" > const href = $(anchor).attr('href');</span> <span class="cstat-no" title="statement not covered" > this.$popover.find('a').attr('href', href).html(href);</span> <span class="cstat-no" title="statement not covered" > const pos = dom.posFromPlaceholder(anchor);</span> <span class="cstat-no" title="statement not covered" > this.$popover.css({</span> display: 'block', left: pos.left, top: pos.top }); } else { <span class="cstat-no" title="statement not covered" > this.hide();</span> } } hide() { this.$popover.hide(); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/VideoDialog.js.html000064400000061004151677271550021015 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/VideoDialog.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/js/base/module/</a> VideoDialog.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">60.4% </span> <span class="quiet">Statements</span> <span class='fraction'>61/101</span> </div> <div class='fl pad1y space-right2'> <span class="strong">55.1% </span> <span class="quiet">Branches</span> <span class='fraction'>27/49</span> </div> <div class='fl pad1y space-right2'> <span class="strong">31.25% </span> <span class="quiet">Functions</span> <span class='fraction'>5/16</span> </div> <div class='fl pad1y space-right2'> <span class="strong">60.4% </span> <span class="quiet">Lines</span> <span class='fraction'>61/101</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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">79×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">79×</span> <span class="cline-any cline-yes">79×</span> <span class="cline-any cline-yes">79×</span> <span class="cline-any cline-yes">79×</span> <span class="cline-any cline-yes">79×</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">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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">2×</span> <span class="cline-any cline-yes">2×</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-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-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">5×</span> <span class="cline-any cline-yes">5×</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-yes">5×</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-yes">5×</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">5×</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-yes">5×</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-yes">5×</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">5×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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">3×</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">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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-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-no"> </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-neutral"> </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-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> <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-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-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-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-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-no"> </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-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-no"> </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></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import env from '../core/env'; import key from '../core/key'; export default class VideoDialog { constructor(context) { this.context = context; this.ui = $.summernote.ui; this.$body = $(document.body); this.$editor = context.layoutInfo.editor; this.options = context.options; this.lang = this.options.langInfo; } initialize() { const $container = this.options.dialogsInBody ? <span class="branch-0 cbranch-no" title="branch not covered" >this.$body </span>: this.$editor; const body = [ '<div class="form-group note-form-group row-fluid">', `<label class="note-form-label">${this.lang.video.url} <small class="text-muted">${this.lang.video.providers}</small></label>`, '<input class="note-video-url form-control note-form-control note-input" type="text" />', '</div>' ].join(''); const buttonClass = 'btn btn-primary note-btn note-btn-primary note-video-btn'; const footer = `<button type="submit" href="#" class="${buttonClass}" disabled>${this.lang.video.insert}</button>`; this.$dialog = this.ui.dialog({ title: this.lang.video.insert, fade: this.options.dialogsFade, body: body, footer: footer }).render().appendTo($container); } destroy() { this.ui.hideDialog(this.$dialog); this.$dialog.remove(); } <span class="fstat-no" title="function not covered" > bindEnterKey($input, $btn)</span> { <span class="cstat-no" title="statement not covered" > $input.on('keypress', <span class="fstat-no" title="function not covered" >(event)</span> => {</span> <span class="cstat-no" title="statement not covered" > if (event.keyCode === key.code.ENTER) {</span> <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> <span class="cstat-no" title="statement not covered" > $btn.trigger('click');</span> } }); } createVideoNode(url) { // video url patterns(youtube, instagram, vimeo, dailymotion, youku, mp4, ogg, webm) const ytRegExp = /^(?:https?:\/\/)?(?:www\.)?(?:youtu\.be\/|youtube\.com\/(?:embed\/|v\/|watch\?v=|watch\?.+&v=))((\w|-){11})(?:\S+)?$/; const ytMatch = url.match(ytRegExp); const igRegExp = /(?:www\.|\/\/)instagram\.com\/p\/(.[a-zA-Z0-9_-]*)/; const igMatch = url.match(igRegExp); const vRegExp = /\/\/vine\.co\/v\/([a-zA-Z0-9]+)/; const vMatch = url.match(vRegExp); const vimRegExp = /\/\/(player\.)?vimeo\.com\/([a-z]*\/)*(\d+)[?]?.*/; const vimMatch = url.match(vimRegExp); const dmRegExp = /.+dailymotion.com\/(video|hub)\/([^_]+)[^#]*(#video=([^_&]+))?/; const dmMatch = url.match(dmRegExp); const youkuRegExp = /\/\/v\.youku\.com\/v_show\/id_(\w+)=*\.html/; const youkuMatch = url.match(youkuRegExp); const qqRegExp = /\/\/v\.qq\.com.*?vid=(.+)/; const qqMatch = url.match(qqRegExp); const qqRegExp2 = /\/\/v\.qq\.com\/x?\/?(page|cover).*?\/([^\/]+)\.html\??.*/; const qqMatch2 = url.match(qqRegExp2); const mp4RegExp = /^.+.(mp4|m4v)$/; const mp4Match = url.match(mp4RegExp); const oggRegExp = /^.+.(ogg|ogv)$/; const oggMatch = url.match(oggRegExp); const webmRegExp = /^.+.(webm)$/; const webmMatch = url.match(webmRegExp); let $video; <span class="missing-if-branch" title="if path not taken" >I</span>if (ytMatch && <span class="branch-1 cbranch-no" title="branch not covered" >ytMatch[1].length === 11)</span> { <span class="cstat-no" title="statement not covered" > const youtubeId = ytMatch[1];</span> <span class="cstat-no" title="statement not covered" > $video = $('<iframe>')</span> .attr('frameborder', 0) .attr('src', '//www.youtube.com/embed/' + youtubeId) .attr('width', '640').attr('height', '360'); } else <span class="missing-if-branch" title="if path not taken" >I</span>if (igMatch && <span class="branch-1 cbranch-no" title="branch not covered" >igMatch[0].length)</span> { <span class="cstat-no" title="statement not covered" > $video = $('<iframe>')</span> .attr('frameborder', 0) .attr('src', 'https://instagram.com/p/' + igMatch[1] + '/embed/') .attr('width', '612').attr('height', '710') .attr('scrolling', 'no') .attr('allowtransparency', 'true'); } else <span class="missing-if-branch" title="if path not taken" >I</span>if (vMatch && <span class="branch-1 cbranch-no" title="branch not covered" >vMatch[0].length)</span> { <span class="cstat-no" title="statement not covered" > $video = $('<iframe>')</span> .attr('frameborder', 0) .attr('src', vMatch[0] + '/embed/simple') .attr('width', '600').attr('height', '600') .attr('class', 'vine-embed'); } else <span class="missing-if-branch" title="if path not taken" >I</span>if (vimMatch && <span class="branch-1 cbranch-no" title="branch not covered" >vimMatch[3].length)</span> { <span class="cstat-no" title="statement not covered" > $video = $('<iframe webkitallowfullscreen mozallowfullscreen allowfullscreen>')</span> .attr('frameborder', 0) .attr('src', '//player.vimeo.com/video/' + vimMatch[3]) .attr('width', '640').attr('height', '360'); } else <span class="missing-if-branch" title="if path not taken" >I</span>if (dmMatch && <span class="branch-1 cbranch-no" title="branch not covered" >dmMatch[2].length)</span> { <span class="cstat-no" title="statement not covered" > $video = $('<iframe>')</span> .attr('frameborder', 0) .attr('src', '//www.dailymotion.com/embed/video/' + dmMatch[2]) .attr('width', '640').attr('height', '360'); } else <span class="missing-if-branch" title="if path not taken" >I</span>if (youkuMatch && <span class="branch-1 cbranch-no" title="branch not covered" >youkuMatch[1].length)</span> { <span class="cstat-no" title="statement not covered" > $video = $('<iframe webkitallowfullscreen mozallowfullscreen allowfullscreen>')</span> .attr('frameborder', 0) .attr('height', '498') .attr('width', '510') .attr('src', '//player.youku.com/embed/' + youkuMatch[1]); } else if ((qqMatch && qqMatch[1].length) || (qqMatch2 && qqMatch2[2].length)) { const vid = ((qqMatch && qqMatch[1].length) ? qqMatch[1] : qqMatch2[2]); $video = $('<iframe webkitallowfullscreen mozallowfullscreen allowfullscreen>') .attr('frameborder', 0) .attr('height', '310') .attr('width', '500') .attr('src', 'http://v.qq.com/iframe/player.html?vid=' + vid + '&amp;auto=0'); } else <span class="missing-if-branch" title="if path not taken" >I</span>if (mp4Match || oggMatch || webmMatch) { <span class="cstat-no" title="statement not covered" > $video = $('<video controls>')</span> .attr('src', url) .attr('width', '640').attr('height', '360'); } else { // this is not a known video link. Now what, Cat? Now what? return false; } $video.addClass('note-video-clip'); return $video[0]; } <span class="fstat-no" title="function not covered" > show() {</span> <span class="cstat-no" title="statement not covered" > const text = this.context.invoke('editor.getSelectedText');</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.saveRange');</span> <span class="cstat-no" title="statement not covered" > this.showVideoDialog(text).then(<span class="fstat-no" title="function not covered" >(url)</span> => {</span> // [workaround] hide dialog before restore range for IE range focus <span class="cstat-no" title="statement not covered" > this.ui.hideDialog(this.$dialog);</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.restoreRange');</span> // build node <span class="cstat-no" title="statement not covered" > const $node = this.createVideoNode(url);</span> <span class="cstat-no" title="statement not covered" > if ($node) {</span> // insert video node <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.insertNode', $node);</span> } }).fail(<span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.restoreRange');</span> }); } /** * show image dialog * * @param {jQuery} $dialog * @return {Promise} */ <span class="fstat-no" title="function not covered" > showVideoDialog(text)</span> { <span class="cstat-no" title="statement not covered" > return $.Deferred(<span class="fstat-no" title="function not covered" >(deferred)</span> => {</span> <span class="cstat-no" title="statement not covered" > const $videoUrl = this.$dialog.find('.note-video-url');</span> <span class="cstat-no" title="statement not covered" > const $videoBtn = this.$dialog.find('.note-video-btn');</span> <span class="cstat-no" title="statement not covered" > this.ui.onDialogShown(this.$dialog, <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('dialog.shown');</span> <span class="cstat-no" title="statement not covered" > $videoUrl.val(text).on('input', <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.ui.toggleBtn($videoBtn, $videoUrl.val());</span> }); <span class="cstat-no" title="statement not covered" > if (!env.isSupportTouch) {</span> <span class="cstat-no" title="statement not covered" > $videoUrl.trigger('focus');</span> } <span class="cstat-no" title="statement not covered" > $videoBtn.click(<span class="fstat-no" title="function not covered" >(event)</span> => {</span> <span class="cstat-no" title="statement not covered" > event.preventDefault();</span> <span class="cstat-no" title="statement not covered" > deferred.resolve($videoUrl.val());</span> }); <span class="cstat-no" title="statement not covered" > this.bindEnterKey($videoUrl, $videoBtn);</span> }); <span class="cstat-no" title="statement not covered" > this.ui.onDialogHidden(this.$dialog, <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > $videoUrl.off('input');</span> <span class="cstat-no" title="statement not covered" > $videoBtn.off('click');</span> <span class="cstat-no" title="statement not covered" > if (deferred.state() === 'pending') {</span> <span class="cstat-no" title="statement not covered" > deferred.reject();</span> } }); <span class="cstat-no" title="statement not covered" > this.ui.showDialog(this.$dialog);</span> }); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/HintPopover.js.html000064400000067316151677271550021120 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/HintPopover.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/js/base/module/</a> HintPopover.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">26.36% </span> <span class="quiet">Statements</span> <span class='fraction'>34/129</span> </div> <div class='fl pad1y space-right2'> <span class="strong">7.55% </span> <span class="quiet">Branches</span> <span class='fraction'>4/53</span> </div> <div class='fl pad1y space-right2'> <span class="strong">12.5% </span> <span class="quiet">Functions</span> <span class='fraction'>3/24</span> </div> <div class='fl pad1y space-right2'> <span class="strong">26.36% </span> <span class="quiet">Lines</span> <span class='fraction'>34/129</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227</td><td class="line-coverage quiet"><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-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-yes">1×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</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-no"> </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-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">79×</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-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-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-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-yes">1×</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-yes">1×</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-yes">1×</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-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-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-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-yes">1×</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-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-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-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-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-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-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-yes">1×</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-no"> </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-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-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-yes">1×</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-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-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-yes">1×</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-yes">1×</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-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-no"> </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-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-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-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-no"> </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-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-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-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-no"> </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-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import func from '../core/func'; import lists from '../core/lists'; import dom from '../core/dom'; import range from '../core/range'; import key from '../core/key'; const POPOVER_DIST = 5; export default class HintPopover { constructor(context) { this.context = context; this.ui = $.summernote.ui; this.$editable = context.layoutInfo.editable; this.options = context.options; this.hint = this.options.hint || []; this.direction = this.options.hintDirection || <span class="branch-1 cbranch-no" title="branch not covered" >'bottom';</span> this.hints = $.isArray(this.hint) ? this.hint : <span class="branch-1 cbranch-no" title="branch not covered" >[this.hint];</span> this.events = { 'summernote.keyup': <span class="fstat-no" title="function not covered" >(we, e)</span> => { <span class="cstat-no" title="statement not covered" > if (!e.isDefaultPrevented()) {</span> <span class="cstat-no" title="statement not covered" > this.handleKeyup(e);</span> } }, 'summernote.keydown': <span class="fstat-no" title="function not covered" >(we, e)</span> => { <span class="cstat-no" title="statement not covered" > this.handleKeydown(e);</span> }, 'summernote.disable summernote.dialog.shown': <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.hide();</span> } }; } shouldInitialize() { return this.hints.length > 0; } <span class="fstat-no" title="function not covered" > initialize() {</span> <span class="cstat-no" title="statement not covered" > this.lastWordRange = null;</span> <span class="cstat-no" title="statement not covered" > this.$popover = this.ui.popover({</span> className: 'note-hint-popover', hideArrow: true, direction: '' }).render().appendTo(this.options.container); <span class="cstat-no" title="statement not covered" > this.$popover.hide();</span> <span class="cstat-no" title="statement not covered" > this.$content = this.$popover.find('.popover-content,.note-popover-content');</span> <span class="cstat-no" title="statement not covered" > this.$content.on('click', '.note-hint-item', <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.$content.find('.active').removeClass('active');</span> <span class="cstat-no" title="statement not covered" > $(this).addClass('active');</span> <span class="cstat-no" title="statement not covered" > this.replace();</span> }); } <span class="fstat-no" title="function not covered" > destroy() {</span> <span class="cstat-no" title="statement not covered" > this.$popover.remove();</span> } <span class="fstat-no" title="function not covered" > selectItem($item)</span> { <span class="cstat-no" title="statement not covered" > this.$content.find('.active').removeClass('active');</span> <span class="cstat-no" title="statement not covered" > $item.addClass('active');</span> <span class="cstat-no" title="statement not covered" > this.$content[0].scrollTop = $item[0].offsetTop - (this.$content.innerHeight() / 2);</span> } <span class="fstat-no" title="function not covered" > moveDown() {</span> <span class="cstat-no" title="statement not covered" > const $current = this.$content.find('.note-hint-item.active');</span> <span class="cstat-no" title="statement not covered" > const $next = $current.next();</span> <span class="cstat-no" title="statement not covered" > if ($next.length) {</span> <span class="cstat-no" title="statement not covered" > this.selectItem($next);</span> } else { <span class="cstat-no" title="statement not covered" > let $nextGroup = $current.parent().next();</span> <span class="cstat-no" title="statement not covered" > if (!$nextGroup.length) {</span> <span class="cstat-no" title="statement not covered" > $nextGroup = this.$content.find('.note-hint-group').first();</span> } <span class="cstat-no" title="statement not covered" > this.selectItem($nextGroup.find('.note-hint-item').first());</span> } } <span class="fstat-no" title="function not covered" > moveUp() {</span> <span class="cstat-no" title="statement not covered" > const $current = this.$content.find('.note-hint-item.active');</span> <span class="cstat-no" title="statement not covered" > const $prev = $current.prev();</span> <span class="cstat-no" title="statement not covered" > if ($prev.length) {</span> <span class="cstat-no" title="statement not covered" > this.selectItem($prev);</span> } else { <span class="cstat-no" title="statement not covered" > let $prevGroup = $current.parent().prev();</span> <span class="cstat-no" title="statement not covered" > if (!$prevGroup.length) {</span> <span class="cstat-no" title="statement not covered" > $prevGroup = this.$content.find('.note-hint-group').last();</span> } <span class="cstat-no" title="statement not covered" > this.selectItem($prevGroup.find('.note-hint-item').last());</span> } } <span class="fstat-no" title="function not covered" > replace() {</span> <span class="cstat-no" title="statement not covered" > const $item = this.$content.find('.note-hint-item.active');</span> <span class="cstat-no" title="statement not covered" > if ($item.length) {</span> <span class="cstat-no" title="statement not covered" > const node = this.nodeFromItem($item);</span> // XXX: consider to move codes to editor for recording redo/undo. <span class="cstat-no" title="statement not covered" > this.lastWordRange.insertNode(node);</span> <span class="cstat-no" title="statement not covered" > range.createFromNode(node).collapse().select();</span> <span class="cstat-no" title="statement not covered" > this.lastWordRange = null;</span> <span class="cstat-no" title="statement not covered" > this.hide();</span> <span class="cstat-no" title="statement not covered" > this.context.triggerEvent('change', this.$editable.html(), this.$editable[0]);</span> <span class="cstat-no" title="statement not covered" > this.context.invoke('editor.focus');</span> } } <span class="fstat-no" title="function not covered" > nodeFromItem($item)</span> { <span class="cstat-no" title="statement not covered" > const hint = this.hints[$item.data('index')];</span> <span class="cstat-no" title="statement not covered" > const item = $item.data('item');</span> <span class="cstat-no" title="statement not covered" > let node = hint.content ? hint.content(item) : item;</span> <span class="cstat-no" title="statement not covered" > if (typeof node === 'string') {</span> <span class="cstat-no" title="statement not covered" > node = dom.createText(node);</span> } <span class="cstat-no" title="statement not covered" > return node;</span> } <span class="fstat-no" title="function not covered" > createItemTemplates(hintIdx, items)</span> { <span class="cstat-no" title="statement not covered" > const hint = this.hints[hintIdx];</span> <span class="cstat-no" title="statement not covered" > return items.map(<span class="fstat-no" title="function not covered" >(item, idx)</span> => {</span> <span class="cstat-no" title="statement not covered" > const $item = $('<div class="note-hint-item"/>');</span> <span class="cstat-no" title="statement not covered" > $item.append(hint.template ? hint.template(item) : item + '');</span> <span class="cstat-no" title="statement not covered" > $item.data({</span> 'index': hintIdx, 'item': item }); <span class="cstat-no" title="statement not covered" > return $item;</span> }); } <span class="fstat-no" title="function not covered" > handleKeydown(e)</span> { <span class="cstat-no" title="statement not covered" > if (!this.$popover.is(':visible')) {</span> <span class="cstat-no" title="statement not covered" > return;</span> } <span class="cstat-no" title="statement not covered" > if (e.keyCode === key.code.ENTER) {</span> <span class="cstat-no" title="statement not covered" > e.preventDefault();</span> <span class="cstat-no" title="statement not covered" > this.replace();</span> } else <span class="cstat-no" title="statement not covered" >if (e.keyCode === key.code.UP) {</span> <span class="cstat-no" title="statement not covered" > e.preventDefault();</span> <span class="cstat-no" title="statement not covered" > this.moveUp();</span> } else <span class="cstat-no" title="statement not covered" >if (e.keyCode === key.code.DOWN) {</span> <span class="cstat-no" title="statement not covered" > e.preventDefault();</span> <span class="cstat-no" title="statement not covered" > this.moveDown();</span> } } <span class="fstat-no" title="function not covered" > searchKeyword(index, keyword, callback)</span> { <span class="cstat-no" title="statement not covered" > const hint = this.hints[index];</span> <span class="cstat-no" title="statement not covered" > if (hint && hint.match.test(keyword) && hint.search) {</span> <span class="cstat-no" title="statement not covered" > const matches = hint.match.exec(keyword);</span> <span class="cstat-no" title="statement not covered" > hint.search(matches[1], callback);</span> } else { <span class="cstat-no" title="statement not covered" > callback();</span> } } <span class="fstat-no" title="function not covered" > createGroup(idx, keyword)</span> { <span class="cstat-no" title="statement not covered" > const $group = $('<div class="note-hint-group note-hint-group-' + idx + '"/>');</span> <span class="cstat-no" title="statement not covered" > this.searchKeyword(idx, keyword, <span class="fstat-no" title="function not covered" >(items)</span> => {</span> <span class="cstat-no" title="statement not covered" > items = items || [];</span> <span class="cstat-no" title="statement not covered" > if (items.length) {</span> <span class="cstat-no" title="statement not covered" > $group.html(this.createItemTemplates(idx, items));</span> <span class="cstat-no" title="statement not covered" > this.show();</span> } }); <span class="cstat-no" title="statement not covered" > return $group;</span> } <span class="fstat-no" title="function not covered" > handleKeyup(e)</span> { <span class="cstat-no" title="statement not covered" > if (!lists.contains([key.code.ENTER, key.code.UP, key.code.DOWN], e.keyCode)) {</span> <span class="cstat-no" title="statement not covered" > const wordRange = this.context.invoke('editor.createRange').getWordRange();</span> <span class="cstat-no" title="statement not covered" > const keyword = wordRange.toString();</span> <span class="cstat-no" title="statement not covered" > if (this.hints.length && keyword) {</span> <span class="cstat-no" title="statement not covered" > this.$content.empty();</span> <span class="cstat-no" title="statement not covered" > const bnd = func.rect2bnd(lists.last(wordRange.getClientRects()));</span> <span class="cstat-no" title="statement not covered" > if (bnd) {</span> <span class="cstat-no" title="statement not covered" > this.$popover.hide();</span> <span class="cstat-no" title="statement not covered" > this.lastWordRange = wordRange;</span> <span class="cstat-no" title="statement not covered" > this.hints.forEach(<span class="fstat-no" title="function not covered" >(hint, idx)</span> => {</span> <span class="cstat-no" title="statement not covered" > if (hint.match.test(keyword)) {</span> <span class="cstat-no" title="statement not covered" > this.createGroup(idx, keyword).appendTo(this.$content);</span> } }); // select first .note-hint-item <span class="cstat-no" title="statement not covered" > this.$content.find('.note-hint-item:first').addClass('active');</span> // set position for popover after group is created <span class="cstat-no" title="statement not covered" > if (this.direction === 'top') {</span> <span class="cstat-no" title="statement not covered" > this.$popover.css({</span> left: bnd.left, top: bnd.top - this.$popover.outerHeight() - POPOVER_DIST }); } else { <span class="cstat-no" title="statement not covered" > this.$popover.css({</span> left: bnd.left, top: bnd.top + bnd.height + POPOVER_DIST }); } } } else { <span class="cstat-no" title="statement not covered" > this.hide();</span> } } } <span class="fstat-no" title="function not covered" > show() {</span> <span class="cstat-no" title="statement not covered" > this.$popover.show();</span> } <span class="fstat-no" title="function not covered" > hide() {</span> <span class="cstat-no" title="statement not covered" > this.$popover.hide();</span> } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/Placeholder.js.html000064400000014347151677271550021061 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/Placeholder.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/js/base/module/</a> Placeholder.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">59.09% </span> <span class="quiet">Statements</span> <span class='fraction'>13/22</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/2</span> </div> <div class='fl pad1y space-right2'> <span class="strong">33.33% </span> <span class="quiet">Functions</span> <span class='fraction'>3/9</span> </div> <div class='fl pad1y space-right2'> <span class="strong">59.09% </span> <span class="quiet">Lines</span> <span class='fraction'>13/22</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</td><td class="line-coverage quiet"><span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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-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">79×</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-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-no"> </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-no"> </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-no"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; export default class Placeholder { constructor(context) { this.context = context; this.$editingArea = context.layoutInfo.editingArea; this.options = context.options; this.events = { 'summernote.init summernote.change': <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.update();</span> }, 'summernote.codeview.toggled': <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.update();</span> } }; } shouldInitialize() { return !!this.options.placeholder; } <span class="fstat-no" title="function not covered" > initialize() {</span> <span class="cstat-no" title="statement not covered" > this.$placeholder = $('<div class="note-placeholder">');</span> <span class="cstat-no" title="statement not covered" > this.$placeholder.on('click', <span class="fstat-no" title="function not covered" >() => {</span></span> <span class="cstat-no" title="statement not covered" > this.context.invoke('focus');</span> }).text(this.options.placeholder).prependTo(this.$editingArea); <span class="cstat-no" title="statement not covered" > this.update();</span> } <span class="fstat-no" title="function not covered" > destroy() {</span> <span class="cstat-no" title="statement not covered" > this.$placeholder.remove();</span> } <span class="fstat-no" title="function not covered" > update() {</span> <span class="cstat-no" title="statement not covered" > const isShow = !this.context.invoke('codeview.isActivated') && this.context.invoke('editor.isEmpty');</span> <span class="cstat-no" title="statement not covered" > this.$placeholder.toggle(isShow);</span> } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/module/AutoSync.js.html000064400000007441151677271550020401 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/module/AutoSync.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/js/base/module/</a> AutoSync.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">88.89% </span> <span class="quiet">Statements</span> <span class='fraction'>8/9</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">75% </span> <span class="quiet">Functions</span> <span class='fraction'>3/4</span> </div> <div class='fl pad1y space-right2'> <span class="strong">88.89% </span> <span class="quiet">Lines</span> <span class='fraction'>8/9</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</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">78×</span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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">79×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import dom from '../core/dom'; /** * textarea auto sync. */ export default class AutoSync { constructor(context) { this.$note = context.layoutInfo.note; this.events = { 'summernote.change': <span class="fstat-no" title="function not covered" >() => {</span> <span class="cstat-no" title="statement not covered" > this.$note.val(context.invoke('code'));</span> } }; } shouldInitialize() { return dom.isTextarea(this.$note[0]); } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/summernote-en-US.js.html000064400000037505151677271550020476 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/summernote-en-US.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/js/base/</a> summernote-en-US.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>3/3</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>2/2</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>3/3</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160</td><td class="line-coverage quiet"><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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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">import $ from 'jquery'; $.summernote = $.summernote || { lang: {} }; $.extend($.summernote.lang, { 'en-US': { font: { bold: 'Bold', italic: 'Italic', underline: 'Underline', clear: 'Remove Font Style', height: 'Line Height', name: 'Font Family', strikethrough: 'Strikethrough', subscript: 'Subscript', superscript: 'Superscript', size: 'Font Size' }, image: { image: 'Picture', insert: 'Insert Image', resizeFull: 'Resize Full', resizeHalf: 'Resize Half', resizeQuarter: 'Resize Quarter', floatLeft: 'Float Left', floatRight: 'Float Right', floatNone: 'Float None', shapeRounded: 'Shape: Rounded', shapeCircle: 'Shape: Circle', shapeThumbnail: 'Shape: Thumbnail', shapeNone: 'Shape: None', dragImageHere: 'Drag image or text here', dropImage: 'Drop image or Text', selectFromFiles: 'Select from files', maximumFileSize: 'Maximum file size', maximumFileSizeError: 'Maximum file size exceeded.', url: 'Image URL', remove: 'Remove Image', original: 'Original' }, video: { video: 'Video', videoLink: 'Video Link', insert: 'Insert Video', url: 'Video URL', providers: '(YouTube, Vimeo, Vine, Instagram, DailyMotion or Youku)' }, link: { link: 'Link', insert: 'Insert Link', unlink: 'Unlink', edit: 'Edit', textToDisplay: 'Text to display', url: 'To what URL should this link go?', openInNewWindow: 'Open in new window' }, table: { table: 'Table', addRowAbove: 'Add row above', addRowBelow: 'Add row below', addColLeft: 'Add column left', addColRight: 'Add column right', delRow: 'Delete row', delCol: 'Delete column', delTable: 'Delete table' }, hr: { insert: 'Insert Horizontal Rule' }, style: { style: 'Style', p: 'Normal', blockquote: 'Quote', pre: 'Code', h1: 'Header 1', h2: 'Header 2', h3: 'Header 3', h4: 'Header 4', h5: 'Header 5', h6: 'Header 6' }, lists: { unordered: 'Unordered list', ordered: 'Ordered list' }, options: { help: 'Help', fullscreen: 'Full Screen', codeview: 'Code View' }, paragraph: { paragraph: 'Paragraph', outdent: 'Outdent', indent: 'Indent', left: 'Align left', center: 'Align center', right: 'Align right', justify: 'Justify full' }, color: { recent: 'Recent Color', more: 'More Color', background: 'Background Color', foreground: 'Foreground Color', transparent: 'Transparent', setTransparent: 'Set transparent', reset: 'Reset', resetToDefault: 'Reset to default' }, shortcut: { shortcuts: 'Keyboard shortcuts', close: 'Close', textFormatting: 'Text formatting', action: 'Action', paragraphFormatting: 'Paragraph formatting', documentStyle: 'Document Style', extraKeys: 'Extra keys' }, help: { 'insertParagraph': 'Insert Paragraph', 'undo': 'Undoes the last command', 'redo': 'Redoes the last command', 'tab': 'Tab', 'untab': 'Untab', 'bold': 'Set a bold style', 'italic': 'Set a italic style', 'underline': 'Set a underline style', 'strikethrough': 'Set a strikethrough style', 'removeFormat': 'Clean a style', 'justifyLeft': 'Set left align', 'justifyCenter': 'Set center align', 'justifyRight': 'Set right align', 'justifyFull': 'Set full align', 'insertUnorderedList': 'Toggle unordered list', 'insertOrderedList': 'Toggle ordered list', 'outdent': 'Outdent on current paragraph', 'indent': 'Indent on current paragraph', 'formatPara': 'Change current block\'s format as a paragraph(P tag)', 'formatH1': 'Change current block\'s format as H1', 'formatH2': 'Change current block\'s format as H2', 'formatH3': 'Change current block\'s format as H3', 'formatH4': 'Change current block\'s format as H4', 'formatH5': 'Change current block\'s format as H5', 'formatH6': 'Change current block\'s format as H6', 'insertHorizontalRule': 'Insert horizontal rule', 'linkDialog.show': 'Show Link Dialog' }, history: { undo: 'Undo', redo: 'Redo' }, specialChar: { specialChar: 'SPECIAL CHARACTERS', select: 'Select Special characters' } } }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/index.html000064400000011777151677271550016052 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/</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> src/js/base/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">95.78% </span> <span class="quiet">Statements</span> <span class='fraction'>159/166</span> </div> <div class='fl pad1y space-right2'> <span class="strong">87.1% </span> <span class="quiet">Branches</span> <span class='fraction'>81/93</span> </div> <div class='fl pad1y space-right2'> <span class="strong">97.06% </span> <span class="quiet">Functions</span> <span class='fraction'>33/34</span> </div> <div class='fl pad1y space-right2'> <span class="strong">95.78% </span> <span class="quiet">Lines</span> <span class='fraction'>159/166</span> </div> </div> </div> <div class='status-line high'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file high" data-value="Context.js"><a href="Context.js.html">Context.js</a></td> <td data-value="94.44" class="pic high"><div class="chart"><div class="cover-fill" style="width: 94%;"></div><div class="cover-empty" style="width:6%;"></div></div></td> <td data-value="94.44" class="pct high">94.44%</td> <td data-value="126" class="abs high">119/126</td> <td data-value="81.82" class="pct high">81.82%</td> <td data-value="55" class="abs high">45/55</td> <td data-value="96.3" class="pct high">96.3%</td> <td data-value="27" class="abs high">26/27</td> <td data-value="94.44" class="pct high">94.44%</td> <td data-value="126" class="abs high">119/126</td> </tr> <tr> <td class="file high" data-value="renderer.js"><a href="renderer.js.html">renderer.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="37" class="abs high">37/37</td> <td data-value="94.44" class="pct high">94.44%</td> <td data-value="36" class="abs high">34/36</td> <td data-value="100" class="pct high">100%</td> <td data-value="7" class="abs high">7/7</td> <td data-value="100" class="pct high">100%</td> <td data-value="37" class="abs high">37/37</td> </tr> <tr> <td class="file high" data-value="summernote-en-US.js"><a href="summernote-en-US.js.html">summernote-en-US.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="3" class="abs high">3/3</td> <td data-value="100" class="pct high">100%</td> <td data-value="2" class="abs high">2/2</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="3" class="abs high">3/3</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/Context.js.html000064400000053337151677271550017000 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/Context.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/js/base/</a> Context.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">94.44% </span> <span class="quiet">Statements</span> <span class='fraction'>119/126</span> </div> <div class='fl pad1y space-right2'> <span class="strong">81.82% </span> <span class="quiet">Branches</span> <span class='fraction'>45/55</span> </div> <div class='fl pad1y space-right2'> <span class="strong">96.3% </span> <span class="quiet">Functions</span> <span class='fraction'>26/27</span> </div> <div class='fl pad1y space-right2'> <span class="strong">94.44% </span> <span class="quiet">Lines</span> <span class='fraction'>119/126</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232</td><td class="line-coverage quiet"><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-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-yes">1×</span> <span class="cline-any cline-yes">56×</span> <span class="cline-any cline-yes">56×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">56×</span> <span class="cline-any cline-yes">56×</span> <span class="cline-any cline-yes">56×</span> <span class="cline-any cline-yes">56×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">56×</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">76×</span> <span class="cline-any cline-yes">76×</span> <span class="cline-any cline-yes">76×</span> <span class="cline-any cline-yes">76×</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-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-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-yes">1×</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-yes">78×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">77×</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-yes">77×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">1617×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">77×</span> <span class="cline-any cline-yes">1617×</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">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">42×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">176×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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">8×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6×</span> <span class="cline-any cline-yes">6×</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">115×</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-yes">3×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3×</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">170×</span> <span class="cline-any cline-yes">170×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">170×</span> <span class="cline-any cline-yes">170×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">170×</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">1617×</span> <span class="cline-any cline-yes">1617×</span> <span class="cline-any cline-yes">1617×</span> <span class="cline-any cline-yes">308×</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">1309×</span> <span class="cline-any cline-yes">1155×</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">1309×</span> <span class="cline-any cline-yes">385×</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">1617×</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-yes">1617×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">1617×</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-yes">1×</span> <span class="cline-any cline-yes">42×</span> <span class="cline-any cline-yes">42×</span> <span class="cline-any cline-yes">34×</span> <span class="cline-any cline-yes">10×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">34×</span> <span class="cline-any cline-yes">30×</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">42×</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">11439×</span> <span class="cline-any cline-yes">4663×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6776×</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">176×</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-yes">176×</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">400×</span> <span class="cline-any cline-yes">399×</span> <span class="cline-any cline-yes">13×</span> <span class="cline-any cline-yes">13×</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">2515×</span> <span class="cline-any cline-yes">2514×</span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-yes">14×</span> <span class="cline-any cline-yes">14×</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">873×</span> <span class="cline-any cline-yes">873×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">873×</span> <span class="cline-any cline-yes">873×</span> <span class="cline-any cline-yes">873×</span> <span class="cline-any cline-yes">873×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">873×</span> <span class="cline-any cline-yes">873×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">869×</span> <span class="cline-any cline-yes">869×</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></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import func from './core/func'; import lists from './core/lists'; import dom from './core/dom'; export default class Context { /** * @param {jQuery} $note * @param {Object} options */ constructor($note, options) { this.ui = $.summernote.ui; this.$note = $note; this.memos = {}; this.modules = {}; this.layoutInfo = {}; this.options = options; this.initialize(); } /** * create layout and initialize modules and other resources */ initialize() { this.layoutInfo = this.ui.createLayout(this.$note, this.options); this._initialize(); this.$note.hide(); return this; } /** * destroy modules and other resources and remove layout */ destroy() { this._destroy(); this.$note.removeData('summernote'); this.ui.removeLayout(this.$note, this.layoutInfo); } /** * destory modules and other resources and initialize it again */ reset() { const disabled = this.isDisabled(); this.code(dom.emptyPara); this._destroy(); this._initialize(); <span class="missing-if-branch" title="else path not taken" >E</span>if (disabled) { this.disable(); } } _initialize() { // add optional buttons const buttons = $.extend({}, this.options.buttons); Object.keys(buttons).forEach(<span class="fstat-no" title="function not covered" >(key)</span> => { <span class="cstat-no" title="statement not covered" > this.memo('button.' + key, buttons[key]);</span> }); const modules = $.extend({}, this.options.modules, $.summernote.plugins || <span class="branch-1 cbranch-no" title="branch not covered" >{})</span>; // add and initialize modules Object.keys(modules).forEach((key) => { this.module(key, modules[key], true); }); Object.keys(this.modules).forEach((key) => { this.initializeModule(key); }); } _destroy() { // destroy modules with reversed order Object.keys(this.modules).reverse().forEach((key) => { this.removeModule(key); }); Object.keys(this.memos).forEach((key) => { this.removeMemo(key); }); // trigger custom onDestroy callback this.triggerEvent('destroy', this); } code(html) { const isActivated = this.invoke('codeview.isActivated'); if (html === undefined) { this.invoke('codeview.sync'); return isActivated ? <span class="branch-0 cbranch-no" title="branch not covered" >this.layoutInfo.codable.val() </span>: this.layoutInfo.editable.html(); } else { <span class="missing-if-branch" title="if path not taken" >I</span>if (isActivated) { <span class="cstat-no" title="statement not covered" > this.layoutInfo.codable.val(html);</span> } else { this.layoutInfo.editable.html(html); } this.$note.val(html); this.triggerEvent('change', html); } } isDisabled() { return this.layoutInfo.editable.attr('contenteditable') === 'false'; } enable() { this.layoutInfo.editable.attr('contenteditable', true); this.invoke('toolbar.activate', true); this.triggerEvent('disable', false); } disable() { // close codeview if codeview is opend <span class="missing-if-branch" title="if path not taken" >I</span>if (this.invoke('codeview.isActivated')) { <span class="cstat-no" title="statement not covered" > this.invoke('codeview.deactivate');</span> } this.layoutInfo.editable.attr('contenteditable', false); this.invoke('toolbar.deactivate', true); this.triggerEvent('disable', true); } triggerEvent() { const namespace = lists.head(arguments); const args = lists.tail(lists.from(arguments)); const callback = this.options.callbacks[func.namespaceToCamel(namespace, 'on')]; <span class="missing-if-branch" title="if path not taken" >I</span>if (callback) { <span class="cstat-no" title="statement not covered" > callback.apply(this.$note[0], args);</span> } this.$note.trigger('summernote.' + namespace, args); } initializeModule(key) { const module = this.modules[key]; module.shouldInitialize = module.shouldInitialize || func.ok; if (!module.shouldInitialize()) { return; } // initialize module if (module.initialize) { module.initialize(); } // attach events if (module.events) { dom.attachEvents(this.$note, module.events); } } module(key, ModuleClass, withoutIntialize) { <span class="missing-if-branch" title="if path not taken" >I</span>if (arguments.length === 1) { <span class="cstat-no" title="statement not covered" > return this.modules[key];</span> } this.modules[key] = new ModuleClass(this); <span class="missing-if-branch" title="if path not taken" >I</span>if (!withoutIntialize) { <span class="cstat-no" title="statement not covered" > this.initializeModule(key);</span> } } removeModule(key) { const module = this.modules[key]; if (module.shouldInitialize()) { if (module.events) { dom.detachEvents(this.$note, module.events); } if (module.destroy) { module.destroy(); } } delete this.modules[key]; } memo(key, obj) { if (arguments.length === 1) { return this.memos[key]; } this.memos[key] = obj; } removeMemo(key) { <span class="missing-if-branch" title="if path not taken" >I</span>if (this.memos[key] && this.memos[key].destroy) { <span class="cstat-no" title="statement not covered" > this.memos[key].destroy();</span> } delete this.memos[key]; } /** * Some buttons need to change their visual style immediately once they get pressed */ createInvokeHandlerAndUpdateState(namespace, value) { return (event) => { this.createInvokeHandler(namespace, value)(event); this.invoke('buttons.updateCurrentStyle'); }; } createInvokeHandler(namespace, value) { return (event) => { event.preventDefault(); const $target = $(event.target); this.invoke(namespace, value || $target.closest('[data-value]').data('value'), $target); }; } invoke() { const namespace = lists.head(arguments); const args = lists.tail(lists.from(arguments)); const splits = namespace.split('.'); const hasSeparator = splits.length > 1; const moduleName = hasSeparator && lists.head(splits); const methodName = hasSeparator ? lists.last(splits) : lists.head(splits); const module = this.modules[moduleName || 'editor']; if (!moduleName && this[methodName]) { return this[methodName].apply(this, args); } else <span class="missing-if-branch" title="else path not taken" >E</span>if (module && module[methodName] && module.shouldInitialize()) { return module[methodName].apply(module, args); } } } </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/base/renderer.js.html000064400000017154151677271550017157 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/base/renderer.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/js/base/</a> renderer.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>37/37</span> </div> <div class='fl pad1y space-right2'> <span class="strong">94.44% </span> <span class="quiet">Branches</span> <span class='fraction'>34/36</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>7/7</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>37/37</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</td><td class="line-coverage quiet"><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-yes">1×</span> <span class="cline-any cline-yes">6335×</span> <span class="cline-any cline-yes">6335×</span> <span class="cline-any cline-yes">6335×</span> <span class="cline-any cline-yes">6335×</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">6311×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6311×</span> <span class="cline-any cline-yes">3095×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6311×</span> <span class="cline-any cline-yes">3281×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6311×</span> <span class="cline-any cline-yes">401×</span> <span class="cline-any cline-yes">401×</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">6311×</span> <span class="cline-any cline-yes">2949×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6311×</span> <span class="cline-any cline-yes">6311×</span> <span class="cline-any cline-yes">6311×</span> <span class="cline-any cline-yes">1839×</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">6311×</span> <span class="cline-any cline-yes">4258×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6311×</span> <span class="cline-any cline-yes">373×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6311×</span> <span class="cline-any cline-yes">1839×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6311×</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-yes">1×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">3134×</span> <span class="cline-any cline-yes">6335×</span> <span class="cline-any cline-yes">6335×</span> <span class="cline-any cline-yes">6335×</span> <span class="cline-any cline-yes">219×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6335×</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">import $ from 'jquery'; class Renderer { constructor(markup, children, options, callback) { this.markup = markup; this.children = children; this.options = options; this.callback = callback; } render($parent) { const $node = $(this.markup); if (this.options && this.options.contents) { $node.html(this.options.contents); } if (this.options && this.options.className) { $node.addClass(this.options.className); } if (this.options && this.options.data) { $.each(this.options.data, (k, v) => { $node.attr('data-' + k, v); }); } if (this.options && this.options.click) { $node.on('click', this.options.click); } <span class="missing-if-branch" title="else path not taken" >E</span>if (this.children) { const $container = $node.find('.note-children-container'); this.children.forEach((child) => { child.render($container.length ? <span class="branch-0 cbranch-no" title="branch not covered" >$container </span>: $node); }); } if (this.callback) { this.callback($node, this.options); } if (this.options && this.options.callback) { this.options.callback($node); } if ($parent) { $parent.append($node); } return $node; } } export default { create: (markup, callback) => { return () => { const options = typeof arguments[1] === 'object' ? arguments[1] : arguments[0]; let children = $.isArray(arguments[0]) ? arguments[0] : []; if (options && options.children) { children = options.children; } return new Renderer(markup, children, options, callback); }; } }; </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/index.html000064400000007075151677271550015134 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/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> src/js/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">19.23% </span> <span class="quiet">Statements</span> <span class='fraction'>5/26</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/12</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/2</span> </div> <div class='fl pad1y space-right2'> <span class="strong">19.23% </span> <span class="quiet">Lines</span> <span class='fraction'>5/26</span> </div> </div> </div> <div class='status-line low'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file low" data-value="summernote.js"><a href="summernote.js.html">summernote.js</a></td> <td data-value="19.23" class="pic low"><div class="chart"><div class="cover-fill" style="width: 19%;"></div><div class="cover-empty" style="width:81%;"></div></div></td> <td data-value="19.23" class="pct low">19.23%</td> <td data-value="26" class="abs low">5/26</td> <td data-value="0" class="pct low">0%</td> <td data-value="12" class="abs low">0/12</td> <td data-value="0" class="pct low">0%</td> <td data-value="2" class="abs low">0/2</td> <td data-value="19.23" class="pct low">19.23%</td> <td data-value="26" class="abs low">5/26</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/summernote.js.html000064400000016761151677271550016640 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/summernote.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/js/</a> summernote.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">19.23% </span> <span class="quiet">Statements</span> <span class='fraction'>5/26</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/12</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/2</span> </div> <div class='fl pad1y space-right2'> <span class="strong">19.23% </span> <span class="quiet">Lines</span> <span class='fraction'>5/26</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</td><td class="line-coverage quiet"><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-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-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-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-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-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-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-no"> </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">import $ from 'jquery'; import env from './base/core/env'; import lists from './base/core/lists'; import Context from './base/Context'; $.fn.extend({ /** * Summernote API * * @param {Object|String} * @return {this} */ summernote: <span class="fstat-no" title="function not covered" >function() {</span> <span class="cstat-no" title="statement not covered" > const type = $.type(lists.head(arguments));</span> <span class="cstat-no" title="statement not covered" > const isExternalAPICalled = type === 'string';</span> <span class="cstat-no" title="statement not covered" > const hasInitOptions = type === 'object';</span> <span class="cstat-no" title="statement not covered" > const options = $.extend({}, $.summernote.options, hasInitOptions ? lists.head(arguments) : {});</span> // Update options <span class="cstat-no" title="statement not covered" > options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]);</span> <span class="cstat-no" title="statement not covered" > options.icons = $.extend(true, {}, $.summernote.options.icons, options.icons);</span> <span class="cstat-no" title="statement not covered" > options.tooltip = options.tooltip === 'auto' ? !env.isSupportTouch : options.tooltip;</span> <span class="cstat-no" title="statement not covered" > this.each(<span class="fstat-no" title="function not covered" >(idx, note)</span> => {</span> <span class="cstat-no" title="statement not covered" > const $note = $(note);</span> <span class="cstat-no" title="statement not covered" > if (!$note.data('summernote')) {</span> <span class="cstat-no" title="statement not covered" > const context = new Context($note, options);</span> <span class="cstat-no" title="statement not covered" > $note.data('summernote', context);</span> <span class="cstat-no" title="statement not covered" > $note.data('summernote').triggerEvent('init', context.layoutInfo);</span> } }); <span class="cstat-no" title="statement not covered" > const $note = this.first();</span> <span class="cstat-no" title="statement not covered" > if ($note.length) {</span> <span class="cstat-no" title="statement not covered" > const context = $note.data('summernote');</span> <span class="cstat-no" title="statement not covered" > if (isExternalAPICalled) {</span> <span class="cstat-no" title="statement not covered" > return context.invoke.apply(context, lists.from(arguments));</span> } else <span class="cstat-no" title="statement not covered" >if (options.focus) {</span> <span class="cstat-no" title="statement not covered" > context.invoke('editor.focus');</span> } } <span class="cstat-no" title="statement not covered" > return this;</span> } }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/lite/ui.js.html000064400000213603151677271550016006 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/lite/ui.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/js/lite/</a> ui.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Statements</span> <span class='fraction'>0/178</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/91</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/40</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Lines</span> <span class='fraction'>0/178</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619</td><td class="line-coverage quiet"><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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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> <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-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> <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-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-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-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-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-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-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-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-no"> </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-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-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-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-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-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-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-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> <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-neutral"> </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-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> <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-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-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-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-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-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-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-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-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-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-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-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-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-no"> </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-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-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-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-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-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-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> <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> <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-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-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-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-neutral"> </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-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-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-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-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-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-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> <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-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> <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-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-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-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-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-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-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-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-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> <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-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-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-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> <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-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-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-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-no"> </span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" >import renderer from '../base/renderer';</span> <span class="cstat-no" title="statement not covered" >import TooltipUI from './ui/TooltipUI';</span> <span class="cstat-no" title="statement not covered" >import DropdownUI from './ui/DropdownUI';</span> <span class="cstat-no" title="statement not covered" >import ModalUI from './ui/ModalUI';</span> <span class="cstat-no" title="statement not covered" >const editor = renderer.create('<div class="note-editor note-frame"/>');</span> <span class="cstat-no" title="statement not covered" >const toolbar = renderer.create('<div class="note-toolbar" role="toolbar"/>');</span> <span class="cstat-no" title="statement not covered" >const editingArea = renderer.create('<div class="note-editing-area"/>');</span> <span class="cstat-no" title="statement not covered" >const codable = renderer.create('<textarea class="note-codable" role="textbox" aria-multiline="true"/>');</span> <span class="cstat-no" title="statement not covered" >const editable = renderer.create('<div class="note-editable" contentEditable="true" role="textbox" aria-multiline="true"/>');</span> <span class="cstat-no" title="statement not covered" >const statusbar = renderer.create([</span> '<output class="note-status-output" role="status" aria-live="polite"/>', '<div class="note-statusbar" role="resize">', ' <div class="note-resizebar" role="seperator" aria-orientation="horizontal" aria-label="resize">', ' <div class="note-icon-bar"/>', ' <div class="note-icon-bar"/>', ' <div class="note-icon-bar"/>', ' </div>', '</div>' ].join('')); <span class="cstat-no" title="statement not covered" >const airEditor = renderer.create('<div class="note-editor"/>');</span> <span class="cstat-no" title="statement not covered" >const airEditable = renderer.create([</span> '<output class="note-status-output" role="status" aria-live="polite"/>', '<div class="note-editable" contentEditable="true" role="textbox" aria-multiline="true"/>' ].join('')); <span class="cstat-no" title="statement not covered" >const buttonGroup = renderer.create('<div class="note-btn-group">');</span> <span class="cstat-no" title="statement not covered" >const button = renderer.create('<button type="button" class="note-btn" role="button" tabindex="-1">', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> // set button type <span class="cstat-no" title="statement not covered" > if (options && options.tooltip) {</span> <span class="cstat-no" title="statement not covered" > $node.attr({</span> 'aria-label': options.tooltip }); <span class="cstat-no" title="statement not covered" > $node.data('_lite_tooltip', new TooltipUI($node, {</span> title: options.tooltip, container: options.container })); } <span class="cstat-no" title="statement not covered" > if (options.contents) {</span> <span class="cstat-no" title="statement not covered" > $node.html(options.contents);</span> } <span class="cstat-no" title="statement not covered" > if (options && options.data && options.data.toggle === 'dropdown') {</span> <span class="cstat-no" title="statement not covered" > $node.data('_lite_dropdown', new DropdownUI($node, {</span> container: options.container })); } }); <span class="cstat-no" title="statement not covered" >const dropdown = renderer.create('<div class="note-dropdown-menu" role="list">', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > const markup = $.isArray(options.items) ? options.items.map(<span class="fstat-no" title="function not covered" >function(item)</span> {</span> <span class="cstat-no" title="statement not covered" > const value = (typeof item === 'string') ? item : (item.value || '');</span> <span class="cstat-no" title="statement not covered" > const content = options.template ? options.template(item) : item;</span> <span class="cstat-no" title="statement not covered" > const $temp = $('<a class="note-dropdown-item" href="#" data-value="' + value + '" role="listitem" aria-label="' + item + '"></a>');</span> <span class="cstat-no" title="statement not covered" > $temp.html(content).data('item', item);</span> <span class="cstat-no" title="statement not covered" > return $temp;</span> }) : options.items; <span class="cstat-no" title="statement not covered" > $node.html(markup).attr({'aria-label': options.title});</span> <span class="cstat-no" title="statement not covered" > $node.on('click', '> .note-dropdown-item', <span class="fstat-no" title="function not covered" >function(e)</span> {</span> <span class="cstat-no" title="statement not covered" > const $a = $(this);</span> <span class="cstat-no" title="statement not covered" > const item = $a.data('item');</span> <span class="cstat-no" title="statement not covered" > const value = $a.data('value');</span> <span class="cstat-no" title="statement not covered" > if (item.click) {</span> <span class="cstat-no" title="statement not covered" > item.click($a);</span> } else <span class="cstat-no" title="statement not covered" >if (options.itemClick) {</span> <span class="cstat-no" title="statement not covered" > options.itemClick(e, item, value);</span> } }); }); <span class="cstat-no" title="statement not covered" >const dropdownCheck = renderer.create('<div class="note-dropdown-menu note-check" role="list">', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > const markup = $.isArray(options.items) ? options.items.map(<span class="fstat-no" title="function not covered" >function(item)</span> {</span> <span class="cstat-no" title="statement not covered" > const value = (typeof item === 'string') ? item : (item.value || '');</span> <span class="cstat-no" title="statement not covered" > const content = options.template ? options.template(item) : item;</span> <span class="cstat-no" title="statement not covered" > const $temp = $('<a class="note-dropdown-item" href="#" data-value="' + value + '" role="listitem" aria-label="' + item + '"></a>');</span> <span class="cstat-no" title="statement not covered" > $temp.html([icon(options.checkClassName), ' ', content]).data('item', item);</span> <span class="cstat-no" title="statement not covered" > return $temp;</span> }) : options.items; <span class="cstat-no" title="statement not covered" > $node.html(markup).attr({'aria-label': options.title});</span> <span class="cstat-no" title="statement not covered" > $node.on('click', '> .note-dropdown-item', <span class="fstat-no" title="function not covered" >function(e)</span> {</span> <span class="cstat-no" title="statement not covered" > const $a = $(this);</span> <span class="cstat-no" title="statement not covered" > const item = $a.data('item');</span> <span class="cstat-no" title="statement not covered" > const value = $a.data('value');</span> <span class="cstat-no" title="statement not covered" > if (item.click) {</span> <span class="cstat-no" title="statement not covered" > item.click($a);</span> } else <span class="cstat-no" title="statement not covered" >if (options.itemClick) {</span> <span class="cstat-no" title="statement not covered" > options.itemClick(e, item, value);</span> } }); }); <span class="cstat-no" title="statement not covered" >const dropdownButtonContents = <span class="fstat-no" title="function not covered" >function(contents, options)</span> {</span> <span class="cstat-no" title="statement not covered" > return contents + ' ' + icon(options.icons.caret, 'span');</span> }; <span class="cstat-no" title="statement not covered" >const dropdownButton = <span class="fstat-no" title="function not covered" >function(opt, callback)</span> {</span> <span class="cstat-no" title="statement not covered" > return buttonGroup([</span> button({ className: 'dropdown-toggle', contents: opt.title + ' ' + icon('note-icon-caret'), tooltip: opt.tooltip, data: { toggle: 'dropdown' } }), dropdown({ className: opt.className, items: opt.items, template: opt.template, itemClick: opt.itemClick }) ], { callback: callback }).render(); }; <span class="cstat-no" title="statement not covered" >const dropdownCheckButton = <span class="fstat-no" title="function not covered" >function(opt, callback)</span> {</span> <span class="cstat-no" title="statement not covered" > return buttonGroup([</span> button({ className: 'dropdown-toggle', contents: opt.title + ' ' + icon('note-icon-caret'), tooltip: opt.tooltip, data: { toggle: 'dropdown' } }), dropdownCheck({ className: opt.className, checkClassName: opt.checkClassName, items: opt.items, template: opt.template, itemClick: opt.itemClick }) ], { callback: callback }).render(); }; <span class="cstat-no" title="statement not covered" >const paragraphDropdownButton = <span class="fstat-no" title="function not covered" >function(opt)</span> {</span> <span class="cstat-no" title="statement not covered" > return buttonGroup([</span> button({ className: 'dropdown-toggle', contents: opt.title + ' ' + icon('note-icon-caret'), tooltip: opt.tooltip, data: { toggle: 'dropdown' } }), dropdown([ buttonGroup({ className: 'note-align', children: opt.items[0] }), buttonGroup({ className: 'note-list', children: opt.items[1] }) ]) ]).render(); }; <span class="cstat-no" title="statement not covered" >const tableMoveHandler = <span class="fstat-no" title="function not covered" >function(event, col, row)</span> {</span> <span class="cstat-no" title="statement not covered" > const PX_PER_EM = 18;</span> <span class="cstat-no" title="statement not covered" > const $picker = $(event.target.parentNode); </span>// target is mousecatcher <span class="cstat-no" title="statement not covered" > const $dimensionDisplay = $picker.next();</span> <span class="cstat-no" title="statement not covered" > const $catcher = $picker.find('.note-dimension-picker-mousecatcher');</span> <span class="cstat-no" title="statement not covered" > const $highlighted = $picker.find('.note-dimension-picker-highlighted');</span> <span class="cstat-no" title="statement not covered" > const $unhighlighted = $picker.find('.note-dimension-picker-unhighlighted');</span> <span class="cstat-no" title="statement not covered" > let posOffset;</span> // HTML5 with jQuery - e.offsetX is undefined in Firefox <span class="cstat-no" title="statement not covered" > if (event.offsetX === undefined) {</span> <span class="cstat-no" title="statement not covered" > const posCatcher = $(event.target).offset();</span> <span class="cstat-no" title="statement not covered" > posOffset = {</span> x: event.pageX - posCatcher.left, y: event.pageY - posCatcher.top }; } else { <span class="cstat-no" title="statement not covered" > posOffset = {</span> x: event.offsetX, y: event.offsetY }; } <span class="cstat-no" title="statement not covered" > const dim = {</span> c: Math.ceil(posOffset.x / PX_PER_EM) || 1, r: Math.ceil(posOffset.y / PX_PER_EM) || 1 }; <span class="cstat-no" title="statement not covered" > $highlighted.css({ width: dim.c + 'em', height: dim.r + 'em' });</span> <span class="cstat-no" title="statement not covered" > $catcher.data('value', dim.c + 'x' + dim.r);</span> <span class="cstat-no" title="statement not covered" > if (dim.c > 3 && dim.c < col) {</span> <span class="cstat-no" title="statement not covered" > $unhighlighted.css({ width: dim.c + 1 + 'em' });</span> } <span class="cstat-no" title="statement not covered" > if (dim.r > 3 && dim.r < row) {</span> <span class="cstat-no" title="statement not covered" > $unhighlighted.css({ height: dim.r + 1 + 'em' });</span> } <span class="cstat-no" title="statement not covered" > $dimensionDisplay.html(dim.c + ' x ' + dim.r);</span> }; <span class="cstat-no" title="statement not covered" >const tableDropdownButton = <span class="fstat-no" title="function not covered" >function(opt)</span> {</span> <span class="cstat-no" title="statement not covered" > return buttonGroup([</span> button({ className: 'dropdown-toggle', contents: opt.title + ' ' + icon('note-icon-caret'), tooltip: opt.tooltip, data: { toggle: 'dropdown' } }), dropdown({ className: 'note-table', items: [ '<div class="note-dimension-picker">', ' <div class="note-dimension-picker-mousecatcher" data-event="insertTable" data-value="1x1"/>', ' <div class="note-dimension-picker-highlighted"/>', ' <div class="note-dimension-picker-unhighlighted"/>', '</div>', '<div class="note-dimension-display">1 x 1</div>' ].join('') }) ], { callback: <span class="fstat-no" title="function not covered" >function($node)</span> { <span class="cstat-no" title="statement not covered" > const $catcher = $node.find('.note-dimension-picker-mousecatcher');</span> <span class="cstat-no" title="statement not covered" > $catcher.css({</span> width: opt.col + 'em', height: opt.row + 'em' }) .mousedown(opt.itemClick) .mousemove(<span class="fstat-no" title="function not covered" >function(e)</span> { <span class="cstat-no" title="statement not covered" > tableMoveHandler(e, opt.col, opt.row);</span> }); } }).render(); }; <span class="cstat-no" title="statement not covered" >const palette = renderer.create('<div class="note-color-palette"/>', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > const contents = [];</span> <span class="cstat-no" title="statement not covered" > for (let row = 0, rowSize = options.colors.length; row < rowSize; row++) {</span> <span class="cstat-no" title="statement not covered" > const eventName = options.eventName;</span> <span class="cstat-no" title="statement not covered" > const colors = options.colors[row];</span> <span class="cstat-no" title="statement not covered" > const colorsName = options.colorsName[row];</span> <span class="cstat-no" title="statement not covered" > const buttons = [];</span> <span class="cstat-no" title="statement not covered" > for (let col = 0, colSize = colors.length; col < colSize; col++) {</span> <span class="cstat-no" title="statement not covered" > const color = colors[col];</span> <span class="cstat-no" title="statement not covered" > const colorName = colorsName[col];</span> <span class="cstat-no" title="statement not covered" > buttons.push([</span> '<button type="button" class="note-btn note-color-btn"', 'style="background-color:', color, '" ', 'data-event="', eventName, '" ', 'data-value="', color, '" ', 'title="', colorName, '" ', 'aria-label="', colorName, '" ', 'data-toggle="button" tabindex="-1"></button>' ].join('')); } <span class="cstat-no" title="statement not covered" > contents.push('<div class="note-color-row">' + buttons.join('') + '</div>');</span> } <span class="cstat-no" title="statement not covered" > $node.html(contents.join(''));</span> <span class="cstat-no" title="statement not covered" > $node.find('.note-color-btn').each(<span class="fstat-no" title="function not covered" >function() {</span></span> <span class="cstat-no" title="statement not covered" > $(this).data('_lite_tooltip', new TooltipUI($(this), {</span> container: options.container })); }); }); <span class="cstat-no" title="statement not covered" >const colorDropdownButton = <span class="fstat-no" title="function not covered" >function(opt, type)</span> {</span> <span class="cstat-no" title="statement not covered" > return buttonGroup({</span> className: 'note-color', children: [ button({ className: 'note-current-color-button', contents: opt.title, tooltip: opt.lang.color.recent, click: opt.currentClick, callback: <span class="fstat-no" title="function not covered" >function($button)</span> { <span class="cstat-no" title="statement not covered" > const $recentColor = $button.find('.note-recent-color');</span> <span class="cstat-no" title="statement not covered" > if (type !== 'foreColor') {</span> <span class="cstat-no" title="statement not covered" > $recentColor.css('background-color', '#FFFF00');</span> <span class="cstat-no" title="statement not covered" > $button.attr('data-backColor', '#FFFF00');</span> } } }), button({ className: 'dropdown-toggle', contents: icon('note-icon-caret'), tooltip: opt.lang.color.more, data: { toggle: 'dropdown' } }), dropdown({ items: [ '<div>', '<div class="note-btn-group btn-background-color">', ' <div class="note-palette-title">' + opt.lang.color.background + '</div>', ' <div>', '<button type="button" class="note-color-reset note-btn note-btn-block" ' + ' data-event="backColor" data-value="inherit">', opt.lang.color.transparent, ' </button>', ' </div>', ' <div class="note-holder" data-event="backColor"/>', '</div>', '<div class="note-btn-group btn-foreground-color">', ' <div class="note-palette-title">' + opt.lang.color.foreground + '</div>', ' <div>', '<button type="button" class="note-color-reset note-btn note-btn-block" ' + ' data-event="removeFormat" data-value="foreColor">', opt.lang.color.resetToDefault, ' </button>', ' </div>', ' <div class="note-holder" data-event="foreColor"/>', '</div>', '</div>' ].join(''), callback: <span class="fstat-no" title="function not covered" >function($dropdown)</span> { <span class="cstat-no" title="statement not covered" > $dropdown.find('.note-holder').each(<span class="fstat-no" title="function not covered" >function() {</span></span> <span class="cstat-no" title="statement not covered" > const $holder = $(this);</span> <span class="cstat-no" title="statement not covered" > $holder.append(palette({</span> colors: opt.colors, eventName: $holder.data('event') }).render()); }); <span class="cstat-no" title="statement not covered" > if (type === 'fore') {</span> <span class="cstat-no" title="statement not covered" > $dropdown.find('.btn-background-color').hide();</span> <span class="cstat-no" title="statement not covered" > $dropdown.css({ 'min-width': '210px' });</span> } else <span class="cstat-no" title="statement not covered" >if (type === 'back') {</span> <span class="cstat-no" title="statement not covered" > $dropdown.find('.btn-foreground-color').hide();</span> <span class="cstat-no" title="statement not covered" > $dropdown.css({ 'min-width': '210px' });</span> } }, click: <span class="fstat-no" title="function not covered" >function(event)</span> { <span class="cstat-no" title="statement not covered" > const $button = $(event.target);</span> <span class="cstat-no" title="statement not covered" > const eventName = $button.data('event');</span> <span class="cstat-no" title="statement not covered" > const value = $button.data('value');</span> <span class="cstat-no" title="statement not covered" > if (eventName && value) {</span> <span class="cstat-no" title="statement not covered" > const key = eventName === 'backColor' ? 'background-color' : 'color';</span> <span class="cstat-no" title="statement not covered" > const $color = $button.closest('.note-color').find('.note-recent-color');</span> <span class="cstat-no" title="statement not covered" > const $currentButton = $button.closest('.note-color').find('.note-current-color-button');</span> <span class="cstat-no" title="statement not covered" > $color.css(key, value);</span> <span class="cstat-no" title="statement not covered" > $currentButton.attr('data-' + eventName, value);</span> <span class="cstat-no" title="statement not covered" > if (type === 'fore') {</span> <span class="cstat-no" title="statement not covered" > opt.itemClick('foreColor', value);</span> } else <span class="cstat-no" title="statement not covered" >if (type === 'back') {</span> <span class="cstat-no" title="statement not covered" > opt.itemClick('backColor', value);</span> } else { <span class="cstat-no" title="statement not covered" > opt.itemClick(eventName, value);</span> } } } }) ] }).render(); }; <span class="cstat-no" title="statement not covered" >const dialog = renderer.create('<div class="note-modal" aria-hidden="false" tabindex="-1" role="dialog"/>', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > if (options.fade) {</span> <span class="cstat-no" title="statement not covered" > $node.addClass('fade');</span> } <span class="cstat-no" title="statement not covered" > $node.attr({</span> 'aria-label': options.title }); <span class="cstat-no" title="statement not covered" > $node.html([</span> ' <div class="note-modal-content">', (options.title ? ' <div class="note-modal-header">' + ' <button type="button" class="close" aria-label="Close" aria-hidden="true"><i class="note-icon-close"></i></button>' + ' <h4 class="note-modal-title">' + options.title + '</h4>' + ' </div>' : '' ), ' <div class="note-modal-body">' + options.body + '</div>', (options.footer ? ' <div class="note-modal-footer">' + options.footer + '</div>' : '' ), ' </div>' ].join('')); <span class="cstat-no" title="statement not covered" > $node.data('modal', new ModalUI($node, options));</span> }); <span class="cstat-no" title="statement not covered" >const videoDialog = <span class="fstat-no" title="function not covered" >function(opt)</span> {</span> <span class="cstat-no" title="statement not covered" > const body = '<div class="note-form-group">' +</span> '<label class="note-form-label">' + opt.lang.video.url + ' <small class="text-muted">' + opt.lang.video.providers + '</small>' + '</label>' + '<input class="note-video-url note-input" type="text" />' + '</div>'; <span class="cstat-no" title="statement not covered" > const footer = [</span> '<button type="button" href="#" class="note-btn note-btn-primary note-video-btn disabled" disabled>', opt.lang.video.insert, '</button>' ].join(''); <span class="cstat-no" title="statement not covered" > return dialog({</span> title: opt.lang.video.insert, fade: opt.fade, body: body, footer: footer }).render(); }; <span class="cstat-no" title="statement not covered" >const imageDialog = <span class="fstat-no" title="function not covered" >function(opt)</span> {</span> <span class="cstat-no" title="statement not covered" > const body = '<div class="note-form-group note-group-select-from-files">' +</span> '<label class="note-form-label">' + opt.lang.image.selectFromFiles + '</label>' + '<input class="note-note-image-input note-input" type="file" name="files" accept="image/*" multiple="multiple" />' + opt.imageLimitation + '</div>' + '<div class="note-form-group" style="overflow:auto;">' + '<label class="note-form-label">' + opt.lang.image.url + '</label>' + '<input class="note-image-url note-input" type="text" />' + '</div>'; <span class="cstat-no" title="statement not covered" > const footer = [</span> '<button href="#" type="button" class="note-btn note-btn-primary note-btn-large note-image-btn disabled" disabled>', opt.lang.image.insert, '</button>' ].join(''); <span class="cstat-no" title="statement not covered" > return dialog({</span> title: opt.lang.image.insert, fade: opt.fade, body: body, footer: footer }).render(); }; <span class="cstat-no" title="statement not covered" >const linkDialog = <span class="fstat-no" title="function not covered" >function(opt)</span> {</span> <span class="cstat-no" title="statement not covered" > const body = '<div class="note-form-group">' +</span> '<label class="note-form-label">' + opt.lang.link.textToDisplay + '</label>' + '<input class="note-link-text note-input" type="text" />' + '</div>' + '<div class="note-form-group">' + '<label class="note-form-label">' + opt.lang.link.url + '</label>' + '<input class="note-link-url note-input" type="text" value="http://" />' + '</div>' + (!opt.disableLinkTarget ? '<div class="checkbox">' + '<label>' + '<input type="checkbox" checked> ' + opt.lang.link.openInNewWindow + '</label>' + '</div>' : '' ); <span class="cstat-no" title="statement not covered" > const footer = [</span> '<button href="#" type="button" class="note-btn note-btn-primary note-link-btn disabled" disabled>', opt.lang.link.insert, '</button>' ].join(''); <span class="cstat-no" title="statement not covered" > return dialog({</span> className: 'link-dialog', title: opt.lang.link.insert, fade: opt.fade, body: body, footer: footer }).render(); }; <span class="cstat-no" title="statement not covered" >const popover = renderer.create([</span> '<div class="note-popover bottom">', ' <div class="note-popover-arrow"/>', ' <div class="note-popover-content note-children-container"/>', '</div>' ].join(''), <span class="fstat-no" title="function not covered" >function($node, options)</span> { <span class="cstat-no" title="statement not covered" > const direction = typeof options.direction !== 'undefined' ? options.direction : 'bottom';</span> <span class="cstat-no" title="statement not covered" > $node.addClass(direction).hide();</span> <span class="cstat-no" title="statement not covered" > if (options.hideArrow) {</span> <span class="cstat-no" title="statement not covered" > $node.find('.note-popover-arrow').hide();</span> } }); <span class="cstat-no" title="statement not covered" >const checkbox = renderer.create('<div class="checkbox"></div>', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > $node.html([</span> ' <label' + (options.id ? ' for="' + options.id + '"' : '') + '>', ' <input role="checkbox" type="checkbox"' + (options.id ? ' id="' + options.id + '"' : ''), (options.checked ? ' checked' : ''), ' aria-checked="' + (options.checked ? 'true' : 'false') + '"/>', (options.text ? options.text : ''), '</label>' ].join('')); }); <span class="cstat-no" title="statement not covered" >const icon = <span class="fstat-no" title="function not covered" >function(iconClassName, tagName)</span> {</span> <span class="cstat-no" title="statement not covered" > tagName = tagName || 'i';</span> <span class="cstat-no" title="statement not covered" > return '<' + tagName + ' class="' + iconClassName + '"/>';</span> }; <span class="cstat-no" title="statement not covered" >const ui = {</span> editor: editor, toolbar: toolbar, editingArea: editingArea, codable: codable, editable: editable, statusbar: statusbar, airEditor: airEditor, airEditable: airEditable, buttonGroup: buttonGroup, button: button, dropdown: dropdown, dropdownCheck: dropdownCheck, dropdownButton: dropdownButton, dropdownButtonContents: dropdownButtonContents, dropdownCheckButton: dropdownCheckButton, paragraphDropdownButton: paragraphDropdownButton, tableDropdownButton: tableDropdownButton, colorDropdownButton: colorDropdownButton, palette: palette, dialog: dialog, videoDialog: videoDialog, imageDialog: imageDialog, linkDialog: linkDialog, popover: popover, checkbox: checkbox, icon: icon, toggleBtn: <span class="fstat-no" title="function not covered" >function($btn, isEnable)</span> { <span class="cstat-no" title="statement not covered" > $btn.toggleClass('disabled', !isEnable);</span> <span class="cstat-no" title="statement not covered" > $btn.attr('disabled', !isEnable);</span> }, toggleBtnActive: <span class="fstat-no" title="function not covered" >function($btn, isActive)</span> { <span class="cstat-no" title="statement not covered" > $btn.toggleClass('active', isActive);</span> }, check: <span class="fstat-no" title="function not covered" >function($dom, value)</span> { <span class="cstat-no" title="statement not covered" > $dom.find('.checked').removeClass('checked');</span> <span class="cstat-no" title="statement not covered" > $dom.find('[data-value="' + value + '"]').addClass('checked');</span> }, onDialogShown: <span class="fstat-no" title="function not covered" >function($dialog, handler)</span> { <span class="cstat-no" title="statement not covered" > $dialog.one('note.modal.show', handler);</span> }, onDialogHidden: <span class="fstat-no" title="function not covered" >function($dialog, handler)</span> { <span class="cstat-no" title="statement not covered" > $dialog.one('note.modal.hide', handler);</span> }, showDialog: <span class="fstat-no" title="function not covered" >function($dialog)</span> { <span class="cstat-no" title="statement not covered" > $dialog.data('modal').show();</span> }, hideDialog: <span class="fstat-no" title="function not covered" >function($dialog)</span> { <span class="cstat-no" title="statement not covered" > $dialog.data('modal').hide();</span> }, /** * get popover content area * * @param $popover * @returns {*} */ getPopoverContent: <span class="fstat-no" title="function not covered" >function($popover)</span> { <span class="cstat-no" title="statement not covered" > return $popover.find('.note-popover-content');</span> }, /** * get dialog's body area * * @param $dialog * @returns {*} */ getDialogBody: <span class="fstat-no" title="function not covered" >function($dialog)</span> { <span class="cstat-no" title="statement not covered" > return $dialog.find('.note-modal-body');</span> }, createLayout: <span class="fstat-no" title="function not covered" >function($note, options)</span> { <span class="cstat-no" title="statement not covered" > const $editor = (options.airMode ? ui.airEditor([</span> ui.editingArea([ ui.airEditable() ]) ]) : ui.editor([ ui.toolbar(), ui.editingArea([ ui.codable(), ui.editable() ]), ui.statusbar() ])).render(); <span class="cstat-no" title="statement not covered" > $editor.insertAfter($note);</span> <span class="cstat-no" title="statement not covered" > return {</span> note: $note, editor: $editor, toolbar: $editor.find('.note-toolbar'), editingArea: $editor.find('.note-editing-area'), editable: $editor.find('.note-editable'), codable: $editor.find('.note-codable'), statusbar: $editor.find('.note-statusbar') }; }, removeLayout: <span class="fstat-no" title="function not covered" >function($note, layoutInfo)</span> { <span class="cstat-no" title="statement not covered" > $note.html(layoutInfo.editable.html());</span> <span class="cstat-no" title="statement not covered" > layoutInfo.editor.remove();</span> <span class="cstat-no" title="statement not covered" > $note.off('summernote'); </span>// remove summernote custom event <span class="cstat-no" title="statement not covered" > $note.show();</span> } }; <span class="cstat-no" title="statement not covered" >export default ui;</span> </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/lite/index.html000064400000010302151677271550016054 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/lite/</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> src/js/lite/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Statements</span> <span class='fraction'>0/204</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/91</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/40</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Lines</span> <span class='fraction'>0/204</span> </div> </div> </div> <div class='status-line low'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file low" data-value="settings.js"><a href="settings.js.html">settings.js</a></td> <td data-value="0" class="pic low"><div class="chart"><div class="cover-fill" style="width: 0%;"></div><div class="cover-empty" style="width:100%;"></div></div></td> <td data-value="0" class="pct low">0%</td> <td data-value="26" class="abs low">0/26</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="0" class="pct low">0%</td> <td data-value="26" class="abs low">0/26</td> </tr> <tr> <td class="file low" data-value="ui.js"><a href="ui.js.html">ui.js</a></td> <td data-value="0" class="pic low"><div class="chart"><div class="cover-fill" style="width: 0%;"></div><div class="cover-empty" style="width:100%;"></div></div></td> <td data-value="0" class="pct low">0%</td> <td data-value="178" class="abs low">0/178</td> <td data-value="0" class="pct low">0%</td> <td data-value="91" class="abs low">0/91</td> <td data-value="0" class="pct low">0%</td> <td data-value="40" class="abs low">0/40</td> <td data-value="0" class="pct low">0%</td> <td data-value="178" class="abs low">0/178</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/lite/ui/TooltipUI.js.html000064400000032230151677271550017671 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/lite/ui/TooltipUI.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/js/lite/ui/</a> TooltipUI.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">2.08% </span> <span class="quiet">Statements</span> <span class='fraction'>1/48</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/23</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">2.08% </span> <span class="quiet">Lines</span> <span class='fraction'>1/48</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 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94</td><td class="line-coverage quiet"><span class="cline-any cline-no"> </span> <span class="cline-any cline-yes">1×</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> <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> <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-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-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-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-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-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-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-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-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-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-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-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-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-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >class TooltipUI {</span></span> <span class="fstat-no" title="function not covered" > constructor($node, options)</span> { <span class="cstat-no" title="statement not covered" > this.$node = $node;</span> <span class="cstat-no" title="statement not covered" > this.options = $.extend({}, {</span> title: '', target: options.container, trigger: 'hover focus', placement: 'bottom' }, options); // create tooltip node <span class="cstat-no" title="statement not covered" > this.$tooltip = $([</span> '<div class="note-tooltip in">', ' <div class="note-tooltip-arrow"/>', ' <div class="note-tooltip-content"/>', '</div>' ].join('')); // define event <span class="cstat-no" title="statement not covered" > if (this.options.trigger !== 'manual') {</span> <span class="cstat-no" title="statement not covered" > const showCallback = this.show.bind(this);</span> <span class="cstat-no" title="statement not covered" > const hideCallback = this.hide.bind(this);</span> <span class="cstat-no" title="statement not covered" > const toggleCallback = this.toggle.bind(this);</span> <span class="cstat-no" title="statement not covered" > this.options.trigger.split(' ').forEach(<span class="fstat-no" title="function not covered" >function(eventName)</span> {</span> <span class="cstat-no" title="statement not covered" > if (eventName === 'hover') {</span> <span class="cstat-no" title="statement not covered" > $node.off('mouseenter mouseleave');</span> <span class="cstat-no" title="statement not covered" > $node.on('mouseenter', showCallback).on('mouseleave', hideCallback);</span> } else <span class="cstat-no" title="statement not covered" >if (eventName === 'click') {</span> <span class="cstat-no" title="statement not covered" > $node.on('click', toggleCallback);</span> } else <span class="cstat-no" title="statement not covered" >if (eventName === 'focus') {</span> <span class="cstat-no" title="statement not covered" > $node.on('focus', showCallback).on('blur', hideCallback);</span> } }); } } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > show() {</span></span> <span class="cstat-no" title="statement not covered" > const $node = this.$node;</span> <span class="cstat-no" title="statement not covered" > const offset = $node.offset();</span> <span class="cstat-no" title="statement not covered" > const $tooltip = this.$tooltip;</span> <span class="cstat-no" title="statement not covered" > const title = this.options.title || $node.attr('title') || $node.data('title');</span> <span class="cstat-no" title="statement not covered" > const placement = this.options.placement || $node.data('placement');</span> <span class="cstat-no" title="statement not covered" > $tooltip.addClass(placement);</span> <span class="cstat-no" title="statement not covered" > $tooltip.addClass('in');</span> <span class="cstat-no" title="statement not covered" > $tooltip.find('.note-tooltip-content').text(title);</span> <span class="cstat-no" title="statement not covered" > $tooltip.appendTo(this.options.target);</span> <span class="cstat-no" title="statement not covered" > const nodeWidth = $node.outerWidth();</span> <span class="cstat-no" title="statement not covered" > const nodeHeight = $node.outerHeight();</span> <span class="cstat-no" title="statement not covered" > const tooltipWidth = $tooltip.outerWidth();</span> <span class="cstat-no" title="statement not covered" > const tooltipHeight = $tooltip.outerHeight();</span> <span class="cstat-no" title="statement not covered" > if (placement === 'bottom') {</span> <span class="cstat-no" title="statement not covered" > $tooltip.css({</span> top: offset.top + nodeHeight, left: offset.left + (nodeWidth / 2 - tooltipWidth / 2) }); } else <span class="cstat-no" title="statement not covered" >if (placement === 'top') {</span> <span class="cstat-no" title="statement not covered" > $tooltip.css({</span> top: offset.top - tooltipHeight, left: offset.left + (nodeWidth / 2 - tooltipWidth / 2) }); } else <span class="cstat-no" title="statement not covered" >if (placement === 'left') {</span> <span class="cstat-no" title="statement not covered" > $tooltip.css({</span> top: offset.top + (nodeHeight / 2 - tooltipHeight / 2), left: offset.left - tooltipWidth }); } else <span class="cstat-no" title="statement not covered" >if (placement === 'right') {</span> <span class="cstat-no" title="statement not covered" > $tooltip.css({</span> top: offset.top + (nodeHeight / 2 - tooltipHeight / 2), left: offset.left + nodeWidth }); } } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > hide() {</span></span> <span class="cstat-no" title="statement not covered" > this.$tooltip.removeClass('in');</span> <span class="cstat-no" title="statement not covered" > this.$tooltip.remove();</span> } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > toggle() {</span></span> <span class="cstat-no" title="statement not covered" > if (this.$tooltip.hasClass('in')) {</span> <span class="cstat-no" title="statement not covered" > this.hide();</span> } else { <span class="cstat-no" title="statement not covered" > this.show();</span> } } <span class="cstat-no" title="statement not covered" >}</span> <span class="cstat-no" title="statement not covered" >export default TooltipUI;</span> </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/lite/ui/ModalUI.js.html000064400000014714151677271550017302 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/lite/ui/ModalUI.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/js/lite/ui/</a> ModalUI.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">4.76% </span> <span class="quiet">Statements</span> <span class='fraction'>1/21</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/4</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/4</span> </div> <div class='fl pad1y space-right2'> <span class="strong">4.76% </span> <span class="quiet">Lines</span> <span class='fraction'>1/21</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</td><td class="line-coverage quiet"><span class="cline-any cline-no"> </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-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-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-no"> </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-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-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-no"> </span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >class ModalUI {</span></span> <span class="fstat-no" title="function not covered" > constructor($node, options)</span> { <span class="cstat-no" title="statement not covered" > this.options = $.extend({}, {</span> target: options.container || 'body' }, options); <span class="cstat-no" title="statement not covered" > this.$modal = $node;</span> <span class="cstat-no" title="statement not covered" > this.$backdrop = $('<div class="note-modal-backdrop" />');</span> } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > show() {</span></span> <span class="cstat-no" title="statement not covered" > if (this.options.target === 'body') {</span> <span class="cstat-no" title="statement not covered" > this.$backdrop.css('position', 'fixed');</span> <span class="cstat-no" title="statement not covered" > this.$modal.css('position', 'fixed');</span> } else { <span class="cstat-no" title="statement not covered" > this.$backdrop.css('position', 'absolute');</span> <span class="cstat-no" title="statement not covered" > this.$modal.css('position', 'absolute');</span> } <span class="cstat-no" title="statement not covered" > this.$backdrop.appendTo(this.options.target).show();</span> <span class="cstat-no" title="statement not covered" > this.$modal.appendTo(this.options.target).addClass('open').show();</span> <span class="cstat-no" title="statement not covered" > this.$modal.trigger('note.modal.show');</span> <span class="cstat-no" title="statement not covered" > this.$modal.off('click', '.close').on('click', '.close', this.hide.bind(this));</span> } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > hide() {</span></span> <span class="cstat-no" title="statement not covered" > this.$modal.removeClass('open').hide();</span> <span class="cstat-no" title="statement not covered" > this.$backdrop.hide();</span> <span class="cstat-no" title="statement not covered" > this.$modal.trigger('note.modal.hide');</span> } <span class="cstat-no" title="statement not covered" >}</span> <span class="cstat-no" title="statement not covered" >export default ModalUI;</span> </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/lite/ui/PopoverUI.js.html000064400000032572151677271550017702 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/lite/ui/PopoverUI.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/js/lite/ui/</a> PopoverUI.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">2% </span> <span class="quiet">Statements</span> <span class='fraction'>1/50</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/22</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">2% </span> <span class="quiet">Lines</span> <span class='fraction'>1/50</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 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95</td><td class="line-coverage quiet"><span class="cline-any cline-no"> </span> <span class="cline-any cline-yes">1×</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> <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-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-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-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-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-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-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-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-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-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-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-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-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-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-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >class PopoverUI {</span></span> <span class="fstat-no" title="function not covered" > constructor($node, options)</span> { <span class="cstat-no" title="statement not covered" > this.$node = $node;</span> <span class="cstat-no" title="statement not covered" > this.options = $.extend({}, {</span> title: '', content: '', target: options.container, trigger: 'hover focus', placement: 'bottom' }, options); // create popover node <span class="cstat-no" title="statement not covered" > this.$popover = $([</span> '<div class="note-popover in">', ' <div class="note-popover-arrow" />', ' <div class="note-popover-content" />', '</div>' ].join('')); // define event <span class="cstat-no" title="statement not covered" > if (this.options.trigger !== 'manual') {</span> <span class="cstat-no" title="statement not covered" > const showCallback = this.show.bind(this);</span> <span class="cstat-no" title="statement not covered" > const hideCallback = this.hide.bind(this);</span> <span class="cstat-no" title="statement not covered" > const toggleCallback = this.toggle.bind(this);</span> <span class="cstat-no" title="statement not covered" > this.options.trigger.split(' ').forEach(<span class="fstat-no" title="function not covered" >function(eventName)</span> {</span> <span class="cstat-no" title="statement not covered" > if (eventName === 'hover') {</span> <span class="cstat-no" title="statement not covered" > $node.off('mouseenter').on('mouseenter', showCallback);</span> <span class="cstat-no" title="statement not covered" > $node.off('mouseleave').on('mouseleave', hideCallback);</span> } else <span class="cstat-no" title="statement not covered" >if (eventName === 'click') {</span> <span class="cstat-no" title="statement not covered" > $node.on('click', toggleCallback);</span> } else <span class="cstat-no" title="statement not covered" >if (eventName === 'focus') {</span> <span class="cstat-no" title="statement not covered" > $node.on('focus', showCallback);</span> <span class="cstat-no" title="statement not covered" > $node.on('blur', hideCallback);</span> } }); } } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > show() {</span></span> <span class="cstat-no" title="statement not covered" > const $node = this.$node;</span> <span class="cstat-no" title="statement not covered" > const offset = $node.offset();</span> <span class="cstat-no" title="statement not covered" > const $popover = this.$popover;</span> <span class="cstat-no" title="statement not covered" > const content = this.options.content || $node.data('content');</span> <span class="cstat-no" title="statement not covered" > const placement = $node.data('placement') || this.options.placement;</span> <span class="cstat-no" title="statement not covered" > const dist = 6;</span> <span class="cstat-no" title="statement not covered" > $popover.addClass(placement);</span> <span class="cstat-no" title="statement not covered" > $popover.addClass('in');</span> <span class="cstat-no" title="statement not covered" > $popover.find('.note-popover-content').html(content);</span> <span class="cstat-no" title="statement not covered" > $popover.appendTo(this.options.target);</span> <span class="cstat-no" title="statement not covered" > const nodeWidth = $node.outerWidth();</span> <span class="cstat-no" title="statement not covered" > const nodeHeight = $node.outerHeight();</span> <span class="cstat-no" title="statement not covered" > const popoverWidth = $popover.outerWidth();</span> <span class="cstat-no" title="statement not covered" > const popoverHeight = $popover.outerHeight();</span> <span class="cstat-no" title="statement not covered" > if (placement === 'bottom') {</span> <span class="cstat-no" title="statement not covered" > $popover.css({</span> top: offset.top + nodeHeight + dist, left: offset.left + (nodeWidth / 2 - popoverWidth / 2) }); } else <span class="cstat-no" title="statement not covered" >if (placement === 'top') {</span> <span class="cstat-no" title="statement not covered" > $popover.css({</span> top: offset.top - popoverHeight - dist, left: offset.left + (nodeWidth / 2 - popoverWidth / 2) }); } else <span class="cstat-no" title="statement not covered" >if (placement === 'left') {</span> <span class="cstat-no" title="statement not covered" > $popover.css({</span> top: offset.top + (nodeHeight / 2 - popoverHeight / 2), left: offset.left - popoverWidth - dist }); } else <span class="cstat-no" title="statement not covered" >if (placement === 'right') {</span> <span class="cstat-no" title="statement not covered" > $popover.css({</span> top: offset.top + (nodeHeight / 2 - popoverHeight / 2), left: offset.left + nodeWidth + dist }); } } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > hide() {</span></span> <span class="cstat-no" title="statement not covered" > this.$popover.removeClass('in');</span> <span class="cstat-no" title="statement not covered" > this.$popover.remove();</span> } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > toggle() {</span></span> <span class="cstat-no" title="statement not covered" > if (this.$popover.hasClass('in')) {</span> <span class="cstat-no" title="statement not covered" > this.hide();</span> } else { <span class="cstat-no" title="statement not covered" > this.show();</span> } } <span class="cstat-no" title="statement not covered" >}</span> <span class="cstat-no" title="statement not covered" >export default PopoverUI;</span> </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/lite/ui/index.html000064400000013044151677271550016477 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/lite/ui/</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> src/js/lite/ui/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">2.55% </span> <span class="quiet">Statements</span> <span class='fraction'>4/157</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/55</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/25</span> </div> <div class='fl pad1y space-right2'> <span class="strong">2.55% </span> <span class="quiet">Lines</span> <span class='fraction'>4/157</span> </div> </div> </div> <div class='status-line low'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file low" data-value="DropdownUI.js"><a href="DropdownUI.js.html">DropdownUI.js</a></td> <td data-value="2.63" class="pic low"><div class="chart"><div class="cover-fill" style="width: 2%;"></div><div class="cover-empty" style="width:98%;"></div></div></td> <td data-value="2.63" class="pct low">2.63%</td> <td data-value="38" class="abs low">1/38</td> <td data-value="0" class="pct low">0%</td> <td data-value="6" class="abs low">0/6</td> <td data-value="0" class="pct low">0%</td> <td data-value="9" class="abs low">0/9</td> <td data-value="2.63" class="pct low">2.63%</td> <td data-value="38" class="abs low">1/38</td> </tr> <tr> <td class="file low" data-value="ModalUI.js"><a href="ModalUI.js.html">ModalUI.js</a></td> <td data-value="4.76" class="pic low"><div class="chart"><div class="cover-fill" style="width: 4%;"></div><div class="cover-empty" style="width:96%;"></div></div></td> <td data-value="4.76" class="pct low">4.76%</td> <td data-value="21" class="abs low">1/21</td> <td data-value="0" class="pct low">0%</td> <td data-value="4" class="abs low">0/4</td> <td data-value="0" class="pct low">0%</td> <td data-value="4" class="abs low">0/4</td> <td data-value="4.76" class="pct low">4.76%</td> <td data-value="21" class="abs low">1/21</td> </tr> <tr> <td class="file low" data-value="PopoverUI.js"><a href="PopoverUI.js.html">PopoverUI.js</a></td> <td data-value="2" class="pic low"><div class="chart"><div class="cover-fill" style="width: 2%;"></div><div class="cover-empty" style="width:98%;"></div></div></td> <td data-value="2" class="pct low">2%</td> <td data-value="50" class="abs low">1/50</td> <td data-value="0" class="pct low">0%</td> <td data-value="22" class="abs low">0/22</td> <td data-value="0" class="pct low">0%</td> <td data-value="6" class="abs low">0/6</td> <td data-value="2" class="pct low">2%</td> <td data-value="50" class="abs low">1/50</td> </tr> <tr> <td class="file low" data-value="TooltipUI.js"><a href="TooltipUI.js.html">TooltipUI.js</a></td> <td data-value="2.08" class="pic low"><div class="chart"><div class="cover-fill" style="width: 2%;"></div><div class="cover-empty" style="width:98%;"></div></div></td> <td data-value="2.08" class="pct low">2.08%</td> <td data-value="48" class="abs low">1/48</td> <td data-value="0" class="pct low">0%</td> <td data-value="23" class="abs low">0/23</td> <td data-value="0" class="pct low">0%</td> <td data-value="6" class="abs low">0/6</td> <td data-value="2.08" class="pct low">2.08%</td> <td data-value="48" class="abs low">1/48</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/lite/ui/DropdownUI.js.html000064400000024155151677271550020042 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/lite/ui/DropdownUI.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/js/lite/ui/</a> DropdownUI.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">2.63% </span> <span class="quiet">Statements</span> <span class='fraction'>1/38</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/9</span> </div> <div class='fl pad1y space-right2'> <span class="strong">2.63% </span> <span class="quiet">Lines</span> <span class='fraction'>1/38</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</td><td class="line-coverage quiet"><span class="cline-any cline-no"> </span> <span class="cline-any cline-yes">1×</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-no"> </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-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-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-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-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-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-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-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-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-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-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-no"> </span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >class DropdownUI {</span></span> <span class="fstat-no" title="function not covered" > constructor($node, options)</span> { <span class="cstat-no" title="statement not covered" > this.$button = $node;</span> <span class="cstat-no" title="statement not covered" > this.options = $.extend({}, {</span> target: options.container }, options); <span class="cstat-no" title="statement not covered" > this.setEvent();</span> } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > setEvent() {</span></span> <span class="cstat-no" title="statement not covered" > this.$button.on('click', this.toggle.bind(this));</span> } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > clear() {</span></span> <span class="cstat-no" title="statement not covered" > var $parent = $('.note-btn-group.open');</span> <span class="cstat-no" title="statement not covered" > $parent.find('.note-btn.active').removeClass('active');</span> <span class="cstat-no" title="statement not covered" > $parent.removeClass('open');</span> } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > show() {</span></span> <span class="cstat-no" title="statement not covered" > this.$button.addClass('active');</span> <span class="cstat-no" title="statement not covered" > this.$button.parent().addClass('open');</span> <span class="cstat-no" title="statement not covered" > var $dropdown = this.$button.next();</span> <span class="cstat-no" title="statement not covered" > var offset = $dropdown.offset();</span> <span class="cstat-no" title="statement not covered" > var width = $dropdown.outerWidth();</span> <span class="cstat-no" title="statement not covered" > var windowWidth = $(window).width();</span> <span class="cstat-no" title="statement not covered" > var targetMarginRight = parseFloat($(this.options.target).css('margin-right'));</span> <span class="cstat-no" title="statement not covered" > if (offset.left + width > windowWidth - targetMarginRight) {</span> <span class="cstat-no" title="statement not covered" > $dropdown.css('margin-left', windowWidth - targetMarginRight - (offset.left + width));</span> } else { <span class="cstat-no" title="statement not covered" > $dropdown.css('margin-left', '');</span> } } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > hide() {</span></span> <span class="cstat-no" title="statement not covered" > this.$button.removeClass('active');</span> <span class="cstat-no" title="statement not covered" > this.$button.parent().removeClass('open');</span> } <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > toggle() {</span></span> <span class="cstat-no" title="statement not covered" > var isOpened = this.$button.parent().hasClass('open');</span> <span class="cstat-no" title="statement not covered" > this.clear();</span> <span class="cstat-no" title="statement not covered" > if (isOpened) {</span> <span class="cstat-no" title="statement not covered" > this.hide();</span> } else { <span class="cstat-no" title="statement not covered" > this.show();</span> } } <span class="cstat-no" title="statement not covered" >}</span> <span class="cstat-no" title="statement not covered" >$(document).on('click', <span class="fstat-no" title="function not covered" >function(e)</span> {</span> <span class="cstat-no" title="statement not covered" > if (!$(e.target).closest('.note-btn-group').length) {</span> <span class="cstat-no" title="statement not covered" > $('.note-btn-group.open').removeClass('open');</span> } }); <span class="cstat-no" title="statement not covered" >$(document).on('click.note-dropdown-menu', <span class="fstat-no" title="function not covered" >function(e)</span> {</span> <span class="cstat-no" title="statement not covered" > $(e.target).closest('.note-dropdown-menu').parent().removeClass('open');</span> }); <span class="cstat-no" title="statement not covered" >export default DropdownUI;</span> </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/lite/settings.js.html000064400000075015151677271550017234 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/lite/settings.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/js/lite/</a> settings.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Statements</span> <span class='fraction'>0/26</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Lines</span> <span class='fraction'>0/26</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297</td><td class="line-coverage quiet"><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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-no"> </span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" >import $ from 'jquery';</span> <span class="cstat-no" title="statement not covered" >import ui from './ui';</span> <span class="cstat-no" title="statement not covered" >import '../base/summernote-en-US';</span> <span class="cstat-no" title="statement not covered" >import Editor from '../base/module/Editor';</span> <span class="cstat-no" title="statement not covered" >import Clipboard from '../base/module/Clipboard';</span> <span class="cstat-no" title="statement not covered" >import Dropzone from '../base/module/Dropzone';</span> <span class="cstat-no" title="statement not covered" >import Codeview from '../base/module/Codeview';</span> <span class="cstat-no" title="statement not covered" >import Statusbar from '../base/module/Statusbar';</span> <span class="cstat-no" title="statement not covered" >import Fullscreen from '../base/module/Fullscreen';</span> <span class="cstat-no" title="statement not covered" >import Handle from '../base/module/Handle';</span> <span class="cstat-no" title="statement not covered" >import AutoLink from '../base/module/AutoLink';</span> <span class="cstat-no" title="statement not covered" >import AutoSync from '../base/module/AutoSync';</span> <span class="cstat-no" title="statement not covered" >import Placeholder from '../base/module/Placeholder';</span> <span class="cstat-no" title="statement not covered" >import Buttons from '../base/module/Buttons';</span> <span class="cstat-no" title="statement not covered" >import Toolbar from '../base/module/Toolbar';</span> <span class="cstat-no" title="statement not covered" >import LinkDialog from '../base/module/LinkDialog';</span> <span class="cstat-no" title="statement not covered" >import LinkPopover from '../base/module/LinkPopover';</span> <span class="cstat-no" title="statement not covered" >import ImageDialog from '../base/module/ImageDialog';</span> <span class="cstat-no" title="statement not covered" >import ImagePopover from '../base/module/ImagePopover';</span> <span class="cstat-no" title="statement not covered" >import TablePopover from '../base/module/TablePopover';</span> <span class="cstat-no" title="statement not covered" >import VideoDialog from '../base/module/VideoDialog';</span> <span class="cstat-no" title="statement not covered" >import HelpDialog from '../base/module/HelpDialog';</span> <span class="cstat-no" title="statement not covered" >import AirPopover from '../base/module/AirPopover';</span> <span class="cstat-no" title="statement not covered" >import HintPopover from '../base/module/HintPopover';</span> <span class="cstat-no" title="statement not covered" >$.summernote = $.extend($.summernote, {</span> version: '@@VERSION@@', ui: ui, plugins: {}, options: { modules: { 'editor': Editor, 'clipboard': Clipboard, 'dropzone': Dropzone, 'codeview': Codeview, 'statusbar': Statusbar, 'fullscreen': Fullscreen, 'handle': Handle, // FIXME: HintPopover must be front of autolink // - Script error about range when Enter key is pressed on hint popover 'hintPopover': HintPopover, 'autoLink': AutoLink, 'autoSync': AutoSync, 'placeholder': Placeholder, 'buttons': Buttons, 'toolbar': Toolbar, 'linkDialog': LinkDialog, 'linkPopover': LinkPopover, 'imageDialog': ImageDialog, 'imagePopover': ImagePopover, 'tablePopover': TablePopover, 'videoDialog': VideoDialog, 'helpDialog': HelpDialog, 'airPopover': AirPopover }, buttons: {}, lang: 'en-US', followingToolbar: true, otherStaticBar: '', // toolbar toolbar: [ ['style', ['style']], ['font', ['bold', 'underline', 'clear']], ['fontname', ['fontname']], ['fontsize', ['fontsize']], ['color', ['color']], ['para', ['ul', 'ol', 'paragraph']], ['table', ['table']], ['insert', ['link', 'picture', 'video']], ['view', ['fullscreen', 'codeview', 'help']] ], // popover popatmouse: true, popover: { image: [ ['imagesize', ['imageSize100', 'imageSize50', 'imageSize25']], ['float', ['floatLeft', 'floatRight', 'floatNone']], ['remove', ['removeMedia']] ], link: [ ['link', ['linkDialogShow', 'unlink']] ], table: [ ['add', ['addRowDown', 'addRowUp', 'addColLeft', 'addColRight']], ['delete', ['deleteRow', 'deleteCol', 'deleteTable']] ], air: [ ['color', ['color']], ['font', ['bold', 'underline', 'clear']], ['para', ['ul', 'paragraph']], ['table', ['table']], ['insert', ['link', 'picture']] ] }, // air mode: inline editor airMode: false, width: null, height: null, focus: false, tabSize: 4, styleWithSpan: true, shortcuts: true, textareaAutoSync: true, hintDirection: 'bottom', tooltip: 'auto', container: 'body', maxTextLength: 0, styleTags: ['p', 'pre', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6'], fontNames: [ 'Arial', 'Arial Black', 'Comic Sans MS', 'Courier New', 'Helvetica Neue', 'Helvetica', 'Impact', 'Lucida Grande', 'Tahoma', 'Times New Roman', 'Verdana' ], fontSizes: ['8', '9', '10', '11', '12', '14', '18', '24', '36'], // pallete colors(n x n) colors: [ ['#000000', '#424242', '#636363', '#9C9C94', '#CEC6CE', '#EFEFEF', '#F7F7F7', '#FFFFFF'], ['#FF0000', '#FF9C00', '#FFFF00', '#00FF00', '#00FFFF', '#0000FF', '#9C00FF', '#FF00FF'], ['#F7C6CE', '#FFE7CE', '#FFEFC6', '#D6EFD6', '#CEDEE7', '#CEE7F7', '#D6D6E7', '#E7D6DE'], ['#E79C9C', '#FFC69C', '#FFE79C', '#B5D6A5', '#A5C6CE', '#9CC6EF', '#B5A5D6', '#D6A5BD'], ['#E76363', '#F7AD6B', '#FFD663', '#94BD7B', '#73A5AD', '#6BADDE', '#8C7BC6', '#C67BA5'], ['#CE0000', '#E79439', '#EFC631', '#6BA54A', '#4A7B8C', '#3984C6', '#634AA5', '#A54A7B'], ['#9C0000', '#B56308', '#BD9400', '#397B21', '#104A5A', '#085294', '#311873', '#731842'], ['#630000', '#7B3900', '#846300', '#295218', '#083139', '#003163', '#21104A', '#4A1031'] ], // http://chir.ag/projects/name-that-color/ colorsName: [ ['Black', 'Tundora', 'Dove Gray', 'Star Dust', 'Pale Slate', 'Gallery', 'Alabaster', 'White'], ['Red', 'Orange Peel', 'Yellow', 'Green', 'Cyan', 'Blue', 'Electric Violet', 'Magenta'], ['Azalea', 'Karry', 'Egg White', 'Zanah', 'Botticelli', 'Tropical Blue', 'Mischka', 'Twilight'], ['Tonys Pink', 'Peach Orange', 'Cream Brulee', 'Sprout', 'Casper', 'Perano', 'Cold Purple', 'Careys Pink'], ['Mandy', 'Rajah', 'Dandelion', 'Olivine', 'Gulf Stream', 'Viking', 'Blue Marguerite', 'Puce'], ['Guardsman Red', 'Fire Bush', 'Golden Dream', 'Chelsea Cucumber', 'Smalt Blue', 'Boston Blue', 'Butterfly Bush', 'Cadillac'], ['Sangria', 'Mai Tai', 'Buddha Gold', 'Forest Green', 'Eden', 'Venice Blue', 'Meteorite', 'Claret'], ['Rosewood', 'Cinnamon', 'Olive', 'Parsley', 'Tiber', 'Midnight Blue', 'Valentino', 'Loulou'] ], lineHeights: ['1.0', '1.2', '1.4', '1.5', '1.6', '1.8', '2.0', '3.0'], tableClassName: 'table table-bordered', insertTableMaxSize: { col: 10, row: 10 }, dialogsInBody: false, dialogsFade: false, maximumImageFileSize: null, callbacks: { onInit: null, onFocus: null, onBlur: null, onBlurCodeview: null, onEnter: null, onKeyup: null, onKeydown: null, onSubmit: null, onImageUpload: null, onImageUploadError: null }, codemirror: { mode: 'text/html', htmlMode: true, lineNumbers: true }, keyMap: { pc: { 'ENTER': 'insertParagraph', 'CTRL+Z': 'undo', 'CTRL+Y': 'redo', 'TAB': 'tab', 'SHIFT+TAB': 'untab', 'CTRL+B': 'bold', 'CTRL+I': 'italic', 'CTRL+U': 'underline', 'CTRL+SHIFT+S': 'strikethrough', 'CTRL+BACKSLASH': 'removeFormat', 'CTRL+SHIFT+L': 'justifyLeft', 'CTRL+SHIFT+E': 'justifyCenter', 'CTRL+SHIFT+R': 'justifyRight', 'CTRL+SHIFT+J': 'justifyFull', 'CTRL+SHIFT+NUM7': 'insertUnorderedList', 'CTRL+SHIFT+NUM8': 'insertOrderedList', 'CTRL+LEFTBRACKET': 'outdent', 'CTRL+RIGHTBRACKET': 'indent', 'CTRL+NUM0': 'formatPara', 'CTRL+NUM1': 'formatH1', 'CTRL+NUM2': 'formatH2', 'CTRL+NUM3': 'formatH3', 'CTRL+NUM4': 'formatH4', 'CTRL+NUM5': 'formatH5', 'CTRL+NUM6': 'formatH6', 'CTRL+ENTER': 'insertHorizontalRule', 'CTRL+K': 'linkDialog.show' }, mac: { 'ENTER': 'insertParagraph', 'CMD+Z': 'undo', 'CMD+SHIFT+Z': 'redo', 'TAB': 'tab', 'SHIFT+TAB': 'untab', 'CMD+B': 'bold', 'CMD+I': 'italic', 'CMD+U': 'underline', 'CMD+SHIFT+S': 'strikethrough', 'CMD+BACKSLASH': 'removeFormat', 'CMD+SHIFT+L': 'justifyLeft', 'CMD+SHIFT+E': 'justifyCenter', 'CMD+SHIFT+R': 'justifyRight', 'CMD+SHIFT+J': 'justifyFull', 'CMD+SHIFT+NUM7': 'insertUnorderedList', 'CMD+SHIFT+NUM8': 'insertOrderedList', 'CMD+LEFTBRACKET': 'outdent', 'CMD+RIGHTBRACKET': 'indent', 'CMD+NUM0': 'formatPara', 'CMD+NUM1': 'formatH1', 'CMD+NUM2': 'formatH2', 'CMD+NUM3': 'formatH3', 'CMD+NUM4': 'formatH4', 'CMD+NUM5': 'formatH5', 'CMD+NUM6': 'formatH6', 'CMD+ENTER': 'insertHorizontalRule', 'CMD+K': 'linkDialog.show' } }, icons: { 'align': 'note-icon-align', 'alignCenter': 'note-icon-align-center', 'alignJustify': 'note-icon-align-justify', 'alignLeft': 'note-icon-align-left', 'alignRight': 'note-icon-align-right', 'rowBelow': 'note-icon-row-below', 'colBefore': 'note-icon-col-before', 'colAfter': 'note-icon-col-after', 'rowAbove': 'note-icon-row-above', 'rowRemove': 'note-icon-row-remove', 'colRemove': 'note-icon-col-remove', 'indent': 'note-icon-align-indent', 'outdent': 'note-icon-align-outdent', 'arrowsAlt': 'note-icon-arrows-alt', 'bold': 'note-icon-bold', 'caret': 'note-icon-caret', 'circle': 'note-icon-circle', 'close': 'note-icon-close', 'code': 'note-icon-code', 'eraser': 'note-icon-eraser', 'font': 'note-icon-font', 'frame': 'note-icon-frame', 'italic': 'note-icon-italic', 'link': 'note-icon-link', 'unlink': 'note-icon-chain-broken', 'magic': 'note-icon-magic', 'menuCheck': 'note-icon-menu-check', 'minus': 'note-icon-minus', 'orderedlist': 'note-icon-orderedlist', 'pencil': 'note-icon-pencil', 'picture': 'note-icon-picture', 'question': 'note-icon-question', 'redo': 'note-icon-redo', 'square': 'note-icon-square', 'strikethrough': 'note-icon-strikethrough', 'subscript': 'note-icon-subscript', 'superscript': 'note-icon-superscript', 'table': 'note-icon-table', 'textHeight': 'note-icon-text-height', 'trash': 'note-icon-trash', 'underline': 'note-icon-underline', 'undo': 'note-icon-undo', 'unorderedlist': 'note-icon-unorderedlist', 'video': 'note-icon-video' } } }); <span class="cstat-no" title="statement not covered" >import '../summernote'; </span>// eslint-disable-line </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/bs3/ui.js.html000064400000063155151677271550015545 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/bs3/ui.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/js/bs3/</a> ui.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">93.42% </span> <span class="quiet">Statements</span> <span class='fraction'>71/76</span> </div> <div class='fl pad1y space-right2'> <span class="strong">54% </span> <span class="quiet">Branches</span> <span class='fraction'>27/50</span> </div> <div class='fl pad1y space-right2'> <span class="strong">85% </span> <span class="quiet">Functions</span> <span class='fraction'>17/20</span> </div> <div class='fl pad1y space-right2'> <span class="strong">93.42% </span> <span class="quiet">Lines</span> <span class='fraction'>71/76</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238</td><td class="line-coverage quiet"><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-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-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-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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">292×</span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-yes">657×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">292×</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">401×</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">109×</span> <span class="cline-any cline-yes">1171×</span> <span class="cline-any cline-yes">1171×</span> <span class="cline-any cline-yes">1171×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">109×</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">146×</span> <span class="cline-any cline-yes">146×</span> <span class="cline-any cline-yes">1168×</span> <span class="cline-any cline-yes">1168×</span> <span class="cline-any cline-yes">1168×</span> <span class="cline-any cline-yes">1168×</span> <span class="cline-any cline-yes">1168×</span> <span class="cline-any cline-yes">9344×</span> <span class="cline-any cline-yes">9344×</span> <span class="cline-any cline-yes">9344×</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">1168×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">146×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">146×</span> <span class="cline-any cline-yes">146×</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">308×</span> <span class="cline-any cline-no"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">308×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">308×</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-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-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">231×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">231×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">231×</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-yes">1×</span> <span class="cline-any cline-yes">77×</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">4278×</span> <span class="cline-any cline-yes">4278×</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-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">3119×</span> <span class="cline-any cline-yes">3095×</span> <span class="cline-any cline-yes">3095×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">6×</span> <span class="cline-any cline-yes">6×</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">856×</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-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-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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">8×</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">76×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">76×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">76×</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-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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import renderer from '../base/renderer'; const editor = renderer.create('<div class="note-editor note-frame panel"/>'); const toolbar = renderer.create('<div class="note-toolbar-wrapper panel-default"><div class="note-toolbar panel-heading" role="toolbar"></div></div>'); const editingArea = renderer.create('<div class="note-editing-area"/>'); const codable = renderer.create('<textarea class="note-codable" role="textbox" aria-multiline="true"/>'); const editable = renderer.create('<div class="note-editable" contentEditable="true" role="textbox" aria-multiline="true"/>'); const statusbar = renderer.create([ '<output class="note-status-output" aria-live="polite"/>', '<div class="note-statusbar" role="status">', ' <div class="note-resizebar" role="seperator" aria-orientation="horizontal" aria-label="Resize">', ' <div class="note-icon-bar"/>', ' <div class="note-icon-bar"/>', ' <div class="note-icon-bar"/>', ' </div>', '</div>' ].join('')); const airEditor = renderer.create('<div class="note-editor"/>'); const airEditable = renderer.create([ ' <output class="note-status-output" aria-live="polite"/>', '<div class="note-editable" contentEditable="true" role="textbox" aria-multiline="true"/>' ].join('')); const buttonGroup = renderer.create('<div class="note-btn-group btn-group">'); const dropdown = renderer.create('<ul class="dropdown-menu" role="list">', function($node, options) { const markup = $.isArray(options.items) ? options.items.map(function(item) { const value = (typeof item === 'string') ? item : (<span class="branch-1 cbranch-no" title="branch not covered" >item.value || '')</span>; const content = options.template ? options.template(item) : <span class="branch-1 cbranch-no" title="branch not covered" >item;</span> const option = (typeof item === 'object') ? <span class="branch-0 cbranch-no" title="branch not covered" >item.option </span>: undefined; const dataValue = 'data-value="' + value + '"'; const dataOption = (option !== undefined) ? <span class="branch-0 cbranch-no" title="branch not covered" >' data-option="' + option + '"' </span>: ''; return '<li role="listitem" aria-label="' + item + '"><a href="#" ' + (dataValue + dataOption) + '>' + content + '</a></li>'; }).join('') : options.items; $node.html(markup).attr({'aria-label': options.title}); }); const dropdownButtonContents = function(contents, options) { return contents + ' ' + icon(options.icons.caret, 'span'); }; const dropdownCheck = renderer.create('<ul class="dropdown-menu note-check" role="list">', function($node, options) { const markup = $.isArray(options.items) ? options.items.map(function(item) { const value = (typeof item === 'string') ? item : (<span class="branch-1 cbranch-no" title="branch not covered" >item.value || '')</span>; const content = options.template ? options.template(item) : item; return '<li role="listitem" aria-label="' + item + '"><a href="#" data-value="' + value + '">' + icon(options.checkClassName) + ' ' + content + '</a></li>'; }).join('') : <span class="branch-1 cbranch-no" title="branch not covered" >options.items;</span> $node.html(markup).attr({'aria-label': options.title}); }); const palette = renderer.create('<div class="note-color-palette"/>', function($node, options) { const contents = []; for (let row = 0, rowSize = options.colors.length; row < rowSize; row++) { const eventName = options.eventName; const colors = options.colors[row]; const colorsName = options.colorsName[row]; const buttons = []; for (let col = 0, colSize = colors.length; col < colSize; col++) { const color = colors[col]; const colorName = colorsName[col]; buttons.push([ '<button type="button" class="note-color-btn"', 'style="background-color:', color, '" ', 'data-event="', eventName, '" ', 'data-value="', color, '" ', 'title="', colorName, '" ', 'aria-label="', colorName, '" ', 'data-toggle="button" tabindex="-1"></button>' ].join('')); } contents.push('<div class="note-color-row">' + buttons.join('') + '</div>'); } $node.html(contents.join('')); <span class="missing-if-branch" title="else path not taken" >E</span>if (options.tooltip) { $node.find('.note-color-btn').tooltip({ container: options.container, trigger: 'hover', placement: 'bottom' }); } }); const dialog = renderer.create('<div class="modal" aria-hidden="false" tabindex="-1" role="dialog"/>', function($node, options) { <span class="missing-if-branch" title="if path not taken" >I</span>if (options.fade) { <span class="cstat-no" title="statement not covered" > $node.addClass('fade');</span> } $node.attr({ 'aria-label': options.title }); $node.html([ '<div class="modal-dialog">', ' <div class="modal-content">', (options.title ? ' <div class="modal-header">' + ' <button type="button" class="close" data-dismiss="modal" aria-label="Close" aria-hidden="true">&times;</button>' + ' <h4 class="modal-title">' + options.title + '</h4>' + ' </div>' : <span class="branch-1 cbranch-no" title="branch not covered" >''</span> ), ' <div class="modal-body">' + options.body + '</div>', (options.footer ? ' <div class="modal-footer">' + options.footer + '</div>' : <span class="branch-1 cbranch-no" title="branch not covered" >''</span> ), ' </div>', '</div>' ].join('')); }); const popover = renderer.create([ '<div class="note-popover popover in">', ' <div class="arrow"/>', ' <div class="popover-content note-children-container"/>', '</div>' ].join(''), function($node, options) { const direction = typeof options.direction !== 'undefined' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.direction </span>: 'bottom'; $node.addClass(direction); <span class="missing-if-branch" title="if path not taken" >I</span>if (options.hideArrow) { <span class="cstat-no" title="statement not covered" > $node.find('.arrow').hide();</span> } }); const checkbox = renderer.create('<div class="checkbox"></div>', function($node, options) { $node.html([ ' <label' + (options.id ? ' for="' + options.id + '"' : <span class="branch-1 cbranch-no" title="branch not covered" >'')</span> + '>', ' <input role="checkbox" type="checkbox"' + (options.id ? ' id="' + options.id + '"' : <span class="branch-1 cbranch-no" title="branch not covered" >'')</span>, (options.checked ? ' checked' : <span class="branch-1 cbranch-no" title="branch not covered" >'')</span>, ' aria-checked="' + (options.checked ? 'true' : <span class="branch-1 cbranch-no" title="branch not covered" >'false')</span> + '"/>', (options.text ? options.text : <span class="branch-1 cbranch-no" title="branch not covered" >'')</span>, '</label>' ].join('')); }); const icon = function(iconClassName, tagName) { tagName = tagName || 'i'; return '<' + tagName + ' class="' + iconClassName + '"/>'; }; const ui = { editor: editor, toolbar: toolbar, editingArea: editingArea, codable: codable, editable: editable, statusbar: statusbar, airEditor: airEditor, airEditable: airEditable, buttonGroup: buttonGroup, dropdown: dropdown, dropdownButtonContents: dropdownButtonContents, dropdownCheck: dropdownCheck, palette: palette, dialog: dialog, popover: popover, checkbox: checkbox, icon: icon, options: {}, button: function($node, options) { return renderer.create('<button type="button" class="note-btn btn btn-default btn-sm" role="button" tabindex="-1">', function($node, options) { <span class="missing-if-branch" title="else path not taken" >E</span>if (options && options.tooltip) { $node.attr({ title: options.tooltip, 'aria-label': options.tooltip }).tooltip({ container: options.container, trigger: 'hover', placement: 'bottom' }); } })($node, options); }, toggleBtn: function($btn, isEnable) { $btn.toggleClass('disabled', !isEnable); $btn.attr('disabled', !isEnable); }, toggleBtnActive: function($btn, isActive) { $btn.toggleClass('active', isActive); }, onDialogShown: <span class="fstat-no" title="function not covered" >function($dialog, handler)</span> { <span class="cstat-no" title="statement not covered" > $dialog.one('shown.bs.modal', handler);</span> }, onDialogHidden: <span class="fstat-no" title="function not covered" >function($dialog, handler)</span> { <span class="cstat-no" title="statement not covered" > $dialog.one('hidden.bs.modal', handler);</span> }, showDialog: <span class="fstat-no" title="function not covered" >function($dialog)</span> { <span class="cstat-no" title="statement not covered" > $dialog.modal('show');</span> }, hideDialog: function($dialog) { $dialog.modal('hide'); }, createLayout: function($note, options) { const $editor = (options.airMode ? <span class="branch-0 cbranch-no" title="branch not covered" >ui.airEditor([</span> ui.editingArea([ ui.airEditable() ]) ]) : ui.editor([ ui.toolbar(), ui.editingArea([ ui.codable(), ui.editable() ]), ui.statusbar() ])).render(); $editor.insertAfter($note); return { note: $note, editor: $editor, toolbar: $editor.find('.note-toolbar'), editingArea: $editor.find('.note-editing-area'), editable: $editor.find('.note-editable'), codable: $editor.find('.note-codable'), statusbar: $editor.find('.note-statusbar') }; }, removeLayout: function($note, layoutInfo) { $note.html(layoutInfo.editable.html()); layoutInfo.editor.remove(); $note.show(); } }; export default ui; </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/bs3/index.html000064400000010421151677271550015610 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/bs3/</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> src/js/bs3/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">95.15% </span> <span class="quiet">Statements</span> <span class='fraction'>98/103</span> </div> <div class='fl pad1y space-right2'> <span class="strong">54% </span> <span class="quiet">Branches</span> <span class='fraction'>27/50</span> </div> <div class='fl pad1y space-right2'> <span class="strong">85% </span> <span class="quiet">Functions</span> <span class='fraction'>17/20</span> </div> <div class='fl pad1y space-right2'> <span class="strong">95.15% </span> <span class="quiet">Lines</span> <span class='fraction'>98/103</span> </div> </div> </div> <div class='status-line high'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file high" data-value="settings.js"><a href="settings.js.html">settings.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="27" class="abs high">27/27</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="27" class="abs high">27/27</td> </tr> <tr> <td class="file high" data-value="ui.js"><a href="ui.js.html">ui.js</a></td> <td data-value="93.42" class="pic high"><div class="chart"><div class="cover-fill" style="width: 93%;"></div><div class="cover-empty" style="width:7%;"></div></div></td> <td data-value="93.42" class="pct high">93.42%</td> <td data-value="76" class="abs high">71/76</td> <td data-value="54" class="pct medium">54%</td> <td data-value="50" class="abs medium">27/50</td> <td data-value="85" class="pct high">85%</td> <td data-value="20" class="abs high">17/20</td> <td data-value="93.42" class="pct high">93.42%</td> <td data-value="76" class="abs high">71/76</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/bs3/settings.js.html000064400000072006151677271550016763 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/bs3/settings.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/js/bs3/</a> settings.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>27/27</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>27/27</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298</td><td class="line-coverage quiet"><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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import $ from 'jquery'; import ui from '../bs3/ui'; import dom from '../base/core/dom'; import '../base/summernote-en-US'; import Editor from '../base/module/Editor'; import Clipboard from '../base/module/Clipboard'; import Dropzone from '../base/module/Dropzone'; import Codeview from '../base/module/Codeview'; import Statusbar from '../base/module/Statusbar'; import Fullscreen from '../base/module/Fullscreen'; import Handle from '../base/module/Handle'; import AutoLink from '../base/module/AutoLink'; import AutoSync from '../base/module/AutoSync'; import Placeholder from '../base/module/Placeholder'; import Buttons from '../base/module/Buttons'; import Toolbar from '../base/module/Toolbar'; import LinkDialog from '../base/module/LinkDialog'; import LinkPopover from '../base/module/LinkPopover'; import ImageDialog from '../base/module/ImageDialog'; import ImagePopover from '../base/module/ImagePopover'; import TablePopover from '../base/module/TablePopover'; import VideoDialog from '../base/module/VideoDialog'; import HelpDialog from '../base/module/HelpDialog'; import AirPopover from '../base/module/AirPopover'; import HintPopover from '../base/module/HintPopover'; $.summernote = $.extend($.summernote, { version: '@@VERSION@@', ui: ui, dom: dom, plugins: {}, options: { modules: { 'editor': Editor, 'clipboard': Clipboard, 'dropzone': Dropzone, 'codeview': Codeview, 'statusbar': Statusbar, 'fullscreen': Fullscreen, 'handle': Handle, // FIXME: HintPopover must be front of autolink // - Script error about range when Enter key is pressed on hint popover 'hintPopover': HintPopover, 'autoLink': AutoLink, 'autoSync': AutoSync, 'placeholder': Placeholder, 'buttons': Buttons, 'toolbar': Toolbar, 'linkDialog': LinkDialog, 'linkPopover': LinkPopover, 'imageDialog': ImageDialog, 'imagePopover': ImagePopover, 'tablePopover': TablePopover, 'videoDialog': VideoDialog, 'helpDialog': HelpDialog, 'airPopover': AirPopover }, buttons: {}, lang: 'en-US', followingToolbar: true, otherStaticBar: '', // toolbar toolbar: [ ['style', ['style']], ['font', ['bold', 'underline', 'clear']], ['fontname', ['fontname']], ['color', ['color']], ['para', ['ul', 'ol', 'paragraph']], ['table', ['table']], ['insert', ['link', 'picture', 'video']], ['view', ['fullscreen', 'codeview', 'help']] ], // popover popatmouse: true, popover: { image: [ ['imagesize', ['imageSize100', 'imageSize50', 'imageSize25']], ['float', ['floatLeft', 'floatRight', 'floatNone']], ['remove', ['removeMedia']] ], link: [ ['link', ['linkDialogShow', 'unlink']] ], table: [ ['add', ['addRowDown', 'addRowUp', 'addColLeft', 'addColRight']], ['delete', ['deleteRow', 'deleteCol', 'deleteTable']] ], air: [ ['color', ['color']], ['font', ['bold', 'underline', 'clear']], ['para', ['ul', 'paragraph']], ['table', ['table']], ['insert', ['link', 'picture']] ] }, // air mode: inline editor airMode: false, width: null, height: null, linkTargetBlank: true, focus: false, tabSize: 4, styleWithSpan: true, shortcuts: true, textareaAutoSync: true, hintDirection: 'bottom', tooltip: 'auto', container: 'body', maxTextLength: 0, styleTags: ['p', 'blockquote', 'pre', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6'], fontNames: [ 'Arial', 'Arial Black', 'Comic Sans MS', 'Courier New', 'Helvetica Neue', 'Helvetica', 'Impact', 'Lucida Grande', 'Tahoma', 'Times New Roman', 'Verdana' ], fontSizes: ['8', '9', '10', '11', '12', '14', '18', '24', '36'], // pallete colors(n x n) colors: [ ['#000000', '#424242', '#636363', '#9C9C94', '#CEC6CE', '#EFEFEF', '#F7F7F7', '#FFFFFF'], ['#FF0000', '#FF9C00', '#FFFF00', '#00FF00', '#00FFFF', '#0000FF', '#9C00FF', '#FF00FF'], ['#F7C6CE', '#FFE7CE', '#FFEFC6', '#D6EFD6', '#CEDEE7', '#CEE7F7', '#D6D6E7', '#E7D6DE'], ['#E79C9C', '#FFC69C', '#FFE79C', '#B5D6A5', '#A5C6CE', '#9CC6EF', '#B5A5D6', '#D6A5BD'], ['#E76363', '#F7AD6B', '#FFD663', '#94BD7B', '#73A5AD', '#6BADDE', '#8C7BC6', '#C67BA5'], ['#CE0000', '#E79439', '#EFC631', '#6BA54A', '#4A7B8C', '#3984C6', '#634AA5', '#A54A7B'], ['#9C0000', '#B56308', '#BD9400', '#397B21', '#104A5A', '#085294', '#311873', '#731842'], ['#630000', '#7B3900', '#846300', '#295218', '#083139', '#003163', '#21104A', '#4A1031'] ], // http://chir.ag/projects/name-that-color/ colorsName: [ ['Black', 'Tundora', 'Dove Gray', 'Star Dust', 'Pale Slate', 'Gallery', 'Alabaster', 'White'], ['Red', 'Orange Peel', 'Yellow', 'Green', 'Cyan', 'Blue', 'Electric Violet', 'Magenta'], ['Azalea', 'Karry', 'Egg White', 'Zanah', 'Botticelli', 'Tropical Blue', 'Mischka', 'Twilight'], ['Tonys Pink', 'Peach Orange', 'Cream Brulee', 'Sprout', 'Casper', 'Perano', 'Cold Purple', 'Careys Pink'], ['Mandy', 'Rajah', 'Dandelion', 'Olivine', 'Gulf Stream', 'Viking', 'Blue Marguerite', 'Puce'], ['Guardsman Red', 'Fire Bush', 'Golden Dream', 'Chelsea Cucumber', 'Smalt Blue', 'Boston Blue', 'Butterfly Bush', 'Cadillac'], ['Sangria', 'Mai Tai', 'Buddha Gold', 'Forest Green', 'Eden', 'Venice Blue', 'Meteorite', 'Claret'], ['Rosewood', 'Cinnamon', 'Olive', 'Parsley', 'Tiber', 'Midnight Blue', 'Valentino', 'Loulou'] ], lineHeights: ['1.0', '1.2', '1.4', '1.5', '1.6', '1.8', '2.0', '3.0'], tableClassName: 'table table-bordered', insertTableMaxSize: { col: 10, row: 10 }, dialogsInBody: false, dialogsFade: false, maximumImageFileSize: null, callbacks: { onInit: null, onFocus: null, onBlur: null, onBlurCodeview: null, onEnter: null, onKeyup: null, onKeydown: null, onImageUpload: null, onImageUploadError: null }, codemirror: { mode: 'text/html', htmlMode: true, lineNumbers: true }, keyMap: { pc: { 'ENTER': 'insertParagraph', 'CTRL+Z': 'undo', 'CTRL+Y': 'redo', 'TAB': 'tab', 'SHIFT+TAB': 'untab', 'CTRL+B': 'bold', 'CTRL+I': 'italic', 'CTRL+U': 'underline', 'CTRL+SHIFT+S': 'strikethrough', 'CTRL+BACKSLASH': 'removeFormat', 'CTRL+SHIFT+L': 'justifyLeft', 'CTRL+SHIFT+E': 'justifyCenter', 'CTRL+SHIFT+R': 'justifyRight', 'CTRL+SHIFT+J': 'justifyFull', 'CTRL+SHIFT+NUM7': 'insertUnorderedList', 'CTRL+SHIFT+NUM8': 'insertOrderedList', 'CTRL+LEFTBRACKET': 'outdent', 'CTRL+RIGHTBRACKET': 'indent', 'CTRL+NUM0': 'formatPara', 'CTRL+NUM1': 'formatH1', 'CTRL+NUM2': 'formatH2', 'CTRL+NUM3': 'formatH3', 'CTRL+NUM4': 'formatH4', 'CTRL+NUM5': 'formatH5', 'CTRL+NUM6': 'formatH6', 'CTRL+ENTER': 'insertHorizontalRule', 'CTRL+K': 'linkDialog.show' }, mac: { 'ENTER': 'insertParagraph', 'CMD+Z': 'undo', 'CMD+SHIFT+Z': 'redo', 'TAB': 'tab', 'SHIFT+TAB': 'untab', 'CMD+B': 'bold', 'CMD+I': 'italic', 'CMD+U': 'underline', 'CMD+SHIFT+S': 'strikethrough', 'CMD+BACKSLASH': 'removeFormat', 'CMD+SHIFT+L': 'justifyLeft', 'CMD+SHIFT+E': 'justifyCenter', 'CMD+SHIFT+R': 'justifyRight', 'CMD+SHIFT+J': 'justifyFull', 'CMD+SHIFT+NUM7': 'insertUnorderedList', 'CMD+SHIFT+NUM8': 'insertOrderedList', 'CMD+LEFTBRACKET': 'outdent', 'CMD+RIGHTBRACKET': 'indent', 'CMD+NUM0': 'formatPara', 'CMD+NUM1': 'formatH1', 'CMD+NUM2': 'formatH2', 'CMD+NUM3': 'formatH3', 'CMD+NUM4': 'formatH4', 'CMD+NUM5': 'formatH5', 'CMD+NUM6': 'formatH6', 'CMD+ENTER': 'insertHorizontalRule', 'CMD+K': 'linkDialog.show' } }, icons: { 'align': 'note-icon-align', 'alignCenter': 'note-icon-align-center', 'alignJustify': 'note-icon-align-justify', 'alignLeft': 'note-icon-align-left', 'alignRight': 'note-icon-align-right', 'rowBelow': 'note-icon-row-below', 'colBefore': 'note-icon-col-before', 'colAfter': 'note-icon-col-after', 'rowAbove': 'note-icon-row-above', 'rowRemove': 'note-icon-row-remove', 'colRemove': 'note-icon-col-remove', 'indent': 'note-icon-align-indent', 'outdent': 'note-icon-align-outdent', 'arrowsAlt': 'note-icon-arrows-alt', 'bold': 'note-icon-bold', 'caret': 'note-icon-caret', 'circle': 'note-icon-circle', 'close': 'note-icon-close', 'code': 'note-icon-code', 'eraser': 'note-icon-eraser', 'font': 'note-icon-font', 'frame': 'note-icon-frame', 'italic': 'note-icon-italic', 'link': 'note-icon-link', 'unlink': 'note-icon-chain-broken', 'magic': 'note-icon-magic', 'menuCheck': 'note-icon-menu-check', 'minus': 'note-icon-minus', 'orderedlist': 'note-icon-orderedlist', 'pencil': 'note-icon-pencil', 'picture': 'note-icon-picture', 'question': 'note-icon-question', 'redo': 'note-icon-redo', 'square': 'note-icon-square', 'strikethrough': 'note-icon-strikethrough', 'subscript': 'note-icon-subscript', 'superscript': 'note-icon-superscript', 'table': 'note-icon-table', 'textHeight': 'note-icon-text-height', 'trash': 'note-icon-trash', 'underline': 'note-icon-underline', 'undo': 'note-icon-undo', 'unorderedlist': 'note-icon-unorderedlist', 'video': 'note-icon-video' } } }); import '../summernote'; // eslint-disable-line </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/bs4/ui.js.html000064400000074272151677271550015550 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/bs4/ui.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/js/bs4/</a> ui.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Statements</span> <span class='fraction'>0/78</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/50</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/20</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Lines</span> <span class='fraction'>0/78</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243</td><td class="line-coverage quiet"><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-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-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-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-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-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-no"> </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-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-no"> </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-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-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> <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-neutral"> </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> <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-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> <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-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-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-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-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-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-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-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> <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-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-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-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-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-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-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-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-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-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> <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-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-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-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-no"> </span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" >import $ from 'jquery';</span> <span class="cstat-no" title="statement not covered" >import renderer from '../base/renderer';</span> <span class="cstat-no" title="statement not covered" >const editor = renderer.create('<div class="note-editor note-frame card"/>');</span> <span class="cstat-no" title="statement not covered" >const toolbar = renderer.create('<div class="note-toolbar-wrapper"><div class="note-toolbar card-header" role="toolbar"></div></div>');</span> <span class="cstat-no" title="statement not covered" >const editingArea = renderer.create('<div class="note-editing-area"/>');</span> <span class="cstat-no" title="statement not covered" >const codable = renderer.create('<textarea class="note-codable" role="textbox" aria-multiline="true"/>');</span> <span class="cstat-no" title="statement not covered" >const editable = renderer.create('<div class="note-editable card-block" contentEditable="true" role="textbox" aria-multiline="true"/>');</span> <span class="cstat-no" title="statement not covered" >const statusbar = renderer.create([</span> '<output class="note-status-output" aria-live="polite"/>', '<div class="note-statusbar" role="status">', ' <output class="note-status-output" aria-live="polite"></output>', ' <div class="note-resizebar" role="seperator" aria-orientation="horizontal" aria-label="Resize">', ' <div class="note-icon-bar"/>', ' <div class="note-icon-bar"/>', ' <div class="note-icon-bar"/>', ' </div>', '</div>' ].join('')); <span class="cstat-no" title="statement not covered" >const airEditor = renderer.create('<div class="note-editor"/>');</span> <span class="cstat-no" title="statement not covered" >const airEditable = renderer.create([</span> '<output class="note-status-output" aria-live="polite"/>', '<div class="note-editable" contentEditable="true" role="textbox" aria-multiline="true"/>' ].join('')); <span class="cstat-no" title="statement not covered" >const buttonGroup = renderer.create('<div class="note-btn-group btn-group">');</span> <span class="cstat-no" title="statement not covered" >const dropdown = renderer.create('<div class="dropdown-menu" role="list">', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > const markup = $.isArray(options.items) ? options.items.map(<span class="fstat-no" title="function not covered" >function(item)</span> {</span> <span class="cstat-no" title="statement not covered" > const value = (typeof item === 'string') ? item : (item.value || '');</span> <span class="cstat-no" title="statement not covered" > const content = options.template ? options.template(item) : item;</span> <span class="cstat-no" title="statement not covered" > const option = (typeof item === 'object') ? item.option : undefined;</span> <span class="cstat-no" title="statement not covered" > const dataValue = 'data-value="' + value + '"';</span> <span class="cstat-no" title="statement not covered" > const dataOption = (option !== undefined) ? ' data-option="' + option + '"' : '';</span> <span class="cstat-no" title="statement not covered" > return '<a class="dropdown-item" href="#" ' + (dataValue + dataOption) + ' role="listitem" aria-label="' + item + '">' + content + '</a>';</span> }).join('') : options.items; <span class="cstat-no" title="statement not covered" > $node.html(markup).attr({'aria-label': options.title});</span> }); <span class="cstat-no" title="statement not covered" >const dropdownButtonContents = <span class="fstat-no" title="function not covered" >function(contents)</span> {</span> <span class="cstat-no" title="statement not covered" > return contents;</span> }; <span class="cstat-no" title="statement not covered" >const dropdownCheck = renderer.create('<div class="dropdown-menu note-check" role="list">', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > const markup = $.isArray(options.items) ? options.items.map(<span class="fstat-no" title="function not covered" >function(item)</span> {</span> <span class="cstat-no" title="statement not covered" > const value = (typeof item === 'string') ? item : (item.value || '');</span> <span class="cstat-no" title="statement not covered" > const content = options.template ? options.template(item) : item;</span> <span class="cstat-no" title="statement not covered" > return '<a class="dropdown-item" href="#" data-value="' + value + '" role="listitem" aria-label="' + item + '">' + icon(options.checkClassName) + ' ' + content + '</a>';</span> }).join('') : options.items; <span class="cstat-no" title="statement not covered" > $node.html(markup).attr({'aria-label': options.title});</span> }); <span class="cstat-no" title="statement not covered" >const palette = renderer.create('<div class="note-color-palette"/>', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > const contents = [];</span> <span class="cstat-no" title="statement not covered" > for (let row = 0, rowSize = options.colors.length; row < rowSize; row++) {</span> <span class="cstat-no" title="statement not covered" > const eventName = options.eventName;</span> <span class="cstat-no" title="statement not covered" > const colors = options.colors[row];</span> <span class="cstat-no" title="statement not covered" > const colorsName = options.colorsName[row];</span> <span class="cstat-no" title="statement not covered" > const buttons = [];</span> <span class="cstat-no" title="statement not covered" > for (let col = 0, colSize = colors.length; col < colSize; col++) {</span> <span class="cstat-no" title="statement not covered" > const color = colors[col];</span> <span class="cstat-no" title="statement not covered" > const colorName = colorsName[col];</span> <span class="cstat-no" title="statement not covered" > buttons.push([</span> '<button type="button" class="note-color-btn"', 'style="background-color:', color, '" ', 'data-event="', eventName, '" ', 'data-value="', color, '" ', 'title="', colorName, '" ', 'aria-label="', colorName, '" ', 'data-toggle="button" tabindex="-1"></button>' ].join('')); } <span class="cstat-no" title="statement not covered" > contents.push('<div class="note-color-row">' + buttons.join('') + '</div>');</span> } <span class="cstat-no" title="statement not covered" > $node.html(contents.join(''));</span> <span class="cstat-no" title="statement not covered" > if (options.tooltip) {</span> <span class="cstat-no" title="statement not covered" > $node.find('.note-color-btn').tooltip({</span> container: options.container, trigger: 'hover', placement: 'bottom' }); } }); <span class="cstat-no" title="statement not covered" >const dialog = renderer.create('<div class="modal" aria-hidden="false" tabindex="-1" role="dialog"/>', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > if (options.fade) {</span> <span class="cstat-no" title="statement not covered" > $node.addClass('fade');</span> } <span class="cstat-no" title="statement not covered" > $node.attr({</span> 'aria-label': options.title }); <span class="cstat-no" title="statement not covered" > $node.html([</span> '<div class="modal-dialog">', ' <div class="modal-content">', (options.title ? ' <div class="modal-header">' + ' <h4 class="modal-title">' + options.title + '</h4>' + ' <button type="button" class="close" data-dismiss="modal" aria-label="Close" aria-hidden="true">&times;</button>' + ' </div>' : '' ), ' <div class="modal-body">' + options.body + '</div>', (options.footer ? ' <div class="modal-footer">' + options.footer + '</div>' : '' ), ' </div>', '</div>' ].join('')); }); <span class="cstat-no" title="statement not covered" >const popover = renderer.create([</span> '<div class="note-popover popover in">', ' <div class="arrow"/>', ' <div class="popover-content note-children-container"/>', '</div>' ].join(''), <span class="fstat-no" title="function not covered" >function($node, options)</span> { <span class="cstat-no" title="statement not covered" > const direction = typeof options.direction !== 'undefined' ? options.direction : 'bottom';</span> <span class="cstat-no" title="statement not covered" > $node.addClass(direction);</span> <span class="cstat-no" title="statement not covered" > if (options.hideArrow) {</span> <span class="cstat-no" title="statement not covered" > $node.find('.arrow').hide();</span> } }); <span class="cstat-no" title="statement not covered" >const checkbox = renderer.create('<label class="custom-control custom-checkbox"></label>', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > if (options.id) {</span> <span class="cstat-no" title="statement not covered" > $node.attr('for', options.id);</span> } <span class="cstat-no" title="statement not covered" > $node.html([</span> ' <input role="checkbox" type="checkbox" class="custom-control-input"' + (options.id ? ' id="' + options.id + '"' : ''), (options.checked ? ' checked' : ''), ' aria-checked="' + (options.checked ? 'true' : 'false') + '"/>', ' <span class="custom-control-indicator"></span>', ' <span class="custom-control-description">' + (options.text ? options.text : '') + '</span>', '</label>' ].join('')); }); <span class="cstat-no" title="statement not covered" >const icon = <span class="fstat-no" title="function not covered" >function(iconClassName, tagName)</span> {</span> <span class="cstat-no" title="statement not covered" > tagName = tagName || 'i';</span> <span class="cstat-no" title="statement not covered" > return '<' + tagName + ' class="' + iconClassName + '"/>';</span> }; <span class="cstat-no" title="statement not covered" >const ui = {</span> editor: editor, toolbar: toolbar, editingArea: editingArea, codable: codable, editable: editable, statusbar: statusbar, airEditor: airEditor, airEditable: airEditable, buttonGroup: buttonGroup, dropdown: dropdown, dropdownButtonContents: dropdownButtonContents, dropdownCheck: dropdownCheck, palette: palette, dialog: dialog, popover: popover, icon: icon, checkbox: checkbox, options: {}, button: <span class="fstat-no" title="function not covered" >function($node, options)</span> { <span class="cstat-no" title="statement not covered" > return renderer.create('<button type="button" class="note-btn btn btn-light btn-sm" role="button" tabindex="-1">', <span class="fstat-no" title="function not covered" >function($node, options)</span> {</span> <span class="cstat-no" title="statement not covered" > if (options && options.tooltip) {</span> <span class="cstat-no" title="statement not covered" > $node.attr({</span> title: options.tooltip, 'aria-label': options.tooltip }).tooltip({ container: options.container, trigger: 'hover', placement: 'bottom' }); } })($node, options); }, toggleBtn: <span class="fstat-no" title="function not covered" >function($btn, isEnable)</span> { <span class="cstat-no" title="statement not covered" > $btn.toggleClass('disabled', !isEnable);</span> <span class="cstat-no" title="statement not covered" > $btn.attr('disabled', !isEnable);</span> }, toggleBtnActive: <span class="fstat-no" title="function not covered" >function($btn, isActive)</span> { <span class="cstat-no" title="statement not covered" > $btn.toggleClass('active', isActive);</span> }, onDialogShown: <span class="fstat-no" title="function not covered" >function($dialog, handler)</span> { <span class="cstat-no" title="statement not covered" > $dialog.one('shown.bs.modal', handler);</span> }, onDialogHidden: <span class="fstat-no" title="function not covered" >function($dialog, handler)</span> { <span class="cstat-no" title="statement not covered" > $dialog.one('hidden.bs.modal', handler);</span> }, showDialog: <span class="fstat-no" title="function not covered" >function($dialog)</span> { <span class="cstat-no" title="statement not covered" > $dialog.modal('show');</span> }, hideDialog: <span class="fstat-no" title="function not covered" >function($dialog)</span> { <span class="cstat-no" title="statement not covered" > $dialog.modal('hide');</span> }, createLayout: <span class="fstat-no" title="function not covered" >function($note, options)</span> { <span class="cstat-no" title="statement not covered" > const $editor = (options.airMode ? ui.airEditor([</span> ui.editingArea([ ui.airEditable() ]) ]) : ui.editor([ ui.toolbar(), ui.editingArea([ ui.codable(), ui.editable() ]), ui.statusbar() ])).render(); <span class="cstat-no" title="statement not covered" > $editor.insertAfter($note);</span> <span class="cstat-no" title="statement not covered" > return {</span> note: $note, editor: $editor, toolbar: $editor.find('.note-toolbar'), editingArea: $editor.find('.note-editing-area'), editable: $editor.find('.note-editable'), codable: $editor.find('.note-codable'), statusbar: $editor.find('.note-statusbar') }; }, removeLayout: <span class="fstat-no" title="function not covered" >function($note, layoutInfo)</span> { <span class="cstat-no" title="statement not covered" > $note.html(layoutInfo.editable.html());</span> <span class="cstat-no" title="statement not covered" > layoutInfo.editor.remove();</span> <span class="cstat-no" title="statement not covered" > $note.show();</span> } }; <span class="cstat-no" title="statement not covered" >export default ui;</span> </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/bs4/index.html000064400000010274151677271550015617 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/bs4/</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> src/js/bs4/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Statements</span> <span class='fraction'>0/105</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/50</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/20</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Lines</span> <span class='fraction'>0/105</span> </div> </div> </div> <div class='status-line low'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file low" data-value="settings.js"><a href="settings.js.html">settings.js</a></td> <td data-value="0" class="pic low"><div class="chart"><div class="cover-fill" style="width: 0%;"></div><div class="cover-empty" style="width:100%;"></div></div></td> <td data-value="0" class="pct low">0%</td> <td data-value="27" class="abs low">0/27</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="0" class="pct low">0%</td> <td data-value="27" class="abs low">0/27</td> </tr> <tr> <td class="file low" data-value="ui.js"><a href="ui.js.html">ui.js</a></td> <td data-value="0" class="pic low"><div class="chart"><div class="cover-fill" style="width: 0%;"></div><div class="cover-empty" style="width:100%;"></div></div></td> <td data-value="0" class="pct low">0%</td> <td data-value="78" class="abs low">0/78</td> <td data-value="0" class="pct low">0%</td> <td data-value="50" class="abs low">0/50</td> <td data-value="0" class="pct low">0%</td> <td data-value="20" class="abs low">0/20</td> <td data-value="0" class="pct low">0%</td> <td data-value="78" class="abs low">0/78</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/src/js/bs4/settings.js.html000064400000075755151677271550017002 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/js/bs4/settings.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/js/bs4/</a> settings.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Statements</span> <span class='fraction'>0/27</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Lines</span> <span class='fraction'>0/27</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302</td><td class="line-coverage quiet"><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-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-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-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-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-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> <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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-no"> </span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" >import $ from 'jquery';</span> <span class="cstat-no" title="statement not covered" >import ui from '../bs4/ui';</span> <span class="cstat-no" title="statement not covered" >import dom from '../base/core/dom';</span> <span class="cstat-no" title="statement not covered" >import '../base/summernote-en-US';</span> <span class="cstat-no" title="statement not covered" >import Editor from '../base/module/Editor';</span> <span class="cstat-no" title="statement not covered" >import Clipboard from '../base/module/Clipboard';</span> <span class="cstat-no" title="statement not covered" >import Dropzone from '../base/module/Dropzone';</span> <span class="cstat-no" title="statement not covered" >import Codeview from '../base/module/Codeview';</span> <span class="cstat-no" title="statement not covered" >import Statusbar from '../base/module/Statusbar';</span> <span class="cstat-no" title="statement not covered" >import Fullscreen from '../base/module/Fullscreen';</span> <span class="cstat-no" title="statement not covered" >import Handle from '../base/module/Handle';</span> <span class="cstat-no" title="statement not covered" >import AutoLink from '../base/module/AutoLink';</span> <span class="cstat-no" title="statement not covered" >import AutoSync from '../base/module/AutoSync';</span> <span class="cstat-no" title="statement not covered" >import Placeholder from '../base/module/Placeholder';</span> <span class="cstat-no" title="statement not covered" >import Buttons from '../base/module/Buttons';</span> <span class="cstat-no" title="statement not covered" >import Toolbar from '../base/module/Toolbar';</span> <span class="cstat-no" title="statement not covered" >import LinkDialog from '../base/module/LinkDialog';</span> <span class="cstat-no" title="statement not covered" >import LinkPopover from '../base/module/LinkPopover';</span> <span class="cstat-no" title="statement not covered" >import ImageDialog from '../base/module/ImageDialog';</span> <span class="cstat-no" title="statement not covered" >import ImagePopover from '../base/module/ImagePopover';</span> <span class="cstat-no" title="statement not covered" >import TablePopover from '../base/module/TablePopover';</span> <span class="cstat-no" title="statement not covered" >import VideoDialog from '../base/module/VideoDialog';</span> <span class="cstat-no" title="statement not covered" >import HelpDialog from '../base/module/HelpDialog';</span> <span class="cstat-no" title="statement not covered" >import AirPopover from '../base/module/AirPopover';</span> <span class="cstat-no" title="statement not covered" >import HintPopover from '../base/module/HintPopover';</span> <span class="cstat-no" title="statement not covered" >$.summernote = $.extend($.summernote, {</span> version: '@@VERSION@@', ui: ui, dom: dom, plugins: {}, options: { modules: { 'editor': Editor, 'clipboard': Clipboard, 'dropzone': Dropzone, 'codeview': Codeview, 'statusbar': Statusbar, 'fullscreen': Fullscreen, 'handle': Handle, // FIXME: HintPopover must be front of autolink // - Script error about range when Enter key is pressed on hint popover 'hintPopover': HintPopover, 'autoLink': AutoLink, 'autoSync': AutoSync, 'placeholder': Placeholder, 'buttons': Buttons, 'toolbar': Toolbar, 'linkDialog': LinkDialog, 'linkPopover': LinkPopover, 'imageDialog': ImageDialog, 'imagePopover': ImagePopover, 'tablePopover': TablePopover, 'videoDialog': VideoDialog, 'helpDialog': HelpDialog, 'airPopover': AirPopover }, buttons: {}, lang: 'en-US', followingToolbar: true, otherStaticBar: '', // toolbar toolbar: [ ['style', ['style']], ['font', ['bold', 'underline', 'clear']], ['fontname', ['fontname']], ['color', ['color']], ['para', ['ul', 'ol', 'paragraph']], ['table', ['table']], ['insert', ['link', 'picture', 'video']], ['view', ['fullscreen', 'codeview', 'help']] ], // popover popatmouse: true, popover: { image: [ ['imagesize', ['imageSize100', 'imageSize50', 'imageSize25']], ['float', ['floatLeft', 'floatRight', 'floatNone']], ['remove', ['removeMedia']] ], link: [ ['link', ['linkDialogShow', 'unlink']] ], table: [ ['add', ['addRowDown', 'addRowUp', 'addColLeft', 'addColRight']], ['delete', ['deleteRow', 'deleteCol', 'deleteTable']] ], air: [ ['color', ['color']], ['font', ['bold', 'underline', 'clear']], ['para', ['ul', 'paragraph']], ['table', ['table']], ['insert', ['link', 'picture']] ] }, // air mode: inline editor airMode: false, width: null, height: null, linkTargetBlank: true, focus: false, tabSize: 4, styleWithSpan: true, shortcuts: true, textareaAutoSync: true, hintDirection: 'bottom', tooltip: 'auto', container: 'body', maxTextLength: 0, styleTags: [ 'p', { title: 'Blockquote', tag: 'blockquote', className: 'blockquote', value: 'blockquote' }, 'h1', 'h2', 'h3', 'h4', 'h5', 'h6' ], fontNames: [ 'Arial', 'Arial Black', 'Comic Sans MS', 'Courier New', 'Helvetica Neue', 'Helvetica', 'Impact', 'Lucida Grande', 'Tahoma', 'Times New Roman', 'Verdana' ], fontSizes: ['8', '9', '10', '11', '12', '14', '18', '24', '36'], // pallete colors(n x n) colors: [ ['#000000', '#424242', '#636363', '#9C9C94', '#CEC6CE', '#EFEFEF', '#F7F7F7', '#FFFFFF'], ['#FF0000', '#FF9C00', '#FFFF00', '#00FF00', '#00FFFF', '#0000FF', '#9C00FF', '#FF00FF'], ['#F7C6CE', '#FFE7CE', '#FFEFC6', '#D6EFD6', '#CEDEE7', '#CEE7F7', '#D6D6E7', '#E7D6DE'], ['#E79C9C', '#FFC69C', '#FFE79C', '#B5D6A5', '#A5C6CE', '#9CC6EF', '#B5A5D6', '#D6A5BD'], ['#E76363', '#F7AD6B', '#FFD663', '#94BD7B', '#73A5AD', '#6BADDE', '#8C7BC6', '#C67BA5'], ['#CE0000', '#E79439', '#EFC631', '#6BA54A', '#4A7B8C', '#3984C6', '#634AA5', '#A54A7B'], ['#9C0000', '#B56308', '#BD9400', '#397B21', '#104A5A', '#085294', '#311873', '#731842'], ['#630000', '#7B3900', '#846300', '#295218', '#083139', '#003163', '#21104A', '#4A1031'] ], // http://chir.ag/projects/name-that-color/ colorsName: [ ['Black', 'Tundora', 'Dove Gray', 'Star Dust', 'Pale Slate', 'Gallery', 'Alabaster', 'White'], ['Red', 'Orange Peel', 'Yellow', 'Green', 'Cyan', 'Blue', 'Electric Violet', 'Magenta'], ['Azalea', 'Karry', 'Egg White', 'Zanah', 'Botticelli', 'Tropical Blue', 'Mischka', 'Twilight'], ['Tonys Pink', 'Peach Orange', 'Cream Brulee', 'Sprout', 'Casper', 'Perano', 'Cold Purple', 'Careys Pink'], ['Mandy', 'Rajah', 'Dandelion', 'Olivine', 'Gulf Stream', 'Viking', 'Blue Marguerite', 'Puce'], ['Guardsman Red', 'Fire Bush', 'Golden Dream', 'Chelsea Cucumber', 'Smalt Blue', 'Boston Blue', 'Butterfly Bush', 'Cadillac'], ['Sangria', 'Mai Tai', 'Buddha Gold', 'Forest Green', 'Eden', 'Venice Blue', 'Meteorite', 'Claret'], ['Rosewood', 'Cinnamon', 'Olive', 'Parsley', 'Tiber', 'Midnight Blue', 'Valentino', 'Loulou'] ], lineHeights: ['1.0', '1.2', '1.4', '1.5', '1.6', '1.8', '2.0', '3.0'], tableClassName: 'table table-bordered', insertTableMaxSize: { col: 10, row: 10 }, dialogsInBody: false, dialogsFade: false, maximumImageFileSize: null, callbacks: { onInit: null, onFocus: null, onBlur: null, onBlurCodeview: null, onEnter: null, onKeyup: null, onKeydown: null, onImageUpload: null, onImageUploadError: null }, codemirror: { mode: 'text/html', htmlMode: true, lineNumbers: true }, keyMap: { pc: { 'ENTER': 'insertParagraph', 'CTRL+Z': 'undo', 'CTRL+Y': 'redo', 'TAB': 'tab', 'SHIFT+TAB': 'untab', 'CTRL+B': 'bold', 'CTRL+I': 'italic', 'CTRL+U': 'underline', 'CTRL+SHIFT+S': 'strikethrough', 'CTRL+BACKSLASH': 'removeFormat', 'CTRL+SHIFT+L': 'justifyLeft', 'CTRL+SHIFT+E': 'justifyCenter', 'CTRL+SHIFT+R': 'justifyRight', 'CTRL+SHIFT+J': 'justifyFull', 'CTRL+SHIFT+NUM7': 'insertUnorderedList', 'CTRL+SHIFT+NUM8': 'insertOrderedList', 'CTRL+LEFTBRACKET': 'outdent', 'CTRL+RIGHTBRACKET': 'indent', 'CTRL+NUM0': 'formatPara', 'CTRL+NUM1': 'formatH1', 'CTRL+NUM2': 'formatH2', 'CTRL+NUM3': 'formatH3', 'CTRL+NUM4': 'formatH4', 'CTRL+NUM5': 'formatH5', 'CTRL+NUM6': 'formatH6', 'CTRL+ENTER': 'insertHorizontalRule', 'CTRL+K': 'linkDialog.show' }, mac: { 'ENTER': 'insertParagraph', 'CMD+Z': 'undo', 'CMD+SHIFT+Z': 'redo', 'TAB': 'tab', 'SHIFT+TAB': 'untab', 'CMD+B': 'bold', 'CMD+I': 'italic', 'CMD+U': 'underline', 'CMD+SHIFT+S': 'strikethrough', 'CMD+BACKSLASH': 'removeFormat', 'CMD+SHIFT+L': 'justifyLeft', 'CMD+SHIFT+E': 'justifyCenter', 'CMD+SHIFT+R': 'justifyRight', 'CMD+SHIFT+J': 'justifyFull', 'CMD+SHIFT+NUM7': 'insertUnorderedList', 'CMD+SHIFT+NUM8': 'insertOrderedList', 'CMD+LEFTBRACKET': 'outdent', 'CMD+RIGHTBRACKET': 'indent', 'CMD+NUM0': 'formatPara', 'CMD+NUM1': 'formatH1', 'CMD+NUM2': 'formatH2', 'CMD+NUM3': 'formatH3', 'CMD+NUM4': 'formatH4', 'CMD+NUM5': 'formatH5', 'CMD+NUM6': 'formatH6', 'CMD+ENTER': 'insertHorizontalRule', 'CMD+K': 'linkDialog.show' } }, icons: { 'align': 'note-icon-align', 'alignCenter': 'note-icon-align-center', 'alignJustify': 'note-icon-align-justify', 'alignLeft': 'note-icon-align-left', 'alignRight': 'note-icon-align-right', 'rowBelow': 'note-icon-row-below', 'colBefore': 'note-icon-col-before', 'colAfter': 'note-icon-col-after', 'rowAbove': 'note-icon-row-above', 'rowRemove': 'note-icon-row-remove', 'colRemove': 'note-icon-col-remove', 'indent': 'note-icon-align-indent', 'outdent': 'note-icon-align-outdent', 'arrowsAlt': 'note-icon-arrows-alt', 'bold': 'note-icon-bold', 'caret': 'note-icon-caret', 'circle': 'note-icon-circle', 'close': 'note-icon-close', 'code': 'note-icon-code', 'eraser': 'note-icon-eraser', 'font': 'note-icon-font', 'frame': 'note-icon-frame', 'italic': 'note-icon-italic', 'link': 'note-icon-link', 'unlink': 'note-icon-chain-broken', 'magic': 'note-icon-magic', 'menuCheck': 'note-icon-menu-check', 'minus': 'note-icon-minus', 'orderedlist': 'note-icon-orderedlist', 'pencil': 'note-icon-pencil', 'picture': 'note-icon-picture', 'question': 'note-icon-question', 'redo': 'note-icon-redo', 'square': 'note-icon-square', 'strikethrough': 'note-icon-strikethrough', 'subscript': 'note-icon-subscript', 'superscript': 'note-icon-superscript', 'table': 'note-icon-table', 'textHeight': 'note-icon-text-height', 'trash': 'note-icon-trash', 'underline': 'note-icon-underline', 'undo': 'note-icon-undo', 'unorderedlist': 'note-icon-unorderedlist', 'video': 'note-icon-video' } } }); <span class="cstat-no" title="statement not covered" >import '../summernote'; </span>// eslint-disable-line </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/editing/style.spec.js.html000064400000026417151677271550021622 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/editing/style.spec.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">test/unit/base/editing/</a> style.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>58/58</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>10/10</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>58/58</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 80 81 82 83 84 85 86 87 88 89 90 91 92 93</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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** * Style.spec.js * (c) 2015~ Summernote Team * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import $ from 'jquery'; import range from '../../../../src/js/base/core/range'; import Style from '../../../../src/js/base/editing/Style'; var expect = chai.expect; describe('base:editing.Style', () => { var style = new Style(); describe('styleNodes', () => { it('should wrap selected text with span', () => { var $cont = $('<div class="note-editable"><p>text</p></div>'); var $p = $cont.find('p'); var rng = range.create($p[0].firstChild, 0, $p[0].firstChild, 4); style.styleNodes(rng); expect($cont.html()).to.deep.equal('<p><span>text</span></p>'); }); it('should split text and wrap selected text with span', () => { var $cont = $('<div class="note-editable"><p>text</p></div>'); var $p = $cont.find('p'); var rng = range.create($p[0].firstChild, 1, $p[0].firstChild, 3); style.styleNodes(rng); expect($cont.html()).to.deep.equal('<p>t<span>ex</span>t</p>'); }); it('should split text and insert span', () => { var $cont = $('<div class="note-editable"><p>text</p></div>'); var $p = $cont.find('p'); var rng = range.create($p[0].firstChild, 2, $p[0].firstChild, 2); style.styleNodes(rng); expect($cont.html()).to.deep.equal('<p>te<span></span>xt</p>'); }); it('should just return a parent span', () => { var $cont = $('<div class="note-editable"><p><span>text</span></p></div>'); var $span = $cont.find('span'); var rng = range.create($span[0].firstChild, 0, $span[0].firstChild, 4); style.styleNodes(rng); expect($cont.html()).to.deep.equal('<p><span>text</span></p>'); }); it('should wrap each texts with span', () => { var $cont = $('<div class="note-editable"><p><b>bold</b><span>span</span></p></div>'); var $b = $cont.find('b'); var $span = $cont.find('span'); var rng = range.create($b[0].firstChild, 2, $span[0].firstChild, 2); style.styleNodes(rng); expect($cont.html()).to.deep.equal('<p><b>bo<span>ld</span></b><span><span>sp</span>an</span></p>'); }); it('should wrap each texts with span except not a single blood line', () => { var $cont = $('<div class="note-editable"><p><b>bold</b><span>span</span></p></div>'); var $b = $cont.find('b'); var $span = $cont.find('span'); var rng = range.create($b[0].firstChild, 2, $span[0].firstChild, 4); style.styleNodes(rng); expect($cont.html()).to.deep.equal('<p><b>bo<span>ld</span></b><span>span</span></p>'); }); it('should expand b tag when providing the expandClosestSibling option', () => { var $cont = $('<div class="note-editable"><p>text<b>bold</b></p></div>'); var $p = $cont.find('p'); var rng = range.create($p[0].firstChild, 0, $p[0].firstChild, 4); style.styleNodes(rng, { nodeName: 'B', expandClosestSibling: true }); expect($cont.html()).to.deep.equal('<p><b>textbold</b></p>'); }); it('should not expand b tag when providing the onlyPartialContains option', () => { var $cont = $('<div class="note-editable"><p>text<b>bold</b></p></div>'); var $p = $cont.find('p'); var rng = range.create($p[0].firstChild, 0, $p[0].firstChild, 4); style.styleNodes(rng, { nodeName: 'B', expandClosestSibling: true, onlyPartialContains: true }); expect($cont.html()).to.deep.equal('<p><b>text</b><b>bold</b></p>'); }); }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/editing/index.html000064400000010537151677271550020221 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/editing/</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> test/unit/base/editing/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>493/493</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>38/38</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>493/493</span> </div> </div> </div> <div class='status-line high'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file high" data-value="Table.spec.js"><a href="Table.spec.js.html">Table.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="435" class="abs high">435/435</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="28" class="abs high">28/28</td> <td data-value="100" class="pct high">100%</td> <td data-value="435" class="abs high">435/435</td> </tr> <tr> <td class="file high" data-value="style.spec.js"><a href="style.spec.js.html">style.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="58" class="abs high">58/58</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="10" class="abs high">10/10</td> <td data-value="100" class="pct high">100%</td> <td data-value="58" class="abs high">58/58</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/editing/Table.spec.js.html000064400000176032151677271550021510 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/editing/Table.spec.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">test/unit/base/editing/</a> Table.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>435/435</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>28/28</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>435/435</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554</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-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-yes">1×</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-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-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-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-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-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-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-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-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-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-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-yes">1×</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-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-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-yes">1×</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-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-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-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-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-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-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-yes">1×</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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** * Table.spec.js * (c) 2015~ Summernote Team * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import $ from 'jquery'; import range from '../../../../src/js/base/core/range'; import Table from '../../../../src/js/base/editing/Table'; var expect = chai.expect; describe('base:editing.Table', () => { var table = new Table(); describe('tableWorker', () => { it('should create simple 1x1 table', () => { var resultTable = table.createTable(1, 1); expect(1).to.deep.equal(resultTable.rows.length); expect(1).to.deep.equal(resultTable.rows[0].cells.length); }); it('should delete simple 1x1 table', () => { var $cont = $('<div class="note-editable"><table><tr><td>content</td></tr></table></div>'); var $cell = $cont.find('td'); var rng = range.create($cell[0].firstChild, 1); table.deleteTable(rng); expect('').to.deep.equal($cont.html()); }); it('should add simple row to table on top', () => { var $cont = $('<div class="note-editable"><table><tr><td>content</td></tr></table></div>'); var $cell = $cont.find('td'); var rng = range.create($cell[0].firstChild, 1); table.addRow(rng, 'top'); expect('<table><tbody><tr><td><br></td></tr><tr><td>content</td></tr></tbody></table>').to.equalsIgnoreCase($cont.html()); }); it('should add simple row to table on bottom', () => { var $cont = $('<div class="note-editable"><table><tr><td>content</td></tr></table></div>'); var $cell = $cont.find('td'); var rng = range.create($cell[0].firstChild, 1); table.addRow(rng, 'bottom'); expect('<table><tbody><tr><td>content</td></tr><tr><td><br></td></tr></tbody></table>').to.equalsIgnoreCase($cont.html()); }); it('should add simple row to table on top between two rows', () => { var htmlContent = '<div class="note-editable"><table><tr><td>content1</td></tr><tr><td id="td2">content2</td></tr></table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#td2'); var rng = range.create($cell[0].firstChild, 1); table.addRow(rng, 'top'); var resultTable = $('<table><tbody><tr><td>content1</td></tr></tbody></table>'); $(resultTable).append('<tr><td><br/></td></tr>'); $(resultTable).append('<tr><td id="td2">content2</td></tr>'); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should add simple row to table on bottom between two rows', () => { var baseTable = $('<table><tbody><tr><td id="td1">content1</td></tr></tbody></table>'); $(baseTable).append('<tr><td id="td2">content2</td></tr>'); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#td1'); var rng = range.create($cell[0].firstChild, 1); table.addRow(rng, 'bottom'); var resultTable = $('<table><tbody><tr><td id="td1">content1</td></tr></tbody></table>'); $(resultTable).append('<tr><td><br/></td></tr>'); $(resultTable).append('<tr><td id="td2">content2</td></tr>'); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should add simple col to table on left between two cols', () => { var baseTable = $('<table><tbody></tbody></table>'); var baseTr = '<tr><td id="td1">content1</td><td id="td2">content2</td></tr>'; baseTable.append(baseTr); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#td2'); var rng = range.create($cell[0].firstChild, 1); table.addCol(rng, 'left'); var resultTable = $('<table><tbody></tbody></table>'); $(resultTable).append('<tr><td id="td1">content1</td><td><br/></td><td id="td2">content2</td></tr>'); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should add simple col to table on right between two cols', () => { var baseTable = $('<table><tbody></tbody></table>'); var baseTr = '<tr><td id="td1">content1</td><td id="td2">content2</td></tr>'; baseTable.append(baseTr); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#td1'); var rng = range.create($cell[0].firstChild, 1); table.addCol(rng, 'right'); var resultTable = $('<table><tbody></tbody></table>'); $(resultTable).append('<tr><td id="td1">content1</td><td><br/></td><td id="td2">content2</td></tr>'); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should delete row to table between two other rows', () => { var baseTable = $('<table><tbody></tbody></table>'); var baseTr = '<tr><td id="td1">content1</td></tr>'; baseTr += '<td id="td2">content2</td></tr>'; baseTr += '<td id="td3">content3</td></tr>'; baseTable.append(baseTr); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#td2'); var rng = range.create($cell[0].firstChild, 1); table.deleteRow(rng); var resultTable = $('<table><tbody></tbody></table>'); $(resultTable).append('<tr><td id="td1">content1</td></tr><tr><td id="td3">content3</td></tr>'); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should delete col to table between two other cols', () => { var baseTable = $('<table><tbody></tbody></table>'); var baseTr = '<tr><td id="td1">content1</td><td id="td2">content2</td><td id="td3">content3</td></tr>'; baseTable.append(baseTr); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#td2'); var rng = range.create($cell[0].firstChild, 1); table.deleteCol(rng); var resultTable = $('<table><tbody></tbody></table>'); $(resultTable).append('<tr><td id="td1">content1</td><td id="td3">content3</td></tr>'); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should delete first col to table with colspan in column with colspan', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td colspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td1">Col1</td><td id="tr2td2">Col2</td><td id="tr2td3">Col3</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td1'); var rng = range.create($cell[0].firstChild, 1); table.deleteCol(rng); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td id="tr1td1"></td><td id="tr1td2">Col2</td></tr>'; var resultTr2 = '<tr><td id="tr2td2">Col2</td><td id="tr2td3">Col3</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should delete second col to table with colspan in column', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td colspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td1">Col1</td><td id="tr2td2">Col2</td><td id="tr2td3">Col3</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr2td2'); var rng = range.create($cell[0].firstChild, 1); table.deleteCol(rng); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var resultTr2 = '<tr><td id="tr2td1">Col1</td><td id="tr2td3">Col3</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should delete second col to table with colspan in 3 columns', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td colspan="3" id="tr1td1">Col1-Span</td><td id="tr1td4">Col4</td></tr>'; var baseTr2 = '<tr><td id="tr2td1">Col1</td><td id="tr2td2">Col2</td><td id="tr2td3">Col3</td><td id="tr2td4">Col4</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr2td2'); var rng = range.create($cell[0].firstChild, 1); table.deleteCol(rng); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td colspan="2" id="tr1td1">Col1-Span</td><td id="tr1td4">Col4</td></tr>'; var resultTr2 = '<tr><td id="tr2td1">Col1</td><td id="tr2td3">Col3</td><td id="tr2td4">Col4</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should delete first row to table with rowspan in line with rowspan', () => { var baseTable = $('<table><tbody></tbody></table>'); var baseTr1 = '<tr><td class="test" rowspan="2" id="tr1td1">Row1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td2">Col2</td></tr>'; var baseTr3 = '<tr><td id="tr3td1">Col1</td><td id="tr3td2">Col2</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); baseTable.append(baseTr3); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td1'); var rng = range.create($cell[0].firstChild, 1); table.deleteRow(rng); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1AndTr2 = '<tr><td class="test" id="tr1td1"></td><td id="tr2td2">Col2</td></tr>'; var resultTr3 = '<tr><td id="tr3td1">Col1</td><td id="tr3td2">Col2</td></tr>'; resultTable.append(resultTr1AndTr2); resultTable.append(resultTr3); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should delete second row to table with rowspan in line without rowspan', () => { var baseTable = $('<table><tbody></tbody></table>'); var baseTr1 = '<tr><td rowspan="3" id="tr1td1">Row1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td2">Col2</td></tr>'; var baseTr3 = '<tr><td id="tr3td2">Col2</td></tr>'; var baseTr4 = '<tr><td id="tr4td1">Col1</td><td id="tr4td2">Col2</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); baseTable.append(baseTr3); baseTable.append(baseTr4); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr2td2'); var rng = range.create($cell[0].firstChild, 1); table.deleteRow(rng); var resultTable = $('<table><tbody></tbody></table>'); var resultTr1 = '<tr><td rowspan="2" id="tr1td1">Row1-Span</td><td id="tr1td2">Col2</td></tr>'; var resultTr3 = '<tr><td id="tr3td2">Col2</td></tr>'; var resultTr4 = '<tr><td id="tr4td1">Col1</td><td id="tr4td2">Col2</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr3); resultTable.append(resultTr4); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should delete second col to table with rowspan in 2 rows', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td2">Col2</td></tr>'; var baseTr3 = '<tr><td id="tr3td1">Col1</td><td id="tr3td2">Col2</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); baseTable.append(baseTr3); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td2'); var rng = range.create($cell[0].firstChild, 1); table.deleteCol(rng); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td></tr>'; var resultTr2 = '<tr></tr>'; var resultTr3 = '<tr><td id="tr3td1">Col1</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); resultTable.append(resultTr3); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should delete second col to table with rowspan in 2 rows on second row', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td2">Col2</td></tr>'; var baseTr3 = '<tr><td id="tr3td1">Col1</td><td id="tr3td2">Col2</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); baseTable.append(baseTr3); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr2td2'); var rng = range.create($cell[0].firstChild, 1); table.deleteCol(rng); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td></tr>'; var resultTr2 = '<tr></tr>'; var resultTr3 = '<tr><td id="tr3td1">Col1</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); resultTable.append(resultTr3); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should add row on bottom rowspan cell.', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td2">Col2</td></tr>'; var baseTr3 = '<tr><td id="tr3td1">Col1</td><td id="tr3td2">Col2</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); baseTable.append(baseTr3); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr2td2'); var rng = range.create($cell[0].firstChild, 1); table.addRow(rng); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td rowspan="3" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var resultTr2 = '<tr><td id="tr2td2">Col2</td></tr>'; var resultTr3 = '<tr><td><br></td></tr>'; var resultTr4 = '<tr><td id="tr3td1">Col1</td><td id="tr3td2">Col2</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); resultTable.append(resultTr3); resultTable.append(resultTr4); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should add row on bottom colspan cell.', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td colspan="2" id="tr1td1">Col1-Span</td></tr>'; var baseTr2 = '<tr><td id="tr2td1">Col1</td><td id="tr2td2">Col2</td></tr>'; var baseTr3 = '<tr><td id="tr3td1">Col1</td><td id="tr3td2">Col2</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); baseTable.append(baseTr3); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td1'); var rng = range.create($cell[0].firstChild, 1); table.addRow(rng, 'bottom'); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td colspan="2" id="tr1td1">Col1-Span</td></tr>'; var resultTr2 = '<tr><td colspan="2"><br></td></tr>'; var resultTr3 = '<tr><td id="tr2td1">Col1</td><td id="tr2td2">Col2</td></tr>'; var resultTr4 = '<tr><td id="tr3td1">Col1</td><td id="tr3td2">Col2</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); resultTable.append(resultTr3); resultTable.append(resultTr4); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should add row above rowspan cell.', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td2">Col1</td></tr>'; var baseTr3 = '<tr><td id="tr3td1">Col1</td><td id="tr3td2">Col2</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); baseTable.append(baseTr3); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td1'); var rng = range.create($cell[0].firstChild, 1); table.addRow(rng, 'top'); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td><br></td><td><br></td></tr>'; var resultTr2 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var resultTr3 = '<tr><td id="tr2td2">Col1</td></tr>'; var resultTr4 = '<tr><td id="tr3td1">Col1</td><td id="tr3td2">Col2</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); resultTable.append(resultTr3); resultTable.append(resultTr4); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should add row on bottom rowspan cell and with aditional column.', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td2">Col1</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td1'); var rng = range.create($cell[0].firstChild, 1); table.addRow(rng, 'bottom'); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td rowspan="3" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var resultTr2 = '<tr><td id="tr2td2">Col1</td></tr>'; var resultTr3 = '<tr><td><br></td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); resultTable.append(resultTr3); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should add column on right having rowspan cell and with aditional column.', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td2">Col1</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td2'); var rng = range.create($cell[0].firstChild, 1); table.addCol(rng, 'right'); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td><td><br></td></tr>'; var resultTr2 = '<tr><td id="tr2td2">Col1</td><td><br></td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should add column on right having rowspan cell and with aditional column with focus on rowspan column.', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td><td id="tr1td2">Col2</td></tr>'; var baseTr2 = '<tr><td id="tr2td2">Col1</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td1'); var rng = range.create($cell[0].firstChild, 1); table.addCol(rng, 'right'); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td rowspan="2" id="tr1td1">Col1-Span</td><td rowspan="2"><br></td><td id="tr1td2">Col2</td></tr>'; var resultTr2 = '<tr><td id="tr2td2">Col1</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should remove column after colspan column.', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td id="tr1td1">Col1</td><td colspan="2" id="tr1td2">Col2-Span</td><td id="tr1td4">Col4</td></tr>'; var baseTr2 = '<tr><td id="tr2td1">Col1</td><td id="tr2td2">Col2</td><td id="tr2td3">Col3</td><td id="tr2td4">Col4</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td4'); var rng = range.create($cell[0].firstChild, 1); table.deleteCol(rng); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td id="tr1td1">Col1</td><td colspan="2" id="tr1td2">Col2-Span</td></tr>'; var resultTr2 = '<tr><td id="tr2td1">Col1</td><td id="tr2td2">Col2</td><td id="tr2td3">Col3</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should remove column before colspan column.', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td id="tr1td1">TR1TD1</td><td id="tr1td2" colspan="2">TR1TD2-COLSPAN</td>'; baseTr1 += '<td id="tr1td4">TR1TD4</td></tr>'; var baseTr2 = '<tr><td id="tr2td1">TR2TD1</td><td id="tr2td2">TR2TD2</td><td id="tr2td3">TR2TD3</td>'; baseTr2 += '<td id="tr2td4">TR2TD4</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td1'); var rng = range.create($cell[0].firstChild, 1); table.deleteCol(rng); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td id="tr1td2" colspan="2">TR1TD2-COLSPAN</td>'; resultTr1 += '<td id="tr1td4">TR1TD4</td></tr>'; var resultTr2 = '<tr><td id="tr2td2">TR2TD2</td><td id="tr2td3">TR2TD3</td><td id="tr2td4">TR2TD4</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); it('should add column before colspan column.', () => { var baseTable = $('<table><tbody></tbody></table> '); var baseTr1 = '<tr><td id="tr1td1">TR1TD1</td><td id="tr1td2">TR1TD2</td></tr>'; var baseTr2 = '<tr><td id="tr2td1" colspan="2">TR2TD1</td></tr>'; baseTable.append(baseTr1); baseTable.append(baseTr2); var htmlContent = '<div class="note-editable"><table>' + $(baseTable).html() + '</table></div>'; var $cont = $(htmlContent); var $cell = $cont.find('#tr1td1'); var rng = range.create($cell[0].firstChild, 1); table.addCol(rng, 'right'); var resultTable = $('<table><tbody></tbody></table> '); var resultTr1 = '<tr><td id="tr1td1">TR1TD1</td><td><br></td><td id="tr1td2">TR1TD2</td></tr>'; var resultTr2 = '<tr><td id="tr2td1" colspan="3">TR2TD1</td></tr>'; resultTable.append(resultTr1); resultTable.append(resultTr2); var expectedResult = '<table>' + $(resultTable).html() + '</table>'; expect(expectedResult).to.equalsIgnoreCase($cont.html()); }); }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/core/key.spec.js.html000064400000010446151677271550020552 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/core/key.spec.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">test/unit/base/core/</a> key.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>12/12</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>6/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>12/12</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</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-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-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-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-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">/** * key.spec.js * (c) 2013~ Alan Hong * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import key from '../../../../src/js/base/core/key'; var expect = chai.expect; describe('base:core.key', () => { describe('isEdit', () => { it('should return true for BACKSPACE', () => { expect(key.isEdit(key.code.BACKSPACE)).to.be.true; }); it('should return true for DELETE', () => { expect(key.isEdit(key.code.DELETE)).to.be.true; }); }); describe('isMove', () => { it('should return true for LEFT', () => { expect(key.isMove(key.code.LEFT)).to.be.true; }); }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/core/lists.spec.js.html000064400000030041151677271550021111 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/core/lists.spec.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">test/unit/base/core/</a> lists.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>63/63</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>33/33</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>62/62</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 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 108 109 110 111 112 113 114 115 116 117 118 119</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-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-yes">1×</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-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-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-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-neutral"> </span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">5×</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-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-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-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">3×</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-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-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-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">4×</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-yes">1×</span> <span class="cline-any cline-yes">1×</span> <span class="cline-any cline-yes">4×</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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** * lists.spec.js * (c) 2013~ Alan Hong * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import $ from 'jquery'; import lists from '../../../../src/js/base/core/lists'; var expect = chai.expect; describe('base:core.lists', () => { describe('head', () => { it('should return the first element', () => { expect(lists.head([1, 2, 3])).to.be.equal(1); }); }); describe('last', () => { it('should return the last element', () => { expect(lists.last([1, 2, 3])).to.be.equal(3); }); }); describe('initial', () => { it('should exclude last element', () => { expect(lists.initial([1, 2, 3])).to.deep.equal([1, 2]); }); }); describe('tail', () => { it('should exclude first element', () => { expect(lists.tail([1, 2, 3])).to.deep.equal([2, 3]); }); }); function isEven(num) { return num % 2 === 0; } describe('find', () => { it('should return first matched element', () => { expect(lists.find([1, 2, 3], isEven)).to.be.equal(2); }); }); describe('all', () => { it('should return false if all elements are not even', () => { expect(lists.all([1, 2, 3], isEven)).to.be.false; }); it('should return true if all elements are even', () => { expect(lists.all([2, 4], isEven)).to.be.true; }); }); describe('all', () => { it('should return false if the element is not contained', () => { expect(lists.contains([1, 2, 3], 4)).to.be.false; }); it('should return true if the element is contained', () => { expect(lists.contains([1, 2, 4], 4)).to.be.true; }); }); describe('sum', () => { it('should return sum of all elements', () => { expect(lists.sum([1, 2, 3])).to.be.equal(6); }); it('should return sum of all elements iterated', () => { var result = lists.sum([1, 2, 3], (v) => { return v * 2; }); expect(result).to.be.equal(12); }); }); describe('from', () => { it('should return an array of childNodes', () => { var $cont, $b, $u, $s, $i; $cont = $('<div><b>b</b><u>u</u><s>s</s><i>i</i></div>'); // busi $b = $cont.find('b'); $u = $cont.find('u'); $s = $cont.find('s'); $i = $cont.find('i'); expect(lists.from($cont[0].childNodes)).to.deep.equal([$b[0], $u[0], $s[0], $i[0]]); }); }); describe('clusterBy', () => { it('should cluster by equality 1', () => { var aaClustered = lists.clusterBy([1, 1, 2, 2, 3], (itemA, itemB) => { return itemA === itemB; }); expect(aaClustered).to.deep.equal([[1, 1], [2, 2], [3]]); }); it('should cluster by equality 2', () => { var aaClustered = lists.clusterBy([1, 2, 2, 1, 3], (itemA, itemB) => { return itemA === itemB; }); expect(aaClustered).to.deep.equal([[1], [2, 2], [1], [3]]); }); }); describe('compact', () => { it('should remove all elements has false value', () => { expect(lists.compact([0, 1, false, 2, '', 3])).to.deep.equal([1, 2, 3]); }); }); describe('unique', () => { it('should return duplicate-free version of array', () => { expect(lists.unique([1, 2, 3, 3, 2, 1])).to.deep.equal([1, 2, 3]); }); }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/core/dom.spec.js.html000064400000102230151677271550020532 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/core/dom.spec.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">test/unit/base/core/</a> dom.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>205/205</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>2/2</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>63/63</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>203/203</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328</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-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-yes">1×</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-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-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-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-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-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-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-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">4×</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">2×</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-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-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-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">4×</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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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">4×</span> <span class="cline-any cline-yes">4×</span> <span class="cline-any cline-yes">4×</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-yes">1×</span> <span class="cline-any cline-yes">10×</span> <span class="cline-any cline-yes">10×</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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-yes">1×</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></td><td class="text"><pre class="prettyprint lang-js">/** * dom.spec.js * (c) 2013~ Alan Hong * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import chaidom from '../../../chaidom'; import $ from 'jquery'; import dom from '../../../../src/js/base/core/dom'; import func from '../../../../src/js/base/core/func'; let expect = chai.expect; chai.use(chaidom); describe('base:core.dom', () => { describe('ancestor', () => { let $cont, $b, txtB; before(() => { // basic case $cont = $('<div class="note-editable"><b>b</b><u>u</u><s>s</s><i>i</i></div>'); // busi $b = $cont.find('b'); txtB = $b[0].firstChild; }); it('should find ancestor B', () => { expect(dom.ancestor(txtB, dom.isB)).to.deep.equal($b[0]); }); it('should find ancestor DIV', () => { expect(dom.ancestor(txtB, dom.isDiv)).to.deep.equal($cont[0]); }); it('should return null when finding ancestor U does not exist', () => { expect(dom.ancestor(txtB, dom.isU)).to.be.null; }); it('should return null when finding paragraph ancestor outsider note-editable', () => { expect(dom.ancestor(txtB, dom.isLi)).to.be.null; }); }); describe('listAncestor', () => { let $cont, $b, $u, $s, $i; before(() => { $cont = $('<div class="note-editable"><i><s><u><b>b</b></u></s></i></div>'); // busi $b = $cont.find('b'); $u = $cont.find('u'); $s = $cont.find('s'); $i = $cont.find('i'); }); it('should return [$b, $u, $s, $i] from b to i', () => { let result = dom.listAncestor($b[0], (node) => { return node === $i[0]; }); expect(result).to.deep.equal([$b[0], $u[0], $s[0], $i[0]]); }); it('should return [$u, $s] from u to s', () => { let result = dom.listAncestor($u[0], (node) => { return node === $s[0]; }); expect(result).to.deep.equal([$u[0], $s[0]]); }); }); describe('listDescendant', () => { let $cont, $b, $u, $s, $i; before(() => { $cont = $('<div class="note-editable"><b></b><u></u><s></s><i></i></div>'); // busi $b = $cont.find('b'); $u = $cont.find('u'); $s = $cont.find('s'); $i = $cont.find('i'); }); it('should return an array of descendant elements', () => { expect(dom.listDescendant($cont[0])).to.deep.equal([$b[0], $u[0], $s[0], $i[0]]); }); it('should filter an array of descendant elements', () => { let result = dom.listDescendant($cont[0], (node) => { return node.nodeName === 'B' || node.nodeName === 'S'; }); expect(result).to.deep.equal([$b[0], $s[0]]); }); }); describe('commonAncestor', () => { let $cont, $span, $div, $b, $u, $s; before(() => { $cont = $('<div class="note-editable"><div><span><b>b</b><u>u</u></span><span><s>s</s><i>i</i></span></div></div>'); $span = $cont.find('span'); $div = $cont.find('div'); $b = $cont.find('b'); $u = $cont.find('u'); $s = $cont.find('s'); }); it('should return a common element in ancestors', () => { expect(dom.commonAncestor($b[0], $u[0])).to.deep.equal($span[0]); }); it('should return a common element in ancestors even if they have same nodeName', () => { expect(dom.commonAncestor($b[0], $s[0])).to.deep.equal($div[0]); }); }); describe('listNext', () => { let $cont, $u, $s, $i; before(() => { $cont = $('<div class="note-editable"><b>b</b><u>u</u><s>s</s><i>i</i></div>'); // busi $u = $cont.find('u'); $s = $cont.find('s'); $i = $cont.find('i'); }); it('should return an array of next sibling elements including itself', () => { expect(dom.listNext($u[0])).to.deep.equal([$u[0], $s[0], $i[0]]); }); it('should return itself if there are no next sibling', () => { expect(dom.listNext($i[0])).to.deep.equal([$i[0]]); }); it('should return an array of next sibling elements before predicate is true', () => { expect(dom.listNext($s[0], func.eq($i[0]))).to.deep.equal([$s[0]]); }); }); describe('listPrev', () => { let $cont, $b, $u, $s, $i; before(() => { $cont = $('<div class="note-editable"><b>b</b><u>u</u><s>s</s><i>i</i></div>'); // busi $b = $cont.find('b'); $u = $cont.find('u'); $s = $cont.find('s'); $i = $cont.find('i'); }); it('should return an array of previous sibling elements including itself', () => { expect(dom.listPrev($s[0])).to.deep.equal([$s[0], $u[0], $b[0]]); }); it('should return itself if there are no previous sibling', () => { expect(dom.listPrev($b[0])).to.deep.equal([$b[0]]); }); it('should return an array of previous sibling elements before predicate is true', () => { expect(dom.listPrev($i[0], func.eq($s[0]))).to.deep.equal([$i[0]]); }); }); describe('position', () => { let $cont, $b, $u, $s, $i; before(() => { $cont = $('<div class="note-editable"><b>b</b><u>u</u><s>s</s><i>i</i></div>'); // busi $b = $cont.find('b'); $u = $cont.find('u'); $s = $cont.find('s'); $i = $cont.find('i'); }); it('should return the position of element', () => { expect(dom.position($b[0])).to.be.equal(0); expect(dom.position($u[0])).to.be.equal(1); expect(dom.position($s[0])).to.be.equal(2); expect(dom.position($i[0])).to.be.equal(3); }); it('should return position 0 for text node in b', () => { expect(dom.position($b[0].firstChild)).to.be.equal(0); }); }); describe('makeOffsetPath', () => { let $cont, $b, $u, $s, $i; before(() => { $cont = $('<div class="note-editable"><b>b</b><u>u</u><s>s</s><i>i</i></div>'); // busi $b = $cont.find('b'); $u = $cont.find('u'); $s = $cont.find('s'); $i = $cont.find('i'); }); it('should return empty array if two elements are same', () => { expect(dom.makeOffsetPath($cont[0], $cont[0])).to.deep.equal([]); }); it('should return offset path array between two elements #1', () => { expect(dom.makeOffsetPath($cont[0], $b[0])).to.deep.equal([0]); expect(dom.makeOffsetPath($cont[0], $b[0].firstChild)).to.deep.equal([0, 0]); }); it('should return offset path array between two elements #2', () => { expect(dom.makeOffsetPath($cont[0], $u[0])).to.deep.equal([1]); expect(dom.makeOffsetPath($cont[0], $u[0].firstChild)).to.deep.equal([1, 0]); }); it('should return offset path array between two elements #3', () => { expect(dom.makeOffsetPath($cont[0], $s[0])).to.deep.equal([2]); expect(dom.makeOffsetPath($cont[0], $s[0].firstChild)).to.deep.equal([2, 0]); }); it('should return offset path array between two elements #2', () => { expect(dom.makeOffsetPath($cont[0], $i[0])).to.deep.equal([3]); expect(dom.makeOffsetPath($cont[0], $i[0].firstChild)).to.deep.equal([3, 0]); }); }); describe('fromOffsetPath', () => { let $cont, $b, $u, $s, $i; before(() => { $cont = $('<div class="note-editable"><b>b</b><u>u</u><s>s</s><i>i</i></div>'); // busi $b = $cont.find('b'); $u = $cont.find('u'); $s = $cont.find('s'); $i = $cont.find('i'); }); it('should return the element by offsetPath', () => { let cont = $cont[0]; $.each([$b[0], $u[0], $s[0], $i[0]], (idx, node) => { expect(dom.fromOffsetPath(cont, dom.makeOffsetPath(cont, node))).to.deep.equal(node); let child = node.firstChild; expect(dom.fromOffsetPath(cont, dom.makeOffsetPath(cont, child))).to.deep.equal(child); }); }); }); describe('splitTree', () => { let $para; beforeEach(() => { let $busi = $('<div class="note-editable"><p><b>b</b><u>u</u><s>strike</s><i>i</i></p></div>'); // busi $para = $busi.clone().find('p'); }); describe('element pivot case', () => { it('should be split by u tag with offset 0', () => { let $u = $para.find('u'); dom.splitTree($para[0], { node: $u[0], offset: 0 }); expect($para.html()).to.equalsIgnoreCase('<b>b</b><u><br></u>'); expect($para.next().html()).to.equalsIgnoreCase('<u>u</u><s>strike</s><i>i</i>'); }); it('should be split by u tag with offset 1', () => { let $u = $para.find('u'); dom.splitTree($para[0], { node: $u[0], offset: 1 }); expect($para.html()).to.equalsIgnoreCase('<b>b</b><u>u</u>'); expect($para.next().html()).to.equalsIgnoreCase('<u><br></u><s>strike</s><i>i</i>'); }); it('should be split by b tag with offset 0 (left edge case)', () => { let $b = $para.find('b'); dom.splitTree($para[0], { node: $b[0], offset: 0 }); expect($para.html()).to.equalsIgnoreCase('<b><br></b>'); expect($para.next().html()).to.equalsIgnoreCase('<b>b</b><u>u</u><s>strike</s><i>i</i>'); }); it('should be split by i tag with offset 1 (right edge case)', () => { let $i = $para.find('i'); dom.splitTree($para[0], { node: $i[0], offset: 1 }); expect($para.html()).to.equalsIgnoreCase('<b>b</b><u>u</u><s>strike</s><i>i</i>'); expect($para.next().html()).to.equalsIgnoreCase('<i><br></i>'); }); }); describe('textNode case', () => { it('should be split by s tag with offset 3 (middle case)', () => { let $s = $para.find('s'); dom.splitTree($para[0], { node: $s[0].firstChild, offset: 3 }); expect($para.html()).to.equalsIgnoreCase('<b>b</b><u>u</u><s>str</s>'); expect($para.next().html()).to.equalsIgnoreCase('<s>ike</s><i>i</i>'); }); it('should be split by s tag with offset 0 (left edge case)', () => { let $s = $para.find('s'); dom.splitTree($para[0], { node: $s[0].firstChild, offset: 0 }); expect($para.html()).to.equalsIgnoreCase('<b>b</b><u>u</u><s><br></s>'); expect($para.next().html()).to.equalsIgnoreCase('<s>strike</s><i>i</i>'); }); it('should be split by s tag with offset 6 (right edge case)', () => { let $s = $para.find('s'); dom.splitTree($para[0], { node: $s[0].firstChild, offset: 6 }); expect($para.html()).to.equalsIgnoreCase('<b>b</b><u>u</u><s>strike</s>'); expect($para.next().html()).to.equalsIgnoreCase('<s><br></s><i>i</i>'); }); it('should be split by s tag with offset 3 (2 depth case)', () => { let $s = $para.find('s'); dom.splitTree($s[0], { node: $s[0].firstChild, offset: 3 }); expect($para.html()).to.equalsIgnoreCase('<b>b</b><u>u</u><s>str</s><s>ike</s><i>i</i>'); }); it('should be split by s tag with offset 3 (1 depth and textNode case)', () => { let $s = $para.find('s'); dom.splitTree($s[0].firstChild, { node: $s[0].firstChild, offset: 3 }); expect($para.html()).to.equalsIgnoreCase('<b>b</b><u>u</u><s>strike</s><i>i</i>'); }); it('should be split by span tag with offset 2 (1 depth and element case)', () => { let $cont = $('<div class="note-editable"><p><span><b>b</b><u>u</u><s>s</s><i>i</i></span></p></div>'); // busi let $span = $cont.find('span'); dom.splitTree($span[0], { node: $span[0], offset: 2 }); expect($cont.html()).to.equalsIgnoreCase('<p><span><b>b</b><u>u</u></span><span><s>s</s><i>i</i></span></p>'); }); }); }); describe('splitPoint', () => { it('should return rightNode and container for empty paragraph with inline', () => { let $editable = $('<div class="note-editable"><p><br></p></div>'); let $para = $editable.clone().find('p'); let $br = $para.find('br'); let result = dom.splitPoint({ node: $para[0], offset: 0 }, true); expect(result).to.deep.equal({ rightNode: $br[0], container: $para[0] }); }); }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/core/index.html000064400000014575151677271550017534 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/core/</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> test/unit/base/core/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>616/616</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>2/2</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>193/193</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>613/613</span> </div> </div> </div> <div class='status-line high'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file high" data-value="dom.spec.js"><a href="dom.spec.js.html">dom.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="205" class="abs high">205/205</td> <td data-value="100" class="pct high">100%</td> <td data-value="2" class="abs high">2/2</td> <td data-value="100" class="pct high">100%</td> <td data-value="63" class="abs high">63/63</td> <td data-value="100" class="pct high">100%</td> <td data-value="203" class="abs high">203/203</td> </tr> <tr> <td class="file high" data-value="func.spec.js"><a href="func.spec.js.html">func.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="75" class="abs high">75/75</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="35" class="abs high">35/35</td> <td data-value="100" class="pct high">100%</td> <td data-value="75" class="abs high">75/75</td> </tr> <tr> <td class="file high" data-value="key.spec.js"><a href="key.spec.js.html">key.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="12" class="abs high">12/12</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="6" class="abs high">6/6</td> <td data-value="100" class="pct high">100%</td> <td data-value="12" class="abs high">12/12</td> </tr> <tr> <td class="file high" data-value="lists.spec.js"><a href="lists.spec.js.html">lists.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="63" class="abs high">63/63</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="33" class="abs high">33/33</td> <td data-value="100" class="pct high">100%</td> <td data-value="62" class="abs high">62/62</td> </tr> <tr> <td class="file high" data-value="range.spec.js"><a href="range.spec.js.html">range.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="261" class="abs high">261/261</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="56" class="abs high">56/56</td> <td data-value="100" class="pct high">100%</td> <td data-value="261" class="abs high">261/261</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/core/range.spec.js.html000064400000121562151677271550021060 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/core/range.spec.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">test/unit/base/core/</a> range.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>261/261</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>56/56</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>261/261</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408</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-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-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-yes">1×</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-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-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-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-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-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-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-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-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-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-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-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-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-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-yes">1×</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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-yes">1×</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-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-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-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-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-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-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-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-yes">1×</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-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-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-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-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-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">2×</span> <span class="cline-any cline-yes">2×</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-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-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-yes">1×</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-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-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-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-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-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-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-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-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-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-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-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-yes">1×</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-yes">1×</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-yes">1×</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-yes">1×</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-neutral"> </span> <span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** * range.spec.js * (c) 2013~ Alan Hong * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import chaidom from '../../../chaidom'; import $ from 'jquery'; import dom from '../../../../src/js/base/core/dom'; import range from '../../../../src/js/base/core/range'; var expect = chai.expect; chai.use(chaidom); describe('base:core.range', () => { describe('nodes', () => { describe('1 depth', () => { var $para; before(() => { var $cont = $('<div class="note-editable"><p>para1</p><p>para2</p></div>'); $para = $cont.find('p'); }); it('should return array of two paragraphs', () => { var rng = range.create($para[0].firstChild, 0, $para[1].firstChild, 1); expect(rng.nodes(dom.isPara, {includeAncestor: true})).to.have.length(2); }); it('should return array of a paragraph', () => { var rng = range.create($para[0].firstChild, 0, $para[0].firstChild, 0); expect(rng.nodes(dom.isPara, { includeAncestor: true })).to.have.length(1); }); }); describe('multi depth', () => { it('should return array of a paragraph', () => { var $cont = $('<div class="note-editable"><p>p<b>ar</b>a1</p><p>para2</p></div>'); var $b = $cont.find('b'); var rng = range.create($b[0].firstChild, 0, $b[0].firstChild, 0); expect(rng.nodes(dom.isPara, { includeAncestor: true })).to.have.length(1); }); }); describe('on list, on heading', () => { it('should return array of list paragraphs', () => { var $cont = $('<div class="note-editable"><ul><li>para1</li><li>para2</li></ul></div>'); var $li = $cont.find('li'); var rng = range.create($li[0].firstChild, 0, $li[1].firstChild, 1); expect(rng.nodes(dom.isPara, { includeAncestor: true })).to.have.length(2); }); it('should return array of list paragraphs', () => { var $cont = $('<div class="note-editable"><h1>heading1</h1><h2>heading2</h2></div>'); var $h1 = $cont.find('h1'); var $h2 = $cont.find('h2'); var rng = range.create($h1[0].firstChild, 0, $h2[0].firstChild, 1); expect(rng.nodes(dom.isPara, { includeAncestor: true })).to.have.length(2); }); }); }); describe('commonAncestor', () => { var $cont; before(() => { $cont = $('<div><span><b>b</b><u>u</u></span></div>'); }); it('should return <span> for <b>|b</b> and <u>u|</u>', () => { var $span = $cont.find('span'); var $b = $cont.find('b'); var $u = $cont.find('u'); var rng = range.create($b[0].firstChild, 0, $u[0].firstChild, 1); expect(rng.commonAncestor()).to.deep.equal($span[0]); }); it('should return b(#textNode) for <b>|b|</b>', () => { var $b = $cont.find('b'); var rng = range.create($b[0].firstChild, 0, $b[0].firstChild, 1); expect(rng.commonAncestor()).to.deep.equal($b[0].firstChild); }); }); describe('expand', () => { it('should return <b>|b</b> ~ <u>u|</u> for <b>|b</b> with isAnchor', () => { var $cont = $('<div><a><b>b</b><u>u</u></a></div>'); var $anchor = $cont.find('a'); var $b = $cont.find('b'); var rng = range.create($b[0].firstChild, 0, $b[0].firstChild, 0).expand(dom.isAnchor); expect(rng.sc).to.deep.equal($anchor[0]); expect(rng.so).to.equal(0); expect(rng.ec).to.deep.equal($anchor[0]); expect(rng.eo).to.equal(2); }); }); describe('collapse', () => { it('should return <u>u|</u> for <b>|b</b> ~ <u>u|</u>', () => { var $cont = $('<div><b>b</b><u>u</u></div>'); var $b = $cont.find('b'); var $u = $cont.find('u'); var rng = range.create($b[0].firstChild, 0, $u[0].firstChild, 1).collapse(); expect(rng.sc).to.deep.equal($u[0].firstChild); expect(rng.so).to.equal(1); expect(rng.ec).to.deep.equal($u[0].firstChild); expect(rng.eo).to.equal(1); }); }); describe('normalize', () => { var $cont; before(() => { $cont = $('<div><p><b>b</b><u>u</u><s>s</s></p></div>'); }); it('should return <b>|b</b> ~ <u>u|</u> for |<b>b</b> ~ <u>u</u>|', () => { var $p = $cont.find('p'); var $b = $cont.find('b'); var $u = $cont.find('u'); var rng = range.create($p[0], 0, $p[0], 2).normalize(); expect(rng.sc).to.deep.equal($b[0].firstChild); expect(rng.so).to.equal(0); expect(rng.ec).to.deep.equal($u[0].firstChild); expect(rng.eo).to.equal(1); }); it('should return <b>b|</b><u>u</u> for <b>b</b>|<u>u</u>', () => { var $p = $cont.find('p'); var $b = $cont.find('b'); var rng = range.create($p[0], 1, $p[0], 1).normalize(); expect(rng.sc).to.deep.equal($b[0].firstChild); expect(rng.so).to.equal(1); expect(rng.ec).to.deep.equal($b[0].firstChild); expect(rng.eo).to.equal(1); }); it('should return <b>b</b><u>|u|</u><s>s</s> for <b>b|</b><u>u</u><s>|s</s>', () => { var $b = $cont.find('b'); var $u = $cont.find('u'); var $s = $cont.find('s'); var rng = range.create($b[0].firstChild, 1, $s[0].firstChild, 0).normalize(); expect(rng.sc).to.deep.equal($u[0].firstChild); expect(rng.so).to.equal(0); expect(rng.ec).to.deep.equal($u[0].firstChild); expect(rng.eo).to.equal(1); }); it('should return <b>b|</b><u>u</u><s>s</s> for <b>b|</b><u>u</u><s>s</s>', () => { var $b = $cont.find('b'); var rng = range.create($b[0].firstChild, 1, $b[0].firstChild, 1).normalize(); expect(rng.sc).to.deep.equal($b[0].firstChild); expect(rng.so).to.equal(1); expect(rng.ec).to.deep.equal($b[0].firstChild); expect(rng.eo).to.equal(1); }); }); describe('normalize (block mode)', () => { it('should return <p>text</p><p>|<br></p> for <p>text</p><p>|<br></p>', () => { var $cont = $('<div><p>text</p><p><br></p></div>'); var $p = $cont.find('p'); var rng = range.create($p[1], 0, $p[1], 0).normalize(); expect(rng.sc).to.deep.equal($p[1]); expect(rng.so).to.equal(0); expect(rng.ec).to.deep.equal($p[1]); expect(rng.eo).to.equal(0); }); it('should return <p>text</p><p>|text</b></p> for <p>text</p><p>|text</p>', () => { var $cont = $('<div><p>text</p><p>text</p></div>'); var $p = $cont.find('p'); var rng = range.create($p[1], 0, $p[1], 0).normalize(); expect(rng.sc).to.deep.equal($p[1].firstChild); expect(rng.so).to.equal(0); expect(rng.ec).to.deep.equal($p[1].firstChild); expect(rng.eo).to.equal(0); }); it('should return <p>|text</p><p>text|</b></p> for |<p>text</p><p>text</p>|', () => { var $cont = $('<div class="note-editable"><p>text</p><p>text</p></div>'); var $p = $cont.find('p'); var rng = range.create($cont[0], 0, $cont[0], 2).normalize(); expect(rng.sc).to.deep.equal($p[0].firstChild); expect(rng.so).to.equal(0); expect(rng.ec).to.deep.equal($p[1].firstChild); expect(rng.eo).to.equal(4); }); }); describe('normalize (void element)', () => { it('should return <p><img>|<b>bold</b></p> for <p><img>|<b>bold</b></p>', () => { var $cont = $('<div><p><img><b>bold</b></p></div>'); var $p = $cont.find('p'); var $b = $cont.find('b'); var rng = range.create($p[0], 1, $p[0], 1).normalize(); expect(rng.sc).to.deep.equal($b[0].firstChild); expect(rng.so).to.equal(0); expect(rng.ec).to.deep.equal($b[0].firstChild); expect(rng.eo).to.equal(0); }); }); describe('insertNode', () => { it('should split paragraph when inserting a block element', () => { var $cont = $('<div class="note-editable"><p><b>bold</b></p></div>'); var $b = $cont.find('b'); var $p2 = $('<p>p</p>'); var rng = range.create($b[0].firstChild, 2, $b[0].firstChild, 2); rng.insertNode($p2[0]); expect($cont.html()).to.equalsIgnoreCase('<p><b>bo</b></p><p>p</p><p><b>ld</b></p>'); }); it('should not split paragraph when inserting an inline element', () => { var $cont = $('<div class="note-editable"><p>text</p></div>'); var $p = $cont.find('p'); var $u = $('<u>u</u>'); var rng = range.create($p[0].firstChild, 2, $p[0].firstChild, 2); rng.insertNode($u[0]); expect($cont.html()).to.equalsIgnoreCase('<p>te<u>u</u>xt</p>'); }); it('should not split paragraph when inserting an inline element case 2', () => { var $cont = $('<div class="note-editable"><p><b>bold</b></p></div>'); var $b = $cont.find('b'); var $u = $('<u>u</u>'); var rng = range.create($b[0].firstChild, 2, $b[0].firstChild, 2); rng.insertNode($u[0]); expect($cont.html()).to.equalsIgnoreCase('<p><b>bo</b><u>u</u><b>ld</b></p>'); }); }); describe('pasteHTML', () => { it('should not split a block element when inserting inline elements into it', () => { var $cont = $('<div class="note-editable"><p>text</p></div>'); var $p = $cont.find('p'); var markup = '<span>span</span><i>italic</i>'; var rng = range.create($p[0].firstChild, 2); rng.pasteHTML(markup); expect($cont.html()).to.equalsIgnoreCase('<p>te<span>span</span><i>italic</i>xt</p>'); }); it('should split an inline element when pasting inline elements into it', () => { var $cont = $('<div class="note-editable"><p><b>bold</b></p></div>'); var $b = $cont.find('b'); var markup = '<span>span</span><i>italic</i>'; var rng = range.create($b[0].firstChild, 2); rng.pasteHTML(markup); expect($cont.html()).to.equalsIgnoreCase('<p><b>bo</b><span>span</span><i>italic</i><b>ld</b></p>'); }); it('should split inline node when pasting an inline node and a block node into it', () => { var $cont = $('<div class="note-editable"><p><b>bold</b></p></div>'); var $b = $cont.find('b'); var markup = '<span>span</span><p><i>italic</i></p>'; var rng = range.create($b[0].firstChild, 2); rng.pasteHTML(markup); expect($cont.html()).to.equalsIgnoreCase('<p><b>bo</b><span>span</span></p><p><i>italic</i></p><p><b>ld</b></p>'); }); }); describe('deleteContents', () => { var $cont, $b; beforeEach(() => { $cont = $('<div class="note-editable"><p><b>bold</b><u>u</u></p></div>'); $b = $cont.find('b'); }); it('should remove text only for partial text', () => { var rng = range.create($b[0].firstChild, 1, $b[0].firstChild, 3); rng.deleteContents(); expect($cont.html()).to.equalsIgnoreCase('<p><b>bd</b><u>u</u></p>'); }); it('should remove text for entire text', () => { var rng = range.create($b[0].firstChild, 0, $b[0].firstChild, 4); rng.deleteContents(); expect($cont.html()).to.equalsIgnoreCase('<p><b></b><u>u</u></p>'); }); }); describe('wrapBodyInlineWithPara', () => { it('should insert an empty paragraph when there is no contents', () => { var $cont = $('<div class="note-editable"></div>'); var rng = range.create($cont[0], 0); rng.wrapBodyInlineWithPara(); expect($cont.html()).to.equalsIgnoreCase('<p><br></p>'); }); it('should wrap text with paragraph for text', () => { var $cont = $('<div class="note-editable">text</div>'); var rng = range.create($cont[0].firstChild, 2); rng.wrapBodyInlineWithPara(); expect($cont.html()).to.equalsIgnoreCase('<p>text</p>'); }); it('should wrap an inline node with paragraph when selecting text in the inline node', () => { var $cont = $('<div class="note-editable"><b>bold</b></div>'); var $b = $cont.find('b'); var rng = range.create($b[0].firstChild, 2); rng.wrapBodyInlineWithPara(); expect($cont.html()).to.equalsIgnoreCase('<p><b>bold</b></p>'); }); it('should wrap inline nodes with paragraph when selecting text in the inline nodes', () => { var $cont = $('<div class="note-editable"><b>b</b><i>i</i></div>'); var rng = range.create($cont[0], 0); rng.wrapBodyInlineWithPara(); expect($cont.html()).to.equalsIgnoreCase('<p><b>b</b><i>i</i></p>'); }); it('should wrap inline nodes with paragraph when selection some of text in the inline nodes #1', () => { var $cont = $('<div class="note-editable"><b>b</b><i>i</i></div>'); var rng = range.create($cont[0], 1); rng.wrapBodyInlineWithPara(); expect($cont.html()).to.equalsIgnoreCase('<p><b>b</b><i>i</i></p>'); }); it('should wrap inline nodes with paragraph when selection some of text in the inline nodes #2', () => { var $cont = $('<div class="note-editable"><b>b</b><i>i</i></div>'); var rng = range.create($cont[0], 2); rng.wrapBodyInlineWithPara(); expect($cont.html()).to.equalsIgnoreCase('<p><b>b</b><i>i</i></p>'); }); }); describe('getWordRange', () => { var $cont; before(() => { $cont = $('<div class="note-editable">super simple wysiwyg editor</div>'); }); it('should return the range itself when there is no word before cursor', () => { var rng = range.create($cont[0].firstChild, 0).getWordRange(); expect(rng.sc).to.deep.equal($cont[0].firstChild); expect(rng.so).to.equal(0); expect(rng.ec).to.deep.equal($cont[0].firstChild); expect(rng.eo).to.equal(0); }); it('should return expanded range when there is a word before cursor', () => { var rng = range.create($cont[0].firstChild, 5).getWordRange(); expect(rng.sc).to.deep.equal($cont[0].firstChild); expect(rng.so).to.equal(0); expect(rng.ec).to.deep.equal($cont[0].firstChild); expect(rng.eo).to.equal(5); }); it('should return expanded range when there is a half word before cursor', () => { var rng = range.create($cont[0].firstChild, 3).getWordRange(); expect(rng.sc).to.deep.equal($cont[0].firstChild); expect(rng.so).to.equal(0); expect(rng.ec).to.deep.equal($cont[0].firstChild); expect(rng.eo).to.equal(3); }); it('should return expanded range when there are words before cursor', () => { var rng = range.create($cont[0].firstChild, 12).getWordRange(); expect(rng.sc).to.deep.equal($cont[0].firstChild); expect(rng.so).to.equal(6); expect(rng.ec).to.deep.equal($cont[0].firstChild); expect(rng.eo).to.equal(12); }); }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/core/func.spec.js.html000064400000032771151677271550020722 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/core/func.spec.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">test/unit/base/core/</a> func.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>75/75</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>35/35</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>75/75</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140</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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** * func.spec.js * (c) 2013~ Alan Hong * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import func from '../../../../src/js/base/core/func'; var expect = chai.expect; describe('base:core.func', () => { describe('eq', () => { it('should return true if two values are same', () => { expect(func.eq(1)(1)).to.be.ok; }); }); describe('eq2', () => { it('should return true if two values are same', () => { expect(func.eq2(1, 1)).to.be.ok; }); it('should return false if two values are not same', () => { expect(func.eq2(1, '1')).to.be.not.ok; }); }); describe('peq2', () => { it('should return true when two properties are same', () => { expect(func.peq2('prop')({ prop: 'hello' }, { prop: 'hello' })).to.be.ok; }); it('should return false when two properties are not same', () => { expect(func.peq2('prop')({ prop: 'hello' }, { prop: 'world' })).to.be.not.ok; }); }); describe('ok', () => { it('should return true', () => { expect(func.ok()).to.be.ok; }); }); describe('fail', () => { it('should return false', () => { expect(func.fail()).to.be.not.ok; }); }); describe('not', () => { it('should return opposite function', () => { expect(func.not(func.ok)()).to.be.not.ok; expect(func.not(func.fail)()).to.be.ok; }); }); describe('and', () => { it('should return composite function', () => { expect(func.and(func.ok, func.ok)()).to.be.ok; expect(func.and(func.fail, func.ok)()).to.be.not.ok; expect(func.and(func.fail, func.fail)()).to.be.not.ok; }); }); describe('invoke', () => { it('should return function which invoke the method', () => { expect(func.invoke(func, 'ok')()).to.be.ok; expect(func.invoke(func, 'fail')()).to.be.not.ok; }); }); describe('uniqueId', () => { it('should return uniqueId with the prefix as a parameter', () => { expect(func.uniqueId('note-')).to.be.equal('note-1'); expect(func.uniqueId('note-')).to.be.equal('note-2'); expect(func.uniqueId('note-')).to.be.equal('note-3'); }); }); describe('invertObject', () => { it('should return inverted object between keys and values', () => { expect(func.invertObject({ keyA: 'valueA', keyB: 'valueB' })) .to.deep.equal({ valueA: 'keyA', valueB: 'keyB' }); }); }); describe('namespaceToCamel', () => { it('should return camelcase text', () => { expect(func.namespaceToCamel('upload.image')).to.be.equal('UploadImage'); }); it('should return prefixed camelcase text', () => { expect(func.namespaceToCamel('upload.image', 'summernote')).to.be.equal('summernoteUploadImage'); }); }); describe('debounce', () => { it('shouldnt execute immediately', () => { var hasHappened = false; var fn = func.debounce(() => { hasHappened = true; }, 100); expect(hasHappened).to.be.false; fn(); expect(hasHappened).to.be.false; }); it('should execute after delay', (done) => { var hasHappened = false; var fn = func.debounce(() => { hasHappened = true; }, 100); fn(); setTimeout(() => { expect(hasHappened).to.be.true; done(); }, 101); }); it('should only happen once', (done) => { var count = 0; var fn = func.debounce(() => { count += 1; }, 100); fn(); fn(); fn(); setTimeout(() => { expect(count).to.be.equal(1); done(); }, 101); }); }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/module/Editor.spec.js.html000064400000112347151677271550021550 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/module/Editor.spec.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">test/unit/base/module/</a> Editor.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">99.53% </span> <span class="quiet">Statements</span> <span class='fraction'>210/211</span> </div> <div class='fl pad1y space-right2'> <span class="strong">50% </span> <span class="quiet">Branches</span> <span class='fraction'>5/10</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>50/50</span> </div> <div class='fl pad1y space-right2'> <span class="strong">99.53% </span> <span class="quiet">Lines</span> <span class='fraction'>210/211</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391</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-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-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-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-yes">1×</span> <span class="cline-any cline-yes">29×</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">9×</span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-yes">9×</span> <span class="cline-any cline-yes">9×</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-yes">26×</span> <span class="cline-any cline-yes">26×</span> <span class="cline-any cline-yes">26×</span> <span class="cline-any cline-yes">26×</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">26×</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-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-neutral"> </span> <span class="cline-any cline-yes">8×</span> <span class="cline-any cline-yes">8×</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-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-yes">1×</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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-yes">1000×</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-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-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-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-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-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-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-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-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-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-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-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-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-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-neutral"> </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-yes">1×</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-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-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-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-yes">1×</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-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-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-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-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-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-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-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-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-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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** * Editor.spec.js * (c) 2015~ Summernote Team * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import spies from 'chai-spies'; import chaidom from '../../../chaidom'; import $ from 'jquery'; import env from '../../../../src/js/base/core/env'; import range from '../../../../src/js/base/core/range'; import Context from '../../../../src/js/base/Context'; const expect = chai.expect; chai.use(spies); chai.use(chaidom); function expectContents(context, markup) { expect(context.layoutInfo.editable.html()).to.equalsIgnoreCase(markup); } function expectToHaveBeenCalled(context, customEvent, handler) { const $note = context.layoutInfo.note; const spy = chai.spy(); $note.on(customEvent, spy); handler(); expect(spy).to.have.been.called(); } describe('Editor', () => { var editor, context; beforeEach(function() { var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); context = new Context($('<div><p>hello</p></div>'), options); editor = context.modules.editor; // [workaround] // - Firefox need setTimeout for applying contents // - IE8-11 can't create range in headless mode <span class="missing-if-branch" title="if path not taken" >I</span>if (!(env.isWebkit || <span class="branch-1 cbranch-no" title="branch not covered" >env.isEdge)</span>) { <span class="cstat-no" title="statement not covered" > this.skip();</span> } }); describe('initialize', () => { it('should bind custom events', () => { [ 'keydown', 'keyup', 'blur', 'mousedown', 'mouseup', 'scroll', 'focusin', 'focusout' ].forEach((eventName) => { expectToHaveBeenCalled(context, 'summernote.' + eventName, () => { context.layoutInfo.editable.trigger(eventName); }); }); expectToHaveBeenCalled(context, 'summernote.change', () => { editor.insertText('hello'); }); }); }); <span class="missing-if-branch" title="else path not taken" >E</span>if (env.isWebkit) { describe('undo and redo', () => { it('should control history', () => { editor.insertText(' world'); expectContents(context, '<p>hello world</p>'); editor.undo(); expectContents(context, '<p>hello</p>'); editor.redo(); expectContents(context, '<p>hello world</p>'); }); }); } describe('tab', () => { it('should insert tab', () => { editor.tab(); expectContents(context, '<p>hello&nbsp;&nbsp;&nbsp;&nbsp;</p>'); }); }); describe('insertParagraph', () => { it('should insert paragraph', () => { editor.insertParagraph(); expectContents(context, '<p>hello</p><p><br></p>'); editor.insertParagraph(); expectContents(context, '<p>hello</p><p><br></p><p><br></p>'); }); }); <span class="missing-if-branch" title="else path not taken" >E</span>if (env.isWebkit) { describe('insertImage', () => { it('should insert image', () => { var source = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAYAAAAGCAYAAADgzO9IAAAAF0lEQVQYGWP8////fwYsgAmLGFiIHhIAT+oECGHuN2UAAAAASUVORK5CYII='; return editor.insertImage(source, 'image').then(() => { expectContents(context, '<p>hello<img src="' + source + '" data-filename="image" style="width: 0px;"></p>'); }); }); }); } describe('insertOrderedList and insertUnorderedList', () => { it('should toggle paragraph to list', () => { editor.insertOrderedList(); expectContents(context, '<ol><li>hello</li></ol>'); editor.insertUnorderedList(); expectContents(context, '<ul><li>hello</li></ul>'); editor.insertUnorderedList(); expectContents(context, '<p>hello</p>'); }); }); describe('indent and outdent', () => { // [workaround] style is different by browser <span class="missing-if-branch" title="else path not taken" >E</span>if (env.isPhantom) { it('should indent and outdent paragraph', () => { editor.indent(); expectContents(context, '<p style="margin-left: 25px;">hello</p>'); editor.outdent(); expectContents(context, '<p style="">hello</p>'); }); } it('should indent and outdent list', () => { editor.insertOrderedList(); expectContents(context, '<ol><li>hello</li></ol>'); editor.indent(); expectContents(context, '<ol><ol><li>hello</li></ol></ol>'); editor.outdent(); expectContents(context, '<ol><li>hello</li></ol>'); }); }); describe('insertNode', () => { it('should insert node', () => { editor.insertNode($('<span> world</span>')[0]); expectContents(context, '<p>hello<span> world</span></p>'); }); it('should be limited', () => { var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); options.maxTextLength = 5; context = new Context($('<div><p>hello</p></div>'), options); editor = context.modules.editor; editor.insertNode($('<span> world</span>')[0]); expectContents(context, '<p>hello</p>'); }); }); describe('insertText', () => { it('should insert text', () => { editor.insertText(' world'); expectContents(context, '<p>hello world</p>'); }); it('should be limited', () => { var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); options.maxTextLength = 5; context = new Context($('<div><p>hello</p></div>'), options); editor = context.modules.editor; editor.insertText(' world'); expectContents(context, '<p>hello</p>'); }); }); describe('pasteHTML', () => { it('should paste html', () => { editor.pasteHTML('<span> world</span>'); expectContents(context, '<p>hello<span> world</span></p>'); }); it('should not call change change event more than once per paste event', () => { var generateLargeHtml = () => { var html = '<div>'; for (var i = 0; i < 1000; i++) { html += '<p>HTML element #' + i + '</p>'; } html += '</div>'; return html; }; var $note = context.layoutInfo.note; var spy = chai.spy(); $note.on('summernote.change', spy); var html = generateLargeHtml(); editor.pasteHTML(html); expect(spy).to.have.been.called.once; }); it('should be limited', () => { var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); options.maxTextLength = 5; context = new Context($('<div><p>hello</p></div>'), options); editor = context.modules.editor; editor.pasteHTML('<span> world</span>'); expectContents(context, '<p>hello</p>'); }); }); describe('insertHorizontalRule', () => { it('should insert horizontal rule', () => { editor.insertHorizontalRule(); expectContents(context, '<p>hello</p><hr><p><br></p>'); }); }); describe('insertTable', () => { it('should insert table', () => { var markup = [ '<p>hello</p>', '<table class="table table-bordered"><tbody>', '<tr><td><br></td><td><br></td></tr>', '<tr><td><br></td><td><br></td></tr>', '</tbody></table>', '<p><br></p>' ].join(''); editor.insertTable('2x2'); expectContents(context, markup); }); }); describe('empty', () => { it('should make contents empty', () => { editor.empty(); expect(editor.isEmpty()).to.be.true; }); }); describe('formatBlock', () => { it('should apply formatBlock', () => { context.layoutInfo.editable.appendTo('body'); editor.formatBlock('blockquote'); // start <p>hello</p> => <blockquote>hello</blockquote> expectContents(context, '<blockquote>hello</blockquote>'); }); it('should apply multi formatBlock', () => { // set multi block html var codes = [ '<p><a href="http://summernote.org">hello world</a></p>', '<p><a href="http://summernote.org">hello world</a></p>', '<p><a href="http://summernote.org">hello world</a></p>' ]; context.invoke('code', codes.join('')); // append to body var editable = context.layoutInfo.editable; editable.appendTo('body'); // run formatBlock editor.formatBlock('blockquote'); // check current range position in blockquote element var nodeName = editable.children()[0].nodeName; expect(nodeName).to.equalsIgnoreCase('blockquote'); }); it('should apply multi test 2 - formatBlock', () => { var codes = [ '<p><a href="http://summernote.org">hello world</a></p>', '<p><a href="http://summernote.org">hello world</a></p>', '<p><a href="http://summernote.org">hello world</a></p>' ]; context.invoke('code', codes.join('')); var editable = context.layoutInfo.editable; editable.appendTo('body'); var startNode = editable.find('p').first()[0]; var endNode = editable.find('p').last()[0]; // all p tags is wrapped range.create(startNode, 1, endNode, 1).normalize().select(); editor.formatBlock('blockquote'); var nodeName = editable.children()[0].nodeName; expect(nodeName).to.equalsIgnoreCase('blockquote'); // p -> blockquote, p is none expect(editable.find('p').length).to.equals(0); }); it('should apply custom className in formatBlock', () => { context.layoutInfo.editable.appendTo('body'); var $target = $('<blockquote class="blockquote" />'); editor.formatBlock('blockquote', $target); // start <p>hello</p> => <blockquote class="blockquote">hello</blockquote> expectContents(context, '<blockquote class="blockquote">hello</blockquote>'); }); }); describe('createLink', () => { it('should create normal link', () => { var text = 'hello'; var editable = context.layoutInfo.editable; var pNode = editable.find('p')[0]; var textNode = pNode.childNodes[0]; var startIndex = textNode.wholeText.indexOf(text); var endIndex = startIndex + text.length; range.create(textNode, startIndex, textNode, endIndex).normalize().select(); // check creation normal link editor.createLink({ url: 'http://summernote.org', text: 'summernote' }); expectContents(context, '<p>hello<a href="http://summernote.org">summernote</a></p>'); }); it('should create a link with range', () => { var text = 'hello'; var editable = context.layoutInfo.editable; var pNode = editable.find('p')[0]; var textNode = pNode.childNodes[0]; var startIndex = textNode.wholeText.indexOf(text); var endIndex = startIndex + text.length; var rng = range.create(textNode, startIndex, textNode, endIndex); editor.createLink({ url: 'http://summernote.org', text: 'summernote', range: rng }); expectContents(context, '<p><a href="http://summernote.org">summernote</a></p>'); }); it('should create a link with isNewWindow', () => { var text = 'hello'; var editable = context.layoutInfo.editable; var pNode = editable.find('p')[0]; var textNode = pNode.childNodes[0]; var startIndex = textNode.wholeText.indexOf(text); var endIndex = startIndex + text.length; var rng = range.create(textNode, startIndex, textNode, endIndex); editor.createLink({ url: 'http://summernote.org', text: 'summernote', range: rng, isNewWindow: true }); expectContents(context, '<p><a href="http://summernote.org" target="_blank">summernote</a></p>'); }); it('should modify a link', () => { context.invoke('code', '<p><a href="http://summernote.org">hello world</a></p>'); var editable = context.layoutInfo.editable; var anchorNode = editable.find('a')[0]; var rng = range.createFromNode(anchorNode); editor.createLink({ url: 'http://wow.summernote.org', text: 'summernote wow', range: rng }); expectContents(context, '<p><a href="http://wow.summernote.org">summernote wow</a></p>'); }); }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/module/Fullscreen.spec.js.html000064400000011742151677271550022421 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/module/Fullscreen.spec.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">test/unit/base/module/</a> Fullscreen.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>18/18</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>3/3</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>18/18</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</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-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-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-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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** * Fullscreen.spec.js * (c) 2015~ Summernote Team * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import $ from 'jquery'; import Context from '../../../../src/js/base/Context'; import Fullscreen from '../../../../src/js/base/module/Fullscreen'; var expect = chai.expect; describe('Fullscreen', () => { var fullscreen, context; beforeEach(() => { var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, { }, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); context = new Context($('<div><p>hello</p></div>'), options); fullscreen = new Fullscreen(context); }); it('should toggle fullscreen mode', () => { expect(fullscreen.isFullscreen()).to.be.false; fullscreen.toggle(); expect(fullscreen.isFullscreen()).to.be.true; fullscreen.toggle(); expect(fullscreen.isFullscreen()).to.be.false; }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/module/Codeview.spec.js.html000064400000011735151677271550022066 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/module/Codeview.spec.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">test/unit/base/module/</a> Codeview.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>19/19</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>3/3</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>19/19</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</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-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-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-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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** * Codeview.spec.js * (c) 2015~ Summernote Team * summernote may be freely distributed under the MIT license./ */ import '../../../../src/js/bs3/settings'; import $ from 'jquery'; import chai from 'chai'; import Context from '../../../../src/js/base/Context'; import Codeview from '../../../../src/js/base/module/Codeview'; var expect = chai.expect; describe('Codeview', () => { var codeview, context; beforeEach(() => { var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, { }, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); context = new Context($('<div><p>hello</p></div>'), options); codeview = new Codeview(context); }); it('should toggle codeview mode', () => { expect(codeview.isActivated()).to.be.false; codeview.toggle(); expect(codeview.isActivated()).to.be.true; codeview.toggle(); expect(codeview.isActivated()).to.be.false; }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/module/index.html000064400000012060151677271550020054 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/module/</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> test/unit/base/module/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">99.6% </span> <span class="quiet">Statements</span> <span class='fraction'>247/248</span> </div> <div class='fl pad1y space-right2'> <span class="strong">50% </span> <span class="quiet">Branches</span> <span class='fraction'>5/10</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>56/56</span> </div> <div class='fl pad1y space-right2'> <span class="strong">99.6% </span> <span class="quiet">Lines</span> <span class='fraction'>247/248</span> </div> </div> </div> <div class='status-line high'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file high" data-value="Codeview.spec.js"><a href="Codeview.spec.js.html">Codeview.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="19" class="abs high">19/19</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="3" class="abs high">3/3</td> <td data-value="100" class="pct high">100%</td> <td data-value="19" class="abs high">19/19</td> </tr> <tr> <td class="file high" data-value="Editor.spec.js"><a href="Editor.spec.js.html">Editor.spec.js</a></td> <td data-value="99.53" class="pic high"><div class="chart"><div class="cover-fill" style="width: 99%;"></div><div class="cover-empty" style="width:1%;"></div></div></td> <td data-value="99.53" class="pct high">99.53%</td> <td data-value="211" class="abs high">210/211</td> <td data-value="50" class="pct medium">50%</td> <td data-value="10" class="abs medium">5/10</td> <td data-value="100" class="pct high">100%</td> <td data-value="50" class="abs high">50/50</td> <td data-value="99.53" class="pct high">99.53%</td> <td data-value="211" class="abs high">210/211</td> </tr> <tr> <td class="file high" data-value="Fullscreen.spec.js"><a href="Fullscreen.spec.js.html">Fullscreen.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="18" class="abs high">18/18</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="3" class="abs high">3/3</td> <td data-value="100" class="pct high">100%</td> <td data-value="18" class="abs high">18/18</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/Context.spec.js.html000064400000023207151677271550020455 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/Context.spec.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">test/unit/base/</a> Context.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>55/55</span> </div> <div class='fl pad1y space-right2'> <span class="strong">50% </span> <span class="quiet">Branches</span> <span class='fraction'>1/2</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'>54/54</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 80 81 82 83 84 85 86 87</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-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-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-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-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-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-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-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-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-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-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-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-yes">1×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</span> <span class="cline-any cline-yes">3×</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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** * Context.spec.js * (c) 2015~ Summernote Team * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import spies from 'chai-spies'; /* eslint-disable import/first */ import $ from 'jquery'; window.jQuery = $; import 'bootstrap'; import chaidom from '../../chaidom'; import env from '../../../src/js/base/core/env'; import Context from '../../../src/js/base/Context'; /* eslint-enable import/first */ var expect = chai.expect; chai.use(spies); chai.use(chaidom); describe('Context lifecycle', () => { it('should be initialized without calling callback', () => { var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); var spy = chai.spy(); var $note = $('<div><p>hello</p></div>'); $note.on('summernote.change', spy); var context = new Context($note, options); expect(spy).to.have.not.been.called(); // [workaround] // - IE8-11 can't create range in headless mode <span class="missing-if-branch" title="else path not taken" >E</span>if (!env.isMSIE) { context.invoke('insertText', 'hello'); expect(spy).to.have.been.called(); } }); it('should preserve user events handler after destroy', () => { var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); var spy = chai.spy(); var $note = $('<div><p>hello</p></div>'); $note.on('click', spy); var context = new Context($note, options); context.destroy(); $note.trigger('click'); expect(spy).to.have.been.called(); }); }); describe('Context', () => { var context; beforeEach(() => { var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); context = new Context($('<div><p>hello</p></div>'), options); }); it('should get or set contents with code', () => { expect(context.code()).to.equalsIgnoreCase('<p>hello</p>'); context.code('<p>hello2</p>'); expect(context.code()).to.equalsIgnoreCase('<p>hello2</p>'); }); it('should enable or disable editor', () => { expect(context.isDisabled()).to.be.false; context.disable(); expect(context.isDisabled()).to.be.true; context.enable(); expect(context.isDisabled()).to.be.false; }); it('should preserve disabled status after reset', () => { expect(context.isDisabled()).to.be.false; context.disable(); expect(context.isDisabled()).to.be.true; context.reset(); expect(context.isDisabled()).to.be.true; }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/base/index.html000064400000007173151677271550016600 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/base/</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> test/unit/base/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>55/55</span> </div> <div class='fl pad1y space-right2'> <span class="strong">50% </span> <span class="quiet">Branches</span> <span class='fraction'>1/2</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'>54/54</span> </div> </div> </div> <div class='status-line high'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file high" data-value="Context.spec.js"><a href="Context.spec.js.html">Context.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="55" class="abs high">55/55</td> <td data-value="50" class="pct medium">50%</td> <td data-value="2" class="abs medium">1/2</td> <td data-value="100" class="pct high">100%</td> <td data-value="8" class="abs high">8/8</td> <td data-value="100" class="pct high">100%</td> <td data-value="54" class="abs high">54/54</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/bs/module/VideoDialog.spec.js.html000064400000015105151677271550022174 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/bs/module/VideoDialog.spec.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">test/unit/bs/module/</a> VideoDialog.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Statements</span> <span class='fraction'>28/28</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Branches</span> <span class='fraction'>0/0</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>6/6</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Lines</span> <span class='fraction'>28/28</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</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-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-yes">1×</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">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</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">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-yes">2×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">2×</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-yes">1×</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></td><td class="text"><pre class="prettyprint lang-js">/** * VideoDialog.spec.js * (c) 2015~ Summernote Team * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import $ from 'jquery'; import Context from '../../../../src/js/base/Context'; import VideoDialog from '../../../../src/js/base/module/VideoDialog'; var expect = chai.expect; describe('bs:module.VideoDialog', () => { function expectUrl(source, target) { var iframe = $video.createVideoNode(source); expect(iframe).to.not.equal(false); expect(iframe.tagName).to.equal('IFRAME'); expect(iframe.src).to.equal(target); } var context, $video; beforeEach(() => { var $note = $('<div></div>').appendTo('body'); var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); options.toolbar = [ ['video', ['video']] ]; context = new Context($note, options); context.initialize(); $video = new VideoDialog(context); }); describe('#createVideoNode', () => { it('should execute when insert other url', () => { expect($video.createVideoNode('http://www.google.com')).to.equal(false); expect($video.createVideoNode('http://www.youtube.com')).to.equal(false); expect($video.createVideoNode('http://www.facebook.com')).to.equal(false); }); it('should execute when insert v.qq.com', () => { expectUrl('http://v.qq.com/cover/6/640ewqy2v071ppd.html?vid=f0196y2b2cx', 'http://v.qq.com/iframe/player.html?vid=f0196y2b2cx&amp;auto=0'); expectUrl('http://v.qq.com/x/page/p0330y279lm.html', 'http://v.qq.com/iframe/player.html?vid=p0330y279lm&amp;auto=0'); }); }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/bs/module/Buttons.spec.js.html000064400000057440151677271550021454 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/bs/module/Buttons.spec.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">test/unit/bs/module/</a> Buttons.spec.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">99.24% </span> <span class="quiet">Statements</span> <span class='fraction'>130/131</span> </div> <div class='fl pad1y space-right2'> <span class="strong">80% </span> <span class="quiet">Branches</span> <span class='fraction'>4/5</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>38/38</span> </div> <div class='fl pad1y space-right2'> <span class="strong">99.24% </span> <span class="quiet">Lines</span> <span class='fraction'>130/131</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 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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236</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-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-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-yes">1×</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-yes">18×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">18×</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">18×</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-neutral"> </span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-yes">18×</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">18×</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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-yes">1×</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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** * Buttons.spec.js * (c) 2015~ Summernote Team * summernote may be freely distributed under the MIT license./ */ import chai from 'chai'; import $ from 'jquery'; import env from '../../../../src/js/base/core/env'; import range from '../../../../src/js/base/core/range'; import Context from '../../../../src/js/base/Context'; const expect = chai.expect; const assert = chai.assert; describe('Buttons', () => { var context, $toolbar, $editable; beforeEach(function() { $('body').empty(); // important ! var $note = $('<div><p>hello</p></div>').appendTo('body'); var options = $.extend({}, $.summernote.options); options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]); options.toolbar = [ ['font1', ['style', 'clear']], ['font2', ['bold', 'underline', 'italic', 'superscript', 'subscript', 'strikethrough']], ['font3', ['fontname', 'fontsize']], ['color', ['color']], ['para', ['ul', 'ol', 'paragraph']], ['table', ['table']], ['insert', ['link', 'picture', 'video']], ['view', ['fullscreen', 'codeview', 'help']] ]; context = new Context($note, options); context.initialize(); $toolbar = context.layoutInfo.toolbar; $editable = context.layoutInfo.editable; // [workaround] // - Firefox need setTimeout for applying contents // - IE8~11 can't create range in headless mode <span class="missing-if-branch" title="if path not taken" >I</span>if (env.isFF || env.isMSIE || env.isEdge) { <span class="cstat-no" title="statement not covered" > this.skip();</span> } }); describe('bold button', () => { it('should execute bold command when it is clicked', () => { range.createFromNode($editable.find('p')[0]).normalize().select(); $toolbar.find('.note-btn-bold').click(); expect($editable.html()).to.equalsIgnoreCase('<p><b>hello</b></p>'); }); }); describe('bold button state updated', () => { it('should look toggled immediately when clicked', () => { var $button = $toolbar.find('.note-btn-bold'); assert.isTrue($button.length === 1); assert.isFalse($button.hasClass('active')); $button.click(); assert.isTrue($button.hasClass('active'), 'button is now active'); }); }); describe('italic button', () => { it('should execute italic command when it is clicked', () => { range.createFromNode($editable.find('p')[0]).normalize().select(); $toolbar.find('.note-btn-italic').click(); expect($editable.html()).to.equalsIgnoreCase('<p><i>hello</i></p>'); }); }); describe('italic button state updated', () => { it('should look toggled immediately when clicked', () => { var $button = $toolbar.find('.note-btn-italic'); assert.isTrue($button.length === 1); assert.isFalse($button.hasClass('active')); $button.click(); assert.isTrue($button.hasClass('active'), 'button is now active'); }); }); describe('underline button', () => { it('should execute underline command when it is clicked', () => { range.createFromNode($editable.find('p')[0]).normalize().select(); $toolbar.find('.note-btn-underline').click(); expect($editable.html()).to.equalsIgnoreCase('<p><u>hello</u></p>'); }); }); describe('underline button state updated', () => { it('should look toggled immediately when clicked', () => { var $button = $toolbar.find('.note-btn-underline'); assert.isTrue($button.length === 1); assert.isFalse($button.hasClass('active')); $button.click(); assert.isTrue($button.hasClass('active'), 'button is now active'); }); }); describe('superscript button', () => { it('should execute superscript command when it is clicked', () => { range.createFromNode($editable.find('p')[0]).normalize().select(); $toolbar.find('.note-btn-superscript').click(); expect($editable.html()).to.equalsIgnoreCase('<p><sup>hello</sup></p>'); }); }); describe('superscript button state updated', () => { it('should look toggled immediately when clicked', () => { var $button = $toolbar.find('.note-btn-superscript'); assert.isTrue($button.length === 1); assert.isFalse($button.hasClass('active')); $button.click(); assert.isTrue($button.hasClass('active'), 'button is now active'); }); }); describe('subscript button', () => { it('should execute subscript command when it is clicked', () => { range.createFromNode($editable.find('p')[0]).normalize().select(); $toolbar.find('.note-btn-subscript').click(); expect($editable.html()).to.equalsIgnoreCase('<p><sub>hello</sub></p>'); }); }); describe('subscript button state updated', () => { it('should look toggled immediately when clicked', () => { var $button = $toolbar.find('.note-btn-subscript'); assert.isTrue($button.length === 1); assert.isFalse($button.hasClass('active')); $button.click(); assert.isTrue($button.hasClass('active'), 'button is now active'); }); }); describe('strikethrough button', () => { it('should execute strikethrough command when it is clicked', () => { range.createFromNode($editable.find('p')[0]).normalize().select(); $toolbar.find('.note-btn-strikethrough').click(); expect($editable.html()).to.equalsIgnoreCase('<p><strike>hello</strike></p>'); }); }); describe('strikethrough button state updated', () => { it('should look toggled immediately when clicked', () => { var $button = $toolbar.find('.note-btn-strikethrough'); assert.isTrue($button.length === 1); assert.isFalse($button.hasClass('active')); $button.click(); assert.isTrue($button.hasClass('active'), 'button is now active'); }); }); describe('clear button state not updated when clicked', () => { it('should never look toggled when clicked', () => { var $button = $toolbar.find('i.note-icon-eraser').parent(); assert.isTrue($button.length === 1); assert.isFalse($button.hasClass('active')); $button.click(); assert.isFalse($button.hasClass('active'), 'button is now active'); }); }); describe('font family button', () => { it('should select the right font family name in the dropdown list when it is clicked', () => { // XXX: skip assertions for passing test on travis. // var $li = $toolbar.find('.dropdown-fontname li>a[data-value="Comic Sans MS"]'); // var $span = $toolbar.find('span.note-current-fontname'); // assert.isTrue($li.length === 1); // assert.isTrue($span.text() !== 'Comic Sans MS'); // $li.click(); // assert.isTrue($span.text() === 'Comic Sans MS'); }); }); describe('recent color button', () => { it('should execute color command when it is clicked', () => { range.createFromNode($editable.find('p')[0]).normalize().select(); $toolbar.find('.note-current-color-button').click(); var $span = $editable.find('span'); expect($span).to.be.equalsStyle('#FFFF00', 'background-color'); }); }); describe('fore color button', () => { it('should execute fore color command when it is clicked', () => { range.createFromNode($editable.find('p')[0]).normalize().select(); var $button = $toolbar.find('[data-event=foreColor]').eq(10); $button.click(); var $span = $editable.find('span'); expect($span).to.be.equalsStyle('#FF9C00', 'color'); }); }); describe('back color button', () => { it('should execute back color command when it is clicked', () => { range.createFromNode($editable.find('p')[0]).normalize().select(); var $button = $toolbar.find('[data-event=backColor]').eq(10); $button.click(); var $span = $editable.find('span'); expect($span).to.be.equalsStyle($button.data('value'), 'background-color'); }); }); describe('font size button with empty content', () => { it('should update font size button value when changing font size', () => { var $fontSizeDropdown = $toolbar.find('.dropdown-fontsize'); var $fontSizeButton = $fontSizeDropdown.siblings('button'); var $fontSizeList = $fontSizeDropdown.find('a'); var selectedSize = '36'; // click on dropdown button $fontSizeButton.trigger('click'); // select a font size $fontSizeList.filter('[data-value="' + selectedSize + '"]').trigger('click'); expect($fontSizeButton.text().trim()).to.equal(selectedSize); }); }); }); </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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/test/unit/bs/module/index.html000064400000010555151677271550017555 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for test/unit/bs/module/</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> test/unit/bs/module/ </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">99.37% </span> <span class="quiet">Statements</span> <span class='fraction'>158/159</span> </div> <div class='fl pad1y space-right2'> <span class="strong">80% </span> <span class="quiet">Branches</span> <span class='fraction'>4/5</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>44/44</span> </div> <div class='fl pad1y space-right2'> <span class="strong">99.37% </span> <span class="quiet">Lines</span> <span class='fraction'>158/159</span> </div> </div> </div> <div class='status-line high'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file high" data-value="Buttons.spec.js"><a href="Buttons.spec.js.html">Buttons.spec.js</a></td> <td data-value="99.24" class="pic high"><div class="chart"><div class="cover-fill" style="width: 99%;"></div><div class="cover-empty" style="width:1%;"></div></div></td> <td data-value="99.24" class="pct high">99.24%</td> <td data-value="131" class="abs high">130/131</td> <td data-value="80" class="pct high">80%</td> <td data-value="5" class="abs high">4/5</td> <td data-value="100" class="pct high">100%</td> <td data-value="38" class="abs high">38/38</td> <td data-value="99.24" class="pct high">99.24%</td> <td data-value="131" class="abs high">130/131</td> </tr> <tr> <td class="file high" data-value="VideoDialog.spec.js"><a href="VideoDialog.spec.js.html">VideoDialog.spec.js</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="28" class="abs high">28/28</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="6" class="abs high">6/6</td> <td data-value="100" class="pct high">100%</td> <td data-value="28" class="abs high">28/28</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="../../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../../sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/index.html000064400000031136151677271550013724 0ustar00<!doctype html> <html lang="en"> <head> <title>Code coverage report for All files</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> / </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">76.37% </span> <span class="quiet">Statements</span> <span class='fraction'>4037/5286</span> </div> <div class='fl pad1y space-right2'> <span class="strong">54.01% </span> <span class="quiet">Branches</span> <span class='fraction'>902/1670</span> </div> <div class='fl pad1y space-right2'> <span class="strong">76.75% </span> <span class="quiet">Functions</span> <span class='fraction'>842/1097</span> </div> <div class='fl pad1y space-right2'> <span class="strong">76.47% </span> <span class="quiet">Lines</span> <span class='fraction'>4021/5258</span> </div> </div> </div> <div class='status-line medium'></div> <div class="pad1"> <table class="coverage-summary"> <thead> <tr> <th data-col="file" data-fmt="html" data-html="true" class="file">File</th> <th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th> <th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th> <th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th> <th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th> <th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th> <th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th> <th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th> </tr> </thead> <tbody><tr> <td class="file low" data-value="src/js/"><a href="src/js/index.html">src/js/</a></td> <td data-value="19.23" class="pic low"><div class="chart"><div class="cover-fill" style="width: 19%;"></div><div class="cover-empty" style="width:81%;"></div></div></td> <td data-value="19.23" class="pct low">19.23%</td> <td data-value="26" class="abs low">5/26</td> <td data-value="0" class="pct low">0%</td> <td data-value="12" class="abs low">0/12</td> <td data-value="0" class="pct low">0%</td> <td data-value="2" class="abs low">0/2</td> <td data-value="19.23" class="pct low">19.23%</td> <td data-value="26" class="abs low">5/26</td> </tr> <tr> <td class="file high" data-value="src/js/base/"><a href="src/js/base/index.html">src/js/base/</a></td> <td data-value="95.78" class="pic high"><div class="chart"><div class="cover-fill" style="width: 95%;"></div><div class="cover-empty" style="width:5%;"></div></div></td> <td data-value="95.78" class="pct high">95.78%</td> <td data-value="166" class="abs high">159/166</td> <td data-value="87.1" class="pct high">87.1%</td> <td data-value="93" class="abs high">81/93</td> <td data-value="97.06" class="pct high">97.06%</td> <td data-value="34" class="abs high">33/34</td> <td data-value="95.78" class="pct high">95.78%</td> <td data-value="166" class="abs high">159/166</td> </tr> <tr> <td class="file high" data-value="src/js/base/core/"><a href="src/js/base/core/index.html">src/js/base/core/</a></td> <td data-value="82.09" class="pic high"><div class="chart"><div class="cover-fill" style="width: 82%;"></div><div class="cover-empty" style="width:18%;"></div></div></td> <td data-value="82.09" class="pct high">82.09%</td> <td data-value="860" class="abs high">706/860</td> <td data-value="75.62" class="pct medium">75.62%</td> <td data-value="484" class="abs medium">366/484</td> <td data-value="88.1" class="pct high">88.1%</td> <td data-value="168" class="abs high">148/168</td> <td data-value="82.27" class="pct high">82.27%</td> <td data-value="846" class="abs high">696/846</td> </tr> <tr> <td class="file high" data-value="src/js/base/editing/"><a href="src/js/base/editing/index.html">src/js/base/editing/</a></td> <td data-value="88.13" class="pic high"><div class="chart"><div class="cover-fill" style="width: 88%;"></div><div class="cover-empty" style="width:12%;"></div></div></td> <td data-value="88.13" class="pct high">88.13%</td> <td data-value="514" class="abs high">453/514</td> <td data-value="76.09" class="pct medium">76.09%</td> <td data-value="276" class="abs medium">210/276</td> <td data-value="90" class="pct high">90%</td> <td data-value="70" class="abs high">63/70</td> <td data-value="88.8" class="pct high">88.8%</td> <td data-value="509" class="abs high">452/509</td> </tr> <tr> <td class="file medium" data-value="src/js/base/module/"><a href="src/js/base/module/index.html">src/js/base/module/</a></td> <td data-value="66.01" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 66%;"></div><div class="cover-empty" style="width:34%;"></div></div></td> <td data-value="66.01" class="pct medium">66.01%</td> <td data-value="1580" class="abs medium">1043/1580</td> <td data-value="38.15" class="pct low">38.15%</td> <td data-value="540" class="abs low">206/540</td> <td data-value="63.85" class="pct medium">63.85%</td> <td data-value="379" class="abs medium">242/379</td> <td data-value="66.16" class="pct medium">66.16%</td> <td data-value="1575" class="abs medium">1042/1575</td> </tr> <tr> <td class="file high" data-value="src/js/bs3/"><a href="src/js/bs3/index.html">src/js/bs3/</a></td> <td data-value="95.15" class="pic high"><div class="chart"><div class="cover-fill" style="width: 95%;"></div><div class="cover-empty" style="width:5%;"></div></div></td> <td data-value="95.15" class="pct high">95.15%</td> <td data-value="103" class="abs high">98/103</td> <td data-value="54" class="pct medium">54%</td> <td data-value="50" class="abs medium">27/50</td> <td data-value="85" class="pct high">85%</td> <td data-value="20" class="abs high">17/20</td> <td data-value="95.15" class="pct high">95.15%</td> <td data-value="103" class="abs high">98/103</td> </tr> <tr> <td class="file low" data-value="src/js/bs4/"><a href="src/js/bs4/index.html">src/js/bs4/</a></td> <td data-value="0" class="pic low"><div class="chart"><div class="cover-fill" style="width: 0%;"></div><div class="cover-empty" style="width:100%;"></div></div></td> <td data-value="0" class="pct low">0%</td> <td data-value="105" class="abs low">0/105</td> <td data-value="0" class="pct low">0%</td> <td data-value="50" class="abs low">0/50</td> <td data-value="0" class="pct low">0%</td> <td data-value="20" class="abs low">0/20</td> <td data-value="0" class="pct low">0%</td> <td data-value="105" class="abs low">0/105</td> </tr> <tr> <td class="file low" data-value="src/js/lite/"><a href="src/js/lite/index.html">src/js/lite/</a></td> <td data-value="0" class="pic low"><div class="chart"><div class="cover-fill" style="width: 0%;"></div><div class="cover-empty" style="width:100%;"></div></div></td> <td data-value="0" class="pct low">0%</td> <td data-value="204" class="abs low">0/204</td> <td data-value="0" class="pct low">0%</td> <td data-value="91" class="abs low">0/91</td> <td data-value="0" class="pct low">0%</td> <td data-value="40" class="abs low">0/40</td> <td data-value="0" class="pct low">0%</td> <td data-value="204" class="abs low">0/204</td> </tr> <tr> <td class="file low" data-value="src/js/lite/ui/"><a href="src/js/lite/ui/index.html">src/js/lite/ui/</a></td> <td data-value="2.55" class="pic low"><div class="chart"><div class="cover-fill" style="width: 2%;"></div><div class="cover-empty" style="width:98%;"></div></div></td> <td data-value="2.55" class="pct low">2.55%</td> <td data-value="157" class="abs low">4/157</td> <td data-value="0" class="pct low">0%</td> <td data-value="55" class="abs low">0/55</td> <td data-value="0" class="pct low">0%</td> <td data-value="25" class="abs low">0/25</td> <td data-value="2.55" class="pct low">2.55%</td> <td data-value="157" class="abs low">4/157</td> </tr> <tr> <td class="file high" data-value="test/unit/base/"><a href="test/unit/base/index.html">test/unit/base/</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="55" class="abs high">55/55</td> <td data-value="50" class="pct medium">50%</td> <td data-value="2" class="abs medium">1/2</td> <td data-value="100" class="pct high">100%</td> <td data-value="8" class="abs high">8/8</td> <td data-value="100" class="pct high">100%</td> <td data-value="54" class="abs high">54/54</td> </tr> <tr> <td class="file high" data-value="test/unit/base/core/"><a href="test/unit/base/core/index.html">test/unit/base/core/</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="616" class="abs high">616/616</td> <td data-value="100" class="pct high">100%</td> <td data-value="2" class="abs high">2/2</td> <td data-value="100" class="pct high">100%</td> <td data-value="193" class="abs high">193/193</td> <td data-value="100" class="pct high">100%</td> <td data-value="613" class="abs high">613/613</td> </tr> <tr> <td class="file high" data-value="test/unit/base/editing/"><a href="test/unit/base/editing/index.html">test/unit/base/editing/</a></td> <td data-value="100" class="pic high"><div class="chart"><div class="cover-fill cover-full" style="width: 100%;"></div><div class="cover-empty" style="width:0%;"></div></div></td> <td data-value="100" class="pct high">100%</td> <td data-value="493" class="abs high">493/493</td> <td data-value="100" class="pct high">100%</td> <td data-value="0" class="abs high">0/0</td> <td data-value="100" class="pct high">100%</td> <td data-value="38" class="abs high">38/38</td> <td data-value="100" class="pct high">100%</td> <td data-value="493" class="abs high">493/493</td> </tr> <tr> <td class="file high" data-value="test/unit/base/module/"><a href="test/unit/base/module/index.html">test/unit/base/module/</a></td> <td data-value="99.6" class="pic high"><div class="chart"><div class="cover-fill" style="width: 99%;"></div><div class="cover-empty" style="width:1%;"></div></div></td> <td data-value="99.6" class="pct high">99.6%</td> <td data-value="248" class="abs high">247/248</td> <td data-value="50" class="pct medium">50%</td> <td data-value="10" class="abs medium">5/10</td> <td data-value="100" class="pct high">100%</td> <td data-value="56" class="abs high">56/56</td> <td data-value="99.6" class="pct high">99.6%</td> <td data-value="248" class="abs high">247/248</td> </tr> <tr> <td class="file high" data-value="test/unit/bs/module/"><a href="test/unit/bs/module/index.html">test/unit/bs/module/</a></td> <td data-value="99.37" class="pic high"><div class="chart"><div class="cover-fill" style="width: 99%;"></div><div class="cover-empty" style="width:1%;"></div></div></td> <td data-value="99.37" class="pct high">99.37%</td> <td data-value="159" class="abs high">158/159</td> <td data-value="80" class="pct high">80%</td> <td data-value="5" class="abs high">4/5</td> <td data-value="100" class="pct high">100%</td> <td data-value="44" class="abs high">44/44</td> <td data-value="99.37" class="pct high">99.37%</td> <td data-value="159" class="abs high">158/159</td> </tr> </tbody> </table> </div><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 Tue Feb 20 2018 09:36:40 GMT+0900 (KST) </div> </div> <script src="prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="sorter.js"></script> </body> </html> PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/prettify.css000064400000001245151677271550014305 0ustar00.pln{color:#000}@media screen{.str{color:#080}.kwd{color:#008}.com{color:#800}.typ{color:#606}.lit{color:#066}.pun,.opn,.clo{color:#660}.tag{color:#008}.atn{color:#606}.atv{color:#080}.dec,.var{color:#606}.fun{color:red}}@media print,projection{.str{color:#060}.kwd{color:#006;font-weight:bold}.com{color:#600;font-style:italic}.typ{color:#404;font-weight:bold}.lit{color:#044}.pun,.opn,.clo{color:#440}.tag{color:#006;font-weight:bold}.atn{color:#404}.atv{color:#060}}pre.prettyprint{padding:2px;border:1px solid #888}ol.linenums{margin-top:0;margin-bottom:0}li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8{list-style-type:none}li.L1,li.L3,li.L5,li.L7,li.L9{background:#eee} PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/base.css000064400000012354151677271550013354 0ustar00body, html { margin:0; padding: 0; height: 100%; } body { font-family: Helvetica Neue, Helvetica, Arial; font-size: 14px; color:#333; } .small { font-size: 12px; } *, *:after, *:before { -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box; } h1 { font-size: 20px; margin: 0;} h2 { font-size: 14px; } pre { font: 12px/1.4 Consolas, "Liberation Mono", Menlo, Courier, monospace; margin: 0; padding: 0; -moz-tab-size: 2; -o-tab-size: 2; tab-size: 2; } a { color:#0074D9; text-decoration:none; } a:hover { text-decoration:underline; } .strong { font-weight: bold; } .space-top1 { padding: 10px 0 0 0; } .pad2y { padding: 20px 0; } .pad1y { padding: 10px 0; } .pad2x { padding: 0 20px; } .pad2 { padding: 20px; } .pad1 { padding: 10px; } .space-left2 { padding-left:55px; } .space-right2 { padding-right:20px; } .center { text-align:center; } .clearfix { display:block; } .clearfix:after { content:''; display:block; height:0; clear:both; visibility:hidden; } .fl { float: left; } @media only screen and (max-width:640px) { .col3 { width:100%; max-width:100%; } .hide-mobile { display:none!important; } } .quiet { color: #7f7f7f; color: rgba(0,0,0,0.5); } .quiet a { opacity: 0.7; } .fraction { font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace; font-size: 10px; color: #555; background: #E8E8E8; padding: 4px 5px; border-radius: 3px; vertical-align: middle; } div.path a:link, div.path a:visited { color: #333; } table.coverage { border-collapse: collapse; margin: 10px 0 0 0; padding: 0; } table.coverage td { margin: 0; padding: 0; vertical-align: top; } table.coverage td.line-count { text-align: right; padding: 0 5px 0 20px; } table.coverage td.line-coverage { text-align: right; padding-right: 10px; min-width:20px; } table.coverage td span.cline-any { display: inline-block; padding: 0 5px; width: 100%; } .missing-if-branch { display: inline-block; margin-right: 5px; border-radius: 3px; position: relative; padding: 0 4px; background: #333; color: yellow; } .skip-if-branch { display: none; margin-right: 10px; position: relative; padding: 0 4px; background: #ccc; color: white; } .missing-if-branch .typ, .skip-if-branch .typ { color: inherit !important; } .coverage-summary { border-collapse: collapse; width: 100%; } .coverage-summary tr { border-bottom: 1px solid #bbb; } .keyline-all { border: 1px solid #ddd; } .coverage-summary td, .coverage-summary th { padding: 10px; } .coverage-summary tbody { border: 1px solid #bbb; } .coverage-summary td { border-right: 1px solid #bbb; } .coverage-summary td:last-child { border-right: none; } .coverage-summary th { text-align: left; font-weight: normal; white-space: nowrap; } .coverage-summary th.file { border-right: none !important; } .coverage-summary th.pct { } .coverage-summary th.pic, .coverage-summary th.abs, .coverage-summary td.pct, .coverage-summary td.abs { text-align: right; } .coverage-summary td.file { white-space: nowrap; } .coverage-summary td.pic { min-width: 120px !important; } .coverage-summary tfoot td { } .coverage-summary .sorter { height: 10px; width: 7px; display: inline-block; margin-left: 0.5em; background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent; } .coverage-summary .sorted .sorter { background-position: 0 -20px; } .coverage-summary .sorted-desc .sorter { background-position: 0 -10px; } .status-line { height: 10px; } /* dark red */ .red.solid, .status-line.low, .low .cover-fill { background:#C21F39 } .low .chart { border:1px solid #C21F39 } /* medium red */ .cstat-no, .fstat-no, .cbranch-no, .cbranch-no { background:#F6C6CE } /* light red */ .low, .cline-no { background:#FCE1E5 } /* light green */ .high, .cline-yes { background:rgb(230,245,208) } /* medium green */ .cstat-yes { background:rgb(161,215,106) } /* dark green */ .status-line.high, .high .cover-fill { background:rgb(77,146,33) } .high .chart { border:1px solid rgb(77,146,33) } /* dark yellow (gold) */ .medium .chart { border:1px solid #f9cd0b; } .status-line.medium, .medium .cover-fill { background: #f9cd0b; } /* light yellow */ .medium { background: #fff4c2; } /* light gray */ span.cline-neutral { background: #eaeaea; } .cbranch-no { background: yellow !important; color: #111; } .cstat-skip { background: #ddd; color: #111; } .fstat-skip { background: #ddd; color: #111 !important; } .cbranch-skip { background: #ddd !important; color: #111; } .cover-fill, .cover-empty { display:inline-block; height: 12px; } .chart { line-height: 0; } .cover-empty { background: white; } .cover-full { border-right: none !important; } pre.prettyprint { border: none !important; padding: 0 !important; margin: 0 !important; } .com { color: #999 !important; } .ignore-none { color: #999; font-weight: normal; } .wrapper { min-height: 100%; height: auto !important; height: 100%; margin: 0 auto -48px; } .footer, .push { height: 48px; } PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/prettify.js000064400000042242151677271550014133 0ustar00window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V<U;++V){var ae=Z[V];if(ae.ignoreCase){ac=true}else{if(/[a-z]/i.test(ae.source.replace(/\\u[0-9a-f]{4}|\\x[0-9a-f]{2}|\\[^ux]/gi,""))){S=true;ac=false;break}}}var Y={b:8,t:9,n:10,v:11,f:12,r:13};function ab(ah){var ag=ah.charCodeAt(0);if(ag!==92){return ag}var af=ah.charAt(1);ag=Y[af];if(ag){return ag}else{if("0"<=af&&af<="7"){return parseInt(ah.substring(1),8)}else{if(af==="u"||af==="x"){return parseInt(ah.substring(2),16)}else{return ah.charCodeAt(1)}}}}function T(af){if(af<32){return(af<16?"\\x0":"\\x")+af.toString(16)}var ag=String.fromCharCode(af);if(ag==="\\"||ag==="-"||ag==="["||ag==="]"){ag="\\"+ag}return ag}function X(am){var aq=am.substring(1,am.length-1).match(new RegExp("\\\\u[0-9A-Fa-f]{4}|\\\\x[0-9A-Fa-f]{2}|\\\\[0-3][0-7]{0,2}|\\\\[0-7]{1,2}|\\\\[\\s\\S]|-|[^-\\\\]","g"));var ak=[];var af=[];var ao=aq[0]==="^";for(var ar=ao?1:0,aj=aq.length;ar<aj;++ar){var ah=aq[ar];if(/\\[bdsw]/i.test(ah)){ak.push(ah)}else{var ag=ab(ah);var al;if(ar+2<aj&&"-"===aq[ar+1]){al=ab(aq[ar+2]);ar+=2}else{al=ag}af.push([ag,al]);if(!(al<65||ag>122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;ar<af.length;++ar){var at=af[ar];if(at[0]<=ap[1]+1){ap[1]=Math.max(ap[1],at[1])}else{ai.push(ap=at)}}var an=["["];if(ao){an.push("^")}an.push.apply(an,ak);for(var ar=0;ar<ai.length;++ar){var at=ai[ar];an.push(T(at[0]));if(at[1]>at[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak<ah;++ak){var ag=aj[ak];if(ag==="("){++am}else{if("\\"===ag.charAt(0)){var af=+ag.substring(1);if(af&&af<=am){an[af]=-1}}}}for(var ak=1;ak<an.length;++ak){if(-1===an[ak]){an[ak]=++ad}}for(var ak=0,am=0;ak<ah;++ak){var ag=aj[ak];if(ag==="("){++am;if(an[am]===undefined){aj[ak]="(?:"}}else{if("\\"===ag.charAt(0)){var af=+ag.substring(1);if(af&&af<=am){aj[ak]="\\"+an[am]}}}}for(var ak=0,am=0;ak<ah;++ak){if("^"===aj[ak]&&"^"!==aj[ak+1]){aj[ak]=""}}if(al.ignoreCase&&S){for(var ak=0;ak<ah;++ak){var ag=aj[ak];var ai=ag.charAt(0);if(ag.length>=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V<U;++V){var ae=Z[V];if(ae.global||ae.multiline){throw new Error(""+ae)}aa.push("(?:"+W(ae)+")")}return new RegExp(aa.join("|"),ac?"gi":"g")}function a(V){var U=/(?:^|\s)nocode(?:\s|$)/;var X=[];var T=0;var Z=[];var W=0;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=document.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Y=S&&"pre"===S.substring(0,3);function aa(ab){switch(ab.nodeType){case 1:if(U.test(ab.className)){return}for(var ae=ab.firstChild;ae;ae=ae.nextSibling){aa(ae)}var ad=ab.nodeName;if("BR"===ad||"LI"===ad){X[W]="\n";Z[W<<1]=T++;Z[(W++<<1)|1]=ab}break;case 3:case 4:var ac=ab.nodeValue;if(ac.length){if(!Y){ac=ac.replace(/[ \t\r\n]+/g," ")}else{ac=ac.replace(/\r\n?/g,"\n")}X[W]=ac;Z[W<<1]=T;T+=ac.length;Z[(W++<<1)|1]=ab}break}}aa(V);return{sourceCode:X.join("").replace(/\n$/,""),spans:Z}}function B(S,U,W,T){if(!U){return}var V={sourceCode:U,basePos:S};W(V);T.push.apply(T,V.decorations)}var v=/\S/;function o(S){var V=undefined;for(var U=S.firstChild;U;U=U.nextSibling){var T=U.nodeType;V=(T===1)?(V?S:U):(T===3)?(v.test(U.nodeValue)?S:V):V}return V===S?undefined:V}function g(U,T){var S={};var V;(function(){var ad=U.concat(T);var ah=[];var ag={};for(var ab=0,Z=ad.length;ab<Z;++ab){var Y=ad[ab];var ac=Y[3];if(ac){for(var ae=ac.length;--ae>=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae<aq;++ae){var ag=an[ae];var ap=aj[ag];var ai=void 0;var am;if(typeof ap==="string"){am=false}else{var aa=S[ag.charAt(0)];if(aa){ai=ag.match(aa[1]);ap=aa[0]}else{for(var ao=0;ao<X;++ao){aa=T[ao];ai=ag.match(aa[1]);if(ai){ap=aa[0];break}}if(!ai){ap=F}}am=ap.length>=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y<W.length;++Y){ae(W[Y])}if(ag===(ag|0)){W[0].setAttribute("value",ag)}var aa=ac.createElement("OL");aa.className="linenums";var X=Math.max(0,((ag-1))|0)||0;for(var Y=0,T=W.length;Y<T;++Y){af=W[Y];af.className="L"+((Y+X)%10);if(!af.firstChild){af.appendChild(ac.createTextNode("\xA0"))}aa.appendChild(af)}V.appendChild(aa)}function D(ac){var aj=/\bMSIE\b/.test(navigator.userAgent);var am=/\n/g;var al=ac.sourceCode;var an=al.length;var V=0;var aa=ac.spans;var T=aa.length;var ah=0;var X=ac.decorations;var Y=X.length;var Z=0;X[Y]=an;var ar,aq;for(aq=ar=0;aq<Y;){if(X[aq]!==X[aq+2]){X[ar++]=X[aq++];X[ar++]=X[aq++]}else{aq+=2}}Y=ar;for(aq=ar=0;aq<Y;){var at=X[aq];var ab=X[aq+1];var W=aq+2;while(W+2<=Y&&X[W+1]===ab){W+=2}X[ar++]=at;X[ar++]=ab;aq=W}Y=X.length=ar;var ae=null;while(ah<T){var af=aa[ah];var S=aa[ah+2]||an;var ag=X[Z];var ap=X[Z+2]||an;var W=Math.min(S,ap);var ak=aa[ah+1];var U;if(ak.nodeType!==1&&(U=al.substring(V,W))){if(aj){U=U.replace(am,"\r")}ak.nodeValue=U;var ai=ak.ownerDocument;var ao=ai.createElement("SPAN");ao.className=X[Z+1];var ad=ak.parentNode;ad.replaceChild(ao,ak);ao.appendChild(ak);if(V<S){aa[ah+1]=ak=ai.createTextNode(al.substring(W,S));ad.insertBefore(ak,ao.nextSibling)}}V=W;if(V>=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*</.test(S)?"default-markup":"default-code"}return t[T]}c(K,["default-code"]);c(g([],[[F,/^[^<?]+/],[E,/^<!\w[^>]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^<xmp\b[^>]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^<script\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]),["default-markup","htm","html","mxml","xhtml","xml","xsl"]);c(g([[F,/^[\s]+/,null," \t\r\n"],[n,/^(?:\"[^\"]*\"?|\'[^\']*\'?)/,null,"\"'"]],[[m,/^^<\/?[a-z](?:[\w.:-]*\w)?|\/?>$/i],[P,/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^>\'\"\s]*(?:[^>\'\"\s\/]|\/(?=\s)))/],[L,/^[=<>\/]+/],["lang-js",/^on\w+\s*=\s*\"([^\"]+)\"/i],["lang-js",/^on\w+\s*=\s*\'([^\']+)\'/i],["lang-js",/^on\w+\s*=\s*([^\"\'>\s]+)/i],["lang-css",/^style\s*=\s*\"([^\"]+)\"/i],["lang-css",/^style\s*=\s*\'([^\']+)\'/i],["lang-css",/^style\s*=\s*([^\"\'>\s]+)/i]]),["in.tag"]);c(g([],[[n,/^[\s\S]+/]]),["uq.val"]);c(i({keywords:l,hashComments:true,cStyleComments:true,types:e}),["c","cc","cpp","cxx","cyc","m"]);c(i({keywords:"null,true,false"}),["json"]);c(i({keywords:R,hashComments:true,cStyleComments:true,verbatimStrings:true,types:e}),["cs"]);c(i({keywords:x,cStyleComments:true}),["java"]);c(i({keywords:H,hashComments:true,multiLineStrings:true}),["bsh","csh","sh"]);c(i({keywords:I,hashComments:true,multiLineStrings:true,tripleQuotedStrings:true}),["cv","py"]);c(i({keywords:s,hashComments:true,multiLineStrings:true,regexLiterals:true}),["perl","pl","pm"]);c(i({keywords:f,hashComments:true,multiLineStrings:true,regexLiterals:true}),["rb"]);c(i({keywords:w,cStyleComments:true,regexLiterals:true}),["js"]);c(i({keywords:r,hashComments:3,cStyleComments:true,multilineStrings:true,tripleQuotedStrings:true,regexLiterals:true}),["coffee"]);c(g([],[[C,/^[\s\S]+/]]),["regex"]);function d(V){var U=V.langExtension;try{var S=a(V.sourceNode);var T=S.sourceCode;V.sourceCode=T;V.spans=S.spans;V.basePos=0;q(U,T)(V);D(V)}catch(W){if("console" in window){console.log(W&&W.stack?W.stack:W)}}}function y(W,V,U){var S=document.createElement("PRE");S.innerHTML=W;if(U){Q(S,U)}var T={langExtension:V,numberLines:U,sourceNode:S};d(T);return S.innerHTML}function b(ad){function Y(af){return document.getElementsByTagName(af)}var ac=[Y("pre"),Y("code"),Y("xmp")];var T=[];for(var aa=0;aa<ac.length;++aa){for(var Z=0,V=ac[aa].length;Z<V;++Z){T.push(ac[aa][Z])}}ac=null;var W=Date;if(!W.now){W={now:function(){return +(new Date)}}}var X=0;var S;var ab=/\blang(?:uage)?-([\w.]+)(?!\S)/;var ae=/\bprettyprint\b/;function U(){var ag=(window.PR_SHOULD_USE_CONTINUATION?W.now()+250:Infinity);for(;X<T.length&&W.now()<ag;X++){var aj=T[X];var ai=aj.className;if(ai.indexOf("prettyprint")>=0){var ah=ai.match(ab);var am;if(!ah&&(am=o(aj))&&"CODE"===am.tagName){ah=am.className.match(ab)}if(ah){ah=ah[1]}var al=false;for(var ak=aj.parentNode;ak;ak=ak.parentNode){if((ak.tagName==="pre"||ak.tagName==="code"||ak.tagName==="xmp")&&ak.className&&ak.className.indexOf("prettyprint")>=0){al=true;break}}if(!al){var af=aj.className.match(/\blinenums\b(?::(\d+))?/);af=af?af[1]&&af[1].length?+af[1]:true:false;if(af){Q(aj,af)}S={langExtension:ah,sourceNode:aj,numberLines:af};d(S)}}}if(X<T.length){setTimeout(U,250)}else{if(ad){ad()}}}U()}window.prettyPrintOne=y;window.prettyPrint=b;window.PR={createSimpleLexer:g,registerLangHandler:c,sourceDecorator:i,PR_ATTRIB_NAME:P,PR_ATTRIB_VALUE:n,PR_COMMENT:j,PR_DECLARATION:E,PR_KEYWORD:z,PR_LITERAL:G,PR_NOCODE:N,PR_PLAIN:F,PR_PUNCTUATION:L,PR_SOURCE:J,PR_STRING:C,PR_TAG:m,PR_TYPE:O}})();PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_DECLARATION,/^<!\w[^>]*(?:>|$)/],[PR.PR_COMMENT,/^<\!--[\s\S]*?(?:-\->|$)/],[PR.PR_PUNCTUATION,/^(?:<[%?]|[%?]>)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],["lang-",/^<xmp\b[^>]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-handlebars",/^<script\b[^>]*type\s*=\s*['"]?text\/x-handlebars-template['"]?\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-js",/^<script\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i],[PR.PR_DECLARATION,/^{{[#^>/]?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{&?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{{>?\s*[\w.][^}]*}}}/],[PR.PR_COMMENT,/^{{![^}]*}}/]]),["handlebars","hbs"]);PR.registerLangHandler(PR.createSimpleLexer([[PR.PR_PLAIN,/^[ \t\r\n\f]+/,null," \t\r\n\f"]],[[PR.PR_STRING,/^\"(?:[^\n\r\f\\\"]|\\(?:\r\n?|\n|\f)|\\[\s\S])*\"/,null],[PR.PR_STRING,/^\'(?:[^\n\r\f\\\']|\\(?:\r\n?|\n|\f)|\\[\s\S])*\'/,null],["lang-css-str",/^url\(([^\)\"\']*)\)/i],[PR.PR_KEYWORD,/^(?:url|rgb|\!important|@import|@page|@media|@charset|inherit)(?=[^\-\w]|$)/i,null],["lang-css-kw",/^(-?(?:[_a-z]|(?:\\[0-9a-f]+ ?))(?:[_a-z0-9\-]|\\(?:\\[0-9a-f]+ ?))*)\s*:/i],[PR.PR_COMMENT,/^\/\*[^*]*\*+(?:[^\/*][^*]*\*+)*\//],[PR.PR_COMMENT,/^(?:<!--|-->)/],[PR.PR_LITERAL,/^(?:\d+|\d*\.\d+)(?:%|[a-z]+)?/i],[PR.PR_LITERAL,/^#(?:[0-9a-f]{3}){1,2}/i],[PR.PR_PLAIN,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i],[PR.PR_PUNCTUATION,/^[^\s\w\'\"]+/]]),["css"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_KEYWORD,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i]]),["css-kw"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_STRING,/^[^\)\"\']+/]]),["css-str"]); PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/sort-arrow-sprite.png000064400000000321151677271550016050 0ustar00�PNG IHDR�F�3tEXtSoftwareAdobe ImageReadyq�e<sIDATxڼRA� ����D���e[ � �HfFX� g�f���3�DdF�w�-˘�� � n�g�M+OVں�=�""/�ĥ'Y���?H�hV� �@��p��Y�8Bwc,�IEND�B`�PhantomJS 2.1.1 (Mac OS X 0.0.0)/html/sorter.js000064400000012324151677271550013601 0ustar00var addSorting = (function () { "use strict"; var cols, currentSort = { index: 0, desc: false }; // returns the summary table element function getTable() { return document.querySelector('.coverage-summary'); } // returns the thead element of the summary table function getTableHeader() { return getTable().querySelector('thead tr'); } // returns the tbody element of the summary table function getTableBody() { return getTable().querySelector('tbody'); } // returns the th element for nth column function getNthColumn(n) { return getTableHeader().querySelectorAll('th')[n]; } // loads all columns function loadColumns() { var colNodes = getTableHeader().querySelectorAll('th'), colNode, cols = [], col, i; for (i = 0; i < colNodes.length; i += 1) { colNode = colNodes[i]; col = { key: colNode.getAttribute('data-col'), sortable: !colNode.getAttribute('data-nosort'), type: colNode.getAttribute('data-type') || 'string' }; cols.push(col); if (col.sortable) { col.defaultDescSort = col.type === 'number'; colNode.innerHTML = colNode.innerHTML + '<span class="sorter"></span>'; } } return cols; } // attaches a data attribute to every tr element with an object // of data values keyed by column name function loadRowData(tableRow) { var tableCols = tableRow.querySelectorAll('td'), colNode, col, data = {}, i, val; for (i = 0; i < tableCols.length; i += 1) { colNode = tableCols[i]; col = cols[i]; val = colNode.getAttribute('data-value'); if (col.type === 'number') { val = Number(val); } data[col.key] = val; } return data; } // loads all row data function loadData() { var rows = getTableBody().querySelectorAll('tr'), i; for (i = 0; i < rows.length; i += 1) { rows[i].data = loadRowData(rows[i]); } } // sorts the table using the data for the ith column function sortByIndex(index, desc) { var key = cols[index].key, sorter = function (a, b) { a = a.data[key]; b = b.data[key]; return a < b ? -1 : a > b ? 1 : 0; }, finalSorter = sorter, tableBody = document.querySelector('.coverage-summary tbody'), rowNodes = tableBody.querySelectorAll('tr'), rows = [], i; if (desc) { finalSorter = function (a, b) { return -1 * sorter(a, b); }; } for (i = 0; i < rowNodes.length; i += 1) { rows.push(rowNodes[i]); tableBody.removeChild(rowNodes[i]); } rows.sort(finalSorter); for (i = 0; i < rows.length; i += 1) { tableBody.appendChild(rows[i]); } } // removes sort indicators for current column being sorted function removeSortIndicators() { var col = getNthColumn(currentSort.index), cls = col.className; cls = cls.replace(/ sorted$/, '').replace(/ sorted-desc$/, ''); col.className = cls; } // adds sort indicators for current column being sorted function addSortIndicators() { getNthColumn(currentSort.index).className += currentSort.desc ? ' sorted-desc' : ' sorted'; } // adds event listeners for all sorter widgets function enableUI() { var i, el, ithSorter = function ithSorter(i) { var col = cols[i]; return function () { var desc = col.defaultDescSort; if (currentSort.index === i) { desc = !currentSort.desc; } sortByIndex(i, desc); removeSortIndicators(); currentSort.index = i; currentSort.desc = desc; addSortIndicators(); }; }; for (i =0 ; i < cols.length; i += 1) { if (cols[i].sortable) { // add the click event handler on the th so users // dont have to click on those tiny arrows el = getNthColumn(i).querySelector('.sorter').parentElement; if (el.addEventListener) { el.addEventListener('click', ithSorter(i)); } else { el.attachEvent('onclick', ithSorter(i)); } } } } // adds sorting functionality to the UI return function () { if (!getTable()) { return; } cols = loadColumns(); loadData(cols); addSortIndicators(); enableUI(); }; })(); window.addEventListener('load', addSorting);
/home/emeraadmin/www/node_modules/liftup/../map-cache/../../4d695/coverage.tar