diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/base.css b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/base.css new file mode 100644 index 0000000000000000000000000000000000000000..29737bcb07fdbd725cbfd1d0d7ba0492af356aca --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/base.css @@ -0,0 +1,213 @@ +body, 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; +} diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/index.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/index.html new file mode 100644 index 0000000000000000000000000000000000000000..548351b1997a5dc4f718e69de8be4529fbae431a --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/index.html @@ -0,0 +1,184 @@ +<!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">28.59% </span> + <span class="quiet">Statements</span> + <span class='fraction'>722/2525</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">8.25% </span> + <span class="quiet">Branches</span> + <span class='fraction'>74/897</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">24.27% </span> + <span class="quiet">Functions</span> + <span class='fraction'>92/379</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">27.69% </span> + <span class="quiet">Lines</span> + <span class='fraction'>680/2456</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 high" data-value="src/"><a href="src/index.html">src/</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="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="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> + </tr> + +<tr> + <td class="file high" data-value="src/_scratch/"><a href="src/_scratch/index.html">src/_scratch/</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="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="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> + </tr> + +<tr> + <td class="file low" data-value="src/collections/"><a href="src/collections/index.html">src/collections/</a></td> + <td data-value="13.07" class="pic low"><div class="chart"><div class="cover-fill" style="width: 13%;"></div><div class="cover-empty" style="width:87%;"></div></div></td> + <td data-value="13.07" class="pct low">13.07%</td> + <td data-value="482" class="abs low">63/482</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="134" class="abs low">0/134</td> + <td data-value="16.36" class="pct low">16.36%</td> + <td data-value="55" class="abs low">9/55</td> + <td data-value="12.82" class="pct low">12.82%</td> + <td data-value="476" class="abs low">61/476</td> + </tr> + +<tr> + <td class="file low" data-value="src/domUtil/"><a href="src/domUtil/index.html">src/domUtil/</a></td> + <td data-value="19.93" 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.93" class="pct low">19.93%</td> + <td data-value="271" class="abs low">54/271</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="82" class="abs low">0/82</td> + <td data-value="10.42" class="pct low">10.42%</td> + <td data-value="48" class="abs low">5/48</td> + <td data-value="19.25" class="pct low">19.25%</td> + <td data-value="265" class="abs low">51/265</td> + </tr> + +<tr> + <td class="file low" data-value="src/layers/"><a href="src/layers/index.html">src/layers/</a></td> + <td data-value="44.09" class="pic low"><div class="chart"><div class="cover-fill" style="width: 44%;"></div><div class="cover-empty" style="width:56%;"></div></div></td> + <td data-value="44.09" class="pct low">44.09%</td> + <td data-value="626" class="abs low">276/626</td> + <td data-value="18" class="pct low">18%</td> + <td data-value="300" class="abs low">54/300</td> + <td data-value="30.77" class="pct low">30.77%</td> + <td data-value="117" class="abs low">36/117</td> + <td data-value="42.55" class="pct low">42.55%</td> + <td data-value="597" class="abs low">254/597</td> + </tr> + +<tr> + <td class="file low" data-value="src/mixin/"><a href="src/mixin/index.html">src/mixin/</a></td> + <td data-value="30.14" class="pic low"><div class="chart"><div class="cover-fill" style="width: 30%;"></div><div class="cover-empty" style="width:70%;"></div></div></td> + <td data-value="30.14" class="pct low">30.14%</td> + <td data-value="146" class="abs low">44/146</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="36" class="abs low">0/36</td> + <td data-value="13.04" class="pct low">13.04%</td> + <td data-value="23" class="abs low">3/23</td> + <td data-value="29.08" class="pct low">29.08%</td> + <td data-value="141" class="abs low">41/141</td> + </tr> + +<tr> + <td class="file low" data-value="src/olHelpers/"><a href="src/olHelpers/index.html">src/olHelpers/</a></td> + <td data-value="25.21" class="pic low"><div class="chart"><div class="cover-fill" style="width: 25%;"></div><div class="cover-empty" style="width:75%;"></div></div></td> + <td data-value="25.21" class="pct low">25.21%</td> + <td data-value="817" class="abs low">206/817</td> + <td data-value="1.77" class="pct low">1.77%</td> + <td data-value="283" class="abs low">5/283</td> + <td data-value="24.53" class="pct low">24.53%</td> + <td data-value="106" class="abs low">26/106</td> + <td data-value="24.53" class="pct low">24.53%</td> + <td data-value="795" class="abs low">195/795</td> + </tr> + +<tr> + <td class="file low" data-value="src/util/"><a href="src/util/index.html">src/util/</a></td> + <td data-value="43.17" class="pic low"><div class="chart"><div class="cover-fill" style="width: 43%;"></div><div class="cover-empty" style="width:57%;"></div></div></td> + <td data-value="43.17" class="pct low">43.17%</td> + <td data-value="183" class="abs low">79/183</td> + <td data-value="24.19" class="pct low">24.19%</td> + <td data-value="62" class="abs low">15/62</td> + <td data-value="43.33" class="pct low">43.33%</td> + <td data-value="30" class="abs low">13/30</td> + <td data-value="42.86" class="pct low">42.86%</td> + <td data-value="182" class="abs low">78/182</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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/prettify.css b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/prettify.css new file mode 100644 index 0000000000000000000000000000000000000000..b317a7cda31a440fbd47540297ee3c68d51f343e --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/prettify.css @@ -0,0 +1 @@ +.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} diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/prettify.js b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/prettify.js new file mode 100644 index 0000000000000000000000000000000000000000..ef51e03866898f709d2bed6f55ed10bfb9840e6f --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/prettify.js @@ -0,0 +1 @@ +window.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"]); diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/sort-arrow-sprite.png b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/sort-arrow-sprite.png new file mode 100644 index 0000000000000000000000000000000000000000..03f704a609c6fd0dbfdac63466a7d7c958b5cbf3 Binary files /dev/null and b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/sort-arrow-sprite.png differ diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/sorter.js b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/sorter.js new file mode 100644 index 0000000000000000000000000000000000000000..6c5034e403c70935ae766bfb940f945b04b2595b --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/sorter.js @@ -0,0 +1,158 @@ +var 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); diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/_scratch/_testimport.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/_scratch/_testimport.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..1c58058c3621c6945349105aed7262c38d67d2cf --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/_scratch/_testimport.ts.html @@ -0,0 +1,74 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\_scratch\_testimport.ts</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/_scratch/</a> _testimport.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Statements</span> + <span class='fraction'>0/0</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'>0/0</span> + </div> + </div> + </div> + <div class='status-line high'></div> +<pre><table class="coverage"> +<tr><td class="line-count quiet">1 +2 +3 +4</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></td><td class="text"><pre class="prettyprint lang-js"> +import ol = require('custom-ol'); + +// console.log(ol.animation.bounce({duration: 10, resolution: 30, start: 4, easing: (t) => {return 5}}));</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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/_scratch/index.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/_scratch/index.html new file mode 100644 index 0000000000000000000000000000000000000000..e142fd54fdb3f9bd062f3cadd2687a1f69ea015d --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/_scratch/index.html @@ -0,0 +1,93 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\_scratch\</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/_scratch/ + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Statements</span> + <span class='fraction'>0/0</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'>0/0</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="_testimport.ts"><a href="_testimport.ts.html">_testimport.ts</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="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="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> + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/ItsLayerCollection.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/ItsLayerCollection.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..ff2336e5ad0d0097200d729843401c1a37044ede --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/ItsLayerCollection.ts.html @@ -0,0 +1,563 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\collections\ItsLayerCollection.ts</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/collections/</a> ItsLayerCollection.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">44.44% </span> + <span class="quiet">Statements</span> + <span class='fraction'>12/27</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">50% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/4</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">42.31% </span> + <span class="quiet">Lines</span> + <span class='fraction'>11/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</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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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> +<span class="cline-any cline-yes">1×</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">/** + * Created by gavorhes on 12/14/2015. + */ + +import * as colors from '../util/colors'; +import provide from '../util/provide'; +import ol = require('custom-ol'); +import LayerItsInventory from "../layers/LayerItsInventory"; +let nm = provide('collections'); + + +let itsConfig = [ + { + name: 'Camera', + itsType: 'cctv', + minZoom: 11, + itsIconConfig: { + prop: 'owner', + defaultName: 'WisDOT', + defaultIcon: 'cctv.png', + iconArray: [ + ['City of Madison', 'Madison', 'cctv-mad.png'] + ] + } + }, + { + name: 'Message Signs', + itsType: 'DMS', + minZoom: 11, + itsIconConfig: { + prop: 'dmsType', + defaultName: 'DMS', + defaultIcon: 'dms.png', + iconArray: [ + ['pcms', 'PCMS', 'pcms.png'] + ] + } + }, + {name: 'ATR', itsType: 'atr', minZoom: 8, itsIcon: 'atr.png', visible: false}, + {name: 'Lighting', itsType: 'light', minZoom: 16, itsIcon: 'streetlight.png', visible: false, onDemand: true}, + {name: 'Bluetooth', itsType: 'blue', minZoom: 10, itsIcon: 'bluetooth.png', visible: false}, + {name: 'Cabinets', itsType: 'cabinet', minZoom: 10, itsIcon: 'cabinet.png', visible: false}, + {name: 'Hut', itsType: 'hut', minZoom: 10, itsIcon: 'hut.png', visible: false}, + {name: 'Vault', itsType: 'vault', minZoom: 13, itsIcon: 'vault.png', visible: false}, + {name: 'Advisory Radio', itsType: 'har', minZoom: 10, itsIcon: 'har.png', visible: false}, + { + name: 'Loop Detectors', + itsType: 'loop', + legendCollapse: true, + minZoom: 14, + visible: false, + itsIconConfig: { + prop: 'dtctrType', + defaultName: 'Other', + defaultIcon: 'loopdetectorother.png', + iconArray: [ + ['detector', 'Detector', 'loopdetector.png'], + ['long', 'Long', 'loopdetectorlong.png'], + ['zone', 'Zone', 'loopdetectorzone.png'] + ] + }, + onDemand: true + }, + {name: 'Microwave', itsType: 'microwave', minZoom: 14, itsIcon: 'microwave.png', visible: false}, + {name: 'Pull Box', itsType: 'pull', minZoom: 14, itsIcon: 'pullbox.png', visible: false, onDemand: true}, + {name: 'RWIS', itsType: 'rwis', minZoom: 7, itsIcon: 'rwis.png', visible: false}, + {name: 'Ramp Gates', itsType: 'gate', minZoom: 10, itsIcon: 'rampgate.png', visible: false}, + {name: 'Ramp Meter', itsType: 'meter', minZoom: 10, itsIcon: 'rampmeter.png', visible: false}, + {name: 'Signal', itsType: 'signal', minZoom: 13, itsIcon: 'signal.png', visible: false, onDemand: true}, + {name: 'Tower', itsType: 'tower', minZoom: 10, itsIcon: 'tower.png', visible: false}, + { + name: 'Trench', + itsType: 'trench', + onDemand: true, + visible: false, + onDemandDelay: 500, + minZoom: 15, + legendCollapse: true, + itsLineConfig: { + prop: 'owner', + //defaultName: 'Other', + //defaultWidth: 7, + defaultColor: colors.hexAlphaToRgbOrRgba('#747474', 0.8), + lineArray: [ + ['WisDOT', 'WisDOT', colors.hexAlphaToRgbOrRgba('#FF032F', 0.7)], + ['WIN', 'WIN', colors.hexAlphaToRgbOrRgba('#FFC632', 0.7)], + ['USXchange', 'USXchange', colors.hexAlphaToRgbOrRgba('#2DFF46', 0.7)], + ['AT&T', 'AT&T', colors.hexAlphaToRgbOrRgba('#ff2be5', 0.7)], + ['Touch America', 'Touch America', colors.hexAlphaToRgbOrRgba('#52f3ff', 0.7)], + ['Qwest', 'Qwest', colors.hexAlphaToRgbOrRgba('#9278ff', 0.7)], + ['McLeodUSA', 'McLeodUSA', colors.hexAlphaToRgbOrRgba('#2926FF', 0.7)], + ['CINC', 'CINC', colors.hexAlphaToRgbOrRgba('#CB00FF', 0.7)], + ['City of Madison', 'Madison', colors.hexAlphaToRgbOrRgba('#000380', 0.7)] + ] + } + } + + +]; + + +export class ItsLayerCollection { + _map: ol.Map; + _layers: Array<LayerItsInventory>; + + + /** + * Create a collection of all ITS layers + * @param {ol.Map} theMap the openlayers map + * @param {Array} [exclude=[]] array of Its layer identifiers to exclude + * + * BLUE Bluetooth Detector - Bluetooth Detector + * CABINET Cabinets - The cabinets + * CCTV Camera - Traffic Cameras + * HUT Communication Hut - Communication Hut + * VAULT Communication Vault - The communication vaults + * HAR Highway Advisory Radio - Advisory Radios + * LIGHT Lighting - Lighting + * LOOP Loop Detectors - Loop Detectors + * DMS Message Board - Message Boards and Signs + * MICROWAVE Microwave Detector - Microwave Detectors + * PULL Pull Box - A pull box + * RWIS RWIS - Road weather information system + * GATE Ramp Gate - The ramp Gates + * METER Ramp Meter - The ramp meters + * SIGNAL Signal - Traffic Signal + * TOWER Tower - The towers + * TRENCH + */ +<span class="fstat-no" title="function not covered" > constructor(theMap: ol.Map, exclude?: Array<string>)</span> { + +<span class="cstat-no" title="statement not covered" > this._map = theMap;</span> +<span class="cstat-no" title="statement not covered" > this._layers = [];</span> + +<span class="cstat-no" title="statement not covered" > exclude = typeof exclude == 'object' ? exclude : [];</span> + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < itsConfig.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let lyrConfig = itsConfig[i];</span> +<span class="cstat-no" title="statement not covered" > let addLayer = true;</span> + +<span class="cstat-no" title="statement not covered" > for (let j = 0; j < exclude.length; j++) {</span> +<span class="cstat-no" title="statement not covered" > if (exclude[j] == lyrConfig.itsType) {</span> +<span class="cstat-no" title="statement not covered" > addLayer = false;</span> +<span class="cstat-no" title="statement not covered" > break;</span> + } + } + +<span class="cstat-no" title="statement not covered" > if (addLayer) {</span> +<span class="cstat-no" title="statement not covered" > let inventLyr = new LayerItsInventory(lyrConfig);</span> +<span class="cstat-no" title="statement not covered" > this._map.addLayer(inventLyr.olLayer);</span> +<span class="cstat-no" title="statement not covered" > this._layers.push(inventLyr);</span> + } + } + } + + /** + * Return the array of layers in this collection + * @returns {Array<LayerItsInventory>} an array of layers + */ +<span class="fstat-no" title="function not covered" > get layers() {</span> +<span class="cstat-no" title="statement not covered" > return this._layers;</span> + } +} + +nm.ItsLayerCollection = ItsLayerCollection; +export default ItsLayerCollection; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/LayerLegend.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/LayerLegend.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..7ca9f1a408c21a16733ca0226d834512e38688e4 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/LayerLegend.ts.html @@ -0,0 +1,1145 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\collections\LayerLegend.ts</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/collections/</a> LayerLegend.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">11.46% </span> + <span class="quiet">Statements</span> + <span class='fraction'>18/157</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/60</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">20% </span> + <span class="quiet">Functions</span> + <span class='fraction'>3/15</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">11.69% </span> + <span class="quiet">Lines</span> + <span class='fraction'>18/154</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</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-yes">1×</span> +<span class="cline-any 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> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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">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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-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-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-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-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-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/16/2015. + */ + +import provide from '../util/provide'; +import makeGuid from '../util/makeGuid'; +import mapMove from '../olHelpers/mapMove'; + +let nm = provide('collections'); +import $ = require('jquery'); + +class LayerGroup { + groupLayers: any; + groupLayersLookup: any; + groupGroupsLookup: any; + groupGroups: any; + itemIdArray: any; + groupId: any; + groupName: any; + allLayerArray: any; + parent: any; + allGroupArray: any; + allGroupLookup: any; + allLayerLookup: any; + collapse: any; + addCheck: any; + layerParentLookup: any; + + /** + * + * @param {object} [groupConfig={}] - group configuration object + * @param {string} groupConfig.groupName - the group name + * @param {boolean} [groupConfig.collapse=false] - if the group should be collapsed initially + * @param {boolean} [groupConfig.addCheck=true] - if the group should have a checkbox controlling visibility of all layers + * @param {LayerGroup} [parent=undefined] - the parent group + */ +<span class="fstat-no" title="function not covered" > constructor(groupConfig?, parent?)</span> { +<span class="cstat-no" title="statement not covered" > this.groupLayers = [];</span> +<span class="cstat-no" title="statement not covered" > this.groupLayersLookup = {};</span> +<span class="cstat-no" title="statement not covered" > this.groupGroups = [];</span> +<span class="cstat-no" title="statement not covered" > this.groupGroupsLookup = {};</span> +<span class="cstat-no" title="statement not covered" > this.itemIdArray = [];</span> + +<span class="cstat-no" title="statement not covered" > if (typeof groupConfig == 'undefined') {</span> +<span class="cstat-no" title="statement not covered" > this.parent = null;</span> +<span class="cstat-no" title="statement not covered" > this.groupId = 'root';</span> +<span class="cstat-no" title="statement not covered" > this.groupName = 'root';</span> +<span class="cstat-no" title="statement not covered" > this.allGroupLookup = {root: this};</span> +<span class="cstat-no" title="statement not covered" > this.allGroupArray = [this];</span> +<span class="cstat-no" title="statement not covered" > this.allLayerArray = [];</span> +<span class="cstat-no" title="statement not covered" > this.allLayerLookup = {};</span> +<span class="cstat-no" title="statement not covered" > this.layerParentLookup = {};</span> +<span class="cstat-no" title="statement not covered" > this.collapse = false;</span> +<span class="cstat-no" title="statement not covered" > this.addCheck = false;</span> + } else { +<span class="cstat-no" title="statement not covered" > this.groupId = makeGuid();</span> +<span class="cstat-no" title="statement not covered" > this.parent = parent;</span> +<span class="cstat-no" title="statement not covered" > this.groupName = groupConfig.groupName;</span> +<span class="cstat-no" title="statement not covered" > this.collapse = typeof groupConfig.collapse == 'boolean' ? groupConfig.collapse : false;</span> +<span class="cstat-no" title="statement not covered" > this.addCheck = typeof groupConfig.addCheck == 'boolean' ? groupConfig.addCheck : true;</span> + } + } + + /** + * + * @param {object} groupConfig - configuration object + * @param {string} groupConfig.groupName - the group name + * @param {boolean} groupConfig.collapse if the group should be collapsed initially + * @param {boolean} groupConfig.addCheck if the group should have a checkbox controlling visibility of all layers + * @param {Array<LayerGroup>} parents parent groups + * @returns {LayerGroup} the layer group just added + */ +<span class="fstat-no" title="function not covered" > addGroup(groupConfig, parents)</span> { +<span class="cstat-no" title="statement not covered" > let parent;</span> +<span class="cstat-no" title="statement not covered" > if (parents.length > 0) {</span> +<span class="cstat-no" title="statement not covered" > parent = parents[parents.length - 1];</span> + } else { +<span class="cstat-no" title="statement not covered" > parent = 'root';</span> + } + + + /** + * @type {LayerGroup} + */ +<span class="cstat-no" title="statement not covered" > let parentGroup = this.allGroupLookup[parent];</span> +<span class="cstat-no" title="statement not covered" > let newGroup = new LayerGroup(groupConfig, parentGroup);</span> +<span class="cstat-no" title="statement not covered" > this.allGroupLookup[newGroup.groupId] = newGroup;</span> +<span class="cstat-no" title="statement not covered" > this.allGroupArray.push(newGroup);</span> + +<span class="cstat-no" title="statement not covered" > parentGroup.groupGroups.push(newGroup);</span> +<span class="cstat-no" title="statement not covered" > parentGroup.groupGroupsLookup[newGroup.groupId] = newGroup;</span> + +<span class="cstat-no" title="statement not covered" > if (parentGroup.itemIdArray.indexOf(newGroup.groupId) > 0) {</span> +<span class="cstat-no" title="statement not covered" > console.log(newGroup.groupId);</span> +<span class="cstat-no" title="statement not covered" > throw 'layer and group ids must be unique';</span> + } +<span class="cstat-no" title="statement not covered" > parentGroup.itemIdArray.push(newGroup.groupId);</span> + +<span class="cstat-no" title="statement not covered" > return newGroup;</span> + } + + /** + * + * @param {LayerBase} newLayer the layer to be added + * @param {Array} parents array + */ +<span class="fstat-no" title="function not covered" > addLegendLayer(newLayer, parents)</span> { +<span class="cstat-no" title="statement not covered" > let parent;</span> +<span class="cstat-no" title="statement not covered" > if (parents.length > 0) {</span> +<span class="cstat-no" title="statement not covered" > parent = parents[parents.length - 1];</span> + } else { +<span class="cstat-no" title="statement not covered" > parent = 'root';</span> + } + +<span class="cstat-no" title="statement not covered" > this.allLayerLookup[newLayer.id] = newLayer;</span> +<span class="cstat-no" title="statement not covered" > this.allLayerArray.push(newLayer);</span> + + /** + * @type {LayerGroup} + */ +<span class="cstat-no" title="statement not covered" > let parentGroup = this.allGroupLookup[parent];</span> + +<span class="cstat-no" title="statement not covered" > parentGroup.groupLayers.push(newLayer);</span> +<span class="cstat-no" title="statement not covered" > parentGroup.groupLayersLookup[newLayer.id] = newLayer;</span> +<span class="cstat-no" title="statement not covered" > if (parentGroup.itemIdArray.indexOf(newLayer.id) > 0) {</span> +<span class="cstat-no" title="statement not covered" > console.log(newLayer.id);</span> +<span class="cstat-no" title="statement not covered" > throw 'layer and group ids must be unique';</span> + } +<span class="cstat-no" title="statement not covered" > parentGroup.itemIdArray.push(newLayer.id);</span> + +<span class="cstat-no" title="statement not covered" > this.layerParentLookup[newLayer.id] = parentGroup;</span> + + } + +<span class="fstat-no" title="function not covered" > getLegendHtml(legendId, options)</span> { + + +<span class="cstat-no" title="statement not covered" > let legendHtml = `<ul id="${legendId}" class="legend-container">`;</span> + +<span class="cstat-no" title="statement not covered" > legendHtml += `<li>${options.legendTitle}<input type="checkbox" checked id="suppress-by-extent-${legendId}" class="suppress-by-extent">` +</span> + `<label title="Suppress layers not visible at this zoom level" for="suppress-by-extent-${legendId}">` + + `<span></span>` + + `</label></li>`; + +<span class="cstat-no" title="statement not covered" > legendHtml += this._buildLegend(this.itemIdArray, this, options.layerDivClasses) + '</ul>';</span> + +<span class="cstat-no" title="statement not covered" > return legendHtml;</span> + } + + /** + * @param {Array} itemIds the items to process + * @param {LayerGroup} theGroup new group + * @param {Array} [layerDivClasses=[]] optional classes to apply to the layer divs + * @static + * @returns {string} html string + */ +<span class="fstat-no" title="function not covered" > _buildLegend(itemIds, theGroup, layerDivClasses)</span> { + +<span class="cstat-no" title="statement not covered" > if (itemIds.length == 0) {</span> +<span class="cstat-no" title="statement not covered" > return '';</span> + } + +<span class="cstat-no" title="statement not covered" > let theHml = '';</span> + +<span class="cstat-no" title="statement not covered" > let itemId = itemIds[0];</span> + +<span class="cstat-no" title="statement not covered" > if (theGroup.groupLayersLookup[itemId]) {</span> + + /** + * @type {LayerBase} + */ +<span class="cstat-no" title="statement not covered" > let lyr = theGroup.groupLayersLookup[itemId];</span> +<span class="cstat-no" title="statement not covered" > theHml += `<li id="${lyr.id}-layer-li" class="legend-layer-li ${layerDivClasses.join(' ')}">` + lyr.getLegendDiv() + '</li>';</span> + + + } else <span class="cstat-no" title="statement not covered" >if (theGroup.groupGroupsLookup[itemId]) {</span> + /** + * type {LayerGroup} + */ +<span class="cstat-no" title="statement not covered" > let otherGroup = theGroup.groupGroupsLookup[itemId];</span> + +<span class="cstat-no" title="statement not covered" > theHml += `<li>`;</span> +<span class="cstat-no" title="statement not covered" > theHml += `<div id="${otherGroup.groupId}-legend-layer-div" ` +</span> + `class="legend-layer-group ${layerDivClasses.join(' ')}">`; + +<span class="cstat-no" title="statement not covered" > if (otherGroup.addCheck) {</span> +<span class="cstat-no" title="statement not covered" > theHml += `<input type="checkbox" checked id="${otherGroup.groupId}-group-chck">` +</span> + `<label for="${otherGroup.groupId}-group-chck" title="Click arrow to expand or collapse">${otherGroup.groupName}</label>`; + } else { +<span class="cstat-no" title="statement not covered" > theHml += `<label title="Click arrow to expand or collapse">${otherGroup.groupName}</label>`;</span> + } + +<span class="cstat-no" title="statement not covered" > theHml += `<span title="Expand/Collapse" class="layer-group-expander`;</span> +<span class="cstat-no" title="statement not covered" > theHml += `${otherGroup.collapse ? ' legend-layer-group-initial-collapse' : ''}">`;</span> +<span class="cstat-no" title="statement not covered" > theHml += otherGroup.collapse ? '&#9654;' : '&#9660;';</span> +<span class="cstat-no" title="statement not covered" > theHml += '</span>';</span> + + //parents.push(groupId); +<span class="cstat-no" title="statement not covered" > theHml += '<ul>' + this._buildLegend(otherGroup.itemIdArray, otherGroup, layerDivClasses) + '</ul>';</span> +<span class="cstat-no" title="statement not covered" > theHml += '</div>';</span> +<span class="cstat-no" title="statement not covered" > theHml += '</li>';</span> + } + +<span class="cstat-no" title="statement not covered" > return theHml + this._buildLegend(itemIds.slice(1), theGroup, layerDivClasses);</span> + } +} + +/** + * a wrapper to make a legend + */ +class LayerLegend { + + $divElement: any; + _legendItems: any; + layerGroup: any; + legendId: any; + + /** + * + * @param {Array} legendItems array of layers or objects with {groupName: {string}, collapse: {boolean}, addCheck: {boolean}, items: {Array}} + * @param {string} divId the div where the legend should be added + * @param {object} options for legend + * @param {Array} [options.layerDivClasses=[]] optional array of classes to be applied to the layer legend divs for custom styling + * @param {string} [options.legendTitle=Legend] the legend title + * @param {boolean} [options.scaleDependent=true] if legend display is scale dependent + */ +<span class="fstat-no" title="function not covered" > constructor(legendItems, divId, options)</span> { +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let i </span>of legendItems) {</span> +<span class="cstat-no" title="statement not covered" > if (typeof i == 'undefined') {</span> +<span class="cstat-no" title="statement not covered" > throw 'undefined item passed in array to legend constructor';</span> + } + } + +<span class="cstat-no" title="statement not covered" > options = options || {};</span> + +<span class="cstat-no" title="statement not covered" > options.legendTitle = typeof options.legendTitle == 'string' ? options.legendTitle : 'Legend';</span> +<span class="cstat-no" title="statement not covered" > options.scaleDependent = typeof options.scaleDependent == 'boolean' ? options.scaleDependent : true;</span> +<span class="cstat-no" title="statement not covered" > options.layerDivClasses = options.layerDivClasses || [];</span> + + // if legend display is scale dependent, make sure the mapMove object is initialized first +<span class="cstat-no" title="statement not covered" > if (options.scaleDependent) {</span> +<span class="cstat-no" title="statement not covered" > mapMove.checkInit();</span> + } + +<span class="cstat-no" title="statement not covered" > this.$divElement = $('#' + divId);</span> + +<span class="cstat-no" title="statement not covered" > this._legendItems = legendItems;</span> + +<span class="cstat-no" title="statement not covered" > this.layerGroup = new LayerGroup();</span> + +<span class="cstat-no" title="statement not covered" > this._buildTree(legendItems);</span> + +<span class="cstat-no" title="statement not covered" > this.legendId = makeGuid();</span> + +<span class="cstat-no" title="statement not covered" > this.$divElement.append(this.layerGroup.getLegendHtml(this.legendId, options));</span> + +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let l </span>of this.layerGroup.allLayerArray){</span> +<span class="cstat-no" title="statement not covered" > l.applyCollapse();</span> + } + +<span class="cstat-no" title="statement not covered" > let _this = this;</span> + //// if legend display is scale dependent, make sure the mapMove object is initialized first +<span class="cstat-no" title="statement not covered" > if (options.scaleDependent) {</span> +<span class="cstat-no" title="statement not covered" > mapMove.checkInit();</span> + +<span class="cstat-no" title="statement not covered" > mapMove.addCallback(<span class="fstat-no" title="function not covered" >function (ext, zoom, evt)</span> {</span> + +<span class="cstat-no" title="statement not covered" > if (typeof evt == 'undefined' || evt == 'change:resolution') {</span> +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let lyr </span>of this.layerGroup.allLayerArray) {</span> +<span class="cstat-no" title="statement not covered" > let $lyrLi = $('#' + lyr.id + '-layer-li');</span> +<span class="cstat-no" title="statement not covered" > if (zoom > lyr.maxZoom || zoom < lyr.minZoom) {</span> +<span class="cstat-no" title="statement not covered" > $lyrLi.addClass('layer-not-visible');</span> + } else { +<span class="cstat-no" title="statement not covered" > $lyrLi.removeClass('layer-not-visible');</span> + } + } + } + }, this, 100, true, 'legend1'); + } + + // <editor-fold desc="add event listeners"> + +<span class="cstat-no" title="statement not covered" > this.$divElement.find(".suppress-by-extent").change(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > let legendLayerLis = $('.legend-layer-li');</span> +<span class="cstat-no" title="statement not covered" > if (this.checked) {</span> +<span class="cstat-no" title="statement not covered" > legendLayerLis.removeClass('layer-force-show');</span> + } else { +<span class="cstat-no" title="statement not covered" > legendLayerLis.addClass('layer-force-show');</span> + } + }); + + +<span class="cstat-no" title="statement not covered" > this.$divElement.find('.legend-check').change(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > let lyrId = this.id.replace('-legend-layer-check', '');</span> +<span class="cstat-no" title="statement not covered" > _this.layerGroup.allLayerLookup[lyrId].visible = this.checked;</span> + }); + +<span class="cstat-no" title="statement not covered" > this.$divElement.find('.legend-layer-group > input[type=checkbox]').change(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > $(this).siblings('ul').find('input[type=checkbox]').prop('checked', this.checked).trigger('change');</span> + }); + +<span class="cstat-no" title="statement not covered" > this.$divElement.find('.layer-group-expander').click(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > let $this = $(this);</span> +<span class="cstat-no" title="statement not covered" > $this.removeClass('legend-layer-group-initial-collapse');</span> + +<span class="cstat-no" title="statement not covered" > $this.siblings('ul').slideToggle();</span> + +<span class="cstat-no" title="statement not covered" > if ($this.hasClass('legend-layer-group-collapsed')){</span> +<span class="cstat-no" title="statement not covered" > $this.removeClass('legend-layer-group-collapsed');</span> +<span class="cstat-no" title="statement not covered" > $this.html('&#9660;');</span> + } else { +<span class="cstat-no" title="statement not covered" > $this.addClass('legend-layer-group-collapsed');</span> +<span class="cstat-no" title="statement not covered" > $this.html('&#9654;');</span> + } + }); + +<span class="cstat-no" title="statement not covered" > this.$divElement.find('.legend-layer-group-initial-collapse').trigger('click');</span> + // </editor-fold> + } + + + /** + * @param {Array} [legendItems=this._layerConfig] the legend items + * @param {Array} [parents=[]] the ordered list of groups in which this item is a member + * @private + */ +<span class="fstat-no" title="function not covered" > _buildTree(legendItems, parents?)</span> { + +<span class="cstat-no" title="statement not covered" > if (legendItems.length == 0) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > let oneItem = legendItems[0];</span> + + //reset the parent if the item is in the base array +<span class="cstat-no" title="statement not covered" > if (this._legendItems.indexOf(oneItem) > -1 || typeof parents == 'undefined') {</span> +<span class="cstat-no" title="statement not covered" > parents = [];</span> + } + +<span class="cstat-no" title="statement not covered" > if (typeof oneItem['groupName'] !== 'undefined') {</span> +<span class="cstat-no" title="statement not covered" > let groupItem = legendItems[0];</span> +<span class="cstat-no" title="statement not covered" > let newGroup = this.layerGroup.addGroup(groupItem, parents);</span> +<span class="cstat-no" title="statement not covered" > parents.push(newGroup.groupId);</span> +<span class="cstat-no" title="statement not covered" > this._buildTree(groupItem.items, parents);</span> + } else { + /** + * @type {LayerBase} + */ +<span class="cstat-no" title="statement not covered" > let layerItem = legendItems[0];</span> + +<span class="cstat-no" title="statement not covered" > this.layerGroup.addLegendLayer(layerItem, parents);</span> + } + +<span class="cstat-no" title="statement not covered" > this._buildTree(legendItems.slice(1), parents);</span> + } + +} + +nm.LayerLegend = LayerLegend; +export default LayerLegend; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/Sliders.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/Sliders.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..ac1e8b44911f35993ed02e5670599b66cf991a8a --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/Sliders.ts.html @@ -0,0 +1,2024 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\collections\Sliders.ts</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/collections/</a> Sliders.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">11.07% </span> + <span class="quiet">Statements</span> + <span class='fraction'>33/298</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/68</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">11.11% </span> + <span class="quiet">Functions</span> + <span class='fraction'>4/36</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">10.81% </span> + <span class="quiet">Lines</span> + <span class='fraction'>32/296</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 +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</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-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-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-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-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">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-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-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="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-neutral"> </span> +<span class="cline-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-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-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-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-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-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-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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-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-neutral"> </span> +<span class="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-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-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-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-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-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-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-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/10/2015. + */ + +import provide from '../util/provide'; +import $ = require('jquery'); + +let nm = provide('collections'); + +export interface TipSliderConfig { + label: string; + yearOptions: Array<{column: string, label: string}> +} + +export interface TipPresetConfig { + label: string; + presets: Array<{column: string, value: number}> +} + +export interface ChangeResponse{ + paramWeights: Object; + region: string; + mmVersion: string; +} + +export interface ChangeCallback{ + (chg: ChangeResponse): any +} + + +class TipPresets implements TipPresetConfig { + label: string; + presets: Array<{column: string, value: number}>; + domId: string; + +<span class="fstat-no" title="function not covered" > constructor(conf: TipPresetConfig)</span> { +<span class="cstat-no" title="statement not covered" > this.label = conf.label;</span> +<span class="cstat-no" title="statement not covered" > this.presets = conf.presets;</span> +<span class="cstat-no" title="statement not covered" > this.domId = this.label.replace(/ /g, '').toLowerCase();</span> + +<span class="cstat-no" title="statement not covered" > let theSum = 0;</span> + +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let pr </span>of this.presets){</span> +<span class="cstat-no" title="statement not covered" > theSum += pr.value;</span> + } + +<span class="cstat-no" title="statement not covered" > if (theSum != 100){</span> +<span class="cstat-no" title="statement not covered" > throw 'preset sum does note equal 100';</span> + } + } +} + + +class _Slider { + _min: number; + _max: number; + _locked: boolean; + atMin: boolean; + atMax: boolean; + _weightDefault: number; + _weight: number; + html: string; + domId: string; + name: string; + + labelLow: JQuery; + labelHigh: JQuery; + labelVal: JQuery; + slider: JQuery; + selectionBox: JQuery; + chk: JQuery; + + selectedParam: any; + selectedParamDefault: any; + _dropdownSelection: string; + + /** + * Slider constructor + * @param sliderConfig - the configuration + + */ +<span class="fstat-no" title="function not covered" > constructor(sliderConfig: TipSliderConfig)</span> { +<span class="cstat-no" title="statement not covered" > this._dropdownSelection = null;</span> +<span class="cstat-no" title="statement not covered" > this._weight = null;</span> +<span class="cstat-no" title="statement not covered" > this.name = sliderConfig.label;</span> +<span class="cstat-no" title="statement not covered" > this.domId = this.name.toLowerCase().replace(/ /g, '-');</span> + +<span class="cstat-no" title="statement not covered" > this._locked = false;</span> + +<span class="cstat-no" title="statement not covered" > this._min = 0.0;</span> +<span class="cstat-no" title="statement not covered" > this._max = 100;</span> + +<span class="cstat-no" title="statement not covered" > this.labelLow = null;</span> +<span class="cstat-no" title="statement not covered" > this.labelHigh = null;</span> +<span class="cstat-no" title="statement not covered" > this.labelVal = null;</span> +<span class="cstat-no" title="statement not covered" > this.slider = null;</span> +<span class="cstat-no" title="statement not covered" > this.chk = null;</span> + +<span class="cstat-no" title="statement not covered" > this.atMin = false;</span> +<span class="cstat-no" title="statement not covered" > this.atMax = false;</span> + + +<span class="cstat-no" title="statement not covered" > let sel = `<select class="${sliderConfig.yearOptions.length == 1 ? 'hidden-select' : 'show-select'}" id="${this.domId}_chg">`;</span> + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < sliderConfig.yearOptions.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let itm = sliderConfig.yearOptions[i];</span> +<span class="cstat-no" title="statement not covered" > sel += `<option value="${itm.column}">${itm.label}</option>`;</span> + } +<span class="cstat-no" title="statement not covered" > sel += '</select>';</span> + +<span class="cstat-no" title="statement not covered" > this.selectedParamDefault = this.selectedParam;</span> + +<span class="cstat-no" title="statement not covered" > this.html = '<div class="slider-div">' +</span> + `<label for="${this.domId}_chk" class="slider-label">${this.name}</label>` + + sel + `<br>` + + `<input id="${this.domId}_chk" type="checkbox" title="Lock/Unlock Slider">` + + `<label id="${this.domId}_low" class="low-high"></label>` + + `<input id="${this.domId}" type="range" value="50" min="0" max="100" step="0.1">` + + `<label id="${this.domId}_high" class="low-high"></label>` + + `<label id="${this.domId}_lbl" for="${this.domId}" class="percent-label"></label></div>`; + } + + /** + * add html to dom + * @param {jQuery} $container - container element + */ +<span class="fstat-no" title="function not covered" > addToDom($container)</span> { +<span class="cstat-no" title="statement not covered" > $container.append(this.html);</span> +<span class="cstat-no" title="statement not covered" > this.labelLow = $(`#${this.domId}_low`);</span> +<span class="cstat-no" title="statement not covered" > this.labelHigh = $(`#${this.domId}_high`);</span> +<span class="cstat-no" title="statement not covered" > this.labelVal = $(`#${this.domId}_lbl`);</span> +<span class="cstat-no" title="statement not covered" > this.slider = $(`#${this.domId}`);</span> +<span class="cstat-no" title="statement not covered" > this.selectionBox = $(`#${this.domId}_chg`);</span> +<span class="cstat-no" title="statement not covered" > this.chk = $(`#${this.domId}_chk`);</span> + } + + /** + * increment the slider + * @param {number} delta change delta + * @returns {number} the remainder not able to be allocated to this slider + */ +<span class="fstat-no" title="function not covered" > increment(delta)</span> { +<span class="cstat-no" title="statement not covered" > let remainder = 0;</span> +<span class="cstat-no" title="statement not covered" > delta = Number(delta.toFixed(1));</span> + +<span class="cstat-no" title="statement not covered" > this._weight += delta;</span> +<span class="cstat-no" title="statement not covered" > if (this._weight < this._min) {</span> +<span class="cstat-no" title="statement not covered" > remainder = this._min - this._weight;</span> +<span class="cstat-no" title="statement not covered" > this._weight = this._min;</span> +<span class="cstat-no" title="statement not covered" > this.atMin = true;</span> + } else <span class="cstat-no" title="statement not covered" >if (this._weight > this._max) {</span> +<span class="cstat-no" title="statement not covered" > remainder = this._max - this._weight;</span> +<span class="cstat-no" title="statement not covered" > this._weight = this._max;</span> +<span class="cstat-no" title="statement not covered" > this.atMax = true;</span> + } else { +<span class="cstat-no" title="statement not covered" > this.atMin = false;</span> +<span class="cstat-no" title="statement not covered" > this.atMax = false;</span> + } + +<span class="cstat-no" title="statement not covered" > this.slider.val(this._weight.toFixed(1));</span> +<span class="cstat-no" title="statement not covered" > this.labelVal.html(this._weight.toFixed(1) + '%');</span> + +<span class="cstat-no" title="statement not covered" > return remainder;</span> + } + + /** + * set the value and drop down + * @param {number} newVal the new value + * @param {string} selectedParam the selected parameter + */ +<span class="fstat-no" title="function not covered" > setValAndDropDown(newVal: number, selectedParam: string)</span> { +<span class="cstat-no" title="statement not covered" > this.min = 0;</span> +<span class="cstat-no" title="statement not covered" > this.max = 100;</span> +<span class="cstat-no" title="statement not covered" > this.weight = newVal;</span> +<span class="cstat-no" title="statement not covered" > this.slider.val(newVal.toFixed(1));</span> +<span class="cstat-no" title="statement not covered" > this.selectionBox.val(selectedParam);</span> +<span class="cstat-no" title="statement not covered" > this.selectedParam = selectedParam;</span> +<span class="cstat-no" title="statement not covered" > this.locked = true;</span> + } + + /** + * + * @returns {boolean} if locked + */ +<span class="fstat-no" title="function not covered" > get locked() {</span> +<span class="cstat-no" title="statement not covered" > return this._locked;</span> + } + + /** + * + * @param {boolean} val if locked + */ +<span class="fstat-no" title="function not covered" > set locked(val)</span> { +<span class="cstat-no" title="statement not covered" > this._locked = val;</span> +<span class="cstat-no" title="statement not covered" > this.slider.prop('disabled', this._locked);</span> +<span class="cstat-no" title="statement not covered" > this.selectionBox.prop('disabled', this._locked);</span> +<span class="cstat-no" title="statement not covered" > this.chk.prop('checked', !this._locked);</span> + } + + /** + * + * @returns {number} the minimum + */ +<span class="fstat-no" title="function not covered" > get min() {</span> +<span class="cstat-no" title="statement not covered" > return this._min;</span> + } + + /** + * + * @param {number} newVal new minimum + */ +<span class="fstat-no" title="function not covered" > set min(newVal)</span> { +<span class="cstat-no" title="statement not covered" > this._min = Number(newVal.toFixed(1));</span> +<span class="cstat-no" title="statement not covered" > if (this._min < 0) {</span> +<span class="cstat-no" title="statement not covered" > this._min = 0;</span> + } +<span class="cstat-no" title="statement not covered" > this.labelLow.html(this._min.toFixed(1));</span> +<span class="cstat-no" title="statement not covered" > this.slider.attr('min', this._min.toFixed(1));</span> +<span class="cstat-no" title="statement not covered" > this.atMin = this._weight == this._min;</span> + } + + /** + * + * @returns {number} the maximum + */ +<span class="fstat-no" title="function not covered" > get max() {</span> +<span class="cstat-no" title="statement not covered" > return this._max;</span> + } + + /** + * + * @param {number} newVal the maximum + */ +<span class="fstat-no" title="function not covered" > set max(newVal)</span> { +<span class="cstat-no" title="statement not covered" > this._max = Number(newVal.toFixed(1));</span> +<span class="cstat-no" title="statement not covered" > if (this._max > 100) {</span> +<span class="cstat-no" title="statement not covered" > this._max = 100.0;</span> + } +<span class="cstat-no" title="statement not covered" > this.labelHigh.html(this._max.toFixed(1));</span> +<span class="cstat-no" title="statement not covered" > this.slider.attr('max', this._max.toFixed(1));</span> +<span class="cstat-no" title="statement not covered" > this.atMax = this._weight == this._max;</span> + } + + /** + * + * @returns {number} the weight + */ +<span class="fstat-no" title="function not covered" > get weight() {</span> +<span class="cstat-no" title="statement not covered" > return this._weight;</span> + } + + /** + * + * @param {number} newVal the weight + */ +<span class="fstat-no" title="function not covered" > set weight(newVal)</span> { +<span class="cstat-no" title="statement not covered" > this._weight = Number(newVal.toFixed(1));</span> +<span class="cstat-no" title="statement not covered" > this.labelVal.html(this._weight.toFixed(1) + '%');</span> +<span class="cstat-no" title="statement not covered" > if (this._weight <= this._min) {</span> +<span class="cstat-no" title="statement not covered" > this.atMin = true;</span> +<span class="cstat-no" title="statement not covered" > this.atMax = false;</span> + } else <span class="cstat-no" title="statement not covered" >if (this._weight >= this._max) {</span> +<span class="cstat-no" title="statement not covered" > this.atMin = false;</span> +<span class="cstat-no" title="statement not covered" > this.atMax = true;</span> + } else { +<span class="cstat-no" title="statement not covered" > this.atMin = false;</span> +<span class="cstat-no" title="statement not covered" > this.atMax = false;</span> + } + } +} + +nm._Slider = _Slider; + + +/** + * class to keep track of the sliders + */ +export class TipSliders { + $container: JQuery; + reservedPercent: number; + lockedCount: number; + notLockedCount: number; + private _sliderList: Array<_Slider>; + private _sliderLookup: {[s: string]: _Slider}; + private resetting: boolean; + private _changedCallback: ChangeCallback; + + private _lockedList: Array<_Slider>; + private _inRangeList: Array<_Slider>; + private _atMinList: Array<_Slider>; + private _atMaxList: Array<_Slider>; + + private _presetArray: Array<TipPresets>; + private _presetLookup: {[s: string]: TipPresets}; + + private _$presetSelector: JQuery; + private _$regionSelector: JQuery; + private _$versionSelector: JQuery; + + /** + * + * @param sliderConfigs + * @param presetConfig + * @param divId + * @param presetSelector + * @param regionSelector + * @param versionSelector + * @param chgCallback + */ +<span class="fstat-no" title="function not covered" > constructor(sliderConfigs: Array<TipSliderConfig>, presetConfig: Array<TipPresetConfig>,</span> + divId: string, presetSelector: JQuery, regionSelector: JQuery, versionSelector: JQuery, + chgCallback?: ChangeCallback) { + +<span class="cstat-no" title="statement not covered" > this.resetting = false;</span> +<span class="cstat-no" title="statement not covered" > this.reservedPercent = 0.0;</span> +<span class="cstat-no" title="statement not covered" > this.$container = $('#' + divId);</span> +<span class="cstat-no" title="statement not covered" > this.$container.addClass('slider-container');</span> + +<span class="cstat-no" title="statement not covered" > this._changedCallback = typeof chgCallback == 'function' ? chgCallback : <span class="fstat-no" title="function not covered" >() => {</span>};</span> + +<span class="cstat-no" title="statement not covered" > this._$presetSelector = presetSelector;</span> +<span class="cstat-no" title="statement not covered" > this._$regionSelector = regionSelector;</span> +<span class="cstat-no" title="statement not covered" > this._$versionSelector = versionSelector;</span> + +<span class="cstat-no" title="statement not covered" > this._sliderList = [];</span> +<span class="cstat-no" title="statement not covered" > this._sliderLookup = {};</span> + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < sliderConfigs.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = new _Slider(sliderConfigs[i]);</span> +<span class="cstat-no" title="statement not covered" > this._sliderList.push(sld);</span> +<span class="cstat-no" title="statement not covered" > this._sliderLookup[sld.domId] = sld;</span> +<span class="cstat-no" title="statement not covered" > sld.addToDom(this.$container);</span> + } + +<span class="cstat-no" title="statement not covered" > this._presetArray = [];</span> +<span class="cstat-no" title="statement not covered" > this._presetLookup = {};</span> + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < presetConfig.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let preset = new TipPresets(presetConfig[i]);</span> + +<span class="cstat-no" title="statement not covered" > let idx = (i + 1).toFixed();</span> + +<span class="cstat-no" title="statement not covered" > this._presetLookup[idx] = preset;</span> +<span class="cstat-no" title="statement not covered" > this._presetArray.push(preset);</span> +<span class="cstat-no" title="statement not covered" > this._$presetSelector.append(`<option value="${idx}">${preset.label}</option>`);</span> + } + + +<span class="cstat-no" title="statement not covered" > this._lockedList = [];</span> +<span class="cstat-no" title="statement not covered" > this._inRangeList = [];</span> +<span class="cstat-no" title="statement not covered" > this._atMinList = [];</span> +<span class="cstat-no" title="statement not covered" > this._atMaxList = [];</span> + +<span class="cstat-no" title="statement not covered" > this.lockedCount = 10;</span> +<span class="cstat-no" title="statement not covered" > this.notLockedCount = 0;</span> + +<span class="cstat-no" title="statement not covered" > this._splitSliderArray();</span> + + +<span class="cstat-no" title="statement not covered" > this._$presetSelector.change(<span class="fstat-no" title="function not covered" >() => {</span></span> +<span class="cstat-no" title="statement not covered" > this.setPresetValues();</span> +<span class="cstat-no" title="statement not covered" > this._runChangedCallback();</span> + }); + +<span class="cstat-no" title="statement not covered" > this._$regionSelector.change(<span class="fstat-no" title="function not covered" >() => {</span></span> +<span class="cstat-no" title="statement not covered" > this._runChangedCallback();</span> + }); + +<span class="cstat-no" title="statement not covered" > this._$versionSelector.change(<span class="fstat-no" title="function not covered" >() => {</span></span> +<span class="cstat-no" title="statement not covered" > this._runChangedCallback();</span> + }); + +<span class="cstat-no" title="statement not covered" > this._$presetSelector.trigger('change');</span> + +<span class="cstat-no" title="statement not covered" > this._addEventListeners();</span> + } + +<span class="fstat-no" title="function not covered" > _runChangedCallback(){</span> +<span class="cstat-no" title="statement not covered" > this._changedCallback(this.paramWeightsRegionVersion);</span> + } + +<span class="fstat-no" title="function not covered" > get changedCallback(): ChangeCallback{</span> +<span class="cstat-no" title="statement not covered" > return this._changedCallback</span> + } + +<span class="fstat-no" title="function not covered" > set changedCallback(chg: ChangeCallback)</span>{ +<span class="cstat-no" title="statement not covered" > this._changedCallback = chg;</span> +<span class="cstat-no" title="statement not covered" > this._runChangedCallback();</span> + } + +<span class="fstat-no" title="function not covered" > setPresetValues() {</span> +<span class="cstat-no" title="statement not covered" > let idx = this._$presetSelector.val() || '1';</span> + +<span class="cstat-no" title="statement not covered" > let thePreset = this._presetLookup[idx];</span> + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < thePreset.presets.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let presetValues = thePreset.presets[i];</span> +<span class="cstat-no" title="statement not covered" > let theSlider = this._sliderList[i];</span> + +<span class="cstat-no" title="statement not covered" > theSlider.locked = true;</span> +<span class="cstat-no" title="statement not covered" > theSlider.setValAndDropDown(presetValues.value, presetValues.column);</span> + } + } + + /** + * split array into subarrays holding the sliders + * @private + */ +<span class="fstat-no" title="function not covered" > _splitSliderArray() {</span> +<span class="cstat-no" title="statement not covered" > this._lockedList = [];</span> +<span class="cstat-no" title="statement not covered" > this._inRangeList = [];</span> +<span class="cstat-no" title="statement not covered" > this._atMinList = [];</span> +<span class="cstat-no" title="statement not covered" > this._atMaxList = [];</span> + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < this._sliderList.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = this._sliderList[i];</span> + +<span class="cstat-no" title="statement not covered" > if (sld.locked) {</span> +<span class="cstat-no" title="statement not covered" > this._lockedList.push(sld);</span> + } else <span class="cstat-no" title="statement not covered" >if (sld.atMin) {</span> +<span class="cstat-no" title="statement not covered" > this._atMinList.push(sld);</span> + } else <span class="cstat-no" title="statement not covered" >if (sld.atMax) {</span> +<span class="cstat-no" title="statement not covered" > this._atMaxList.push(sld);</span> + } else { +<span class="cstat-no" title="statement not covered" > this._inRangeList.push(sld);</span> + } + } +<span class="cstat-no" title="statement not covered" > this.lockedCount = this._lockedList.length;</span> +<span class="cstat-no" title="statement not covered" > this.notLockedCount = this._sliderList.length - this.lockedCount;</span> + } + + /** + * handle remainder, recursive to take care of min max overshoots + * @param {number} remain the remainder + * @param {string} skipDomId - this dom id + * @private + */ +<span class="fstat-no" title="function not covered" > _handleRemainder(remain, skipDomId)</span> { + +<span class="cstat-no" title="statement not covered" > remain = Number(remain.toFixed(1));</span> +<span class="cstat-no" title="statement not covered" > if (remain == 0) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > this._splitSliderArray();</span> + +<span class="cstat-no" title="statement not covered" > let canChangeArray = [];</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < this._inRangeList.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = this._inRangeList[i];</span> +<span class="cstat-no" title="statement not covered" > if (sld.domId == skipDomId) {</span> +<span class="cstat-no" title="statement not covered" > continue;</span> + } +<span class="cstat-no" title="statement not covered" > canChangeArray.push(sld);</span> + } + +<span class="cstat-no" title="statement not covered" > if (remain > 0) {</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < this._atMaxList.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = this._atMaxList[i];</span> +<span class="cstat-no" title="statement not covered" > if (sld.domId == skipDomId) {</span> +<span class="cstat-no" title="statement not covered" > continue;</span> + } +<span class="cstat-no" title="statement not covered" > canChangeArray.push(sld);</span> + } + } else { +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < this._atMinList.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = this._atMinList[i];</span> +<span class="cstat-no" title="statement not covered" > if (sld.domId == skipDomId) {</span> +<span class="cstat-no" title="statement not covered" > continue;</span> + } +<span class="cstat-no" title="statement not covered" > canChangeArray.push(sld);</span> + } + } + +<span class="cstat-no" title="statement not covered" > if (canChangeArray.length == 0) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > let inc = -1 * Number((remain / canChangeArray.length).toFixed(1));</span> + +<span class="cstat-no" title="statement not covered" > let newRemainder = 0;</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < canChangeArray.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > newRemainder += canChangeArray[i].increment(inc);</span> + } + +<span class="cstat-no" title="statement not covered" > this._handleRemainder(newRemainder, skipDomId);</span> + } + + /** + * + * @param {object} keyValList key and value list + */ +<span class="fstat-no" title="function not covered" > setValues(keyValList)</span> { +<span class="cstat-no" title="statement not covered" > this.resetting = true;</span> +<span class="cstat-no" title="statement not covered" > for (let k in keyValList) {</span> +<span class="cstat-no" title="statement not covered" > if (keyValList.hasOwnProperty(k)) {</span> +<span class="cstat-no" title="statement not covered" > this._sliderLookup[k].setValAndDropDown(keyValList[k][0], keyValList[k][1]);</span> + } + } +<span class="cstat-no" title="statement not covered" > this.resetting = false;</span> + } + + /** + * get the weight sum + * @returns {number} the weight sum + */ +<span class="fstat-no" title="function not covered" > getSum() {</span> +<span class="cstat-no" title="statement not covered" > let total = 0;</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < this._sliderList.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = this._sliderList[i];</span> +<span class="cstat-no" title="statement not covered" > total += Number(sld.weight.toFixed(1));</span> + } + +<span class="cstat-no" title="statement not covered" > return total;</span> + } + + /** + * get the parameter weights + * @returns {object} lookup with parameter weights + */ +<span class="fstat-no" title="function not covered" > getParams() {</span> +<span class="cstat-no" title="statement not covered" > let paramWeights = {};</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < this._sliderList.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = this._sliderList[i];</span> +<span class="cstat-no" title="statement not covered" > paramWeights[sld.selectedParam] = Number(sld.weight.toFixed(1));</span> + } + +<span class="cstat-no" title="statement not covered" > return paramWeights;</span> + } + +<span class="fstat-no" title="function not covered" > _addEventListeners() {</span> +<span class="cstat-no" title="statement not covered" > let ___this = this;</span> + + + //change function +<span class="cstat-no" title="statement not covered" > this.$container.find('input[type="range"]').change(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > if (___this.resetting) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > let $this = $(this);</span> +<span class="cstat-no" title="statement not covered" > let domId = this['id'];</span> +<span class="cstat-no" title="statement not covered" > let sldr = ___this._sliderLookup[domId];</span> + +<span class="cstat-no" title="statement not covered" > let newValue = parseFloat($this.val());</span> + +<span class="cstat-no" title="statement not covered" > let oldValue = sldr.weight;</span> +<span class="cstat-no" title="statement not covered" > let diff = newValue - oldValue;</span> +<span class="cstat-no" title="statement not covered" > diff = Number(diff.toFixed(1));</span> + +<span class="cstat-no" title="statement not covered" > sldr.weight = Number(newValue.toFixed(1));</span> + +<span class="cstat-no" title="statement not covered" > ___this._handleRemainder(diff, domId);</span> + + //cleanup, make sure the sum is still 100 +<span class="cstat-no" title="statement not covered" > let sum = Number(___this.getSum().toFixed(1));</span> + +<span class="cstat-no" title="statement not covered" > if (sum > 100) {</span> +<span class="cstat-no" title="statement not covered" > loop1:</span> +<span class="cstat-no" title="statement not covered" > while (true) {</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < ___this._sliderList.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = ___this._sliderList[i];</span> +<span class="cstat-no" title="statement not covered" > if (sld.domId == domId || sld.locked || sld.atMin) {</span> +<span class="cstat-no" title="statement not covered" > continue;</span> + } +<span class="cstat-no" title="statement not covered" > sld.increment(-0.1);</span> +<span class="cstat-no" title="statement not covered" > sum -= 0.1;</span> +<span class="cstat-no" title="statement not covered" > if (sum.toFixed(1) == '100.0') {</span> +<span class="cstat-no" title="statement not covered" > break loop1;</span> + } + } + } + } else <span class="cstat-no" title="statement not covered" >if (sum < 100) {</span> +<span class="cstat-no" title="statement not covered" > loop1:</span> +<span class="cstat-no" title="statement not covered" > while (true) {</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < ___this._sliderList.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = ___this._sliderList[i];</span> +<span class="cstat-no" title="statement not covered" > if (sld.domId == domId || sld.locked || sld.atMax) {</span> +<span class="cstat-no" title="statement not covered" > continue;</span> + } +<span class="cstat-no" title="statement not covered" > sld.increment(0.1);</span> +<span class="cstat-no" title="statement not covered" > sum += 0.1;</span> +<span class="cstat-no" title="statement not covered" > if (sum.toFixed(1) == '100.0') {</span> +<span class="cstat-no" title="statement not covered" > break loop1;</span> + } + } + } + } + +<span class="cstat-no" title="statement not covered" > ___this._$presetSelector.val('0');</span> +<span class="cstat-no" title="statement not covered" > ___this._runChangedCallback();</span> + } + ); + + //update the selected parameter when the selection is changed +<span class="cstat-no" title="statement not covered" > $('.show-select').change(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > if (___this.resetting) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } +<span class="cstat-no" title="statement not covered" > ___this._sliderLookup[this['id'].replace('_chg', '')].selectedParam = $(this).val();</span> + +<span class="cstat-no" title="statement not covered" > ___this._$presetSelector.val('0');</span> + +<span class="cstat-no" title="statement not covered" > ___this._runChangedCallback();</span> + + }); + + //lock the slider and update the reserved percent +<span class="cstat-no" title="statement not covered" > this.$container.find('input[type="checkbox"]').change(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > let domEl = this;</span> + +<span class="cstat-no" title="statement not covered" > ___this._sliderLookup[domEl.id.replace('_chk', '')].locked = !domEl.checked;</span> +<span class="cstat-no" title="statement not covered" > ___this.reservedPercent = 0.0;</span> +<span class="cstat-no" title="statement not covered" > ___this.notLockedCount = 0;</span> + +<span class="cstat-no" title="statement not covered" > let notLockedSliders = [];</span> + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < ___this._sliderList.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = ___this._sliderList[i];</span> +<span class="cstat-no" title="statement not covered" > if (sld.locked) {</span> +<span class="cstat-no" title="statement not covered" > ___this.reservedPercent += sld.weight;</span> +<span class="cstat-no" title="statement not covered" > continue;</span> + } +<span class="cstat-no" title="statement not covered" > notLockedSliders.push(sld);</span> +<span class="cstat-no" title="statement not covered" > ___this.notLockedCount++;</span> + } + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < ___this._sliderList.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let sld = ___this._sliderList[i];</span> +<span class="cstat-no" title="statement not covered" > if (sld.locked) {</span> +<span class="cstat-no" title="statement not covered" > continue;</span> + } +<span class="cstat-no" title="statement not covered" > sld.max = 100 - ___this.reservedPercent;</span> + } + +<span class="cstat-no" title="statement not covered" > if (notLockedSliders.length == 1) {</span> +<span class="cstat-no" title="statement not covered" > notLockedSliders[0].min = notLockedSliders[0].weight;</span> + } else { +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < notLockedSliders.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > notLockedSliders[i].min = 0;</span> + } + } + }); + + } + +<span class="fstat-no" title="function not covered" > get paramWeightsRegionVersion(): ChangeResponse{</span> +<span class="cstat-no" title="statement not covered" > return {paramWeights: this.getParams(),</span> + region: this._$regionSelector.val() as string, mmVersion: this._$versionSelector.val() as string} + } +} + +nm.Sliders = TipSliders; +export default TipSliders; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/index.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/index.html new file mode 100644 index 0000000000000000000000000000000000000000..5e019316c65a9a2f7e251393ded844763ac02dc3 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/collections/index.html @@ -0,0 +1,119 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\collections\</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/collections/ + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">13.07% </span> + <span class="quiet">Statements</span> + <span class='fraction'>63/482</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/134</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">16.36% </span> + <span class="quiet">Functions</span> + <span class='fraction'>9/55</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">12.82% </span> + <span class="quiet">Lines</span> + <span class='fraction'>61/476</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="ItsLayerCollection.ts"><a href="ItsLayerCollection.ts.html">ItsLayerCollection.ts</a></td> + <td data-value="44.44" class="pic low"><div class="chart"><div class="cover-fill" style="width: 44%;"></div><div class="cover-empty" style="width:56%;"></div></div></td> + <td data-value="44.44" class="pct low">44.44%</td> + <td data-value="27" class="abs low">12/27</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="6" class="abs low">0/6</td> + <td data-value="50" class="pct medium">50%</td> + <td data-value="4" class="abs medium">2/4</td> + <td data-value="42.31" class="pct low">42.31%</td> + <td data-value="26" class="abs low">11/26</td> + </tr> + +<tr> + <td class="file low" data-value="LayerLegend.ts"><a href="LayerLegend.ts.html">LayerLegend.ts</a></td> + <td data-value="11.46" class="pic low"><div class="chart"><div class="cover-fill" style="width: 11%;"></div><div class="cover-empty" style="width:89%;"></div></div></td> + <td data-value="11.46" class="pct low">11.46%</td> + <td data-value="157" class="abs low">18/157</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="60" class="abs low">0/60</td> + <td data-value="20" class="pct low">20%</td> + <td data-value="15" class="abs low">3/15</td> + <td data-value="11.69" class="pct low">11.69%</td> + <td data-value="154" class="abs low">18/154</td> + </tr> + +<tr> + <td class="file low" data-value="Sliders.ts"><a href="Sliders.ts.html">Sliders.ts</a></td> + <td data-value="11.07" class="pic low"><div class="chart"><div class="cover-fill" style="width: 11%;"></div><div class="cover-empty" style="width:89%;"></div></div></td> + <td data-value="11.07" class="pct low">11.07%</td> + <td data-value="298" class="abs low">33/298</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="68" class="abs low">0/68</td> + <td data-value="11.11" class="pct low">11.11%</td> + <td data-value="36" class="abs low">4/36</td> + <td data-value="10.81" class="pct low">10.81%</td> + <td data-value="296" class="abs low">32/296</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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/SelectBoxBase.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/SelectBoxBase.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..ae0f5de07342b55ab894c2167af684b5088a0235 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/SelectBoxBase.ts.html @@ -0,0 +1,467 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\domUtil\SelectBoxBase.ts</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/domUtil/</a> SelectBoxBase.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">29.79% </span> + <span class="quiet">Statements</span> + <span class='fraction'>14/47</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">20% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/10</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">28.89% </span> + <span class="quiet">Lines</span> + <span class='fraction'>13/45</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</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-yes">1×</span> +<span class="cline-any 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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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">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-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-neutral"> </span> +<span class="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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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">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">/** + * Created by gavorhes on 5/13/2016. + */ + +import makeGuid from '../util/makeGuid'; +import provide from '../util/provide'; +const nm = provide('domUtil'); + +export interface selectChangeCallback{ + /** + * + * @param theValue the current select value of the select box + */ + (theValue: string) : void +} + +/** + * must return in the contents <select id="${guid}"></select> among other things + */ +export interface contentGenerator{ + /** + * @param aGuid + */ + (aGuid: string): string +} + + +export class SelectBoxBase{ + _$container: JQuery; + $label: JQuery; + _box: JQuery; + _changeListeners: Array<selectChangeCallback>; + /** + * + * @param {jQuery} parent - parent container + * @param {string} labelContent + * @param {contentGenerator} [contentGen=undefined] + */ +<span class="fstat-no" title="function not covered" > constructor(parent, labelContent, contentGen?: contentGenerator)</span>{ +<span class="cstat-no" title="statement not covered" > let guidTop = makeGuid();</span> +<span class="cstat-no" title="statement not covered" > let guid = makeGuid();</span> + +<span class="cstat-no" title="statement not covered" > let htmlString = `<div id="${guidTop}">`;</span> +<span class="cstat-no" title="statement not covered" > htmlString += `<label for="${guid}">${labelContent}</label>`;</span> + +<span class="cstat-no" title="statement not covered" > if (contentGen){</span> +<span class="cstat-no" title="statement not covered" > htmlString += contentGen(guid);</span> + } else { +<span class="cstat-no" title="statement not covered" > htmlString += `<select id="${guid}"></select>`;</span> + } +<span class="cstat-no" title="statement not covered" > htmlString += '</div>';</span> + +<span class="cstat-no" title="statement not covered" > parent.append(htmlString);</span> + +<span class="cstat-no" title="statement not covered" > this._$container = parent.find('#' + guidTop);</span> + +<span class="cstat-no" title="statement not covered" > this.$label = this._$container.find('label');</span> + + /** + * + * @type {Array<selectChangeCallback>} + * @private + */ +<span class="cstat-no" title="statement not covered" > this._changeListeners = [];</span> + +<span class="cstat-no" title="statement not covered" > this._box = parent.find(`#${guid}`);</span> + +<span class="cstat-no" title="statement not covered" > if (!this._box){</span> +<span class="cstat-no" title="statement not covered" > throw 'the select box was not found';</span> + } + +<span class="cstat-no" title="statement not covered" > this._box.change(<span class="fstat-no" title="function not covered" >() => {</span></span> +<span class="cstat-no" title="statement not covered" > this.changed();</span> + }) + } + + /** + * + * @returns {jQuery} + */ +<span class="fstat-no" title="function not covered" > get box(){</span> +<span class="cstat-no" title="statement not covered" > return this._box;</span> + } + +<span class="fstat-no" title="function not covered" > changed(){</span> +<span class="cstat-no" title="statement not covered" > let v = this._box.val();</span> + +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let f </span>of this._changeListeners){</span> +<span class="cstat-no" title="statement not covered" > f(v);</span> + } + } + + /** + * + * @param {selectChangeCallback} func + */ +<span class="fstat-no" title="function not covered" > addChangeListener(func: selectChangeCallback)</span>{ +<span class="cstat-no" title="statement not covered" > this._changeListeners.push(func);</span> + } + + +<span class="fstat-no" title="function not covered" > get selectedValue(): string|number{</span> +<span class="cstat-no" title="statement not covered" > let theVal = this.box.val();</span> + +<span class="cstat-no" title="statement not covered" > if (theVal == null || typeof theVal == 'undefined'){</span> +<span class="cstat-no" title="statement not covered" > return null;</span> + } else <span class="cstat-no" title="statement not covered" >if (isNaN(theVal)){</span> +<span class="cstat-no" title="statement not covered" > return theVal</span> + } else { +<span class="cstat-no" title="statement not covered" > if (theVal.indexOf('.') > -1){</span> +<span class="cstat-no" title="statement not covered" > return parseFloat(theVal)</span> + } else { +<span class="cstat-no" title="statement not covered" > return parseInt(theVal);</span> + } + } + } + + /** + * + * @param {string|number} v + */ +<span class="fstat-no" title="function not covered" > set selectedValue(v: string|number)</span>{ +<span class="cstat-no" title="statement not covered" > this.box.val(v);</span> + } + +<span class="fstat-no" title="function not covered" > get selectedText(){</span> +<span class="cstat-no" title="statement not covered" > return this.box.find('option:selected').text();</span> + } + +} + +nm.SelectBoxBase = SelectBoxBase; + +export default SelectBoxBase; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/day-range.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/day-range.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..e8f86c4e0f29b203cabff6566275dfeb6e3bcfa6 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/day-range.ts.html @@ -0,0 +1,401 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\domUtil\day-range.ts</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/domUtil/</a> day-range.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">22.64% </span> + <span class="quiet">Statements</span> + <span class='fraction'>12/53</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/14</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">12.5% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/8</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">21.15% </span> + <span class="quiet">Lines</span> + <span class='fraction'>11/52</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</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-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-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-neutral"> </span> +<span class="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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="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-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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">import provide from '../util/provide'; +import $ = require('jquery'); +import 'jquery-ui'; + +let nm = provide('domUtil'); + +export class DayRange { + _workingDayRange: number; + _$startDate: JQuery; + _$endDate: JQuery; + _maxDateRange: number; + _startDate: Date; + _endDate: Date; + + /** + * constructor for the date range + * @param {number} dayRange number of days + * @param {jQuery|HTMLElement|*} jQueryRef reference to the jquery element + */ +<span class="fstat-no" title="function not covered" > constructor(jQueryRef: JQuery, dayRange: number)</span> { +<span class="cstat-no" title="statement not covered" > this._workingDayRange = dayRange - 1;</span> + +<span class="cstat-no" title="statement not covered" > let pickerHtml = '<label for="start-date" style="width: 78px; display: inline-block; margin:5px;">Start Date</label>' +</span> + '<input type="text" readonly id="start-date" class="date-pick" style="width: 90px;">' + + '<br><label for="end-date" style="width: 78px; display: inline-block; margin:5px;">End Date</label>' + + '<input type="text" readonly id="end-date" class="date-pick" style="width: 90px;">'; + +<span class="cstat-no" title="statement not covered" > jQueryRef.append(pickerHtml);</span> + +<span class="cstat-no" title="statement not covered" > this._$startDate = $('#start-date');</span> +<span class="cstat-no" title="statement not covered" > this._$endDate = $('#end-date');</span> + +<span class="cstat-no" title="statement not covered" > this._$startDate.datepicker();</span> +<span class="cstat-no" title="statement not covered" > this._$endDate.datepicker();</span> + +<span class="cstat-no" title="statement not covered" > this._startDate = null;</span> +<span class="cstat-no" title="statement not covered" > this._endDate = null;</span> + +<span class="cstat-no" title="statement not covered" > let dte1 = new Date();</span> +<span class="cstat-no" title="statement not covered" > dte1.setHours(0, 0, 0, 0);</span> +<span class="cstat-no" title="statement not covered" > let dte2 = new Date(dte1.getTime());</span> +<span class="cstat-no" title="statement not covered" > dte2.setDate(dte2.getDate() + dayRange);</span> +<span class="cstat-no" title="statement not covered" > dte2.setHours(23, 59, 59, 0);</span> +<span class="cstat-no" title="statement not covered" > this._maxDateRange = dte2.getTime() - dte1.getTime();</span> + +<span class="cstat-no" title="statement not covered" > let _this = this;</span> + + //add event listeners +<span class="cstat-no" title="statement not covered" > this._$startDate.change(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > _this.startDate = this.value;</span> + }); + +<span class="cstat-no" title="statement not covered" > this._$endDate.change(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > _this.endDate = this.value;</span> + }); + + // initialize +<span class="cstat-no" title="statement not covered" > this.endDate = new Date();</span> + } + +<span class="fstat-no" title="function not covered" > get startDate(): Date {</span> +<span class="cstat-no" title="statement not covered" > return this._startDate;</span> + } + + /** + * + * @param val + */ +<span class="fstat-no" title="function not covered" > set startDate(val: Date)</span> { +<span class="cstat-no" title="statement not covered" > if (typeof val == 'string') {</span> +<span class="cstat-no" title="statement not covered" > val = new Date(val as string);</span> + } + +<span class="cstat-no" title="statement not covered" > this._startDate = val;</span> +<span class="cstat-no" title="statement not covered" > this._startDate.setHours(0, 0, 0, 0);</span> +<span class="cstat-no" title="statement not covered" > this._$startDate.val(this._startDate.toLocaleDateString());</span> + +<span class="cstat-no" title="statement not covered" > if (</span> + this.endDate == null || + this._endDate.getTime() - this._startDate.getTime() > this._maxDateRange || + this._endDate.getTime() - this._startDate.getTime() < 24 * 60 * 60 * 1000) { +<span class="cstat-no" title="statement not covered" > let tmpDate = new Date(this._startDate.getTime());</span> +<span class="cstat-no" title="statement not covered" > tmpDate.setDate(tmpDate.getDate() + this._workingDayRange);</span> +<span class="cstat-no" title="statement not covered" > this.endDate = new Date(tmpDate.getTime());</span> + } + } + +<span class="fstat-no" title="function not covered" > get endDate(): Date {</span> +<span class="cstat-no" title="statement not covered" > return this._endDate;</span> + } + + +<span class="fstat-no" title="function not covered" > set endDate(val: Date)</span> { +<span class="cstat-no" title="statement not covered" > if (typeof val == 'string') {</span> +<span class="cstat-no" title="statement not covered" > val = new Date(val as string);</span> + } + +<span class="cstat-no" title="statement not covered" > this._endDate = val;</span> +<span class="cstat-no" title="statement not covered" > this._endDate.setHours(23, 59, 59, 0);</span> +<span class="cstat-no" title="statement not covered" > this._$endDate.val(this._endDate.toLocaleDateString());</span> +<span class="cstat-no" title="statement not covered" > if (this._startDate == null || this._endDate.getTime() - this.startDate.getTime() > this._maxDateRange || this._endDate.getTime() - this._startDate.getTime() < 24 * 60 * 60 * 1000) {</span> +<span class="cstat-no" title="statement not covered" > let tmpDate = new Date(this._endDate.getTime());</span> +<span class="cstat-no" title="statement not covered" > tmpDate.setDate(tmpDate.getDate() - this._workingDayRange);</span> +<span class="cstat-no" title="statement not covered" > this.startDate = new Date(tmpDate.getTime());</span> + } + } +} + +nm.DayRange = DayRange; + +export default DayRange; + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/index.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/index.html new file mode 100644 index 0000000000000000000000000000000000000000..220775d835b2c05b6692679180494220f830a5bf --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/index.html @@ -0,0 +1,132 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\domUtil\</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/domUtil/ + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">19.93% </span> + <span class="quiet">Statements</span> + <span class='fraction'>54/271</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/82</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">10.42% </span> + <span class="quiet">Functions</span> + <span class='fraction'>5/48</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">19.25% </span> + <span class="quiet">Lines</span> + <span class='fraction'>51/265</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="SelectBoxBase.ts"><a href="SelectBoxBase.ts.html">SelectBoxBase.ts</a></td> + <td data-value="29.79" class="pic low"><div class="chart"><div class="cover-fill" style="width: 29%;"></div><div class="cover-empty" style="width:71%;"></div></div></td> + <td data-value="29.79" class="pct low">29.79%</td> + <td data-value="47" class="abs low">14/47</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="12" class="abs low">0/12</td> + <td data-value="20" class="pct low">20%</td> + <td data-value="10" class="abs low">2/10</td> + <td data-value="28.89" class="pct low">28.89%</td> + <td data-value="45" class="abs low">13/45</td> + </tr> + +<tr> + <td class="file low" data-value="day-range.ts"><a href="day-range.ts.html">day-range.ts</a></td> + <td data-value="22.64" class="pic low"><div class="chart"><div class="cover-fill" style="width: 22%;"></div><div class="cover-empty" style="width:78%;"></div></div></td> + <td data-value="22.64" class="pct low">22.64%</td> + <td data-value="53" class="abs low">12/53</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="14" class="abs low">0/14</td> + <td data-value="12.5" class="pct low">12.5%</td> + <td data-value="8" class="abs low">1/8</td> + <td data-value="21.15" class="pct low">21.15%</td> + <td data-value="52" class="abs low">11/52</td> + </tr> + +<tr> + <td class="file low" data-value="media-control.ts"><a href="media-control.ts.html">media-control.ts</a></td> + <td data-value="15.25" class="pic low"><div class="chart"><div class="cover-fill" style="width: 15%;"></div><div class="cover-empty" style="width:85%;"></div></div></td> + <td data-value="15.25" class="pct low">15.25%</td> + <td data-value="118" class="abs low">18/118</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="34" class="abs low">0/34</td> + <td data-value="10" class="pct low">10%</td> + <td data-value="20" class="abs low">2/20</td> + <td data-value="14.78" class="pct low">14.78%</td> + <td data-value="115" class="abs low">17/115</td> + </tr> + +<tr> + <td class="file low" data-value="range-change.ts"><a href="range-change.ts.html">range-change.ts</a></td> + <td data-value="18.87" class="pic low"><div class="chart"><div class="cover-fill" style="width: 18%;"></div><div class="cover-empty" style="width:82%;"></div></div></td> + <td data-value="18.87" class="pct low">18.87%</td> + <td data-value="53" class="abs low">10/53</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="10" class="abs low">0/10</td> + <td data-value="18.87" class="pct low">18.87%</td> + <td data-value="53" class="abs low">10/53</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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/media-control.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/media-control.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..e24a9d95d3ac1fbb854250985646e96a9b46613b --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/media-control.ts.html @@ -0,0 +1,824 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\domUtil\media-control.ts</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/domUtil/</a> media-control.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">15.25% </span> + <span class="quiet">Statements</span> + <span class='fraction'>18/118</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/34</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">10% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/20</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">14.78% </span> + <span class="quiet">Lines</span> + <span class='fraction'>17/115</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</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-yes">1×</span> +<span class="cline-any 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-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="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-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-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-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-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-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-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-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 11/2/2015. + */ + +import provide from '../util/provide'; +import {rangeChange} from './range-change'; +import $ = require('jquery'); + +let nm = provide('domUtil'); + +/** + * @callback mediaCallback + * @param {number} tm + */ + +<span class="fstat-no" title="function not covered" >function timeToLocalDateString(tm)</span> { + "use strict"; +<span class="cstat-no" title="statement not covered" > let d = new Date(tm);</span> +<span class="cstat-no" title="statement not covered" > let p1 = d.toLocaleTimeString().split(' ');</span> +<span class="cstat-no" title="statement not covered" > let p2 = p1[0].split(':');</span> +<span class="cstat-no" title="statement not covered" > p2 = p2.slice(0, 2);</span> + +<span class="cstat-no" title="statement not covered" > return d.toLocaleDateString() + '<br>' + p2.join(':') + ' ' + p1[1];</span> +} + +export interface changeFunction{ + (newVal?: number): void; +} + +export interface mediaRangeConfig{ + min?: number; + max?: number; + val?: number; + step?: number; + playInterval?: number; + showAsDate?: boolean; +} + + + +export class MediaControl { + _container: JQuery; + _min: number; + _max: number; + _playInterval: number; + _step: number; + _currentValue: number; + + _playing: boolean; + + _$btnStop: JQuery; + _$slider: JQuery; + _$valLabelVal: JQuery; + _$valLabelMin: JQuery; + _$valLabelMax: JQuery; + _interval: number; + _showAsDate: boolean; + + _changeFunc: changeFunction; + + /** + * + * @param element + * @param changeFunc + * @param mediaConfig + */ +<span class="fstat-no" title="function not covered" > constructor(</span> + element: JQuery|HTMLElement|string, +<span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" > changeFunc: changeFunction = (): void => {<span class="cstat-no" title="statement not covered" ></span>return;}</span>,</span> +<span class="cstat-no" title="statement not covered" > mediaConfig: mediaRangeConfig = {})</span> { + +<span class="cstat-no" title="statement not covered" > mediaConfig.min = typeof mediaConfig.min == 'number' ? mediaConfig.min : 0;</span> +<span class="cstat-no" title="statement not covered" > mediaConfig.max = typeof mediaConfig.max == 'number' ? mediaConfig.max : 100;</span> +<span class="cstat-no" title="statement not covered" > mediaConfig.val = typeof mediaConfig.val == 'number' ? mediaConfig.val : 0;</span> +<span class="cstat-no" title="statement not covered" > mediaConfig.step = typeof mediaConfig.step == 'number' ? mediaConfig.step : 5;</span> +<span class="cstat-no" title="statement not covered" > mediaConfig.playInterval = typeof mediaConfig.playInterval == 'number' ? mediaConfig.playInterval : 500;</span> +<span class="cstat-no" title="statement not covered" > mediaConfig.showAsDate = typeof mediaConfig.showAsDate == 'boolean' ? mediaConfig.showAsDate : false;</span> + +<span class="cstat-no" title="statement not covered" > if (typeof element == 'string'){</span> +<span class="cstat-no" title="statement not covered" > this._container = $('#' + element);</span> + } + else <span class="cstat-no" title="statement not covered" >if (typeof element['style'] !== 'undefined'){</span> +<span class="cstat-no" title="statement not covered" > this._container = $(element);</span> + } else { +<span class="cstat-no" title="statement not covered" > this._container = element as JQuery;</span> + } + +<span class="cstat-no" title="statement not covered" > this._container.addClass('media-control-container');</span> +<span class="cstat-no" title="statement not covered" > this._playInterval = mediaConfig.playInterval;</span> +<span class="cstat-no" title="statement not covered" > this._changeFunc = changeFunc;</span> + +<span class="cstat-no" title="statement not covered" > this._showAsDate = mediaConfig.showAsDate;</span> + +<span class="cstat-no" title="statement not covered" > this._currentValue = undefined;</span> +<span class="cstat-no" title="statement not covered" > this._min = undefined;</span> +<span class="cstat-no" title="statement not covered" > this._max = undefined;</span> +<span class="cstat-no" title="statement not covered" > this._step = undefined;</span> +<span class="cstat-no" title="statement not covered" > this._playing = false;</span> + +<span class="cstat-no" title="statement not covered" > let htmlStr =</span> + '<span class="media-player-button media-back"></span>' + + '<span class="media-player-button media-play"></span>' + + '<span class="media-player-button media-pause media-disabled"></span>' + + '<span class="media-player-button media-stop media-disabled" ></span>' + + '<span class="media-player-button media-ahead"></span>' + + `<input type="range">` + + `<div class="media-control-value-label-container">` + + `<span class="media-control-value-label-min"></span>` + + `<span class="media-control-value-label-val"></span>` + + `<span class="media-control-value-label-max"></span>` + + `</div>`; + +<span class="cstat-no" title="statement not covered" > this._container.append(htmlStr);</span> + + // let btnPause = this._container.find('.media-pause'); +<span class="cstat-no" title="statement not covered" > let btnPlay = this._container.find('.media-play');</span> +<span class="cstat-no" title="statement not covered" > this._$btnStop = this._container.find('.media-stop');</span> +<span class="cstat-no" title="statement not covered" > let btnAhead = this._container.find('.media-ahead');</span> +<span class="cstat-no" title="statement not covered" > let btnBack = this._container.find('.media-back');</span> +<span class="cstat-no" title="statement not covered" > this._$slider = this._container.find('input[type=range]');</span> + +<span class="cstat-no" title="statement not covered" > this._$valLabelMin = this._container.find('.media-control-value-label-min');</span> +<span class="cstat-no" title="statement not covered" > this._$valLabelVal = this._container.find('.media-control-value-label-val');</span> +<span class="cstat-no" title="statement not covered" > this._$valLabelMax = this._container.find('.media-control-value-label-max');</span> + +<span class="cstat-no" title="statement not covered" > this.setMinMaxValueStep(mediaConfig.min, mediaConfig.max, mediaConfig.val, mediaConfig.step);</span> + +<span class="cstat-no" title="statement not covered" > rangeChange(this._$slider,<span class="fstat-no" title="function not covered" >(newVal)</span> => { <span class="cstat-no" title="statement not covered" >this.currentValue = newVal;}</span>, 100);</span> + +<span class="cstat-no" title="statement not covered" > let ___this = this;</span> + +<span class="cstat-no" title="statement not covered" > btnPlay.click(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > let $this = $(this);</span> +<span class="cstat-no" title="statement not covered" > $this.addClass('media-disabled');</span> +<span class="cstat-no" title="statement not covered" > ___this._$btnStop.removeClass('media-disabled');</span> +<span class="cstat-no" title="statement not covered" > btnAhead.addClass('media-locked');</span> +<span class="cstat-no" title="statement not covered" > btnBack.addClass('media-locked');</span> +<span class="cstat-no" title="statement not covered" > ___this._$slider.prop('disabled', true);</span> +<span class="cstat-no" title="statement not covered" > ___this._playing = true;</span> + +<span class="cstat-no" title="statement not covered" > ___this._interval = setInterval(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > ___this.currentValue += ___this._step;</span> + }, ___this._playInterval); + }); + +<span class="cstat-no" title="statement not covered" > this._$btnStop.click(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > clearInterval(___this._interval);</span> +<span class="cstat-no" title="statement not covered" > let $this = $(this);</span> +<span class="cstat-no" title="statement not covered" > $this.addClass('media-disabled');</span> +<span class="cstat-no" title="statement not covered" > btnPlay.removeClass('media-disabled');</span> +<span class="cstat-no" title="statement not covered" > btnAhead.removeClass('media-locked');</span> +<span class="cstat-no" title="statement not covered" > btnBack.removeClass('media-locked');</span> +<span class="cstat-no" title="statement not covered" > ___this._$slider.prop('disabled', false);</span> +<span class="cstat-no" title="statement not covered" > ___this._playing = false;</span> + }); + +<span class="cstat-no" title="statement not covered" > btnAhead.click(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > ___this.currentValue = ___this.currentValue + ___this._step;</span> + }); + +<span class="cstat-no" title="statement not covered" > btnBack.click(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > ___this.currentValue = ___this.currentValue - ___this._step;</span> + }); + } + +<span class="fstat-no" title="function not covered" > stopPlaying(){</span> +<span class="cstat-no" title="statement not covered" > if (this._playing){</span> +<span class="cstat-no" title="statement not covered" > this._$btnStop.trigger('click');</span> + } + } + +<span class="fstat-no" title="function not covered" > get playing(){</span> +<span class="cstat-no" title="statement not covered" > return this._playing;</span> + } + +<span class="fstat-no" title="function not covered" > get min() {</span> +<span class="cstat-no" title="statement not covered" > return this._min;</span> + } + +<span class="fstat-no" title="function not covered" > get max() {</span> +<span class="cstat-no" title="statement not covered" > return this._max;</span> + } + +<span class="fstat-no" title="function not covered" > get step() {</span> +<span class="cstat-no" title="statement not covered" > return this._step;</span> + } + +<span class="fstat-no" title="function not covered" > get currentValue() {</span> +<span class="cstat-no" title="statement not covered" > return this._currentValue;</span> + } + +<span class="fstat-no" title="function not covered" > set currentValue(newValue)</span> { +<span class="cstat-no" title="statement not covered" > if (newValue > this._max) {</span> +<span class="cstat-no" title="statement not covered" > newValue = this._min;</span> + } else <span class="cstat-no" title="statement not covered" >if (newValue < this._min) {</span> +<span class="cstat-no" title="statement not covered" > newValue = this._max;</span> + } +<span class="cstat-no" title="statement not covered" > this._currentValue = newValue;</span> +<span class="cstat-no" title="statement not covered" > this._$slider.val(this._currentValue.toFixed(2));</span> + +<span class="cstat-no" title="statement not covered" > if (this._showAsDate) {</span> +<span class="cstat-no" title="statement not covered" > this._$valLabelVal.html(timeToLocalDateString(this.currentValue));</span> + } else { +<span class="cstat-no" title="statement not covered" > this._$valLabelVal.html(this.currentValue.toString());</span> + } + +<span class="cstat-no" title="statement not covered" > this._changeFunc(newValue);</span> + } + + /** + * set min and max value with step + * @param {number} newMin the new min + * @param {number} newMax the new mas + * @param {number} [newValue=newMin] the value to set + * @param {number} [newStep=(newMax-newMin)/20] step value + */ +<span class="fstat-no" title="function not covered" > setMinMaxValueStep(newMin, newMax, newValue, newStep)</span> { +<span class="cstat-no" title="statement not covered" > this._min = newMin;</span> +<span class="cstat-no" title="statement not covered" > this._max = newMax;</span> + +<span class="cstat-no" title="statement not covered" > newValue = typeof newValue == 'number' ? newValue : newMin;</span> +<span class="cstat-no" title="statement not covered" > newStep = typeof newStep == 'number' ? newStep : (newMax-newMin)/20;</span> + +<span class="cstat-no" title="statement not covered" > this._currentValue = newValue;</span> +<span class="cstat-no" title="statement not covered" > this._step = newStep;</span> + +<span class="cstat-no" title="statement not covered" > this._$slider.prop('min', this.min.toString());</span> +<span class="cstat-no" title="statement not covered" > this._$slider.prop('max', this.max.toString());</span> +<span class="cstat-no" title="statement not covered" > this._$slider.prop('step', this.step.toString());</span> +<span class="cstat-no" title="statement not covered" > this._$slider.val(this.currentValue.toString());</span> + +<span class="cstat-no" title="statement not covered" > if (this._showAsDate) {</span> +<span class="cstat-no" title="statement not covered" > this._$valLabelMin.html(timeToLocalDateString(this._min));</span> +<span class="cstat-no" title="statement not covered" > this._$valLabelVal.html(timeToLocalDateString(this.currentValue));</span> +<span class="cstat-no" title="statement not covered" > this._$valLabelMax.html(timeToLocalDateString(this._max));</span> + } else { +<span class="cstat-no" title="statement not covered" > this._$valLabelMin.html(this._min.toString());</span> +<span class="cstat-no" title="statement not covered" > this._$valLabelVal.html(this.currentValue.toString());</span> +<span class="cstat-no" title="statement not covered" > this._$valLabelMax.html(this._max.toString());</span> + } + } + + /** + * + * @param {mediaCallback} newFunc the callback on change + */ +<span class="fstat-no" title="function not covered" > set changeFunction(newFunc: changeFunction)</span> { +<span class="cstat-no" title="statement not covered" > this._changeFunc = newFunc;</span> + } +} + +nm.MediaControl = MediaControl; + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/range-change.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/range-change.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..433d02d7a61e92d608cc711005b8b348351be4b3 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/domUtil/range-change.ts.html @@ -0,0 +1,503 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\domUtil\range-change.ts</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/domUtil/</a> range-change.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">18.87% </span> + <span class="quiet">Statements</span> + <span class='fraction'>10/53</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/10</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">18.87% </span> + <span class="quiet">Lines</span> + <span class='fraction'>10/53</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</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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="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-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-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-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-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-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import provide from '../util/provide'; +import $ = require('jquery'); + +const nm = provide('domUtil'); + +let mouseIn = false; +let mouseDown = false; +let timeout = null; +let dragged = false; +let lastVal; + + +/** + * callback on range change interaction, context of this is the firing dom element + * @callback rangeChangeCallback + * @param {number} newValue + * @param {number} ratio value from 0 to 1 relative of the value to the min and max + * @param {object} evt + */ + +/*** + * callback funcion after the slider has been moved + */ +export interface rangeChangedCallback{ + /** + * + * @param newValue new value of the slider + * @param ratio ratio from low to high, 0 to 1 + * @param evt the original event + */ + (newValue: number, ratio: number, evt: Event): any +} + + +/** + * Created by gavorhes on 11/2/2015. + */ + +<span class="fstat-no" title="function not covered" >function triggerCallback(callback: rangeChangedCallback, evt)</span> { + "use strict"; + +<span class="cstat-no" title="statement not covered" > let val = parseFloat(this.value);</span> +<span class="cstat-no" title="statement not covered" > let min = parseFloat(this.min);</span> +<span class="cstat-no" title="statement not covered" > let max = parseFloat(this.max);</span> +<span class="cstat-no" title="statement not covered" > let step = parseFloat(this.step);</span> + +<span class="cstat-no" title="statement not covered" > if (max - val < step){</span> +<span class="cstat-no" title="statement not covered" > val = max;</span> + } + +<span class="cstat-no" title="statement not covered" > let percent = (val - min) / (max - min);</span> + +<span class="cstat-no" title="statement not covered" > if (typeof lastVal == 'number' && val == lastVal){</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } +<span class="cstat-no" title="statement not covered" > lastVal = val;</span> +<span class="cstat-no" title="statement not covered" > callback(val, percent, evt);</span> +} + + + +/** + * Add a variety of listeners for range inputs applied to a common callback + * @param $slider - jquery reference to the slider + * @param {rangeChangeCallback} callback - the callback + * @param {number} [changeTimeout=75] before the callback is called + * @this {jQuery} + * @returns {jQuery} the jQuery object + */ +<span class="fstat-no" title="function not covered" >export function rangeChange ($slider: JQuery, callback: rangeChangedCallback, changeTimeout: number)</span> { + +<span class="cstat-no" title="statement not covered" > changeTimeout = typeof changeTimeout == 'number' ? changeTimeout : 75;</span> + +<span class="cstat-no" title="statement not covered" > $slider.mouseenter(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > mouseIn = true;</span> + }); + +<span class="cstat-no" title="statement not covered" > $slider.mouseleave(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > mouseIn = false;</span> +<span class="cstat-no" title="statement not covered" > mouseDown = false;</span> + }); + +<span class="cstat-no" title="statement not covered" > $slider.mousedown(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > mouseDown = true;</span> + }); + +<span class="cstat-no" title="statement not covered" > $slider.mouseup(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > mouseDown = false;</span> + }); + +<span class="cstat-no" title="statement not covered" > $slider.mousemove(</span> + /** + * + * @param {object} evt - event properties + * @this {HTMLElement} + */ +<span class="fstat-no" title="function not covered" > function (evt)</span> { +<span class="cstat-no" title="statement not covered" > if (!(mouseIn && mouseDown)) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > dragged = true;</span> + +<span class="cstat-no" title="statement not covered" > if (lastVal == this['value']) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } +<span class="cstat-no" title="statement not covered" > lastVal = this['value'];</span> + +<span class="cstat-no" title="statement not covered" > if (timeout != null) {</span> +<span class="cstat-no" title="statement not covered" > clearTimeout(timeout);</span> + } + +<span class="cstat-no" title="statement not covered" > let _this = this;</span> + +<span class="cstat-no" title="statement not covered" > timeout = setTimeout(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > triggerCallback.call(_this, callback, evt);</span> +<span class="cstat-no" title="statement not covered" > timeout = null;</span> + + }, changeTimeout); + }); + +<span class="cstat-no" title="statement not covered" > $slider.keyup(</span> + /** + * + * @param {object} evt - event properties + */ +<span class="fstat-no" title="function not covered" > function (evt)</span> { +<span class="cstat-no" title="statement not covered" > if (evt.keyCode == 37 || evt.keyCode == 39) {</span> +<span class="cstat-no" title="statement not covered" > triggerCallback.call(this, callback, evt);</span> + } + }); + +<span class="cstat-no" title="statement not covered" > $slider.change(<span class="fstat-no" title="function not covered" >function (evt)</span> {</span> +<span class="cstat-no" title="statement not covered" > if (dragged) {</span> +<span class="cstat-no" title="statement not covered" > dragged = false;</span> + +<span class="cstat-no" title="statement not covered" > return;</span> + } +<span class="cstat-no" title="statement not covered" > triggerCallback.call(this, callback, evt);</span> + }); + +<span class="cstat-no" title="statement not covered" > return this;</span> +} + +nm.rangeChange = rangeChange; + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/index.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/index.html new file mode 100644 index 0000000000000000000000000000000000000000..47062305c67c1968073a2319e34b3ed912dccf59 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/index.html @@ -0,0 +1,93 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\</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/ + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Statements</span> + <span class='fraction'>0/0</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'>0/0</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="index.ts"><a href="index.ts.html">index.ts</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="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="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> + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/index.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/index.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..f5ec231c6d1fe7025023ee291ed9049430490d87 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/index.ts.html @@ -0,0 +1,74 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\index.ts</title> + <meta charset="utf-8" /> + <link rel="stylesheet" href="../prettify.css" /> + <link rel="stylesheet" href="../base.css" /> + <meta name="viewport" content="width=device-width, initial-scale=1"> + <style type='text/css'> + .coverage-summary .sorter { + background-image: url(../sort-arrow-sprite.png); + } + </style> +</head> +<body> +<div class='wrapper'> + <div class='pad1'> + <h1> + <a href="../index.html">all files</a> / <a href="index.html">src/</a> index.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Statements</span> + <span class='fraction'>0/0</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'>0/0</span> + </div> + </div> + </div> + <div class='status-line high'></div> +<pre><table class="coverage"> +<tr><td class="line-count quiet">1 +2 +3 +4</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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 9/20/2016. + */ +import {} from 'util'</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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBase.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBase.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..d9e98c902dd0988203923d85355054ff36d60108 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBase.ts.html @@ -0,0 +1,1388 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\LayerBase.ts</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/layers/</a> LayerBase.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">60.99% </span> + <span class="quiet">Statements</span> + <span class='fraction'>86/141</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">39.71% </span> + <span class="quiet">Branches</span> + <span class='fraction'>27/68</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">31.58% </span> + <span class="quiet">Functions</span> + <span class='fraction'>12/38</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">60.14% </span> + <span class="quiet">Lines</span> + <span class='fraction'>83/138</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</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-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-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-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-no"> </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">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">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-no"> </span> +<span class="cline-any cline-yes">9×</span> +<span class="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">9×</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">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">9×</span> +<span class="cline-any cline-no"> </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-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-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-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-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">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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any 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">8×</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-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">18×</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-yes">9×</span> +<span class="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">9×</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-yes">9×</span> +<span class="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-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-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-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-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-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">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-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-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">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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-yes">1×</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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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">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-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-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-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-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-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">9×</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></td><td class="text"><pre class="prettyprint lang-js">import * as zoomResolutionConvert from '../olHelpers/zoomResolutionConvert'; +import provide from '../util/provide'; +import ol = require('custom-ol'); +import makeGuid from '../util/makeGuid'; +import $ = require('jquery'); + +const nm = provide('layers'); + + +export interface LayerBaseOptions{ + id?: string; + name?: string; + opacity?: number; + visible?: boolean; + minZoom?: number; + maxZoom?: number; + params?: any; + zIndex?: number; + loadCallback?: Function; + legendCollapse?: boolean; + legendCheckbox?: boolean; + legendContent?: string; +} + + +/** + * The base layer class + * @abstract + */ +export abstract class LayerBase { + + protected _legendCheckbox: boolean; + protected _url: string; + protected _opacity: number; + protected _minZoom: number; + protected _maxZoom: number; + protected _visible: boolean; + protected _loaded: boolean; + protected _zIndex: number; + protected _legendContent: string; + protected _params: any; + protected _id: string; + protected _name: string; + protected _source: ol.source.Source; + protected _animate: boolean; + protected _legendCollapse: boolean; + protected _maxResolution: number; + protected _minResolution: number; + protected _$legendDiv: JQuery; + loadCallback: Function; + protected _olLayer: ol.layer.Layer; + protected _applyCollapseCalled: boolean; + + + + /** + * The base layer for all others + * @param {string} url - url for source + * @param {object} options - config + * @param {string} [options.id=makeGuid()] - layer id + * @param {string} [options.name=Unnamed Layer] - layer name + * @param {number} [options.opacity=1] - opacity + * @param {boolean} [options.visible=true] - default visible + * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28 + * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28 + * @param {object} [options.params={}] - the get parameters to include to retrieve the layer + * @param {number} [options.zIndex=0] - the z index for the layer + * @param {function} [options.loadCallback] - function to call on load, context this is the layer object + * @param {boolean} [options.legendCollapse=false] - if the legend item should be initially collapsed + * @param {boolean} [options.legendCheckbox=true] - if the legend item should have a checkbox for visibility + * @param {boolean} [options.legendContent=undefined] - additional content to add to the legend + */ + constructor(url: string, <span class="missing-if-branch" title="if path not taken" >I</span>options: LayerBaseOptions = {}) { + options = options || <span class="branch-1 cbranch-no" title="branch not covered" >{} as LayerBaseOptions;</span> + + <span class="missing-if-branch" title="if path not taken" >I</span>if (typeof url !== 'string') { +<span class="cstat-no" title="statement not covered" > throw 'Invalid URL';</span> + } + this._url = url; + + + this._params = typeof options.params == 'object' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.params </span>: {}; + this._legendCollapse = typeof options.legendCollapse == 'boolean' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.legendCollapse </span>: false; + this._legendCheckbox = typeof options.legendCheckbox == 'boolean' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.legendCheckbox </span>: true; + + this.id = options.id || makeGuid(); + this._name = options.name || 'Unnamed Layer'; + this.animate = false; + this._opacity = typeof options.opacity == 'number' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.opacity </span>: 1; + + <span class="missing-if-branch" title="if path not taken" >I</span>if (this._opacity > 1) { +<span class="cstat-no" title="statement not covered" > this._opacity = 1;</span> + } else <span class="missing-if-branch" title="if path not taken" >I</span>if (this._opacity < 0) { +<span class="cstat-no" title="statement not covered" > this._opacity = 0;</span> + } + + this._visible = typeof options.visible === 'boolean' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.visible </span>: true; + + this._source = undefined; + + /** + * + * @protected + */ + this._olLayer = undefined; + this._loaded = false; + + this._maxResolution = zoomResolutionConvert.zoomToResolution(options.minZoom); + <span class="missing-if-branch" title="if path not taken" >I</span>if (typeof this._maxResolution !== 'undefined') { +<span class="cstat-no" title="statement not covered" > this._maxResolution += 0.00001;</span> + } + this._minResolution = zoomResolutionConvert.zoomToResolution(options.maxZoom); + + this._minZoom = typeof options.minZoom == 'number' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.minZoom </span>: undefined; + this._maxZoom = typeof options.maxZoom == 'number' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.maxZoom </span>: undefined; + this._zIndex = typeof options.zIndex == 'number' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.zIndex </span>: 0; + + this.loadCallback = typeof options.loadCallback == 'function' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.loadCallback </span>: <span class="fstat-no" title="function not covered" >function () {</span> + }; + + + this._legendContent = ''; + + <span class="missing-if-branch" title="else path not taken" >E</span>if (this._legendCheckbox) { + this._legendContent += `<input type="checkbox" ${this.visible ? 'checked' : <span class="branch-1 cbranch-no" title="branch not covered" >''}</span> ` + + `class="legend-check" id="${this.id}-legend-layer-check"><span></span>`; + this._legendContent += `<label for="${this.id}-legend-layer-check" class="legend-layer-name">${this.name}</label>`; + } else { +<span class="cstat-no" title="statement not covered" > this._legendContent += `<label class="legend-layer-name">${this.name}</label>`;</span> + } + + this._$legendDiv = null; + this._applyCollapseCalled = false; + this._addLegendContent(typeof options.legendContent === 'string' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.legendContent </span>: undefined); + } + + /** + * base load function, sets _loaded = true if it is not already + * @protected + * @returns {boolean} if already loaded + */ + _load() { + if (this.loaded == true) { + return true; + } else { + this._loaded = true; + + return false; + } + } + + /** + * Get the legend html, be sure to only add to the DOM once + * @returns {string} html for layer wrapped in a div + */ +<span class="fstat-no" title="function not covered" > getLegendDiv() {</span> +<span class="cstat-no" title="statement not covered" > return `<div class="legend-layer-div" id="${this.id}-legend-layer-div">${this._legendContent}</div>`;</span> + } + + /** + * + * @param additionalContent - additional content to add to legend + * @private + */ + _addLegendContent(<span class="missing-if-branch" title="else path not taken" >E</span>additionalContent='') { + + let addCollapse = additionalContent.indexOf('<ul>') > -1; + + <span class="missing-if-branch" title="if path not taken" >I</span>if (addCollapse) { +<span class="cstat-no" title="statement not covered" > additionalContent = '<span class="legend-items-expander" title="Expand/Collapse">&#9660;</span>' + additionalContent;</span> + } + + this._legendContent += additionalContent; + + this._$legendDiv = $(`#${this.id}-legend-layer-div`); + + <span class="missing-if-branch" title="if path not taken" >I</span>if (this._$legendDiv.length > 0) { +<span class="cstat-no" title="statement not covered" > this._$legendDiv.append(additionalContent);</span> +<span class="cstat-no" title="statement not covered" > this.applyCollapse();</span> + } + } + + /** + * add additional content to the legend + * @param {string} [additionalContent=] - additonal content to add + */ +<span class="fstat-no" title="function not covered" > addLegendContent(additionalContent)</span> { +<span class="cstat-no" title="statement not covered" > this._addLegendContent(additionalContent);</span> + } + +<span class="fstat-no" title="function not covered" > applyCollapse() {</span> +<span class="cstat-no" title="statement not covered" > if (this._applyCollapseCalled) {</span> +<span class="cstat-no" title="statement not covered" > console.log('collapse already applied');</span> + +<span class="cstat-no" title="statement not covered" > return undefined;</span> + } + +<span class="cstat-no" title="statement not covered" > this._$legendDiv = $(`#${this.id}-legend-layer-div`);</span> + +<span class="cstat-no" title="statement not covered" > if (this._$legendDiv.length > 0) {</span> + +<span class="cstat-no" title="statement not covered" > let $expander = this._$legendDiv.find('.legend-items-expander');</span> + +<span class="cstat-no" title="statement not covered" > if ($expander.length > 0) {</span> +<span class="cstat-no" title="statement not covered" > this._applyCollapseCalled = true;</span> + +<span class="cstat-no" title="statement not covered" > $expander.click(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > let $this = $(this);</span> + +<span class="cstat-no" title="statement not covered" > $this.siblings('ul').slideToggle();</span> + +<span class="cstat-no" title="statement not covered" > if ($this.hasClass('legend-layer-group-collapsed')) {</span> +<span class="cstat-no" title="statement not covered" > $this.removeClass('legend-layer-group-collapsed');</span> +<span class="cstat-no" title="statement not covered" > $this.html('&#9660;');</span> + } else { +<span class="cstat-no" title="statement not covered" > $this.addClass('legend-layer-group-collapsed');</span> +<span class="cstat-no" title="statement not covered" > $this.html('&#9654;');</span> + } + }); + +<span class="cstat-no" title="statement not covered" > if (this._legendCollapse) {</span> +<span class="cstat-no" title="statement not covered" > $expander.trigger('click');</span> + } + } + } + } + + /** + * trick to refresh the layer + */ +<span class="fstat-no" title="function not covered" > refresh() {</span> +<span class="cstat-no" title="statement not covered" > if (this.source) {</span> +<span class="cstat-no" title="statement not covered" > this.source.refresh();</span> + } + } + + get id(): string{ + return this._id; + } + + set id(newId: string){ + this._id = newId; + } + +<span class="fstat-no" title="function not covered" > get animate(): boolean{</span> +<span class="cstat-no" title="statement not covered" > return this._animate;</span> + } + + set animate(animate: boolean){ + this._animate = animate; + } + + /** + * get the legend content + * @type {string} + */ +<span class="fstat-no" title="function not covered" > get legendContent() {</span> +<span class="cstat-no" title="statement not covered" > return this._legendContent;</span> + } + + /** + * set the legend content directly + * @param {string} newVal - new content + * @protected + */ +<span class="fstat-no" title="function not covered" > set legendContent(newVal)</span> { +<span class="cstat-no" title="statement not covered" > this._legendContent = newVal;</span> + } + + /** + * get the map get params + * @type {object} + */ +<span class="fstat-no" title="function not covered" > get params() {</span> +<span class="cstat-no" title="statement not covered" > return this._params;</span> + } + + /** + * set the map get params + * @param {object} newParams - new get params + * @protected + */ +<span class="fstat-no" title="function not covered" > set params(newParams)</span> { +<span class="cstat-no" title="statement not covered" > this._params = newParams;</span> + } + + /** + * get the minimum resolution + * @type {number|*} + */ +<span class="fstat-no" title="function not covered" > get minResolution() {</span> +<span class="cstat-no" title="statement not covered" > return this._minResolution;</span> + } + + /** + * get the maximum resolution + * @type {number|*} + */ +<span class="fstat-no" title="function not covered" > get maxResolution() {</span> +<span class="cstat-no" title="statement not covered" > return this._maxResolution;</span> + } + + /** + * get min zoom + * @type {number|*} + */ +<span class="fstat-no" title="function not covered" > get minZoom() {</span> +<span class="cstat-no" title="statement not covered" > return this._minZoom;</span> + } + + /** + * get max zoom + * @type {number|*} + */ +<span class="fstat-no" title="function not covered" > get maxZoom() {</span> +<span class="cstat-no" title="statement not covered" > return this._maxZoom;</span> + } + + /** + * get the url + * @type {string} + */ + get url() { + return this._url; + } + + /** + * Get the layer visibility + * @type {boolean} + */ +<span class="fstat-no" title="function not covered" > get visible(): boolean {</span> +<span class="cstat-no" title="statement not covered" > return this._visible;</span> + } + + /** + * set the visibility + * @param visibility + */ +<span class="fstat-no" title="function not covered" > set visible(visibility: boolean)</span> { +<span class="cstat-no" title="statement not covered" > this.setVisible(visibility);</span> + } + +<span class="fstat-no" title="function not covered" > protected setVisible(visibility: boolean)</span> { +<span class="cstat-no" title="statement not covered" > this._visible = visibility;</span> +<span class="cstat-no" title="statement not covered" > if (this.olLayer) {</span> +<span class="cstat-no" title="statement not covered" > this.olLayer.setVisible(this._visible);</span> +<span class="cstat-no" title="statement not covered" > if (visibility && !this._loaded) {</span> +<span class="cstat-no" title="statement not covered" > this._load();</span> + } + } + } + + + /** + * Get the layer opacity + * @type {number} + */ +<span class="fstat-no" title="function not covered" > get opacity() {</span> +<span class="cstat-no" title="statement not covered" > return this._opacity;</span> + } + + /** + * Set the layer opacity + * @param {number} opacity - layer opacity + */ +<span class="fstat-no" title="function not covered" > set opacity(opacity)</span> { +<span class="cstat-no" title="statement not covered" > this._opacity = opacity;</span> +<span class="cstat-no" title="statement not covered" > if (this.olLayer) {</span> +<span class="cstat-no" title="statement not covered" > this.olLayer.setOpacity(this._opacity);</span> + } + } + + /** + * Get the layer name + * @type {string} + */ + get name() { + return this._name; + } + + /** + * set the layer name + * @param {string} newName - the new name + */ +<span class="fstat-no" title="function not covered" > set name(newName)</span> { +<span class="cstat-no" title="statement not covered" > this._name = newName;</span> + } + + /** + * Check if the layer is loaded + * @type {boolean} + */ + get loaded() { + return this._loaded; + } + + /** + * get the layer source + * @type {*} + */ +<span class="fstat-no" title="function not covered" > get source(): ol.source.Source {</span> +<span class="cstat-no" title="statement not covered" > return this.getSource();</span> + } + + + protected getSource(): ol.source.Source{ + return this._source; + } + + /** + * get the z index + */ +<span class="fstat-no" title="function not covered" > get zIndex(): number {</span> +<span class="cstat-no" title="statement not covered" > return this._zIndex;</span> + } + + /** + * set the z index + */ +<span class="fstat-no" title="function not covered" > set zIndex(newZ: number)</span> { +<span class="cstat-no" title="statement not covered" > this._zIndex = newZ;</span> + } + +<span class="fstat-no" title="function not covered" > protected setZIndex(newZ: number)</span>{ + + } + + /** + * the the ol layer + */ +<span class="fstat-no" title="function not covered" > get olLayer(): ol.layer.Layer {</span> +<span class="cstat-no" title="statement not covered" > return this.getOlLayer();</span> + } + + protected getOlLayer(): ol.layer.Layer{ + return this._olLayer; + } +} + +nm.LayerBase = LayerBase; +export default LayerBase; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseVector.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseVector.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..5a4982e18ae289c21d0540abdf725c36d38dcf9c --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseVector.ts.html @@ -0,0 +1,1031 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\LayerBaseVector.ts</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/layers/</a> LayerBaseVector.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">58.7% </span> + <span class="quiet">Statements</span> + <span class='fraction'>54/92</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">29.55% </span> + <span class="quiet">Branches</span> + <span class='fraction'>13/44</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">36.36% </span> + <span class="quiet">Functions</span> + <span class='fraction'>8/22</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">57.3% </span> + <span class="quiet">Lines</span> + <span class='fraction'>51/89</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</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-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-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-yes">10×</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">9×</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-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-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">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-no"> </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-yes">9×</span> +<span class="cline-any cline-no"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">9×</span> +<span class="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">9×</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-yes">9×</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-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-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-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> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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">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">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-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-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-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-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-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">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-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">1×</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-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-neutral"> </span> +<span class="cline-any 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-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> +<span class="cline-any 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></td><td class="text"><pre class="prettyprint lang-js">import {LayerBase, LayerBaseOptions} from './LayerBase'; +import mapMove from '../olHelpers/mapMove'; +import MapMoveCls from '../olHelpers/mapMoveCls' +import provide from '../util/provide'; +import ol = require('custom-ol'); +import $ = require('jquery'); + +const nm = provide('layers'); + +export interface makeMapMoveParams { + /** + * + * @param lyr + * @param extent + * @param zoomLevel + */ + (lyr: LayerBaseVector, extent: Array<number>, zoomLevel?: number): any +} + + + + +export interface LayerBaseVectorOptions extends LayerBaseOptions{ + autoLoad?: boolean; + style?: ol.style.Style|Array<ol.style.Style>|ol.StyleFunction; + onDemand?: boolean; + onDemandDelay?: number; + mapMoveMakeGetParams?: makeMapMoveParams; + mapMoveObj?: MapMoveCls; + renderOrder?: (a: ol.Feature, b: ol.Feature) => number; + +} + + + +/** + * The Vector layer base + * @augments LayerBase + * @abstract + */ +export class LayerBaseVector extends LayerBase { + _olLayer: ol.layer.Vector; + _source: ol.source.Vector; + _style: ol.style.Style|Array<ol.style.Style>|ol.StyleFunction; + _autoLoad: boolean; + _onDemand: boolean; + _onDemandDelay: number; + _mapMoveMakeGetParams: makeMapMoveParams; + _mapMoveParams: any; + _mapMove: MapMoveCls; + _projectionMap: ol.proj.Projection; + _projection4326: ol.proj.Projection; + + + + /** + * The base vector layer + * @param {string} url - pass an empty string to prevent default load and add from a json source + * @param {object} options - config + * @param {string} [options.id] - layer id + * @param {string} [options.name=Unnamed Layer] - layer name + * @param {number} [options.opacity=1] - opacity + * @param {boolean} [options.visible=true] - default visible + * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28 + * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28 + * @param {object} [options.params={}] the get parameters to include to retrieve the layer + * @param {number} [options.zIndex=0] the z index for the layer + * @param {function} [options.loadCallback] function to call on load, context this is the layer object + * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed + * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility + * @param {boolean} [options.legendContent] additional content to add to the legend + * + * @param {boolean} [options.autoLoad=false] if the layer should auto load if not visible + * @param {object} [options.style=undefined] the layer style, use openlayers default style if not defined + * @param {boolean} [options.onDemand=false] if the layer should be loaded by extent on map move + * @param {number} [options.onDemandDelay=300] delay before the map move callback should be called + * @param {mapMoveMakeGetParams} [options.mapMoveMakeGetParams=function(lyr, extent, zoomLevel){}] function to create additional map move params + * @param {MapMoveCls} [options.mapMoveObj=mapMove] alternate map move object for use with multi map pages + * + */ + constructor(url: string, <span class="missing-if-branch" title="if path not taken" >I</span>options: LayerBaseVectorOptions = {}) { + super(url, options); + + options = options as LayerBaseVectorOptions; + + //prevent regular load if no url has been provided + if (this.url.trim() == '') { + this._loaded = true; + } + + this._style = typeof options.style == 'undefined' ? undefined : <span class="branch-1 cbranch-no" title="branch not covered" >options.style;</span> + + <span class="missing-if-branch" title="else path not taken" >E</span>if (this.visible) { + this._autoLoad = true; + } else { +<span class="cstat-no" title="statement not covered" > this._autoLoad = (typeof options['autoLoad'] == 'boolean' ? options['autoLoad'] : false);</span> + } + + this._onDemand = typeof options.onDemand == 'boolean' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.onDemand </span>: false; + this._onDemandDelay = typeof options.onDemandDelay == 'number' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.onDemandDelay </span>: 300; + + <span class="missing-if-branch" title="if path not taken" >I</span>if (options.mapMoveObj) { +<span class="cstat-no" title="statement not covered" > this._mapMove = options.mapMoveObj;</span> + } else { + this._mapMove = this._onDemand ? <span class="branch-0 cbranch-no" title="branch not covered" >mapMove </span>: undefined; + } + + + this._mapMoveMakeGetParams = typeof options.mapMoveMakeGetParams == 'function' ? <span class="branch-0 cbranch-no" title="branch not covered" >options.mapMoveMakeGetParams </span>: +<span class="fstat-no" title="function not covered" > function () {<span class="cstat-no" title="statement not covered" ></span>return {};}</span>; + + <span class="missing-if-branch" title="if path not taken" >I</span>if (this._onDemand) { +<span class="cstat-no" title="statement not covered" > this._loaded = true;</span> +<span class="cstat-no" title="statement not covered" > this._mapMoveParams = {};</span> +<span class="cstat-no" title="statement not covered" > this._mapMove.checkInit();</span> +<span class="cstat-no" title="statement not covered" > this._mapMove.addVectorLayer(this);</span> + } + + this._source = new ol.source.Vector(); + + + this._olLayer = new ol.layer.Vector( + { + source: this._source, + visible: this.visible, + style: this.style, + minResolution: this._minResolution, + maxResolution: this._maxResolution, + renderOrder: options.renderOrder + } + ); + + this.olLayer.setZIndex(this._zIndex); + + + this._projectionMap = null; + this._projection4326 = new ol.proj.Projection({code: "EPSG:4326"}); + } + + /** + * dummy to be overridden + * @param {object} featureCollection - geojson or esrijson object + */ +<span class="fstat-no" title="function not covered" > addFeatures(featureCollection)</span> { +<span class="cstat-no" title="statement not covered" > console.log('Layer vector base addFeatures is a placeholder and does nothing');</span> + } + + /** + * Before call to map move callback, can prevent call by returning false + * @param {number} zoom - zoom level + * @param {string} [evtType=undefined] undefined for initial load, otherwise one of 'change:center', 'change:resolution' + * @returns {boolean} if the call should proceed + */ +<span class="fstat-no" title="function not covered" > mapMoveBefore(zoom, evtType)</span> { +<span class="cstat-no" title="statement not covered" > if (this.minZoom !== undefined) {</span> +<span class="cstat-no" title="statement not covered" > if (zoom < this.minZoom) {</span> +<span class="cstat-no" title="statement not covered" > return false;</span> + } + } + +<span class="cstat-no" title="statement not covered" > if (this.maxZoom !== undefined) {</span> +<span class="cstat-no" title="statement not covered" > if (zoom > this.maxZoom) {</span> +<span class="cstat-no" title="statement not covered" > return false;</span> + } + } + +<span class="cstat-no" title="statement not covered" > return this.visible;</span> + } + + /** + * callback to generate the parameters passed in the get request + * @param {object} extent - extent object + * @param {number} extent.minX - minX + * @param {number} extent.minY - minY + * @param {number} extent.maxX - maxX + * @param {number} extent.maxY - maxY + * @param {number} zoomLevel - zoom level + */ +<span class="fstat-no" title="function not covered" > mapMoveMakeGetParams(extent, zoomLevel)</span> { +<span class="cstat-no" title="statement not covered" > this._mapMoveParams = {};</span> +<span class="cstat-no" title="statement not covered" > $.extend(this._mapMoveParams, this.params);</span> +<span class="cstat-no" title="statement not covered" > $.extend(this._mapMoveParams, this._mapMoveMakeGetParams(this, extent, zoomLevel));</span> + } + + /** + * callback function on map move + * @param {object} d - the json response + */ +<span class="fstat-no" title="function not covered" > mapMoveCallback(d)</span> { +<span class="cstat-no" title="statement not covered" > if (this.source) {</span> +<span class="cstat-no" title="statement not covered" > this._source.clear();</span> + } + } + + /** + * clear features in the layer + */ +<span class="fstat-no" title="function not covered" > clear() {</span> +<span class="cstat-no" title="statement not covered" > if (this._source) {</span> +<span class="cstat-no" title="statement not covered" > this._source.clear();</span> + } + } + + /** + * get on demand delay in miliseconds + */ +<span class="fstat-no" title="function not covered" > get onDemandDelay(): number {</span> +<span class="cstat-no" title="statement not covered" > return this._onDemandDelay;</span> + } + + /** + * get if the layer is autoloaded + */ + get autoLoad(): boolean { + return this._autoLoad; + } + + /** + * get the style definition + */ + get style(): ol.StyleFunction|Array<ol.style.Style>|ol.style.Style { + return this._style; + } + + /** + * set the style + * @param style - the style or function + */ +<span class="fstat-no" title="function not covered" > set style(style: ol.StyleFunction|Array<ol.style.Style>|ol.style.Style)</span> { +<span class="cstat-no" title="statement not covered" > this._style = style;</span> +<span class="cstat-no" title="statement not covered" > this.olLayer.setStyle(this._style as ol.style.Style);</span> + } + + /** + * get the map CRS if it is defined by the map move object + */ +<span class="fstat-no" title="function not covered" > get mapCrs(): string {</span> +<span class="cstat-no" title="statement not covered" > return this.mapProj == null ? null : this.mapProj.getCode();</span> + } + +<span class="fstat-no" title="function not covered" > get mapProj(): ol.proj.Projection{</span> +<span class="cstat-no" title="statement not covered" > if (this._projectionMap != null){</span> +<span class="cstat-no" title="statement not covered" > return this._projectionMap;</span> + } + +<span class="cstat-no" title="statement not covered" > if (this._mapMove) {</span> +<span class="cstat-no" title="statement not covered" > this._projectionMap = this._mapMove.map.getView().getProjection();</span> +<span class="cstat-no" title="statement not covered" > return this._projectionMap;</span> + } else { +<span class="cstat-no" title="statement not covered" > return null;</span> + } + + } + + /** + * get the map move object + * @type {MapMoveCls|*} + */ +<span class="fstat-no" title="function not covered" > get mapMove(): MapMoveCls {</span> +<span class="cstat-no" title="statement not covered" > return this._mapMove;</span> + } + + /** + * map move params + * @type {object} + */ +<span class="fstat-no" title="function not covered" > get mapMoveParams() {</span> +<span class="cstat-no" title="statement not covered" > return this._mapMoveParams;</span> + } + + get visible(): boolean{ + return this._visible; + } + + /** + * Set the layer visibility + * @type {boolean} + * @override + */ +<span class="fstat-no" title="function not covered" > set visible(visibility)</span> { +<span class="cstat-no" title="statement not covered" > super.setVisible(visibility);</span> + +<span class="cstat-no" title="statement not covered" > if (this._onDemand) {</span> +<span class="cstat-no" title="statement not covered" > this.mapMove.triggerLyrLoad(this);</span> + } + } + + /** + * get the layer vector source + * @override + */ + get source(): ol.source.Vector { + return this.getSource() as ol.source.Vector; + } + + /** + * array of ol features + */ + get features(): Array<ol.Feature> { + return this.source.getFeatures(); + } + + /** + * + */ + get olLayer(): ol.layer.Vector { + return super.getOlLayer() as ol.layer.Vector; + } + +<span class="fstat-no" title="function not covered" > protected setZIndex(newZ: number)</span> { +<span class="cstat-no" title="statement not covered" > this.olLayer.setZIndex(newZ);</span> + } +} + +nm.LayerBaseVector = LayerBaseVector; +export default LayerBaseVector; + + + + + + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseVectorEsri.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseVectorEsri.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..bf65a522c096cac42558ce51f30c70bf9ee767cf --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseVectorEsri.ts.html @@ -0,0 +1,641 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\LayerBaseVectorEsri.ts</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/layers/</a> LayerBaseVectorEsri.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">28.79% </span> + <span class="quiet">Statements</span> + <span class='fraction'>19/66</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/30</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">16.67% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/12</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">26.56% </span> + <span class="quiet">Lines</span> + <span class='fraction'>17/64</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</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-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any 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-neutral"> </span> +<span class="cline-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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-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-yes">1×</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">/** + * Created by gavorhes on 11/2/2015. + */ + +import {LayerBaseVector, LayerBaseVectorOptions} from './LayerBaseVector'; +import * as esriToOl from '../olHelpers/esriToOlStyle'; +import provide from '../util/provide'; +import ol = require('custom-ol'); +import $ = require('jquery'); +let nm = provide('layers'); + +export interface LayerBaseVectorEsriOptions extends LayerBaseVectorOptions{ + format?: string; + outSR?: number; + where?: string; + outFields?: string; + useEsriStyle?: boolean; +} + +/** + * Base layer for esri vector layers + * @augments LayerBaseVector + */ +export class LayerBaseVectorEsri extends LayerBaseVector { + _outSR: number; + _esriFormat: ol.format.EsriJSON; + _urlCopy: string; + _useEsriStyle: boolean; + + /** + * The base vector layer + * @param {string} url - url for source + * @param {object} options - config + * @param {string} [options.id] - layer id + * @param {string} [options.name=Unnamed Layer] - layer name + * @param {number} [options.opacity=1] - opacity + * @param {boolean} [options.visible=true] - default visible + * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28 + * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28 + * @param {object} [options.params={}] the get parameters to include to retrieve the layer + * @param {number} [options.zIndex=0] the z index for the layer + * @param {function} [options.loadCallback] function to call on load, context this is the layer object + * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed + * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility + * @param {boolean} [options.legendContent] additional content to add to the legend + * + * @param {boolean} [options.autoLoad=false] if the layer should auto load if not visible + * @param {object} [options.style=undefined] the layer style, use openlayers default style if not defined + * @param {boolean} [options.onDemand=false] if the layer should be loaded by extent on map move + * @param {number} [options.onDemandDelay=300] delay before the map move callback should be called + * @param {MapMoveCls} [options.mapMoveObj=mapMove] alternate map move object for use with multi map pages + * + * @param {string} [options.where=1=1] the layer filter clause + * @param {string} [options.outFields=*] comma separated list of output fields, defaults to all + * @param {string} [options.format=pjson] the format the retrieve the _data + * @param {number} [options.outSR=3857] the output spatial reference, defaults to web mercator + * @param {boolean} [options.useEsriStyle=false] if the map service style should be used + * @param {boolean} [options.collapseLegend=false] if the legend should be initially collapsed + * @param {number} [options.mapMoveMakeGetParams=function(extent, zoomLevel){}] function to create additional map move params + */ +<span class="fstat-no" title="function not covered" > constructor(url: string, options: LayerBaseVectorEsriOptions)</span> { + +<span class="cstat-no" title="statement not covered" > if (typeof options.params != 'object') {</span> +<span class="cstat-no" title="statement not covered" > options.params = {};</span> + } +<span class="cstat-no" title="statement not covered" > options.params['where'] = options.where || '1=1';</span> +<span class="cstat-no" title="statement not covered" > options.params['outFields'] = options.outFields || '*';</span> +<span class="cstat-no" title="statement not covered" > options.params['f'] = options.format || 'pjson';</span> +<span class="cstat-no" title="statement not covered" > options.params['outSR'] = options.outSR || 3857;</span> + +<span class="cstat-no" title="statement not covered" > super(url, options);</span> +<span class="cstat-no" title="statement not covered" > this._outSR = this.params['outSR'];</span> +<span class="cstat-no" title="statement not covered" > this._esriFormat = new ol.format.EsriJSON();</span> + +<span class="cstat-no" title="statement not covered" > if (this._url[this._url.length - 1] !== '/') {</span> +<span class="cstat-no" title="statement not covered" > this._url += '/';</span> + } + +<span class="cstat-no" title="statement not covered" > this._urlCopy = this.url;</span> +<span class="cstat-no" title="statement not covered" > this._url += 'query?callback=?';</span> + +<span class="cstat-no" title="statement not covered" > if (this.autoLoad || this.visible) {</span> +<span class="cstat-no" title="statement not covered" > this._load();</span> + } + +<span class="cstat-no" title="statement not covered" > this._useEsriStyle = typeof options.useEsriStyle == 'boolean' ? options.useEsriStyle : false;</span> + +<span class="cstat-no" title="statement not covered" > if (this._useEsriStyle) {</span> +<span class="cstat-no" title="statement not covered" > this.addLegendContent();</span> + } + } + + /** + * add additional content to the legend + * @param {string} [additionalContent=''] additional content to add to legend + */ +<span class="fstat-no" title="function not covered" > addLegendContent(additionalContent?: string)</span> { +<span class="cstat-no" title="statement not covered" > if (!this._useEsriStyle) {</span> +<span class="cstat-no" title="statement not covered" > super.addLegendContent(additionalContent);</span> + } else { +<span class="cstat-no" title="statement not covered" > $.get(this._urlCopy + '?f=pjson&callback=?', {}, <span class="fstat-no" title="function not covered" >(d)</span> => {</span> +<span class="cstat-no" title="statement not covered" > if (d['subLayers'].length > 0) {</span> +<span class="cstat-no" title="statement not covered" > alert('should only use single feature layers, not groups');</span> + +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > let newStyleAndLegend = esriToOl.makeFeatureServiceLegendAndSymbol(d);</span> +<span class="cstat-no" title="statement not covered" > this.style = newStyleAndLegend.style;</span> +<span class="cstat-no" title="statement not covered" > super.addLegendContent(newStyleAndLegend.legend);</span> + }, 'json'); + } + } + + + /** + * add feature collection + * @param {object} featureCollection - features as esrijson + */ +<span class="fstat-no" title="function not covered" > addFeatures(featureCollection)</span> { +<span class="cstat-no" title="statement not covered" > let feats = this._esriFormat.readFeatures(featureCollection);</span> +<span class="cstat-no" title="statement not covered" > this.source.addFeatures(feats);</span> + } + + /** + * trigger load features + * @protected + * @returns {boolean} if already loaded + */ +<span class="fstat-no" title="function not covered" > _load() {</span> +<span class="cstat-no" title="statement not covered" > if (super._load()) {</span> +<span class="cstat-no" title="statement not covered" > return true;</span> + } +<span class="cstat-no" title="statement not covered" > $.get(this._url, this.params, <span class="fstat-no" title="function not covered" >(d)</span> => {</span> +<span class="cstat-no" title="statement not covered" > this.addFeatures(d);</span> +<span class="cstat-no" title="statement not covered" > this.loadCallback(this);</span> + }, 'json').fail(<span class="fstat-no" title="function not covered" >() => {</span> +<span class="cstat-no" title="statement not covered" > this._loaded = false;</span> + }); + +<span class="cstat-no" title="statement not covered" > return false;</span> + } + + /** + * callback to generate the parameters passed in the get request + * @param {object} extent - extent object + * @param {number} extent.minX - minX + * @param {number} extent.minY - minY + * @param {number} extent.maxX - maxX + * @param {number} extent.maxY - maxY + * @param {number} zoomLevel - zoom level + */ +<span class="fstat-no" title="function not covered" > mapMoveMakeGetParams(extent, zoomLevel)</span> { +<span class="cstat-no" title="statement not covered" > super.mapMoveMakeGetParams(extent, zoomLevel);</span> +<span class="cstat-no" title="statement not covered" > this.mapMoveParams['geometry'] = `${extent.minX},${extent.minY},${extent.maxX},${extent.maxY}`;</span> +<span class="cstat-no" title="statement not covered" > this.mapMoveParams['geometryType'] = 'esriGeometryEnvelope';</span> +<span class="cstat-no" title="statement not covered" > this.mapMoveParams['spatialRel'] = 'esriSpatialRelIntersects';</span> +<span class="cstat-no" title="statement not covered" > this.mapMoveParams['spatialRel'] = 'esriSpatialRelIntersects';</span> +<span class="cstat-no" title="statement not covered" > this.mapMoveParams['inSR'] = 3857;</span> +<span class="cstat-no" title="statement not covered" > if (this._outSR == 3857) {</span> +<span class="cstat-no" title="statement not covered" > this.mapMoveParams['geometryPrecision'] = 1;</span> + } + } + + /** + * Before call to map move callback, can prevent call by returning false + * @param {number} zoom - zoom level + * @param {string} [evtType=undefined] undefined for initial load, otherwise one of 'change:center', 'change:resolution' + * @returns {boolean} if the call should proceed + */ +<span class="fstat-no" title="function not covered" > mapMoveBefore(zoom, evtType)</span> { +<span class="cstat-no" title="statement not covered" > return super.mapMoveBefore(zoom, evtType);</span> + //if (super.mapMoveBefore(zoom, evtType)){ + // //place holder for additional processing + // return true; + //} else { + // return false; + //} + } + + /** + * callback function on map move + * @param {object} d - the json response + */ +<span class="fstat-no" title="function not covered" > mapMoveCallback(d)</span> { +<span class="cstat-no" title="statement not covered" > super.mapMoveCallback(d);</span> +<span class="cstat-no" title="statement not covered" > this.source.addFeatures(this._esriFormat.readFeatures(d));</span> + } +} + +nm.LayerBaseVectorEsri = LayerBaseVectorEsri; +export default LayerBaseVectorEsri; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseVectorGeoJson.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseVectorGeoJson.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..185e3e00bca511ba1ac3b1447f824186869eb250 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseVectorGeoJson.ts.html @@ -0,0 +1,449 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\LayerBaseVectorGeoJson.ts</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/layers/</a> LayerBaseVectorGeoJson.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">86.11% </span> + <span class="quiet">Statements</span> + <span class='fraction'>31/36</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">77.78% </span> + <span class="quiet">Branches</span> + <span class='fraction'>14/18</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">62.5% </span> + <span class="quiet">Functions</span> + <span class='fraction'>5/8</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">84.85% </span> + <span class="quiet">Lines</span> + <span class='fraction'>28/33</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</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-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any 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> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-yes">18×</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-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">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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">10×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">9×</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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 11/2/2015. + */ + +import {LayerBaseVector, LayerBaseVectorOptions} from './LayerBaseVector'; +import provide from '../util/provide'; +import ol = require('custom-ol'); +import $ = require('jquery'); +import {MapMoveCls} from "../olHelpers/mapMoveCls"; +import * as proj from '../olHelpers/projections'; +import {proj3857} from "../olHelpers/projections"; + +let nm = provide('layers'); + +export interface crsTransform { + dataProjection?: ol.proj.Projection; + featureProjection?: ol.proj.Projection; +} + + +export interface LayerBaseVectorGeoJsonOptions extends LayerBaseVectorOptions { + transform?: crsTransform; + mapMoveObj?: MapMoveCls; +} + +/** + * The Vector GeoJson Layer + * @augments LayerBaseVector + */ +export class LayerBaseVectorGeoJson extends LayerBaseVector { + _geoJsonFormat: ol.format.GeoJSON; + _transform: crsTransform; + + /** + * @param {string|null} url - resource url, set to '' to make blank layer + * @param {object} options - config + * @param {string} [options.id] - layer id + * @param {string} [options.name=Unnamed Layer] - layer name + * @param {number} [options.opacity=1] - opacity + * @param {boolean} [options.visible=true] - default visible + * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28 + * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28 + * @param {object} [options.params={}] the get parameters to include to retrieve the layer + * @param {number} [options.zIndex=0] the z index for the layer + * @param {function} [options.loadCallback] function to call on load, context this is the layer object + * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed + * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility + * @param {boolean} [options.legendContent] additional content to add to the legend + * + * @param {boolean} [options.autoLoad=false] if the layer should auto load if not visible + * @param {object} [options.style=undefined] the layer style, use openlayers default style if not defined + * @param {boolean} [options.onDemand=false] if the layer should be loaded by extent on map move + * @param {number} [options.onDemandDelay=300] delay before the map move callback should be called + * + * @param {object} [options.transform={}] SR transform, set as false for no transform + * @param {string} options.transform.dataProjection=EPSG:4326 the _data CRS + * @param {string} options.transform.featureProjection=EPSG:3857 the feature/map CRS + * @param {mapMoveMakeGetParams} [options.mapMoveMakeGetParams=function(lyr, extent, zoomLevel){}] function to create additional map move params + * @param {MapMoveCls} [options.mapMoveObj=mapMove] alternate map move object for use with multi map pages + */ + constructor(url?: string, <span class="missing-if-branch" title="else path not taken" >E</span>options: LayerBaseVectorGeoJsonOptions = {}) { + url = typeof url == 'string' ? url : ''; + super(url, options)<span class="branch-1 cbranch-no" title="branch not covered" >;</span> + + this._geoJsonFormat = new ol.format.GeoJSON(); + + this._transform = options.transform || {}; + this._transform.dataProjection = this._transform.dataProjection || proj.proj4326; + this._transform.featureProjection = this._transform.featureProjection || proj3857; + + <span class="missing-if-branch" title="else path not taken" >E</span>if (this.autoLoad || <span class="branch-1 cbranch-no" title="branch not covered" >this.visible)</span> { + this._load(); + } + } + + /** + * add feature collection + * @param {object} featureCollection - as geojson object + */ + addFeatures(featureCollection: any) { + this.source.addFeatures( + this._geoJsonFormat.readFeatures(featureCollection, + {dataProjection: this._transform.dataProjection, + featureProjection: this._transform.featureProjection} + ) + ); + } + + + /** + * trigger load features + * @protected + * @returns {boolean} if already loaded + */ + _load() { + + if (super._load()) { + return true; + } + + $.get(this._url, + this._params, +<span class="fstat-no" title="function not covered" > (d)</span> => { +<span class="cstat-no" title="statement not covered" > this.addFeatures(d);</span> +<span class="cstat-no" title="statement not covered" > this.loadCallback(this);</span> + }, 'json').fail( +<span class="fstat-no" title="function not covered" > function () {</span> +<span class="cstat-no" title="statement not covered" > this._loaded = false;</span> + } + ); + + return false; + } + + /** + * callback function on map move + * @param {object} d the json response + * @override + */ +<span class="fstat-no" title="function not covered" > mapMoveCallback(d)</span> { +<span class="cstat-no" title="statement not covered" > super.mapMoveCallback(d);</span> +<span class="cstat-no" title="statement not covered" > this._source.addFeatures(this._geoJsonFormat.readFeatures(d,</span> + {featureProjection: this._transform.featureProjection, dataProjection: this._transform.dataProjection})); + } +} + +nm.LayerBaseVectorGeoJson = LayerBaseVectorGeoJson; +export default LayerBaseVectorGeoJson; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseXyzTile.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseXyzTile.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..5b552884b00a2d714969e8f834ce19bbf49bcbe6 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerBaseXyzTile.ts.html @@ -0,0 +1,269 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\LayerBaseXyzTile.ts</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/layers/</a> LayerBaseXyzTile.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">68.42% </span> + <span class="quiet">Statements</span> + <span class='fraction'>13/19</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">25% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/4</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">68.75% </span> + <span class="quiet">Lines</span> + <span class='fraction'>11/16</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-neutral"> </span> +<span class="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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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> +<span class="cline-any cline-yes">1×</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">/** + * Created by gavorhes on 12/4/2015. + */ +import {LayerBase, LayerBaseOptions} from './LayerBase'; +import provide from '../util/provide'; +import ol = require('custom-ol'); +const nm = provide('layers'); + + +/** + * XYZ tile + * @augments LayerBase + */ +export class LayerBaseXyzTile extends LayerBase { + + + /** + * The XYZ tile layer + * @param {string} url - url for source + * @param {object} options - config + * @param {string} [options.id] - layer id + * @param {string} [options.name=Unnamed Layer] - layer name + * @param {number} [options.opacity=1] - opacity + * @param {boolean} [options.visible=true] - default visible + * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28 + * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28 + * @param {object} [options.params={}] the get parameters to include to retrieve the layer + * @param {number} [options.zIndex=0] the z index for the layer + * @param {function} [options.loadCallback] function to call on load, context this is the layer object + * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed + * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility + * @param {boolean} [options.legendContent] additional content to add to the legend + * @param {boolean} [options.useEsriStyle=false] if the map service style should be used + */ +<span class="fstat-no" title="function not covered" > constructor(url: string, <span class="cstat-no" title="statement not covered" >options: LayerBaseOptions = {})</span></span> { + super(url, options); +<span class="cstat-no" title="statement not covered" > this._source = new ol.source.XYZ({url: this.url == '' ? undefined : this.url});</span> + +<span class="cstat-no" title="statement not covered" > this._olLayer = new ol.layer.Tile({</span> + source: this._source as ol.source.XYZ, + visible: this.visible, + opacity: this.opacity, + minResolution: this._minResolution, + maxResolution: this._maxResolution + } ); + +<span class="cstat-no" title="statement not covered" > this._olLayer.setZIndex(this._zIndex);</span> + } + + /** + * + * @returns {ol.source.XYZ} the vector source + */ +<span class="fstat-no" title="function not covered" > get source(): ol.source.XYZ {</span> +<span class="cstat-no" title="statement not covered" > return this._source as ol.source.XYZ;</span> + } + + /** + * + * @returns {ol.layer.Tile|ol.layer.Base|undefined} the ol layer + */ +<span class="fstat-no" title="function not covered" > get olLayer() : ol.layer.Tile {</span> +<span class="cstat-no" title="statement not covered" > return this._olLayer as ol.layer.Tile;</span> + } +} + +nm.LayerBaseXyzTile = LayerBaseXyzTile; +export default LayerBaseXyzTile; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerEsriMapServer.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerEsriMapServer.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..c0230b060ba5097161a5a13da903bc7d7fc09d9c --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerEsriMapServer.ts.html @@ -0,0 +1,572 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\LayerEsriMapServer.ts</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/layers/</a> LayerEsriMapServer.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">28.57% </span> + <span class="quiet">Statements</span> + <span class='fraction'>18/63</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/28</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">11.11% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/9</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">27.12% </span> + <span class="quiet">Lines</span> + <span class='fraction'>16/59</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any 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-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-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-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-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-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-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-yes">1×</span> +<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/7/2015. + */ +import {LayerBase, LayerBaseOptions} from './LayerBase'; +import * as esriToOl from '../olHelpers/esriToOlStyle'; +import mapPopup from '../olHelpers/mapPopup'; +import provide from '../util/provide'; +import ol = require('custom-ol'); +import $ = require('jquery'); + +const nm = provide('layers'); + + +export interface LayerEsriMapServerOptions extends LayerBaseOptions { + addPopup?: boolean; + showLayers?: Array<number>; +} + +/** + * esri mapserver layer + * @augments LayerBase + */ +export class LayerEsriMapServer extends LayerBase { + _esriFormat: ol.format.EsriJSON; + _popupRequest: JQueryXHR; + + /** + * The base layer for all others + * @param {string} url - resource url + * @param {object} [options] - config + * @param {string} [options.id] - layer id + * @param {string} [options.name=Unnamed Layer] - layer name + * @param {number} [options.opacity=1] - opacity + * @param {boolean} [options.visible=true] - default visible + * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28 + * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28 + * @param {object} [options.params={}] the get parameters to include to retrieve the layer + * @param {number} [options.zIndex=0] the z index for the layer + * @param {function} [options.loadCallback] function to call on load, context this is the layer object + * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed + * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility + * @param {boolean} [options.legendContent] additional content to add to the legend + * @param {boolean} [options.addPopup=false] if a popup should be added + * @param {undefined|Array<number>} [options.showLayers=undefined] if a popup should be added + */ +<span class="fstat-no" title="function not covered" > constructor(url, <span class="cstat-no" title="statement not covered" >options: LayerEsriMapServerOptions = {})</span></span> { + + super(url, options); +<span class="cstat-no" title="statement not covered" > this._source = new ol.source.TileArcGISRest(</span> + { + url: this.url == '' ? undefined : this.url, + params: typeof options.showLayers == 'undefined' ? undefined : {layers: 'show:' + options.showLayers.join(',')} + } + ); + +<span class="cstat-no" title="statement not covered" > this._olLayer = new ol.layer.Tile({</span> + source: this._source as ol.source.Tile, + visible: this.visible, + opacity: this.opacity, + minResolution: this._minResolution, + maxResolution: this._maxResolution + }); + +<span class="cstat-no" title="statement not covered" > this._olLayer.setZIndex(this._zIndex);</span> + +<span class="cstat-no" title="statement not covered" > options.addPopup = typeof options.addPopup == 'boolean' ? options.addPopup : false;</span> + +<span class="cstat-no" title="statement not covered" > this._esriFormat = new ol.format.EsriJSON();</span> +<span class="cstat-no" title="statement not covered" > this._popupRequest = null;</span> + +<span class="cstat-no" title="statement not covered" > this.addLegendContent();</span> + +<span class="cstat-no" title="statement not covered" > if (options.addPopup) {</span> +<span class="cstat-no" title="statement not covered" > mapPopup.addMapServicePopup(this);</span> + } + } + + /** + * add additional content to the legend + * @param {string} [additionalContent=''] additional content for legend + */ +<span class="fstat-no" title="function not covered" > addLegendContent(additionalContent?: string)</span> { +<span class="cstat-no" title="statement not covered" > let urlCopy = this.url;</span> + +<span class="cstat-no" title="statement not covered" > if (urlCopy[urlCopy.length - 1] !== '/') {</span> +<span class="cstat-no" title="statement not covered" > urlCopy += '/';</span> + } + +<span class="cstat-no" title="statement not covered" > urlCopy += 'legend?f=pjson&callback=?';</span> + +<span class="cstat-no" title="statement not covered" > $.get(urlCopy, {}, <span class="fstat-no" title="function not covered" >(d)</span> => {</span> +<span class="cstat-no" title="statement not covered" > let newHtml = esriToOl.makeMapServiceLegend(d);</span> +<span class="cstat-no" title="statement not covered" > super.addLegendContent(newHtml);</span> + }, 'json'); + } + + +<span class="fstat-no" title="function not covered" > getPopupInfo(queryParams)</span> { +<span class="cstat-no" title="statement not covered" > if (!this.visible) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > let urlCopy = this.url;</span> + +<span class="cstat-no" title="statement not covered" > if (urlCopy[urlCopy.length - 1] != '/') {</span> +<span class="cstat-no" title="statement not covered" > urlCopy += '/';</span> + } + +<span class="cstat-no" title="statement not covered" > urlCopy += 'identify?callback=?';</span> + +<span class="cstat-no" title="statement not covered" > let __this = this;</span> + +<span class="cstat-no" title="statement not covered" > if (this._popupRequest != null) {</span> +<span class="cstat-no" title="statement not covered" > this._popupRequest.abort();</span> + } + + +<span class="cstat-no" title="statement not covered" > this._popupRequest = $.get(urlCopy, queryParams, <span class="fstat-no" title="function not covered" >function (d)</span> {</span> +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let r </span>of d['results']) {</span> + +<span class="cstat-no" title="statement not covered" > let popupHtml = '<table class="esri-popup-table">';</span> + +<span class="cstat-no" title="statement not covered" > for (let a in r['attributes']) {</span> +<span class="cstat-no" title="statement not covered" > if (r['attributes'].hasOwnProperty(a)) {</span> +<span class="cstat-no" title="statement not covered" > let attrVal = r['attributes'][a];</span> + +<span class="cstat-no" title="statement not covered" > if (attrVal == null || attrVal.toString().toLowerCase() == 'null') {</span> +<span class="cstat-no" title="statement not covered" > continue;</span> + } + +<span class="cstat-no" title="statement not covered" > let attr = a;</span> +<span class="cstat-no" title="statement not covered" > if (attr.length > 14) {</span> +<span class="cstat-no" title="statement not covered" > attr = attr.slice(0, 11) + '...';</span> + } + +<span class="cstat-no" title="statement not covered" > popupHtml += `<tr><td>${attr}</td><td>${attrVal}</td></tr>`;</span> + } + } + +<span class="cstat-no" title="statement not covered" > popupHtml += '</table>';</span> + +<span class="cstat-no" title="statement not covered" > mapPopup.addMapServicePopupContent(__this._esriFormat.readFeature(r), __this, popupHtml, r['layerName']);</span> + } + }, 'json'); + +<span class="cstat-no" title="statement not covered" > this._popupRequest.always(<span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > __this._popupRequest = null;</span> + }); + + } + + /** + * + * @returns {ol.source.TileArcGISRest} the vector source + */ +<span class="fstat-no" title="function not covered" > get source(): ol.source.TileArcGISRest {</span> +<span class="cstat-no" title="statement not covered" > return super.getSource() as ol.source.TileArcGISRest;</span> + } + + /** + * + * @returns the ol layer + */ +<span class="fstat-no" title="function not covered" > get olLayer(): ol.layer.Tile {</span> +<span class="cstat-no" title="statement not covered" > return super.getOlLayer() as ol.layer.Tile;</span> + } +} +nm.LayerEsriMapServer = LayerEsriMapServer; +export default LayerEsriMapServer; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerEsriTile.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerEsriTile.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..a75d77b36ee55405ff31853e09e292a40e012d2e --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerEsriTile.ts.html @@ -0,0 +1,347 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\LayerEsriTile.ts</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/layers/</a> LayerEsriTile.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">34.29% </span> + <span class="quiet">Statements</span> + <span class='fraction'>12/35</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/18</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">25% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/4</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">32.26% </span> + <span class="quiet">Lines</span> + <span class='fraction'>10/31</span> + </div> + </div> + </div> + <div class='status-line low'></div> +<pre><table class="coverage"> +<tr><td class="line-count quiet">1 +2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +40 +41 +42 +43 +44 +45 +46 +47 +48 +49 +50 +51 +52 +53 +54 +55 +56 +57 +58 +59 +60 +61 +62 +63 +64 +65 +66 +67 +68 +69 +70 +71 +72 +73 +74 +75 +76 +77 +78 +79 +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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-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> +<span class="cline-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-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-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-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-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-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-yes">1×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/4/2015. + */ +import provide from '../util/provide'; +import {LayerBaseXyzTile} from './LayerBaseXyzTile'; +import {LayerBaseOptions} from './LayerBase' +import * as esriToOl from '../olHelpers/esriToOlStyle'; + + +const nm = provide('layers'); + +export interface LayerEsriTileOptions extends LayerBaseOptions{ + useEsriStyle?: boolean +} + +/** + * Esri tile + * @augments LayerBaseXyzTile + */ +export class LayerEsriTile extends LayerBaseXyzTile { + _useEsriStyle: boolean; + + /** + * The Esri tile layer + * @param {string} url - url for source + * @param {object} options - config + * @param {string} [options.id] - layer id + * @param {string} [options.name=Unnamed Layer] - layer name + * @param {number} [options.opacity=1] - opacity + * @param {boolean} [options.visible=true] - default visible + * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28 + * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28 + * @param {object} [options.params={}] the get parameters to include to retrieve the layer + * @param {number} [options.zIndex=0] the z index for the layer + * @param {function} [options.loadCallback] function to call on load, context this is the layer object + * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed + * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility + * @param {boolean} [options.legendContent] additional content to add to the legend + * @param {boolean} [options.useEsriStyle=false] if the map service style should be used + */ +<span class="fstat-no" title="function not covered" > constructor(url: string, <span class="cstat-no" title="statement not covered" >options: LayerEsriTileOptions = {})</span></span> { +<span class="cstat-no" title="statement not covered" > if (url.search(/\/$/) == -1) {</span> +<span class="cstat-no" title="statement not covered" > url += '/';</span> + } +<span class="cstat-no" title="statement not covered" > url += 'tile/{z}/{y}/{x}';</span> + +<span class="cstat-no" title="statement not covered" > super(url, options);</span> + +<span class="cstat-no" title="statement not covered" > this._useEsriStyle = typeof options.useEsriStyle == 'boolean' ? options.useEsriStyle : false;</span> + +<span class="cstat-no" title="statement not covered" > if (this._useEsriStyle) {</span> +<span class="cstat-no" title="statement not covered" > this.addLegendContent();</span> + } + } + + + /** + * add additional content to the legend + * @param {string} [additionalContent=''] additional content for legend + */ +<span class="fstat-no" title="function not covered" > addLegendContent(<span class="cstat-no" title="statement not covered" >additionalContent = '')</span></span>: void { +<span class="cstat-no" title="statement not covered" > if (!this._useEsriStyle) {</span> +<span class="cstat-no" title="statement not covered" > super.addLegendContent(additionalContent);</span> + } else { +<span class="cstat-no" title="statement not covered" > let urlCopy = this.url;</span> + +<span class="cstat-no" title="statement not covered" > let mapServerIndex = urlCopy.toLowerCase().indexOf('mapserver');</span> +<span class="cstat-no" title="statement not covered" > if (mapServerIndex > -1) {</span> +<span class="cstat-no" title="statement not covered" > urlCopy = urlCopy.slice(0, mapServerIndex + 9);</span> + } else { +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > if (urlCopy[urlCopy.length - 1] !== '/') {</span> +<span class="cstat-no" title="statement not covered" > urlCopy += '/';</span> + } + +<span class="cstat-no" title="statement not covered" > urlCopy += 'legend?f=pjson&callback=?';</span> + +<span class="cstat-no" title="statement not covered" > let superAddLegend = super.addLegendContent;</span> + +<span class="cstat-no" title="statement not covered" > $.get(urlCopy, {}, <span class="fstat-no" title="function not covered" >(d)</span> => {</span> +<span class="cstat-no" title="statement not covered" > let newHtml = esriToOl.makeMapServiceLegend(d);</span> +<span class="cstat-no" title="statement not covered" > superAddLegend.call(this, newHtml);</span> + }, 'json'); + } + } + + +} + +nm.LayerBaseXyzTile = LayerEsriTile; +export default LayerEsriTile; + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerItsInventory.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerItsInventory.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..79c09200ea55014299bb151c5fd2ee89a45f33e2 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerItsInventory.ts.html @@ -0,0 +1,1088 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\LayerItsInventory.ts</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/layers/</a> LayerItsInventory.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">14.29% </span> + <span class="quiet">Statements</span> + <span class='fraction'>17/119</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/64</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">20% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/10</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">13.79% </span> + <span class="quiet">Lines</span> + <span class='fraction'>16/116</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</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-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any 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-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-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-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-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> +<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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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> +<span class="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-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-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">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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/8/2015. + */ + +import LayerBaseVectorGeoJson from './LayerBaseVectorGeoJson'; +import mapPopup from '../olHelpers/mapPopup'; +import provide from '../util/provide'; +import ol = require('custom-ol'); +import $ = require('jquery'); +import {proj4326, proj3857} from '../olHelpers/projections' + +let nm = provide('layers'); + + +<span class="fstat-no" title="function not covered" >function checkStyleNumber(itsIcon, itsLineStyle, itsIconConfig, itsLineConfig)</span> { + "use strict"; + + //make sure one and only one configuration is defined; +<span class="cstat-no" title="statement not covered" > let configCount = 0;</span> +<span class="cstat-no" title="statement not covered" > if (typeof itsIcon == 'string') {</span> +<span class="cstat-no" title="statement not covered" > configCount++;</span> + } + +<span class="cstat-no" title="statement not covered" > if (typeof itsLineStyle == 'object') {</span> +<span class="cstat-no" title="statement not covered" > itsLineStyle.width = typeof itsLineStyle.width == 'number' ? itsLineStyle.width : 5;</span> +<span class="cstat-no" title="statement not covered" > itsLineStyle.color = typeof itsLineStyle.color == 'string' ? itsLineStyle.color : 'red';</span> +<span class="cstat-no" title="statement not covered" > configCount++;</span> + } + +<span class="cstat-no" title="statement not covered" > if (typeof itsIconConfig == 'object') {</span> +<span class="cstat-no" title="statement not covered" > itsIconConfig.defaultName = itsIconConfig.defaultName || 'Other';</span> + +<span class="cstat-no" title="statement not covered" > if (typeof itsIconConfig.iconArray == 'undefined') {</span> +<span class="cstat-no" title="statement not covered" > itsIconConfig.iconArray = [];</span> + } + +<span class="cstat-no" title="statement not covered" > configCount++;</span> + } + +<span class="cstat-no" title="statement not covered" > if (typeof itsLineConfig == 'object') {</span> +<span class="cstat-no" title="statement not covered" > itsLineConfig.defaultName = itsLineConfig.defaultName || 'Other';</span> +<span class="cstat-no" title="statement not covered" > itsLineConfig.defaultWidth = itsLineConfig.defaultWidth || 5;</span> +<span class="cstat-no" title="statement not covered" > itsLineConfig.defaultColor = itsLineConfig.defaultColor || 'red';</span> + + +<span class="cstat-no" title="statement not covered" > if (typeof itsLineConfig.lineArray == 'undefined') {</span> +<span class="cstat-no" title="statement not covered" > itsLineConfig.lineArray = [];</span> + } + + // set the width if not defined +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < itsLineConfig.lineArray.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > if (itsLineConfig.lineArray[i].length == 3) {</span> +<span class="cstat-no" title="statement not covered" > itsLineConfig.lineArray[i].push(5);</span> + } + } + +<span class="cstat-no" title="statement not covered" > configCount++;</span> + } + +<span class="cstat-no" title="statement not covered" > if (configCount > 1) {</span> +<span class="cstat-no" title="statement not covered" > throw 'Only one style config can be defined';</span> + } +} + +/** + * + * @param {string} [itsIcon=undefined] the ITS device type icon image see http://transportal.cee.wisc.edu/its/inventory/icons/ + * + * @param {object} [itsLineStyle=undefined] A single line style + * @param {string} itsLineStyle.color the line color as rgb or hex + * @param {number} [itsLineStyle.width=5] the line width + * + * @param {object} [itsIconConfig=undefined] The icon subtype configuration + * @param {string} itsIconConfig.prop The property used to define icon attribute symbolization + * @param {string} itsIconConfig.defaultName The default name to be used if no other match is found + * @param {string} itsIconConfig.defaultIcon The default icon to be used for no other matches + * @param {object} [itsIconConfig.iconArray=[]] an array, items with format [property, name, img] + * + * @param {object} [itsLineConfig=undefined] The property used to define icon attribute symbolization + * @param {string} itsLineConfig.prop The property used to define icon attribute symbolization + * @param {string} [itsLineConfig.defaultName=Other] The default name to be used if no other match is found + * @param {string} [itsLineConfig.defaultColor=red] The default line color to be used for no other matches + * @param {number} [itsLineConfig.defaultWidth=5] The default line width to be used for no other matches + * @param {object} [itsLineConfig.lineArray=[]] an array, items with format [property, name, color, optional width] + * @returns {*} undefined, style, or style function + */ +<span class="fstat-no" title="function not covered" >function defineStyle(itsIcon, itsLineStyle, itsIconConfig, itsLineConfig)</span> : ol.style.Style|Array<ol.style.Style>|ol.StyleFunction{ + "use strict"; +<span class="cstat-no" title="statement not covered" > checkStyleNumber(itsIcon, itsLineStyle, itsIconConfig, itsLineConfig);</span> + +<span class="cstat-no" title="statement not covered" > let _iconUrlRoot = 'http://transportal.cee.wisc.edu/its/inventory/icons/';</span> + +<span class="cstat-no" title="statement not covered" > if (itsIcon) {</span> +<span class="cstat-no" title="statement not covered" > return new ol.style.Style({</span> + image: new ol.style.Icon( + { + src: _iconUrlRoot + itsIcon, + crossOrigin: 'anonymous' + } + ) + }); + } else <span class="cstat-no" title="statement not covered" >if (itsLineStyle) {</span> +<span class="cstat-no" title="statement not covered" > return new ol.style.Style({</span> + stroke: new ol.style.Stroke({ + color: itsLineStyle.color, + width: itsLineStyle.width + }) + }); + } else <span class="cstat-no" title="statement not covered" >if (itsIconConfig) {</span> +<span class="cstat-no" title="statement not covered" > return <span class="fstat-no" title="function not covered" >function (feature: ol.Feature)</span> {</span> +<span class="cstat-no" title="statement not covered" > let symbolProp = feature.getProperties()[itsIconConfig.prop];</span> +<span class="cstat-no" title="statement not covered" > let iconUrl = _iconUrlRoot + itsIconConfig.defaultIcon;</span> + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < itsIconConfig.iconArray.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let thisProp = itsIconConfig.iconArray[i];</span> + +<span class="cstat-no" title="statement not covered" > if (symbolProp.trim().toLocaleLowerCase() == thisProp[0].trim().toLocaleLowerCase()) {</span> +<span class="cstat-no" title="statement not covered" > iconUrl = _iconUrlRoot + thisProp[2];</span> +<span class="cstat-no" title="statement not covered" > break;</span> + } + } + +<span class="cstat-no" title="statement not covered" > return [new ol.style.Style({</span> + image: new ol.style.Icon( + { + src: iconUrl, + crossOrigin: 'anonymous' + } + ) + })]; + }; + } else <span class="cstat-no" title="statement not covered" >if (itsLineConfig) {</span> +<span class="cstat-no" title="statement not covered" > return <span class="fstat-no" title="function not covered" >function (feature: ol.Feature)</span> {</span> +<span class="cstat-no" title="statement not covered" > let symbolProp = feature.getProperties()[itsLineConfig.prop];</span> +<span class="cstat-no" title="statement not covered" > let colr = itsLineConfig.defaultColor || 'red';</span> +<span class="cstat-no" title="statement not covered" > let width = itsLineConfig.defaultWidth || 5;</span> + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < itsLineConfig.lineArray.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let thisProp = itsLineConfig.lineArray[i];</span> + +<span class="cstat-no" title="statement not covered" > if (symbolProp.trim().toLocaleLowerCase() == thisProp[0].trim().toLocaleLowerCase()) {</span> +<span class="cstat-no" title="statement not covered" > colr = thisProp[2];</span> +<span class="cstat-no" title="statement not covered" > width = thisProp[3];</span> +<span class="cstat-no" title="statement not covered" > break;</span> + } + } + +<span class="cstat-no" title="statement not covered" > return [new ol.style.Style({</span> + stroke: new ol.style.Stroke({ + color: colr, + width: width + }) + })]; + }; + } else { +<span class="cstat-no" title="statement not covered" > return undefined;</span> + } +} + +/** + * + * @param {string} [itsIcon=undefined] the ITS device type icon image see http://transportal.cee.wisc.edu/its/inventory/icons/ + * + * @param {object} [itsLineStyle=undefined] A single line style + * @param {string} itsLineStyle.color the line color as rgb or hex + * @param {number} [itsLineStyle.width=5] the line width + * + * @param {object} [itsIconConfig=undefined] The icon subtype configuration + * @param {string} itsIconConfig.prop The property used to define icon attribute symbolization + * @param {string} itsIconConfig.defaultName The default name to be used if no other match is found + * @param {string} itsIconConfig.defaultIcon The default icon to be used for no other matches + * @param {object} [itsIconConfig.iconArray=[]] an array, items with format [property, name, img] + * + * @param {object} [itsLineConfig=undefined] The property used to define icon attribute symbolization + * @param {string} itsLineConfig.prop The property used to define icon attribute symbolization + * @param {string} [itsLineConfig.defaultName=Other] The default name to be used if no other match is found + * @param {string} [itsLineConfig.defaultColor=red] The default line color to be used for no other matches + * @param {number} [itsLineConfig.defaultWidth=5] The default line width to be used for no other matches + * @param {object} [itsLineConfig.lineArray=[]] an array, items with format [property, name, color, optional width] + * @returns {string} html to be added to the legend + */ +<span class="fstat-no" title="function not covered" >function defineLegend(itsIcon, itsLineStyle, itsIconConfig, itsLineConfig)</span> { + "use strict"; + +<span class="cstat-no" title="statement not covered" > let iconHeight = 17;</span> + +<span class="cstat-no" title="statement not covered" > checkStyleNumber(itsIcon, itsLineStyle, itsIconConfig, itsLineConfig);</span> + +<span class="cstat-no" title="statement not covered" > let _iconUrlRoot = 'http://transportal.cee.wisc.edu/its/inventory/icons/';</span> + +<span class="cstat-no" title="statement not covered" > if (itsIcon) {</span> +<span class="cstat-no" title="statement not covered" > return `<img src="${_iconUrlRoot + itsIcon}" class="legend-layer-icon" height="${iconHeight}">`;</span> + } else <span class="cstat-no" title="statement not covered" >if (itsLineStyle) {</span> +<span class="cstat-no" title="statement not covered" > return `<hr style="height: ${itsLineStyle.width}px; background-color: ${itsLineStyle.color}">`;</span> + } else <span class="cstat-no" title="statement not covered" >if (itsIconConfig) {</span> +<span class="cstat-no" title="statement not covered" > let outHtml = '';</span> +<span class="cstat-no" title="statement not covered" > outHtml += '<ul>';</span> + +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let a </span>of itsIconConfig.iconArray) {</span> +<span class="cstat-no" title="statement not covered" > outHtml += `<li><span class="legend-layer-subitem">${a[1]}</span><img src="${_iconUrlRoot + a[2]}" class="legend-layer-icon" height="${iconHeight}">`;</span> + } +<span class="cstat-no" title="statement not covered" > outHtml += `<li><span class="legend-layer-subitem">${itsIconConfig.defaultName}</span>` +</span> + `<img src="${_iconUrlRoot + itsIconConfig.defaultIcon}" class="legend-layer-icon" height="${iconHeight}"></li>`; +<span class="cstat-no" title="statement not covered" > outHtml += '</ul>';</span> + +<span class="cstat-no" title="statement not covered" > return outHtml;</span> + } else <span class="cstat-no" title="statement not covered" >if (itsLineConfig) {</span> +<span class="cstat-no" title="statement not covered" > let outHtml = '';</span> +<span class="cstat-no" title="statement not covered" > outHtml += '<ul>';</span> +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let ls </span>of itsLineConfig.lineArray) {</span> +<span class="cstat-no" title="statement not covered" > outHtml += `<li><span class="legend-layer-subitem">${ls[1]}</span>` +</span> + `<hr style="height: ${ls[3]}px; background-color: ${ls[2]}">`; + } +<span class="cstat-no" title="statement not covered" > outHtml += `<li><span class="legend-layer-subitem">${itsLineConfig.defaultName}</span>` +</span> + `<hr style="height: ${itsLineConfig.defaultWidth}px; background-color: ${itsLineConfig.defaultColor}"></li>`; +<span class="cstat-no" title="statement not covered" > outHtml += '</ul>';</span> + +<span class="cstat-no" title="statement not covered" > return outHtml;</span> + } else { +<span class="cstat-no" title="statement not covered" > return '';</span> + } +} + +/** + * Its Layer class + * @augments LayerBaseVectorGeoJson + */ +class LayerItsInventory extends LayerBaseVectorGeoJson { + + /** + * ITS device layer, types available at http://transportal.cee.wisc.edu/its/inventory/ + * @param {object} options - config + * @param {string} [options.id] - layer id + * @param {string} [options.name=Unnamed Layer] - layer name + * @param {number} [options.opacity=1] - opacity + * @param {boolean} [options.visible=true] - default visible + * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28 + * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28 + * @param {object} [options.params={}] the get parameters to include to retrieve the layer + * @param {number} [options.zIndex=0] the z index for the layer + * @param {function} [options.loadCallback] function to call on load, context this is the layer object + * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed + * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility + * @param {boolean} [options.legendContent] additional content to add to the legend + * + * @param {boolean} [options.autoLoad=false] if the layer should auto load if not visible + * @param {object|*} [options.style=undefined] the layer style, use openlayers default style if not defined + * @param {boolean} [options.onDemand=false] if the layer should be loaded by extent on map move + * @param {number} [options.onDemandDelay=300] delay before the map move callback should be called + * @param {MapMoveCls} [options.mapMoveObj=mapMove] alternate map move object for use with multi map pages + * + * @param {string} options.itsType the ITS device type, use the url flag at http://transportal.cee.wisc.edu/its/inventory/ + * @param {boolean} [options.addPopup=true] if the popup should be added automatically + * + * @param {string} [options.itsIcon=undefined] the ITS device type icon image see http://transportal.cee.wisc.edu/its/inventory/icons/ + * + * @param {object} [options.itsLineStyle=undefined] A single line style + * @param {string} options.itsLineStyle.color the line color as rgb or hex + * @param {number} [options.itsLineStyle.width=5] the line width + * + * @param {object} [options.itsIconConfig=undefined] The icon subtype configuration + * @param {string} options.itsIconConfig.prop The property used to define icon attribute symbolization + * @param {string} options.itsIconConfig.defaultName The default name to be used if no other match is found + * @param {string} options.itsIconConfig.defaultIcon The default icon to be used for no other matches + * @param {object} [options.itsIconConfig.iconArray=[]] an array, items with format [property, name, img] + * + * @param {object} [options.itsLineConfig=undefined] The property used to define icon attribute symbolization + * @param {string} options.itsLineConfig.prop The property used to define icon attribute symbolization + * @param {string} [options.itsLineConfig.defaultName=Other] The default name to be used if no other match is found + * @param {string} [options.itsLineConfig.defaultColor=red] The default line color to be used for no other matches + * @param {number} [options.itsLineConfig.defaultWidth] The default line width to be used for no other matches + * @param {object} [options.itsLineConfig.lineArray=[]] an array, items with format [property, name, color, optional width = 5] + */ +<span class="fstat-no" title="function not covered" > constructor(options)</span> { +<span class="cstat-no" title="statement not covered" > if (typeof options.itsType !== 'string') {</span> +<span class="cstat-no" title="statement not covered" > throw 'its type must be defined';</span> + } + +<span class="cstat-no" title="statement not covered" > options.transform = {dataProjection: proj4326, featureProjection: proj3857};</span> + +<span class="cstat-no" title="statement not covered" > let addToLegend = '';</span> + + // define a style with the helper function if it is not explicitly defined +<span class="cstat-no" title="statement not covered" > if (typeof options.style == 'undefined') {</span> +<span class="cstat-no" title="statement not covered" > options.style = defineStyle(</span> + options.itsIcon, options.itsLineStyle, options.itsIconConfig, options.itsLineConfig + ); +<span class="cstat-no" title="statement not covered" > addToLegend = defineLegend(</span> + options.itsIcon, options.itsLineStyle, options.itsIconConfig, options.itsLineConfig + ); + } + +<span class="cstat-no" title="statement not covered" > options.params = typeof options.params == 'object' ? options.params : {};</span> +<span class="cstat-no" title="statement not covered" > $.extend(options.params, {format: 'JSON', resource: options.itsType});</span> + +<span class="cstat-no" title="statement not covered" > super('http://transportal.cee.wisc.edu/its/inventory/', options);</span> + + //add any additional content to the legend +<span class="cstat-no" title="statement not covered" > this.addLegendContent(addToLegend);</span> + +<span class="cstat-no" title="statement not covered" > options.addPopup = typeof options.addPopup == 'boolean' ? options.addPopup : true;</span> + +<span class="cstat-no" title="statement not covered" > if (options.addPopup) {</span> +<span class="cstat-no" title="statement not covered" > mapPopup.addVectorPopup(this, <span class="fstat-no" title="function not covered" >function (props)</span> {</span> +<span class="cstat-no" title="statement not covered" > return `<iframe src="http://transportal.cee.wisc.edu/its/inventory/?feature=${props['featureGuid']}" ` +</span> + `height="250" width="350"></iframe>`; + }); + } + } + + /** + * callback to generate the parameters passed in the get request + * @callback makeGetParams + * @param {object} extent - extent object + * @param {number} extent.minX - minX + * @param {number} extent.minY - minY + * @param {number} extent.maxX - maxX + * @param {number} extent.maxY - maxY + * @param {number} zoomLevel - zoom level + */ +<span class="fstat-no" title="function not covered" > mapMoveMakeGetParams(extent, zoomLevel)</span> { +<span class="cstat-no" title="statement not covered" > super.mapMoveMakeGetParams(extent, zoomLevel);</span> +<span class="cstat-no" title="statement not covered" > let lowerLeft = new ol.geom.Point([extent.minX, extent.minY]);</span> +<span class="cstat-no" title="statement not covered" > lowerLeft.transform(this.mapProj, this._projection4326);</span> +<span class="cstat-no" title="statement not covered" > let lowerLeftCoordinates = lowerLeft.getCoordinates();</span> +<span class="cstat-no" title="statement not covered" > let upperRight = new ol.geom.Point([extent.maxX, extent.maxY]);</span> +<span class="cstat-no" title="statement not covered" > upperRight.transform(this.mapProj, this._projection4326);</span> +<span class="cstat-no" title="statement not covered" > let upperRightCoordinates = upperRight.getCoordinates();</span> + +<span class="cstat-no" title="statement not covered" > $.extend(this.mapMoveParams,</span> + { + L: lowerLeftCoordinates[0], + R: upperRightCoordinates[0], + B: lowerLeftCoordinates[1], + T: upperRightCoordinates[1] + }); + } +} + +nm.LayerItsInventory = LayerItsInventory; +export default LayerItsInventory; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerRealEarthTile.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerRealEarthTile.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..5657b13224a423fac5e703ad83008119e4fe67b0 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerRealEarthTile.ts.html @@ -0,0 +1,296 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\LayerRealEarthTile.ts</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/layers/</a> LayerRealEarthTile.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">48.15% </span> + <span class="quiet">Statements</span> + <span class='fraction'>13/27</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">40% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/5</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">44% </span> + <span class="quiet">Lines</span> + <span class='fraction'>11/25</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</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-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> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-neutral"> </span> +<span class="cline-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-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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 11/4/2015. + */ + +import {LayerBaseXyzTile} from './LayerBaseXyzTile'; +import {LayerBaseOptions} from './LayerBase'; +import RealEarthAnimateTile from '../mixin/RealEarthAnimateTile'; +import provide from '../util/provide'; +import {IRealEarthAnimate, timesLoadedCallback} from "../mixin/RealEarthAnimate"; +const nm = provide('layers'); + +export interface LayerRealEarthTileOptions extends LayerBaseOptions { + products: string; + animate?: boolean; + timeLoadCallback?: timesLoadedCallback; +} + + +/** + * Real earth tile + * @augments LayerBaseXyzTile + */ +export class LayerRealEarthTile extends LayerBaseXyzTile implements IRealEarthAnimate { + _products: string; + animator: RealEarthAnimateTile; + + /** + * The base layer for all others + * @param {object} options - config + * @param {string} [options.id] - layer id + * @param {string} [options.name=Unnamed Layer] - layer name + * @param {number} [options.opacity=1] - opacity + * @param {boolean} [options.visible=true] - default visible + * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28 + * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28 + * @param {object} [options.params={}] the get parameters to include to retrieve the layer + * @param {number} [options.zIndex=0] the z index for the layer + * @param {function} [options.loadCallback] function to call on load, context this is the layer object + * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed + * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility + * @param {boolean} [options.legendContent] additional content to add to the legend + * + * @param {string} options.products - the products to request + * @param {boolean} [options.hasTimes=false] If the layer is time dependent, fixed set of dates + * @param {boolean} [options.animate=false] if the layer should be animated + */ +<span class="fstat-no" title="function not covered" > constructor(options: LayerRealEarthTileOptions)</span> { +<span class="cstat-no" title="statement not covered" > options.animate = typeof options.animate == 'boolean' ? options.animate : false;</span> +<span class="cstat-no" title="statement not covered" > if (options.animate) {</span> +<span class="cstat-no" title="statement not covered" > super('', options);</span> +<span class="cstat-no" title="statement not covered" > this._products = options.products;</span> +<span class="cstat-no" title="statement not covered" > this.animator = new RealEarthAnimateTile(this, options.timeLoadCallback);</span> +<span class="cstat-no" title="statement not covered" > this.animator.timeInit();</span> + } else { +<span class="cstat-no" title="statement not covered" > super(`http://realearth.ssec.wisc.edu/api/image?products=${options.products}&x={x}&y={y}&z={z}`, options);</span> +<span class="cstat-no" title="statement not covered" > this._products = options.products;</span> + } + } + +<span class="fstat-no" title="function not covered" > setLayerTime(theTime: number)</span>: boolean { +<span class="cstat-no" title="statement not covered" > if (this.animator) {</span> +<span class="cstat-no" title="statement not covered" > return this.animator.setLayerTime(theTime);</span> + } else { +<span class="cstat-no" title="statement not covered" > return false;</span> + } + } + +<span class="fstat-no" title="function not covered" > _load(): boolean {</span> +<span class="cstat-no" title="statement not covered" > if (this.animator) {</span> +<span class="cstat-no" title="statement not covered" > return false;</span> + } +<span class="cstat-no" title="statement not covered" > return super._load();</span> + } +} + +nm.LayerRealEarthTile = LayerRealEarthTile; +export default LayerRealEarthTile; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerRealEarthVector.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerRealEarthVector.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..f8a9a79397591ef264312cdf30cea42be4fbec3c --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/LayerRealEarthVector.ts.html @@ -0,0 +1,332 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\LayerRealEarthVector.ts</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/layers/</a> LayerRealEarthVector.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">46.43% </span> + <span class="quiet">Statements</span> + <span class='fraction'>13/28</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">40% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/5</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">42.31% </span> + <span class="quiet">Lines</span> + <span class='fraction'>11/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</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-yes">1×</span> +<span class="cline-any 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-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-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-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">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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 11/13/2015. + */ + +import {LayerBaseVectorGeoJson, LayerBaseVectorGeoJsonOptions} from './LayerBaseVectorGeoJson'; +import RealEarthAnimateVector from '../mixin/RealEarthAnimateVector'; +import provide from '../util/provide'; +import {IRealEarthAnimate, timesLoadedCallback} from "../mixin/RealEarthAnimate"; + +const nm = provide('layers'); + +export interface LayerVectorRealEarthOptions extends LayerBaseVectorGeoJsonOptions { + products: string; + animate?: boolean; + timeLoadCallback?: timesLoadedCallback; +} + + +/** + * Vector real earth vector + * @augments LayerBaseVectorGeoJson + */ +export class LayerVectorRealEarth extends LayerBaseVectorGeoJson implements IRealEarthAnimate { + _products: string; + animator: RealEarthAnimateVector; + + /** + * Real Earth vector layer + * @param {object} options - config + * @param {string} [options.id] - layer id + * @param {string} [options.name=Unnamed Layer] - layer name + * @param {number} [options.opacity=1] - opacity + * @param {boolean} [options.visible=true] - default visible + * @param {number} [options.minZoom=undefined] - min zoom level, 0 - 28 + * @param {number} [options.maxZoom=undefined] - max zoom level, 0 - 28 + * @param {object} [options.params={}] the get parameters to include to retrieve the layer + * @param {number} [options.zIndex=0] the z index for the layer + * @param {function} [options.loadCallback] function to call on load, context this is the layer object + * @param {boolean} [options.legendCollapse=false] if the legend item should be initially collapsed + * @param {boolean} [options.legendCheckbox=true] if the legend item should have a checkbox for visibility + * @param {boolean} [options.legendContent] additional content to add to the legend + * + * @param {boolean} [options.autoLoad=false] if the layer should auto load if not visible + * @param {object} [options.style=undefined] the layer style, use openlayers default style if not defined + * @param {boolean} [options.onDemand=false] if the layer should be loaded by extent on map move + * @param {number} [options.onDemandDelay=300] delay before the map move callback should be called + * @param {MapMoveCls} [options.mapMoveObj=mapMove] alternate map move object for use with multi map pages + * + * @param {object} [options.transform={}] SR transform, set as false for no transform + * @param {string} options.transform.dataProjection=EPSG:4326 the _data CRS + * @param {string} options.transform.featureProjection=EPSG:3857 the feature/map CRS + * + * @param {string} options.products real earth products identifier + * @param {boolean} [options.animate=false] if the layer should be animated + */ +<span class="fstat-no" title="function not covered" > constructor(options: LayerVectorRealEarthOptions)</span> { +<span class="cstat-no" title="statement not covered" > options.animate = typeof options.animate == 'boolean' ? options.animate : false;</span> +<span class="cstat-no" title="statement not covered" > if (options.animate) {</span> +<span class="cstat-no" title="statement not covered" > options.autoLoad = false;</span> +<span class="cstat-no" title="statement not covered" > super('', options);</span> +<span class="cstat-no" title="statement not covered" > this._products = options.products;</span> +<span class="cstat-no" title="statement not covered" > this.animator = new RealEarthAnimateVector(this, options.timeLoadCallback);</span> +<span class="cstat-no" title="statement not covered" > this.animator.timeInit();</span> + } else { +<span class="cstat-no" title="statement not covered" > options.params = {products: options.products};</span> +<span class="cstat-no" title="statement not covered" > super('http://realearth.ssec.wisc.edu/api/shapes', options);</span> + } + } + +<span class="fstat-no" title="function not covered" > setLayerTime(theTime: number)</span>: boolean { +<span class="cstat-no" title="statement not covered" > if (this.animator) {</span> +<span class="cstat-no" title="statement not covered" > return this.animator.setLayerTime(theTime);</span> + } else { +<span class="cstat-no" title="statement not covered" > return false;</span> + } + } + +<span class="fstat-no" title="function not covered" > _load(): boolean{</span> +<span class="cstat-no" title="statement not covered" > if (this.animator){</span> +<span class="cstat-no" title="statement not covered" > return false;</span> + } +<span class="cstat-no" title="statement not covered" > return super._load();</span> + } + + +} + +nm.LayerVectorRealEarth = LayerVectorRealEarth; +export default LayerVectorRealEarth; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/index.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/index.html new file mode 100644 index 0000000000000000000000000000000000000000..2a02a5a9c3d4fdefc8c04c988b4b9b754fb4be07 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/layers/index.html @@ -0,0 +1,210 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\layers\</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/layers/ + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">44.09% </span> + <span class="quiet">Statements</span> + <span class='fraction'>276/626</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">18% </span> + <span class="quiet">Branches</span> + <span class='fraction'>54/300</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">30.77% </span> + <span class="quiet">Functions</span> + <span class='fraction'>36/117</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">42.55% </span> + <span class="quiet">Lines</span> + <span class='fraction'>254/597</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 medium" data-value="LayerBase.ts"><a href="LayerBase.ts.html">LayerBase.ts</a></td> + <td data-value="60.99" 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.99" class="pct medium">60.99%</td> + <td data-value="141" class="abs medium">86/141</td> + <td data-value="39.71" class="pct low">39.71%</td> + <td data-value="68" class="abs low">27/68</td> + <td data-value="31.58" class="pct low">31.58%</td> + <td data-value="38" class="abs low">12/38</td> + <td data-value="60.14" class="pct medium">60.14%</td> + <td data-value="138" class="abs medium">83/138</td> + </tr> + +<tr> + <td class="file medium" data-value="LayerBaseVector.ts"><a href="LayerBaseVector.ts.html">LayerBaseVector.ts</a></td> + <td data-value="58.7" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 58%;"></div><div class="cover-empty" style="width:42%;"></div></div></td> + <td data-value="58.7" class="pct medium">58.7%</td> + <td data-value="92" class="abs medium">54/92</td> + <td data-value="29.55" class="pct low">29.55%</td> + <td data-value="44" class="abs low">13/44</td> + <td data-value="36.36" class="pct low">36.36%</td> + <td data-value="22" class="abs low">8/22</td> + <td data-value="57.3" class="pct medium">57.3%</td> + <td data-value="89" class="abs medium">51/89</td> + </tr> + +<tr> + <td class="file low" data-value="LayerBaseVectorEsri.ts"><a href="LayerBaseVectorEsri.ts.html">LayerBaseVectorEsri.ts</a></td> + <td data-value="28.79" class="pic low"><div class="chart"><div class="cover-fill" style="width: 28%;"></div><div class="cover-empty" style="width:72%;"></div></div></td> + <td data-value="28.79" class="pct low">28.79%</td> + <td data-value="66" class="abs low">19/66</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="30" class="abs low">0/30</td> + <td data-value="16.67" class="pct low">16.67%</td> + <td data-value="12" class="abs low">2/12</td> + <td data-value="26.56" class="pct low">26.56%</td> + <td data-value="64" class="abs low">17/64</td> + </tr> + +<tr> + <td class="file high" data-value="LayerBaseVectorGeoJson.ts"><a href="LayerBaseVectorGeoJson.ts.html">LayerBaseVectorGeoJson.ts</a></td> + <td data-value="86.11" class="pic high"><div class="chart"><div class="cover-fill" style="width: 86%;"></div><div class="cover-empty" style="width:14%;"></div></div></td> + <td data-value="86.11" class="pct high">86.11%</td> + <td data-value="36" class="abs high">31/36</td> + <td data-value="77.78" class="pct medium">77.78%</td> + <td data-value="18" class="abs medium">14/18</td> + <td data-value="62.5" class="pct medium">62.5%</td> + <td data-value="8" class="abs medium">5/8</td> + <td data-value="84.85" class="pct high">84.85%</td> + <td data-value="33" class="abs high">28/33</td> + </tr> + +<tr> + <td class="file medium" data-value="LayerBaseXyzTile.ts"><a href="LayerBaseXyzTile.ts.html">LayerBaseXyzTile.ts</a></td> + <td data-value="68.42" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 68%;"></div><div class="cover-empty" style="width:32%;"></div></div></td> + <td data-value="68.42" class="pct medium">68.42%</td> + <td data-value="19" class="abs medium">13/19</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="6" class="abs low">0/6</td> + <td data-value="25" class="pct low">25%</td> + <td data-value="4" class="abs low">1/4</td> + <td data-value="68.75" class="pct medium">68.75%</td> + <td data-value="16" class="abs medium">11/16</td> + </tr> + +<tr> + <td class="file low" data-value="LayerEsriMapServer.ts"><a href="LayerEsriMapServer.ts.html">LayerEsriMapServer.ts</a></td> + <td data-value="28.57" class="pic low"><div class="chart"><div class="cover-fill" style="width: 28%;"></div><div class="cover-empty" style="width:72%;"></div></div></td> + <td data-value="28.57" class="pct low">28.57%</td> + <td data-value="63" class="abs low">18/63</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="28" class="abs low">0/28</td> + <td data-value="11.11" class="pct low">11.11%</td> + <td data-value="9" class="abs low">1/9</td> + <td data-value="27.12" class="pct low">27.12%</td> + <td data-value="59" class="abs low">16/59</td> + </tr> + +<tr> + <td class="file low" data-value="LayerEsriTile.ts"><a href="LayerEsriTile.ts.html">LayerEsriTile.ts</a></td> + <td data-value="34.29" 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.29" class="pct low">34.29%</td> + <td data-value="35" class="abs low">12/35</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="18" class="abs low">0/18</td> + <td data-value="25" class="pct low">25%</td> + <td data-value="4" class="abs low">1/4</td> + <td data-value="32.26" class="pct low">32.26%</td> + <td data-value="31" class="abs low">10/31</td> + </tr> + +<tr> + <td class="file low" data-value="LayerItsInventory.ts"><a href="LayerItsInventory.ts.html">LayerItsInventory.ts</a></td> + <td data-value="14.29" class="pic low"><div class="chart"><div class="cover-fill" style="width: 14%;"></div><div class="cover-empty" style="width:86%;"></div></div></td> + <td data-value="14.29" class="pct low">14.29%</td> + <td data-value="119" class="abs low">17/119</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="64" class="abs low">0/64</td> + <td data-value="20" class="pct low">20%</td> + <td data-value="10" class="abs low">2/10</td> + <td data-value="13.79" class="pct low">13.79%</td> + <td data-value="116" class="abs low">16/116</td> + </tr> + +<tr> + <td class="file low" data-value="LayerRealEarthTile.ts"><a href="LayerRealEarthTile.ts.html">LayerRealEarthTile.ts</a></td> + <td data-value="48.15" class="pic low"><div class="chart"><div class="cover-fill" style="width: 48%;"></div><div class="cover-empty" style="width:52%;"></div></div></td> + <td data-value="48.15" class="pct low">48.15%</td> + <td data-value="27" class="abs low">13/27</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="12" class="abs low">0/12</td> + <td data-value="40" class="pct low">40%</td> + <td data-value="5" class="abs low">2/5</td> + <td data-value="44" class="pct low">44%</td> + <td data-value="25" class="abs low">11/25</td> + </tr> + +<tr> + <td class="file low" data-value="LayerRealEarthVector.ts"><a href="LayerRealEarthVector.ts.html">LayerRealEarthVector.ts</a></td> + <td data-value="46.43" 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.43" class="pct low">46.43%</td> + <td data-value="28" class="abs low">13/28</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="12" class="abs low">0/12</td> + <td data-value="40" class="pct low">40%</td> + <td data-value="5" class="abs low">2/5</td> + <td data-value="42.31" class="pct low">42.31%</td> + <td data-value="26" class="abs low">11/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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/RealEarthAnimate.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/RealEarthAnimate.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..ea0aa372956f9602a4979c4fc3f11fb30c5e0e52 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/RealEarthAnimate.ts.html @@ -0,0 +1,554 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\mixin\RealEarthAnimate.ts</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/mixin/</a> RealEarthAnimate.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">21.43% </span> + <span class="quiet">Statements</span> + <span class='fraction'>15/70</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/14</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">12.5% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/8</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">20.59% </span> + <span class="quiet">Lines</span> + <span class='fraction'>14/68</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/4/2015. + */ +import provide from '../util/provide'; +import mapPopup from '../olHelpers/mapPopup'; +import LayerRealEarthTile from "../layers/LayerRealEarthTile"; +import {LayerVectorRealEarth} from '../layers/LayerRealEarthVector' +import $ = require('jquery'); + +const nm = provide('mixin'); + + +/** + * The GMT offset time in minutes + * @type {number} + */ +let offsetMinutes = (new Date()).getTimezoneOffset(); + +export interface IRealEarthAnimate{ + setLayerTime(theTime: number): boolean; +} + +export interface timesLoadedCallback{ + (lyr?: LayerRealEarthTile|LayerVectorRealEarth): void; +} + + +/** + * Mixin to get the product times + * Be sure to call getTimeInit after the mixin has been applied + */ +export class RealEarthAnimate { + _animateEnabled: boolean; + _currentIndex: number; + _localDates: Date[]; + _rawDateStrings: string[]; + _products: string; + loadCallback: timesLoadedCallback; + localTimes: number[]; + _currentTime: number; + + lyr: LayerRealEarthTile|LayerVectorRealEarth; + +<span class="fstat-no" title="function not covered" > constructor(lyr: LayerRealEarthTile|LayerVectorRealEarth, loadCallback?: timesLoadedCallback)</span>{ +<span class="cstat-no" title="statement not covered" > this.lyr = lyr;</span> +<span class="cstat-no" title="statement not covered" > this._products = lyr._products;</span> +<span class="cstat-no" title="statement not covered" > if (loadCallback){</span> +<span class="cstat-no" title="statement not covered" > this.loadCallback = loadCallback;</span> + } else { +<span class="cstat-no" title="statement not covered" > this.loadCallback = <span class="fstat-no" title="function not covered" >function(): void {<span class="cstat-no" title="statement not covered" ></span>return;}</span>;</span> + } + } + + + /** + * Call this after the mixin has been applied + */ +<span class="fstat-no" title="function not covered" > timeInit() {</span> + +<span class="cstat-no" title="statement not covered" > this._rawDateStrings = [];</span> +<span class="cstat-no" title="statement not covered" > this._localDates = [];</span> +<span class="cstat-no" title="statement not covered" > this.localTimes = [];</span> +<span class="cstat-no" title="statement not covered" > this._animateEnabled = true;</span> + // this._loaded = true; +<span class="cstat-no" title="statement not covered" > this._currentTime = undefined;</span> +<span class="cstat-no" title="statement not covered" > this._currentIndex = undefined;</span> + +<span class="cstat-no" title="statement not covered" > $.get('http://realearth.ssec.wisc.edu/api/products', {products: this._products}, <span class="fstat-no" title="function not covered" >(d)</span> => {</span> +<span class="cstat-no" title="statement not covered" > if (d.length == 0) {</span> +<span class="cstat-no" title="statement not covered" > console.log(`${this._products} layer not available or does not have times`);</span> + +<span class="cstat-no" title="statement not covered" > return;</span> + } +<span class="cstat-no" title="statement not covered" > d = d[0];</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < d['times'].length; i++) {</span> +<span class="cstat-no" title="statement not covered" > this._loadDates.call(this, d['times'][i]);</span> + } +<span class="cstat-no" title="statement not covered" > this.loadCallback.call(this.lyr, this.lyr);</span> +<span class="cstat-no" title="statement not covered" > this._loadLatest.call(this);</span> + }, 'json'); + } + + + /** + * Given the raw time string, add to the arrays to keep track of dates and cache + * @param {string} inString - input string to parse + * @returns {string} the converted string + * @protected + */ +<span class="fstat-no" title="function not covered" > _loadDates(inString: string)</span>: string { +<span class="cstat-no" title="statement not covered" > let yr = inString.slice(0, 4);</span> +<span class="cstat-no" title="statement not covered" > let month = inString.slice(4, 6);</span> +<span class="cstat-no" title="statement not covered" > let d = inString.slice(6, 8);</span> +<span class="cstat-no" title="statement not covered" > let hr = inString.slice(9, 11);</span> +<span class="cstat-no" title="statement not covered" > let mn = inString.slice(11, 13);</span> +<span class="cstat-no" title="statement not covered" > let sec = inString.slice(13, 15);</span> + +<span class="cstat-no" title="statement not covered" > let rawDateStr = inString.replace('.', '_');</span> +<span class="cstat-no" title="statement not covered" > this._rawDateStrings.push(rawDateStr);</span> + +<span class="cstat-no" title="statement not covered" > let dteStr = `${month}/${d}/${yr} ${hr}:${mn}:${sec}`;</span> +<span class="cstat-no" title="statement not covered" > let newDte = new Date(dteStr);</span> +<span class="cstat-no" title="statement not covered" > newDte.setMinutes(newDte.getMinutes() - offsetMinutes);</span> +<span class="cstat-no" title="statement not covered" > this._localDates.push(newDte);</span> +<span class="cstat-no" title="statement not covered" > this.localTimes.push(newDte.getTime());</span> + +<span class="cstat-no" title="statement not covered" > return rawDateStr;</span> + } + + /** + * + * @protected + * @returns {boolean} if should continue + */ +<span class="fstat-no" title="function not covered" > _loadLatest(){</span> +<span class="cstat-no" title="statement not covered" > mapPopup.closePopup();</span> +<span class="cstat-no" title="statement not covered" > if (this.localTimes.length > 0){</span> +<span class="cstat-no" title="statement not covered" > this._currentIndex = this.localTimes.length -1;</span> + +<span class="cstat-no" title="statement not covered" > return true;</span> + } else { +<span class="cstat-no" title="statement not covered" > return false;</span> + } + } + + /** + * + * @param {number} theTime - the time + * @returns {boolean} true if new index, false if the same or below lowest value + */ +<span class="fstat-no" title="function not covered" > setLayerTime(theTime: number)</span>: boolean{ + +<span class="cstat-no" title="statement not covered" > this._currentTime = theTime;</span> + +<span class="cstat-no" title="statement not covered" > let newIndex;</span> + +<span class="cstat-no" title="statement not covered" > if (theTime < this.localTimes[0]){</span> +<span class="cstat-no" title="statement not covered" > return false;</span> + } else <span class="cstat-no" title="statement not covered" >if (theTime > this.localTimes[this.localTimes.length - 1]){</span> +<span class="cstat-no" title="statement not covered" > newIndex = this.localTimes.length - 1;</span> + } + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < this.localTimes.length; i++){</span> +<span class="cstat-no" title="statement not covered" > if (this.localTimes[i] >= theTime){</span> +<span class="cstat-no" title="statement not covered" > newIndex = i;</span> +<span class="cstat-no" title="statement not covered" > break;</span> + } + } + +<span class="cstat-no" title="statement not covered" > if (newIndex == this._currentIndex){</span> +<span class="cstat-no" title="statement not covered" > return false;</span> + } else { +<span class="cstat-no" title="statement not covered" > this._currentIndex = newIndex;</span> +<span class="cstat-no" title="statement not covered" > mapPopup.closePopup();</span> + +<span class="cstat-no" title="statement not covered" > return true;</span> + } + } +} + +nm.RealEarthAnimate = RealEarthAnimate; +export default RealEarthAnimate; + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/RealEarthAnimateTile.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/RealEarthAnimateTile.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..09475e3ecf046ec2c67a9af7c1430cdff3a7ccaf --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/RealEarthAnimateTile.ts.html @@ -0,0 +1,257 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\mixin\RealEarthAnimateTile.ts</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/mixin/</a> RealEarthAnimateTile.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">43.33% </span> + <span class="quiet">Statements</span> + <span class='fraction'>13/30</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/8</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">16.67% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/6</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">41.38% </span> + <span class="quiet">Lines</span> + <span class='fraction'>12/29</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/4/2015. + */ +import RealEarthAnimate from './RealEarthAnimate'; +import provide from '../util/provide'; +import ol = require('custom-ol'); +import LayerRealEarthTile from "../layers/LayerRealEarthTile"; +const nm = provide('mixin'); + +/** + * Animate real earth tile + * @augments RealEarthAnimate + */ +class RealEarthAnimateTile extends RealEarthAnimate { + _sourceUrls: string[]; + _source: ol.source.XYZ; + _olLayer: ol.layer.Tile; + +<span class="fstat-no" title="function not covered" > constructor(layer: LayerRealEarthTile, loadCallback?: (lyr: LayerRealEarthTile) => void)</span>{ + super(layer, loadCallback); +<span class="cstat-no" title="statement not covered" > this._source = layer.source;</span> +<span class="cstat-no" title="statement not covered" > this._olLayer = layer.olLayer;</span> + } + + + +<span class="fstat-no" title="function not covered" > timeInit() {</span> +<span class="cstat-no" title="statement not covered" > super.timeInit();</span> +<span class="cstat-no" title="statement not covered" > this._sourceUrls = [];</span> + } + +<span class="fstat-no" title="function not covered" > _loadDates(inString: string)</span>: string { +<span class="cstat-no" title="statement not covered" > let rawDte = super._loadDates(inString);</span> +<span class="cstat-no" title="statement not covered" > let dteProductUrl =</span> + `http://realearth.ssec.wisc.edu/api/image?products=${this._products}_${rawDte}&x={x}&y={y}&z={z}`; +<span class="cstat-no" title="statement not covered" > this._sourceUrls.push(dteProductUrl);</span> +<span class="cstat-no" title="statement not covered" > return '';</span> + } + + /** + * @protected + */ +<span class="fstat-no" title="function not covered" > _loadLatest(): boolean {</span> +<span class="cstat-no" title="statement not covered" > if (super._loadLatest()){</span> +<span class="cstat-no" title="statement not covered" > this._source.setUrl(this._sourceUrls[this._sourceUrls.length - 1]);</span> + } +<span class="cstat-no" title="statement not covered" > return true;</span> + } + +<span class="fstat-no" title="function not covered" > setLayerTime(theTime: number)</span>: boolean { +<span class="cstat-no" title="statement not covered" > if (super.setLayerTime(theTime)) {</span> +<span class="cstat-no" title="statement not covered" > if (this._olLayer.getZIndex() < 0){</span> +<span class="cstat-no" title="statement not covered" > this._olLayer.setZIndex(0);</span> + } +<span class="cstat-no" title="statement not covered" > this._source.setUrl(this._sourceUrls[this._currentIndex]);</span> + } else { +<span class="cstat-no" title="statement not covered" > this._olLayer.setZIndex(-1);</span> + } +<span class="cstat-no" title="statement not covered" > return true;</span> + } +} + +nm.RealEarthAnimateTile = RealEarthAnimateTile; +export default RealEarthAnimateTile; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/RealEarthAnimateVector.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/RealEarthAnimateVector.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..0f2fe40581dc0dc95ce4cb7b1a576694d6ce2cd4 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/RealEarthAnimateVector.ts.html @@ -0,0 +1,416 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\mixin\RealEarthAnimateVector.ts</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/mixin/</a> RealEarthAnimateVector.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">34.78% </span> + <span class="quiet">Statements</span> + <span class='fraction'>16/46</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/14</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">11.11% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/9</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">34.09% </span> + <span class="quiet">Lines</span> + <span class='fraction'>15/44</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-yes">1×</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">/** + * Created by gavorhes on 12/4/2015. + */ +import RealEarthAnimate from './RealEarthAnimate'; +import provide from '../util/provide'; +import ol = require('custom-ol'); +import {LayerVectorRealEarth} from "../layers/LayerRealEarthVector"; +import $ = require('jquery'); +const nm = provide('mixin'); + + +/** + * class mixin to animate RealEarth vector layers + * @augments RealEarthAnimate + */ +class RealEarthAnimateVector extends RealEarthAnimate { + _dataCache: Array<Array<Object>|Object>; + _source: ol.source.Vector; + _rawTimesLookup: {[s: string]: any}; + _currentIndex: number; + _olLayer: ol.layer.Vector; + _lyr: LayerVectorRealEarth; + +<span class="fstat-no" title="function not covered" > constructor(layer: LayerVectorRealEarth, loadCallback?: (lyr: LayerVectorRealEarth) => void)</span>{ + super(layer, loadCallback); +<span class="cstat-no" title="statement not covered" > this._source = layer.source;</span> +<span class="cstat-no" title="statement not covered" > this._olLayer = layer.olLayer;</span> +<span class="cstat-no" title="statement not covered" > this._lyr = layer;</span> + } + + + /** + * Call this after the mixin has been applied + */ +<span class="fstat-no" title="function not covered" > timeInit() {</span> +<span class="cstat-no" title="statement not covered" > super.timeInit();</span> +<span class="cstat-no" title="statement not covered" > this._rawTimesLookup = {};</span> +<span class="cstat-no" title="statement not covered" > this._dataCache = [];</span> + } + + /** + * Given the raw time string, add to the arrays to keep track of dates and cache + * @param {string} inString - input date string + * @protected + */ +<span class="fstat-no" title="function not covered" > _loadDates(inString: string)</span>: string { +<span class="cstat-no" title="statement not covered" > let rawDte = super._loadDates(inString);</span> +<span class="cstat-no" title="statement not covered" > this._dataCache.push(null);</span> +<span class="cstat-no" title="statement not covered" > this._rawTimesLookup[rawDte] = null;</span> +<span class="cstat-no" title="statement not covered" > return '';</span> + } + + /** + * @protected + */ +<span class="fstat-no" title="function not covered" > _loadLatest(): boolean {</span> +<span class="cstat-no" title="statement not covered" > if (super._loadLatest()) {</span> +<span class="cstat-no" title="statement not covered" > this._loadAtTimeIndex.call(this, this._currentIndex);</span> + } +<span class="cstat-no" title="statement not covered" > return true;</span> + } + + // + //http://realearth.ssec.wisc.edu/api/image?products=nexrhres_20160108_212500&x=1&y=5&z=4 + // + // 20160108.205500 + // http://realearth.ssec.wisc.edu/api/image?products=nexrhres_20160108_205500&x=34&y=46&z=7 + + /** + * Load the features at the date index specified + * @param {number} i the index of the features to be loaded by date + * @param {boolean} [setAsSource=true] set to false to trigger cache load only + * @private + */ +<span class="fstat-no" title="function not covered" > _loadAtTimeIndex(i: number, <span class="cstat-no" title="statement not covered" >setAsSource = true)</span></span> { +<span class="cstat-no" title="statement not covered" > setAsSource = typeof setAsSource == 'boolean' ? setAsSource : true;</span> +<span class="cstat-no" title="statement not covered" > if (this._dataCache[i] != null) {</span> +<span class="cstat-no" title="statement not covered" > this._source.clear();</span> +<span class="cstat-no" title="statement not covered" > this._loadFeatures(this._dataCache[i]);</span> + } else { +<span class="cstat-no" title="statement not covered" > let __this = this;</span> +<span class="cstat-no" title="statement not covered" > $.get('http://realearth.ssec.wisc.edu:80/api/shapes',</span> + {products: `${this._products}_${this._rawDateStrings[i]}`}, +<span class="fstat-no" title="function not covered" > function (d)</span> { +<span class="cstat-no" title="statement not covered" > __this._dataCache[i] = d;</span> +<span class="cstat-no" title="statement not covered" > __this._rawTimesLookup[__this._rawDateStrings[i]] = d;</span> +<span class="cstat-no" title="statement not covered" > if (setAsSource) {</span> +<span class="cstat-no" title="statement not covered" > __this._source.clear();</span> +<span class="cstat-no" title="statement not covered" > __this._loadFeatures.call(__this, __this._dataCache[i]);</span> + } + }, 'json' + ); + } + } + + /** + * helper to load the features at the index specified + * @param {object} geojObj - the geojson object + * @private + */ +<span class="fstat-no" title="function not covered" > _loadFeatures(geojObj)</span> { +<span class="cstat-no" title="statement not covered" > this._source.addFeatures(this._lyr._geoJsonFormat.readFeatures(geojObj,</span> + {featureProjection: this._lyr._transform.featureProjection, dataProjection: this._lyr._transform.dataProjection})); + } + +<span class="fstat-no" title="function not covered" > setLayerTime(theTime: number)</span>: boolean { +<span class="cstat-no" title="statement not covered" > if (super.setLayerTime(theTime)) {</span> +<span class="cstat-no" title="statement not covered" > this._loadAtTimeIndex(this._currentIndex);</span> + } else { +<span class="cstat-no" title="statement not covered" > this._source.clear();</span> + } +<span class="cstat-no" title="statement not covered" > return true;</span> + } +} + +nm.RealEarthAnimateVector = RealEarthAnimateVector; +export default RealEarthAnimateVector; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/index.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/index.html new file mode 100644 index 0000000000000000000000000000000000000000..47e389225b4d505e1d77bc3948ff970f54635ed5 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/mixin/index.html @@ -0,0 +1,119 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\mixin\</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/mixin/ + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">30.14% </span> + <span class="quiet">Statements</span> + <span class='fraction'>44/146</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/36</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">13.04% </span> + <span class="quiet">Functions</span> + <span class='fraction'>3/23</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">29.08% </span> + <span class="quiet">Lines</span> + <span class='fraction'>41/141</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="RealEarthAnimate.ts"><a href="RealEarthAnimate.ts.html">RealEarthAnimate.ts</a></td> + <td data-value="21.43" class="pic low"><div class="chart"><div class="cover-fill" style="width: 21%;"></div><div class="cover-empty" style="width:79%;"></div></div></td> + <td data-value="21.43" class="pct low">21.43%</td> + <td data-value="70" class="abs low">15/70</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="14" class="abs low">0/14</td> + <td data-value="12.5" class="pct low">12.5%</td> + <td data-value="8" class="abs low">1/8</td> + <td data-value="20.59" class="pct low">20.59%</td> + <td data-value="68" class="abs low">14/68</td> + </tr> + +<tr> + <td class="file low" data-value="RealEarthAnimateTile.ts"><a href="RealEarthAnimateTile.ts.html">RealEarthAnimateTile.ts</a></td> + <td data-value="43.33" class="pic low"><div class="chart"><div class="cover-fill" style="width: 43%;"></div><div class="cover-empty" style="width:57%;"></div></div></td> + <td data-value="43.33" class="pct low">43.33%</td> + <td data-value="30" class="abs low">13/30</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="8" class="abs low">0/8</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="41.38" class="pct low">41.38%</td> + <td data-value="29" class="abs low">12/29</td> + </tr> + +<tr> + <td class="file low" data-value="RealEarthAnimateVector.ts"><a href="RealEarthAnimateVector.ts.html">RealEarthAnimateVector.ts</a></td> + <td data-value="34.78" 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.78" class="pct low">34.78%</td> + <td data-value="46" class="abs low">16/46</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="14" class="abs low">0/14</td> + <td data-value="11.11" class="pct low">11.11%</td> + <td data-value="9" class="abs low">1/9</td> + <td data-value="34.09" class="pct low">34.09%</td> + <td data-value="44" class="abs low">15/44</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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/SortedFeatures.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/SortedFeatures.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..9960346e5219d048d2a40215a14ec20ef1a075b0 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/SortedFeatures.ts.html @@ -0,0 +1,428 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\SortedFeatures.ts</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/olHelpers/</a> SortedFeatures.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">13.11% </span> + <span class="quiet">Statements</span> + <span class='fraction'>8/61</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/48</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">25% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/4</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">13.33% </span> + <span class="quiet">Lines</span> + <span class='fraction'>8/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 +117 +118 +119 +120 +121 +122</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/23/2015. + */ +import provide from '../util/provide'; +import ol = require('custom-ol'); +let nm = provide('olHelpers'); + +/** + * take an array of features and sort by a given property name + */ +class SortedFeatures { + sortedFeatures: Array<ol.Feature>; + propertyName: string; + _propertyType: string; + + /** + * + * @param {Array<ol.Feature>} features array of ol features + * @param {string} propertyName - the property name to use for lookup + */ +<span class="fstat-no" title="function not covered" > constructor(features, propertyName)</span> { +<span class="cstat-no" title="statement not covered" > this.sortedFeatures = features;</span> +<span class="cstat-no" title="statement not covered" > this.propertyName = propertyName;</span> + +<span class="cstat-no" title="statement not covered" > if (this.sortedFeatures.length > 0) {</span> +<span class="cstat-no" title="statement not covered" > this._propertyType = typeof this.sortedFeatures[0].getProperties()[this.propertyName];</span> + +<span class="cstat-no" title="statement not covered" > let __this = this;</span> +<span class="cstat-no" title="statement not covered" > this.sortedFeatures.sort(<span class="fstat-no" title="function not covered" >function (a, b)</span> : number {</span> +<span class="cstat-no" title="statement not covered" > if (__this._propertyType == 'number'){</span> +<span class="cstat-no" title="statement not covered" > let aMinusB = a['getProperties']()[__this.propertyName] - b['getProperties']()[__this.propertyName];</span> +<span class="cstat-no" title="statement not covered" > if (aMinusB == 0){</span> +<span class="cstat-no" title="statement not covered" > return 0;</span> + } else { +<span class="cstat-no" title="statement not covered" > return aMinusB > 0 ? 1 : -1;</span> + } + } else <span class="cstat-no" title="statement not covered" >if (__this._propertyType == 'string'){</span> +<span class="cstat-no" title="statement not covered" > let propA = a['getProperties']()[__this.propertyName] || '';</span> +<span class="cstat-no" title="statement not covered" > let propB = b['getProperties']()[__this.propertyName] || '';</span> +<span class="cstat-no" title="statement not covered" > propA = propA.toString().trim();</span> +<span class="cstat-no" title="statement not covered" > propB = propB.toString().trim();</span> + +<span class="cstat-no" title="statement not covered" > if (propA == propB){</span> +<span class="cstat-no" title="statement not covered" > return 0;</span> + } else { +<span class="cstat-no" title="statement not covered" > return propA > propB ? 1 : 0;</span> + } + } + }); + } + } + + /** + * recursive search to find the value + * @param {number|string} propertyValue - the property value to search for + * @param {boolean} [exactMatch=false] if only an exact match should be returned + * @param {Array} [sortedFeatures=this.sortedFeatures] - the candidate features + * @returns {ol.Feature|undefined} the feature matching the lookup + */ +<span class="fstat-no" title="function not covered" > getFeature(propertyValue, <span class="cstat-no" title="statement not covered" >exactMatch: boolean = false,</span> sortedFeatures? :Array<ol.Feature>)</span> { +<span class="cstat-no" title="statement not covered" > if (typeof sortedFeatures == 'undefined'){</span> +<span class="cstat-no" title="statement not covered" > sortedFeatures = this.sortedFeatures;</span> + } + + +<span class="cstat-no" title="statement not covered" > if (sortedFeatures.length == 0){</span> +<span class="cstat-no" title="statement not covered" > return undefined;</span> + } + +<span class="cstat-no" title="statement not covered" > if (sortedFeatures.length == 1){</span> +<span class="cstat-no" title="statement not covered" > if (exactMatch){</span> +<span class="cstat-no" title="statement not covered" > if (sortedFeatures[0].getProperties()[this.propertyName] == propertyValue){</span> +<span class="cstat-no" title="statement not covered" > return sortedFeatures[0];</span> + } else { +<span class="cstat-no" title="statement not covered" > return undefined;</span> + } + } else { +<span class="cstat-no" title="statement not covered" > return sortedFeatures[0];</span> + } + } + +<span class="cstat-no" title="statement not covered" > let lowProp = sortedFeatures[0].getProperties()[this.propertyName];</span> +<span class="cstat-no" title="statement not covered" > let highProp = sortedFeatures[sortedFeatures.length - 1].getProperties()[this.propertyName];</span> + +<span class="cstat-no" title="statement not covered" > if (exactMatch){</span> +<span class="cstat-no" title="statement not covered" > if (lowProp == propertyValue){</span> +<span class="cstat-no" title="statement not covered" > return sortedFeatures[0];</span> + } else <span class="cstat-no" title="statement not covered" >if (propertyValue < lowProp){</span> +<span class="cstat-no" title="statement not covered" > return undefined;</span> + } else <span class="cstat-no" title="statement not covered" >if (highProp == propertyValue){</span> +<span class="cstat-no" title="statement not covered" > return sortedFeatures[sortedFeatures.length - 1];</span> + } else <span class="cstat-no" title="statement not covered" >if (propertyValue > highProp){</span> +<span class="cstat-no" title="statement not covered" > return undefined;</span> + } + } else { +<span class="cstat-no" title="statement not covered" > if (propertyValue <= lowProp){</span> +<span class="cstat-no" title="statement not covered" > return sortedFeatures[0];</span> + } else <span class="cstat-no" title="statement not covered" >if (propertyValue >= highProp){</span> +<span class="cstat-no" title="statement not covered" > return sortedFeatures[sortedFeatures.length - 1];</span> + } + } + +<span class="cstat-no" title="statement not covered" > let midIndex = Math.floor(sortedFeatures.length / 2);</span> +<span class="cstat-no" title="statement not covered" > let midFeature = sortedFeatures[midIndex];</span> +<span class="cstat-no" title="statement not covered" > let midProperty = midFeature.getProperties()[this.propertyName];</span> + +<span class="cstat-no" title="statement not covered" > if (midProperty === propertyValue){</span> +<span class="cstat-no" title="statement not covered" > return midFeature;</span> + } + +<span class="cstat-no" title="statement not covered" > if (propertyValue < midProperty){</span> +<span class="cstat-no" title="statement not covered" > return this.getFeature(propertyValue, exactMatch, sortedFeatures.slice(0, midIndex));</span> + } else { +<span class="cstat-no" title="statement not covered" > return this.getFeature(propertyValue, exactMatch, sortedFeatures.slice(midIndex));</span> + } + } +} + +nm.SortedFeatures = SortedFeatures; +export default SortedFeatures; + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/esriToOlStyle.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/esriToOlStyle.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..0c378019b8e3c4965f901dab97eabab90fe28f45 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/esriToOlStyle.ts.html @@ -0,0 +1,1388 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\esriToOlStyle.ts</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/olHelpers/</a> esriToOlStyle.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">19.47% </span> + <span class="quiet">Statements</span> + <span class='fraction'>37/190</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/52</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">35% </span> + <span class="quiet">Functions</span> + <span class='fraction'>7/20</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">17.58% </span> + <span class="quiet">Lines</span> + <span class='fraction'>32/182</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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">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-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-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="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-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-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-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-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-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-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-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-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-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-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-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-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">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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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">2×</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-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-yes">1×</span> +<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 1/4/2016. + */ +import provide from '../util/provide'; +import ol = require('custom-ol'); +const nm = provide('olHelpers.esriToOlStyle'); + +/** + * This callback is displayed as part of the Requester class. + * @callback styleFunc + * @param {ol.Feature} feat - openlayers feature + * @param {number} resolution - map resolution + */ + +/** + * + * @param {Array<number>} colorArray - input color array + * @param {number} opacity - the opacity 0 to 1 + * @returns {string} rgba string + * @private + */ +<span class="fstat-no" title="function not covered" >function _colorArrayToRgba(colorArray, opacity)</span> { + "use strict"; + +<span class="cstat-no" title="statement not covered" > return `rgba(${colorArray[0]},${colorArray[1]},${colorArray[2]},${opacity})`;</span> +} + +/** + * escape html charcters + * @param {string} str - input string + * @returns {string} escaped string + */ +<span class="fstat-no" title="function not covered" >function htmlEscape(str)</span> { +<span class="cstat-no" title="statement not covered" > return String(str)</span> + .replace(/&/g, '&amp;') + .replace(/"/g, '&quot;') + .replace(/'/g, '&#39;') + .replace(/</g, '&lt;') + .replace(/>/g, '&gt;'); +} + +nm.htmlEscape = htmlEscape; + + +export interface EsriResponse{ + drawingInfo: { + renderer: EsriRenderer + }, + geometryType: string +} + +export interface EsriRenderer{ + type: string; + symbol: EsriSymbol; + uniqueValueInfos: Array<{label: string, value: any, symbol: EsriSymbol}>; +} + +export interface EsriSymbol{ + size: number; + type: string; + outline:{ + color: string; + width: number; + }, + color: string; + width: number; +} + + +class CommonSymbol { + legendHtml: string; + opacity: number; + symbolObj: EsriSymbol; + olStyle: ol.style.Style|Array<ol.style.Style>|ol.StyleFunction; + + /** + * + * @param symbolObj + * @param {number} opacity + */ +<span class="fstat-no" title="function not covered" > constructor(symbolObj: EsriSymbol, opacity: number)</span> { +<span class="cstat-no" title="statement not covered" > this.symbolObj = symbolObj;</span> +<span class="cstat-no" title="statement not covered" > this.opacity = opacity;</span> +<span class="cstat-no" title="statement not covered" > this.olStyle = undefined;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml = '';</span> + } +} + +interface ICommonSymbol{ + new (symbolObj: EsriSymbol, opacity: number): CommonSymbol +} + + +class PointSymbol extends CommonSymbol { +<span class="fstat-no" title="function not covered" > constructor(symbolObj: EsriSymbol, opacity: number)</span> { + super(symbolObj, opacity); +<span class="cstat-no" title="statement not covered" > switch (this.symbolObj.type) {</span> + case 'esriSMS': +<span class="cstat-no" title="statement not covered" > let innerColor = _colorArrayToRgba(this.symbolObj.color, this.opacity);</span> +<span class="cstat-no" title="statement not covered" > let outerColor = _colorArrayToRgba(this.symbolObj.outline.color, this.opacity);</span> +<span class="cstat-no" title="statement not covered" > let outlineWidth = this.symbolObj.outline.width;</span> +<span class="cstat-no" title="statement not covered" > let radius = this.symbolObj.size;</span> + + +<span class="cstat-no" title="statement not covered" > this.olStyle = new ol.style.Style({</span> + image: new ol.style.Circle({ + radius: radius, + fill: new ol.style.Fill({ + color: innerColor + }), + stroke: new ol.style.Stroke({color: outerColor, width: outlineWidth}) + }) + }); +<span class="cstat-no" title="statement not covered" > this.legendHtml = `<span class="legend-layer-icon" style="color: ${innerColor}">&#9679;</span>`;</span> +<span class="cstat-no" title="statement not covered" > break;</span> + case 'esriPMS': +<span class="cstat-no" title="statement not covered" > this.olStyle = new ol.style.Style({</span> + image: new ol.style.Icon({src: `data:image/png;base64,${this.symbolObj['imageData']}`}) + }); +<span class="cstat-no" title="statement not covered" > this.legendHtml = `<img class="legend-layer-icon" height="17" src="data:image/png;base64,${this.symbolObj['imageData']}">`;</span> +<span class="cstat-no" title="statement not covered" > break;</span> + default: +<span class="cstat-no" title="statement not covered" > console.log(this.symbolObj);</span> +<span class="cstat-no" title="statement not covered" > alert('Point symbol does not handle symbol type: ' + this.symbolObj['type']);</span> + } + } +} + +class LineSymbol extends CommonSymbol { +<span class="fstat-no" title="function not covered" > constructor(symbolObj: EsriSymbol, opacity: number)</span> { + super(symbolObj, opacity); +<span class="cstat-no" title="statement not covered" > switch (this.symbolObj.type) {</span> + case 'esriSLS': +<span class="cstat-no" title="statement not covered" > let innerColor = _colorArrayToRgba(this.symbolObj.color, this.opacity);</span> +<span class="cstat-no" title="statement not covered" > let lineWidth = this.symbolObj.width;</span> + +<span class="cstat-no" title="statement not covered" > this.olStyle = new ol.style.Style({</span> + stroke: new ol.style.Stroke({ + color: innerColor, + //lineDash: [4], + width: lineWidth + }) + }); + +<span class="cstat-no" title="statement not covered" > this.legendHtml = `<span class="legend-layer-icon" `;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `style="`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `background-color: ${innerColor};`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `width: 40px;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `height: 4px;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `position: relative;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `display: inline-block;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `top: -1px;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `"></span>`;</span> +<span class="cstat-no" title="statement not covered" > break;</span> + default: +<span class="cstat-no" title="statement not covered" > console.log(this.symbolObj);</span> +<span class="cstat-no" title="statement not covered" > alert('Line symbol does not handle symbol type: ' + this.symbolObj['type']);</span> + } + } +} + +class PolygonSymbol extends CommonSymbol { +<span class="fstat-no" title="function not covered" > constructor(symbolObj: EsriSymbol, opacity: number)</span> { + super(symbolObj, opacity); +<span class="cstat-no" title="statement not covered" > switch (this.symbolObj['type']) {</span> + case 'esriSFS': +<span class="cstat-no" title="statement not covered" > let innerColor = _colorArrayToRgba(this.symbolObj.color, this.opacity);</span> +<span class="cstat-no" title="statement not covered" > let outerColor = _colorArrayToRgba(this.symbolObj.outline.color, this.opacity);</span> +<span class="cstat-no" title="statement not covered" > let outlineWidth = this.symbolObj.outline.width;</span> + +<span class="cstat-no" title="statement not covered" > this.olStyle = new ol.style.Style({</span> + stroke: new ol.style.Stroke({ + color: outerColor, + //lineDash: [4], + width: outlineWidth + }), + fill: new ol.style.Fill({ + color: innerColor + }) + }); + +<span class="cstat-no" title="statement not covered" > this.legendHtml = `<span class="legend-layer-icon" `;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `style="`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `background-color: ${innerColor};`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `border: solid ${outerColor} 1px;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `width: 40px;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `height: 9px;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `position: relative;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `display: inline-block;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `top: 2px;`;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `"></span>`;</span> +<span class="cstat-no" title="statement not covered" > break;</span> + + default: +<span class="cstat-no" title="statement not covered" > console.log(this.symbolObj);</span> +<span class="cstat-no" title="statement not covered" > alert('Polygon symbol does handle symbol type: ' + this.symbolObj['type']);</span> + } + } +} + +class SymbolGenerator { + opacity: number; + renderer: EsriRenderer; + legendHtml: string; + olStyle: ol.style.Style|Array<ol.style.Style>|ol.StyleFunction; + +<span class="fstat-no" title="function not covered" > constructor(esriResponse: EsriResponse)</span> { +<span class="cstat-no" title="statement not covered" > this.opacity = (100 - (esriResponse['drawingInfo']['transparency'] || 0)) / 100;</span> +<span class="cstat-no" title="statement not covered" > this.renderer = esriResponse.drawingInfo.renderer;</span> +<span class="cstat-no" title="statement not covered" > this.olStyle = undefined;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml = '';</span> + } +} + +class SingleSymbol extends SymbolGenerator { + symbol: EsriSymbol; + /** + * + * @param {object} esriResponse - layer info + * @param SymbolClass - the symbol class to use + */ +<span class="fstat-no" title="function not covered" > constructor(esriResponse, SymbolClass: ICommonSymbol)</span> { + super(esriResponse); +<span class="cstat-no" title="statement not covered" > this.symbol = this.renderer.symbol;</span> +<span class="cstat-no" title="statement not covered" > let symbolObj = new SymbolClass(this.symbol, this.opacity);</span> +<span class="cstat-no" title="statement not covered" > this.olStyle = symbolObj.olStyle;</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml = symbolObj.legendHtml;</span> + } +} + +class UniqueValueSymbol extends SymbolGenerator { + + propertyName: string; + defaultSymbol: EsriSymbol; + defaultStyle: ol.style.Style|Array<ol.style.Style>|ol.StyleFunction; + defaultLabelHtml: string; + labelArray: Array<string>; + legendArray: Array<string>; + propertyStyleLookup: Object; + valueArray: Array<any>; + uniqueValueInfos: Array<{label: string, value: any, symbol: EsriSymbol}>; + + /** + * + * @param {object} esriResponse - layer info + * @param SymbolClass - the Symbol class definition + */ +<span class="fstat-no" title="function not covered" > constructor(esriResponse: EsriResponse, SymbolClass: ICommonSymbol)</span> { + super(esriResponse); +<span class="cstat-no" title="statement not covered" > this.uniqueValueInfos = this.renderer['uniqueValueInfos'];</span> +<span class="cstat-no" title="statement not covered" > this.propertyName = this.renderer['field1'];</span> +<span class="cstat-no" title="statement not covered" > this.defaultSymbol = this.renderer['defaultSymbol'];</span> + + +<span class="cstat-no" title="statement not covered" > if (this.defaultSymbol) {</span> +<span class="cstat-no" title="statement not covered" > let symbolObj = new SymbolClass(this.defaultSymbol, this.opacity);</span> +<span class="cstat-no" title="statement not covered" > this.defaultStyle = symbolObj.olStyle;</span> +<span class="cstat-no" title="statement not covered" > this.defaultLabelHtml = `<span class="legend-layer-subitem">${htmlEscape(this.renderer['defaultLabel'])}</span>` + symbolObj.legendHtml;</span> + } else { +<span class="cstat-no" title="statement not covered" > this.defaultStyle = undefined;</span> +<span class="cstat-no" title="statement not covered" > this.defaultLabelHtml = 'other';</span> + } + +<span class="cstat-no" title="statement not covered" > this.valueArray = [];</span> +<span class="cstat-no" title="statement not covered" > this.labelArray = [];</span> +<span class="cstat-no" title="statement not covered" > this.legendArray = [];</span> +<span class="cstat-no" title="statement not covered" > this.propertyStyleLookup = {};</span> + +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let uniqueVal </span>of this.uniqueValueInfos) {</span> +<span class="cstat-no" title="statement not covered" > this.labelArray.push(uniqueVal['label']);</span> +<span class="cstat-no" title="statement not covered" > this.valueArray.push(uniqueVal['value']);</span> +<span class="cstat-no" title="statement not covered" > let uniqueSym = new SymbolClass(uniqueVal.symbol, this.opacity);</span> +<span class="cstat-no" title="statement not covered" > this.legendArray.push(`<span class="legend-layer-subitem">${htmlEscape(uniqueVal['label'])}</span>` + uniqueSym.legendHtml);</span> +<span class="cstat-no" title="statement not covered" > this.propertyStyleLookup[uniqueVal['value']] = uniqueSym.olStyle;</span> + } + + +<span class="cstat-no" title="statement not covered" > this.olStyle = <span class="fstat-no" title="function not covered" >(feature: ol.Feature)</span> => {</span> +<span class="cstat-no" title="statement not covered" > let checkProperties = feature.getProperties();</span> +<span class="cstat-no" title="statement not covered" > let checkProperty = checkProperties[this.propertyName];</span> + +<span class="cstat-no" title="statement not covered" > let returnValue;</span> +<span class="cstat-no" title="statement not covered" > if (this.propertyStyleLookup[checkProperty] !== undefined) {</span> +<span class="cstat-no" title="statement not covered" > returnValue = [this.propertyStyleLookup[checkProperty]];</span> + } else { +<span class="cstat-no" title="statement not covered" > returnValue = [this.defaultStyle];</span> + } + +<span class="cstat-no" title="statement not covered" > return returnValue;</span> + }; + +<span class="cstat-no" title="statement not covered" > if (this.defaultLabelHtml !== null) {</span> +<span class="cstat-no" title="statement not covered" > this.legendArray.push(this.defaultLabelHtml);</span> + } + +<span class="cstat-no" title="statement not covered" > this.legendHtml = '<ul>';</span> +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let h </span>of this.legendArray) {</span> +<span class="cstat-no" title="statement not covered" > this.legendHtml += `<li>${h}</li>`;</span> + } +<span class="cstat-no" title="statement not covered" > this.legendHtml += '</ul>';</span> + } +} + + + + + + + + +/** + * style and legend object + * @typedef {object} styleAndLegend + * @property {styleFunc} style - style function + * @property {string} legend - legend content + */ + +/** + * + * @param {object} esriResponse - layer info + * @returns {styleAndLegend} style and legend object + */ +<span class="fstat-no" title="function not covered" >export function makeFeatureServiceLegendAndSymbol(esriResponse: EsriResponse)</span> { + "use strict"; +<span class="cstat-no" title="statement not covered" > let renderer = esriResponse.drawingInfo.renderer;</span> +<span class="cstat-no" title="statement not covered" > let symbolLegendOut: SymbolGenerator = null;</span> + +<span class="cstat-no" title="statement not covered" > switch (renderer.type) {</span> + case 'simple': +<span class="cstat-no" title="statement not covered" > switch (esriResponse.geometryType) {</span> + case 'esriGeometryPoint': +<span class="cstat-no" title="statement not covered" > symbolLegendOut = new SingleSymbol(esriResponse, PointSymbol);</span> +<span class="cstat-no" title="statement not covered" > break;</span> + case 'esriGeometryPolyline': +<span class="cstat-no" title="statement not covered" > symbolLegendOut = new SingleSymbol(esriResponse, LineSymbol);</span> +<span class="cstat-no" title="statement not covered" > break;</span> + case 'esriGeometryPolygon': +<span class="cstat-no" title="statement not covered" > symbolLegendOut = new SingleSymbol(esriResponse, PolygonSymbol);</span> +<span class="cstat-no" title="statement not covered" > break;</span> + default: +<span class="cstat-no" title="statement not covered" > console.log(esriResponse);</span> +<span class="cstat-no" title="statement not covered" > alert(esriResponse.geometryType + ' not handled');</span> + } +<span class="cstat-no" title="statement not covered" > break;</span> + case 'uniqueValue': +<span class="cstat-no" title="statement not covered" > switch (esriResponse.geometryType) {</span> + case 'esriGeometryPoint': +<span class="cstat-no" title="statement not covered" > symbolLegendOut = new UniqueValueSymbol(esriResponse, PointSymbol);</span> +<span class="cstat-no" title="statement not covered" > break;</span> + case 'esriGeometryPolyline': +<span class="cstat-no" title="statement not covered" > symbolLegendOut = new UniqueValueSymbol(esriResponse, LineSymbol);</span> +<span class="cstat-no" title="statement not covered" > break;</span> + case 'esriGeometryPolygon': +<span class="cstat-no" title="statement not covered" > symbolLegendOut = new UniqueValueSymbol(esriResponse, PolygonSymbol);</span> +<span class="cstat-no" title="statement not covered" > break;</span> + default: +<span class="cstat-no" title="statement not covered" > console.log(esriResponse);</span> +<span class="cstat-no" title="statement not covered" > alert(esriResponse['geometryType'] + ' not handled');</span> + } +<span class="cstat-no" title="statement not covered" > break;</span> + default: +<span class="cstat-no" title="statement not covered" > alert('not handled renderer type: ' + renderer['type']);</span> + } + +<span class="cstat-no" title="statement not covered" > if (symbolLegendOut == null) {</span> +<span class="cstat-no" title="statement not covered" > return {style: undefined, legend: ''};</span> + } else { +<span class="cstat-no" title="statement not covered" > return {style: symbolLegendOut.olStyle, legend: symbolLegendOut.legendHtml};</span> + } +} + +nm.makeFeatureServiceLegendAndSymbol = makeFeatureServiceLegendAndSymbol; + + +/** + * + * @param {object} lyrObject - the layer as defined in the response + * @param {boolean} [skipLayerNameAndExpander=false] use only icons + * @returns {string} legend html + */ +<span class="fstat-no" title="function not covered" >function mapServiceLegendItem(lyrObject, <span class="cstat-no" title="statement not covered" >skipLayerNameAndExpander: boolean = false)</span></span> { + + +<span class="cstat-no" title="statement not covered" > skipLayerNameAndExpander = typeof skipLayerNameAndExpander == 'boolean' ? skipLayerNameAndExpander : false;</span> +<span class="cstat-no" title="statement not covered" > let layerName = lyrObject['layerName'];</span> +<span class="cstat-no" title="statement not covered" > let legendItems = lyrObject['legend'];</span> +<span class="cstat-no" title="statement not covered" > let legendHtml = '';</span> + +<span class="cstat-no" title="statement not covered" > if (!skipLayerNameAndExpander) {</span> +<span class="cstat-no" title="statement not covered" > legendHtml += `<span class="legend-layer-subitem">${layerName}</span>`;</span> + } + +<span class="cstat-no" title="statement not covered" > if (legendItems.length == 1) {</span> +<span class="cstat-no" title="statement not covered" > legendHtml = `<img class="legend-layer-icon" height="17" src="data:image/png;base64,${legendItems[0]['imageData']}">`;</span> + } else { +<span class="cstat-no" title="statement not covered" > if (!skipLayerNameAndExpander) {</span> +<span class="cstat-no" title="statement not covered" > legendHtml += '<span class="legend-items-expander" title="Expand/Collapse">&#9660;</span>';</span> + } +<span class="cstat-no" title="statement not covered" > legendHtml += '<ul>';</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < legendItems.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > legendHtml += `<li>`;</span> +<span class="cstat-no" title="statement not covered" > legendHtml += `<span class="legend-layer-subitem">${htmlEscape(legendItems[i]['label'])}</span>`;</span> +<span class="cstat-no" title="statement not covered" > legendHtml += `<img class="legend-layer-icon" height="17" src="data:image/png;base64,${legendItems[i]['imageData']}">`;</span> +<span class="cstat-no" title="statement not covered" > legendHtml += `</li>`;</span> + } +<span class="cstat-no" title="statement not covered" > legendHtml += '</ul>';</span> + } + +<span class="cstat-no" title="statement not covered" > if (!skipLayerNameAndExpander) {</span> +<span class="cstat-no" title="statement not covered" > legendHtml = `<span class="legend-layer-subitem">${layerName}</span>` + legendHtml;</span> + } + +<span class="cstat-no" title="statement not covered" > return legendHtml;</span> +} + +/** + * make map service legent + * @param {object} esriResponse - layer info + * @returns {string} legend content + */ +<span class="fstat-no" title="function not covered" >export function makeMapServiceLegend(esriResponse)</span> { + "use strict"; + +<span class="cstat-no" title="statement not covered" > let newLegendHtml = '';</span> + +<span class="cstat-no" title="statement not covered" > let layers = esriResponse['layers'];</span> + +<span class="cstat-no" title="statement not covered" > if (layers.length == 1) {</span> +<span class="cstat-no" title="statement not covered" > newLegendHtml += mapServiceLegendItem(layers[0], true);</span> + } else { +<span class="cstat-no" title="statement not covered" > newLegendHtml += '<ul>';</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < layers.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > newLegendHtml += '<li>' + mapServiceLegendItem(layers[i]) + '</li>';</span> + } +<span class="cstat-no" title="statement not covered" > newLegendHtml += '</ul>';</span> + } + +<span class="cstat-no" title="statement not covered" > return newLegendHtml;</span> +} + +nm.makeMapServiceLegend = makeMapServiceLegend; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/extentUtil.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/extentUtil.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..24fdea430c1c74abd32c3197980604b9b1ac468b --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/extentUtil.ts.html @@ -0,0 +1,296 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\extentUtil.ts</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/olHelpers/</a> extentUtil.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">20% </span> + <span class="quiet">Statements</span> + <span class='fraction'>6/30</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/18</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">20.69% </span> + <span class="quiet">Lines</span> + <span class='fraction'>6/29</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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">2×</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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 7/18/2016. + */ +import provide from '../util/provide'; +import ol = require('custom-ol'); +import {LayerBaseVector} from "../layers/LayerBaseVector"; + + +const nm = provide('util'); + +/** + * + * @param {Array<LayerBaseVector>|Array<ol.layer.Vector>|LayerBaseVector|ol.layer.Vector|*} layers - array of layers or single + * @returns {ol.Extent|Array<number>|*} - collective extent + */ +<span class="fstat-no" title="function not covered" >export function calculateExtent(layers: ol.layer.Vector[]|LayerBaseVector[])</span>: ol.Extent|Array<number>| ol.Extent| number[] { + "use strict"; + +<span class="cstat-no" title="statement not covered" > let hasExtent = false;</span> + +<span class="cstat-no" title="statement not covered" > let minX = 10E100;</span> +<span class="cstat-no" title="statement not covered" > let minY = 10E100;</span> +<span class="cstat-no" title="statement not covered" > let maxX = -10E100;</span> +<span class="cstat-no" title="statement not covered" > let maxY = -10E100;</span> + +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let lyr </span>of layers) {</span> + + /** + * + * @type {ol.layer.Vector} + */ +<span class="cstat-no" title="statement not covered" > let olLayer = lyr['olLayer'] || lyr;</span> + + +<span class="cstat-no" title="statement not covered" > if (olLayer.getSource().getFeatures().length > 0) {</span> +<span class="cstat-no" title="statement not covered" > hasExtent = true;</span> +<span class="cstat-no" title="statement not covered" > let ext = olLayer.getSource().getExtent();</span> +<span class="cstat-no" title="statement not covered" > minX = ext[0] < minX ? ext[0] : minX;</span> +<span class="cstat-no" title="statement not covered" > minY = ext[1] < minY ? ext[1] : minY;</span> +<span class="cstat-no" title="statement not covered" > maxX = ext[2] > maxX ? ext[2] : maxX;</span> +<span class="cstat-no" title="statement not covered" > maxY = ext[3] > maxY ? ext[3] : maxY;</span> + } + } + +<span class="cstat-no" title="statement not covered" > if (hasExtent) {</span> +<span class="cstat-no" title="statement not covered" > return [minX, minY, maxX, maxY];</span> + } else { +<span class="cstat-no" title="statement not covered" > return undefined;</span> + } +} + +nm.calculateExtent = calculateExtent; + + +/** + * given one or an array of layers, fit to the map + * @param layers - array of layers or single + * @param mp - the map to fit + * @param [zoomOut=undefined] - levels to zoom out after fit + */ +<span class="fstat-no" title="function not covered" >export function fitToMap(layers: ol.layer.Vector[]|LayerBaseVector[], mp: ol.Map, zoomOut?: number)</span>{ + "use strict"; + +<span class="cstat-no" title="statement not covered" > let ext = calculateExtent(layers);</span> + +<span class="cstat-no" title="statement not covered" > if (typeof ext == 'undefined'){</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > mp.getView().fit(ext as ol.Extent, mp.getSize());</span> + +<span class="cstat-no" title="statement not covered" > if (typeof zoomOut == 'number'){</span> +<span class="cstat-no" title="statement not covered" > mp.getView().setZoom(mp.getView().getZoom() - zoomOut);</span> + } +} + +nm.calculateExtent = calculateExtent; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/index.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/index.html new file mode 100644 index 0000000000000000000000000000000000000000..57bee920f1305ab7f6f550cdb2db2b99a7462fa1 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/index.html @@ -0,0 +1,275 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\</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/olHelpers/ + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">25.21% </span> + <span class="quiet">Statements</span> + <span class='fraction'>206/817</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">1.77% </span> + <span class="quiet">Branches</span> + <span class='fraction'>5/283</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">24.53% </span> + <span class="quiet">Functions</span> + <span class='fraction'>26/106</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">24.53% </span> + <span class="quiet">Lines</span> + <span class='fraction'>195/795</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="SortedFeatures.ts"><a href="SortedFeatures.ts.html">SortedFeatures.ts</a></td> + <td data-value="13.11" class="pic low"><div class="chart"><div class="cover-fill" style="width: 13%;"></div><div class="cover-empty" style="width:87%;"></div></div></td> + <td data-value="13.11" class="pct low">13.11%</td> + <td data-value="61" class="abs low">8/61</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="48" class="abs low">0/48</td> + <td data-value="25" class="pct low">25%</td> + <td data-value="4" class="abs low">1/4</td> + <td data-value="13.33" class="pct low">13.33%</td> + <td data-value="60" class="abs low">8/60</td> + </tr> + +<tr> + <td class="file low" data-value="esriToOlStyle.ts"><a href="esriToOlStyle.ts.html">esriToOlStyle.ts</a></td> + <td data-value="19.47" 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.47" class="pct low">19.47%</td> + <td data-value="190" class="abs low">37/190</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="52" class="abs low">0/52</td> + <td data-value="35" class="pct low">35%</td> + <td data-value="20" class="abs low">7/20</td> + <td data-value="17.58" class="pct low">17.58%</td> + <td data-value="182" class="abs low">32/182</td> + </tr> + +<tr> + <td class="file low" data-value="extentUtil.ts"><a href="extentUtil.ts.html">extentUtil.ts</a></td> + <td data-value="20" class="pic low"><div class="chart"><div class="cover-fill" style="width: 20%;"></div><div class="cover-empty" style="width:80%;"></div></div></td> + <td data-value="20" class="pct low">20%</td> + <td data-value="30" class="abs low">6/30</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="18" class="abs low">0/18</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="2" class="abs low">0/2</td> + <td data-value="20.69" class="pct low">20.69%</td> + <td data-value="29" class="abs low">6/29</td> + </tr> + +<tr> + <td class="file low" data-value="layerSwipe.ts"><a href="layerSwipe.ts.html">layerSwipe.ts</a></td> + <td data-value="15.28" class="pic low"><div class="chart"><div class="cover-fill" style="width: 15%;"></div><div class="cover-empty" style="width:85%;"></div></div></td> + <td data-value="15.28" class="pct low">15.28%</td> + <td data-value="72" class="abs low">11/72</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="16" class="abs low">0/16</td> + <td data-value="12.5" class="pct low">12.5%</td> + <td data-value="16" class="abs low">2/16</td> + <td data-value="15.49" class="pct low">15.49%</td> + <td data-value="71" class="abs low">11/71</td> + </tr> + +<tr> + <td class="file medium" data-value="mapInteractionBase.ts"><a href="mapInteractionBase.ts.html">mapInteractionBase.ts</a></td> + <td data-value="59.26" 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.26" class="pct medium">59.26%</td> + <td data-value="27" class="abs medium">16/27</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="4" class="abs low">0/4</td> + <td data-value="28.57" class="pct low">28.57%</td> + <td data-value="7" class="abs low">2/7</td> + <td data-value="57.69" class="pct medium">57.69%</td> + <td data-value="26" class="abs medium">15/26</td> + </tr> + +<tr> + <td class="file high" data-value="mapMove.ts"><a href="mapMove.ts.html">mapMove.ts</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="0" class="abs high">0/0</td> + <td data-value="100" class="pct high">100%</td> + <td data-value="1" class="abs high">1/1</td> + <td data-value="100" class="pct high">100%</td> + <td data-value="3" class="abs high">3/3</td> + </tr> + +<tr> + <td class="file low" data-value="mapMoveCls.ts"><a href="mapMoveCls.ts.html">mapMoveCls.ts</a></td> + <td data-value="25.81" class="pic low"><div class="chart"><div class="cover-fill" style="width: 25%;"></div><div class="cover-empty" style="width:75%;"></div></div></td> + <td data-value="25.81" class="pct low">25.81%</td> + <td data-value="124" class="abs low">32/124</td> + <td data-value="3.23" class="pct low">3.23%</td> + <td data-value="62" class="abs low">2/62</td> + <td data-value="11.76" class="pct low">11.76%</td> + <td data-value="17" class="abs low">2/17</td> + <td data-value="24.79" class="pct low">24.79%</td> + <td data-value="121" class="abs low">30/121</td> + </tr> + +<tr> + <td class="file high" data-value="mapPopup.ts"><a href="mapPopup.ts.html">mapPopup.ts</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="0" class="abs high">0/0</td> + <td data-value="100" class="pct high">100%</td> + <td data-value="1" class="abs high">1/1</td> + <td data-value="100" class="pct high">100%</td> + <td data-value="3" class="abs high">3/3</td> + </tr> + +<tr> + <td class="file low" data-value="mapPopupCls.ts"><a href="mapPopupCls.ts.html">mapPopupCls.ts</a></td> + <td data-value="22.22" class="pic low"><div class="chart"><div class="cover-fill" style="width: 22%;"></div><div class="cover-empty" style="width:78%;"></div></div></td> + <td data-value="22.22" class="pct low">22.22%</td> + <td data-value="216" class="abs low">48/216</td> + <td data-value="4.35" class="pct low">4.35%</td> + <td data-value="46" class="abs low">2/46</td> + <td data-value="15.38" class="pct low">15.38%</td> + <td data-value="26" class="abs low">4/26</td> + <td data-value="21.53" class="pct low">21.53%</td> + <td data-value="209" class="abs low">45/209</td> + </tr> + +<tr> + <td class="file high" data-value="projections.ts"><a href="projections.ts.html">projections.ts</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="4" class="abs high">4/4</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="4" class="abs high">4/4</td> + </tr> + +<tr> + <td class="file medium" data-value="propertiesZoomStyle.ts"><a href="propertiesZoomStyle.ts.html">propertiesZoomStyle.ts</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="10" class="abs medium">6/10</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="3" class="abs low">1/3</td> + <td data-value="60" class="pct medium">60%</td> + <td data-value="10" class="abs medium">6/10</td> + </tr> + +<tr> + <td class="file medium" data-value="quickMap.ts"><a href="quickMap.ts.html">quickMap.ts</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="12" class="abs medium">8/12</td> + <td data-value="100" class="pct high">100%</td> + <td data-value="0" class="abs high">0/0</td> + <td data-value="50" class="pct medium">50%</td> + <td data-value="2" class="abs medium">1/2</td> + <td data-value="66.67" class="pct medium">66.67%</td> + <td data-value="12" class="abs medium">8/12</td> + </tr> + +<tr> + <td class="file low" data-value="quickMapBase.ts"><a href="quickMapBase.ts.html">quickMapBase.ts</a></td> + <td data-value="20.59" class="pic low"><div class="chart"><div class="cover-fill" style="width: 20%;"></div><div class="cover-empty" style="width:80%;"></div></div></td> + <td data-value="20.59" class="pct low">20.59%</td> + <td data-value="34" class="abs low">7/34</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="26" class="abs low">0/26</td> + <td data-value="50" class="pct medium">50%</td> + <td data-value="2" class="abs medium">1/2</td> + <td data-value="20.59" class="pct low">20.59%</td> + <td data-value="34" class="abs low">7/34</td> + </tr> + +<tr> + <td class="file medium" data-value="quickMapMulti.ts"><a href="quickMapMulti.ts.html">quickMapMulti.ts</a></td> + <td data-value="57.14" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 57%;"></div><div class="cover-empty" style="width:43%;"></div></div></td> + <td data-value="57.14" class="pct medium">57.14%</td> + <td data-value="14" class="abs medium">8/14</td> + <td data-value="100" class="pct high">100%</td> + <td data-value="0" class="abs high">0/0</td> + <td data-value="50" class="pct medium">50%</td> + <td data-value="2" class="abs medium">1/2</td> + <td data-value="57.14" class="pct medium">57.14%</td> + <td data-value="14" class="abs medium">8/14</td> + </tr> + +<tr> + <td class="file medium" data-value="zoomResolutionConvert.ts"><a href="zoomResolutionConvert.ts.html">zoomResolutionConvert.ts</a></td> + <td data-value="52.94" 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.94" class="pct medium">52.94%</td> + <td data-value="17" class="abs medium">9/17</td> + <td data-value="11.11" class="pct low">11.11%</td> + <td data-value="9" class="abs low">1/9</td> + <td data-value="66.67" class="pct medium">66.67%</td> + <td data-value="3" class="abs medium">2/3</td> + <td data-value="52.94" class="pct medium">52.94%</td> + <td data-value="17" class="abs medium">9/17</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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/layerSwipe.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/layerSwipe.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..e36a8ae9ab6868be9ec5a415b26717b418707adb --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/layerSwipe.ts.html @@ -0,0 +1,545 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\layerSwipe.ts</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/olHelpers/</a> layerSwipe.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">15.28% </span> + <span class="quiet">Statements</span> + <span class='fraction'>11/72</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/16</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">12.5% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/16</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">15.49% </span> + <span class="quiet">Lines</span> + <span class='fraction'>11/71</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</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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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-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-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-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-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-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-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-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-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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 6/1/2016. + */ + + +import provide from '../util/provide'; +import {LayerBase} from "../layers/LayerBase"; +import ol = require('custom-ol'); +import $ = require('jquery'); + +let nm = provide('collections.layerSwipe'); + + +class LayerSwipe { + leftLayers: Array<LayerBase>; + rightLayers: Array<LayerBase>; + _percentRight: number; + _map: ol.Map; + $mapElement: JQuery; + $swiper: JQuery; + dragging: boolean; + offset: number; + /** + * + * @param {ol.Map} map - the map + * @param {string} [sliderContent=''] - additional html to be added inside the slider div + */ +<span class="fstat-no" title="function not covered" > constructor(map: ol.Map, <span class="cstat-no" title="statement not covered" >sliderContent: string = '')</span></span> { + +<span class="cstat-no" title="statement not covered" > sliderContent = sliderContent || '';</span> + /** + * + * @type {Array<LayerBase>} + */ +<span class="cstat-no" title="statement not covered" > this.leftLayers = [];</span> + + /** + * + * @type {Array<LayerBase>} + */ +<span class="cstat-no" title="statement not covered" > this.rightLayers = [];</span> + +<span class="cstat-no" title="statement not covered" > this._percentRight = 50;</span> +<span class="cstat-no" title="statement not covered" > this.offset = null;</span> + +<span class="cstat-no" title="statement not covered" > this._map = map;</span> +<span class="cstat-no" title="statement not covered" > this.$mapElement = $(map.getTargetElement());</span> +<span class="cstat-no" title="statement not covered" > this.$mapElement.append(`<div class="layer-swiper">${sliderContent}</div>`);</span> + + +<span class="cstat-no" title="statement not covered" > this.$swiper = this.$mapElement.find('.layer-swiper');</span> +<span class="cstat-no" title="statement not covered" > this.percentRight = this.percentRight;</span> + +<span class="cstat-no" title="statement not covered" > this.dragging = false;</span> + +<span class="cstat-no" title="statement not covered" > this.$mapElement.mouseleave(<span class="fstat-no" title="function not covered" >() => {</span></span> +<span class="cstat-no" title="statement not covered" > this.dragging = false;</span> + }); + +<span class="cstat-no" title="statement not covered" > this.$swiper.bind('mousewheel DOMMouseScroll', <span class="fstat-no" title="function not covered" >function(evt)</span>{</span> +<span class="cstat-no" title="statement not covered" > evt.preventDefault();</span> + }); + +<span class="cstat-no" title="statement not covered" > this.$swiper.mousedown(<span class="fstat-no" title="function not covered" >(evt)</span> => {</span> +<span class="cstat-no" title="statement not covered" > this.dragging = true;</span> +<span class="cstat-no" title="statement not covered" > this.offset = evt.offsetX;</span> + }); + +<span class="cstat-no" title="statement not covered" > $(window).mouseup(<span class="fstat-no" title="function not covered" >() => {</span></span> +<span class="cstat-no" title="statement not covered" > this.dragging = false;</span> + }); + +<span class="cstat-no" title="statement not covered" > this.$mapElement.mousemove(<span class="fstat-no" title="function not covered" >(evt)</span> => {</span> +<span class="cstat-no" title="statement not covered" > if (this.dragging) {</span> +<span class="cstat-no" title="statement not covered" > let mapLeft = this.$mapElement.position().left;</span> +<span class="cstat-no" title="statement not covered" > let mapWidth = this.$mapElement.width();</span> + +<span class="cstat-no" title="statement not covered" > this.percentRight = 100 * (evt.pageX - this.offset - mapLeft) / mapWidth;</span> + } + }); + } + + /** + * + * @param {LayerBase|*} lyr - layer to be added to left side + */ +<span class="fstat-no" title="function not covered" > addLeftLayer(lyr)</span> { + +<span class="cstat-no" title="statement not covered" > if (this.leftLayers.indexOf(lyr) != -1){</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > lyr.olLayer.on('precompose', <span class="fstat-no" title="function not covered" >(event)</span> => {</span> +<span class="cstat-no" title="statement not covered" > let ctx = event['context'];</span> +<span class="cstat-no" title="statement not covered" > let width = ctx.canvas.width * (this.percentRight / 100);</span> + +<span class="cstat-no" title="statement not covered" > ctx.save();</span> +<span class="cstat-no" title="statement not covered" > ctx.beginPath();</span> +<span class="cstat-no" title="statement not covered" > ctx.rect(0, 0, width, ctx.canvas.height);</span> +<span class="cstat-no" title="statement not covered" > ctx.clip();</span> + }); + +<span class="cstat-no" title="statement not covered" > lyr.olLayer.on('postcompose', <span class="fstat-no" title="function not covered" >function (event)</span> {</span> +<span class="cstat-no" title="statement not covered" > let ctx = event['context'];</span> +<span class="cstat-no" title="statement not covered" > ctx.restore();</span> + }); + + +<span class="cstat-no" title="statement not covered" > this.leftLayers.push(lyr);</span> + } + + /** + * + * @param {LayerBase|*} lyr - layer to be added to right side + */ +<span class="fstat-no" title="function not covered" > addRightLayer(lyr)</span> { + +<span class="cstat-no" title="statement not covered" > if (this.rightLayers.indexOf(lyr) != -1){</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > lyr.olLayer.on('precompose', <span class="fstat-no" title="function not covered" >(event)</span> => {</span> +<span class="cstat-no" title="statement not covered" > let ctx = event['context'];</span> +<span class="cstat-no" title="statement not covered" > let width = ctx.canvas.width * (this.percentRight / 100);</span> + +<span class="cstat-no" title="statement not covered" > ctx.save();</span> +<span class="cstat-no" title="statement not covered" > ctx.beginPath();</span> +<span class="cstat-no" title="statement not covered" > ctx.rect(width, 0, ctx.canvas.width - width, ctx.canvas.height);</span> +<span class="cstat-no" title="statement not covered" > ctx.clip();</span> + }); + +<span class="cstat-no" title="statement not covered" > lyr.olLayer.on('postcompose', <span class="fstat-no" title="function not covered" >function (event)</span> {</span> +<span class="cstat-no" title="statement not covered" > let ctx = event['context'];</span> +<span class="cstat-no" title="statement not covered" > ctx.restore();</span> + }); + +<span class="cstat-no" title="statement not covered" > this.rightLayers.push(lyr);</span> + } + +<span class="fstat-no" title="function not covered" > get percentRight() : number{</span> +<span class="cstat-no" title="statement not covered" > return this._percentRight;</span> + } + +<span class="fstat-no" title="function not covered" > set percentRight(percent: number)</span> { +<span class="cstat-no" title="statement not covered" > let maxed = this.$swiper.position().left + this.$swiper.width() > this.$mapElement.width();</span> + +<span class="cstat-no" title="statement not covered" > if (percent < 0) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } else <span class="cstat-no" title="statement not covered" >if (maxed && percent > this.percentRight) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > this._percentRight = percent;</span> +<span class="cstat-no" title="statement not covered" > this.$swiper.css('left', `${this._percentRight.toFixed(2)}%`);</span> +<span class="cstat-no" title="statement not covered" > this._map.render();</span> + } +} + +nm.LayerSwipe = LayerSwipe; +export default LayerSwipe; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapInteractionBase.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapInteractionBase.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..ccd2185f4bb1a26700f65a21da166930390f5c03 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapInteractionBase.ts.html @@ -0,0 +1,299 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\mapInteractionBase.ts</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/olHelpers/</a> mapInteractionBase.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">59.26% </span> + <span class="quiet">Statements</span> + <span class='fraction'>16/27</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">28.57% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/7</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">57.69% </span> + <span class="quiet">Lines</span> + <span class='fraction'>15/26</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/8/2015. + */ +import provide from '../util/provide'; +import ol = require('custom-ol'); +const nm = provide('olHelpers'); + + + +/** + * base interaction + */ +export class MapInteractionBase { + _map: ol.Map; + _initialized: boolean; + _subtype: string; + + /** + * map interaction base + * @param subtype - the interaction subtype + */ + constructor(subtype: string) { + this._map = null; + this._initialized = false; + this._subtype = subtype; + } + + /** + * base initializer, returns true for already initialized + * @param theMap - the ol Map + * @returns true for already initialized + */ +<span class="fstat-no" title="function not covered" > init(theMap: ol.Map)</span>{ +<span class="cstat-no" title="statement not covered" > if (!this._initialized){</span> +<span class="cstat-no" title="statement not covered" > this._map = theMap;</span> +<span class="cstat-no" title="statement not covered" > this._initialized = true;</span> + } + } + + /** + * get reference to the ol map object + * @returns {ol.Map} the map object + */ +<span class="fstat-no" title="function not covered" > get map() {</span> +<span class="cstat-no" title="statement not covered" > return this._map;</span> + } + + /** + * get if is initialized + * @returns {boolean} is initialized + */ +<span class="fstat-no" title="function not covered" > get initialized() {</span> +<span class="cstat-no" title="statement not covered" > return this._initialized;</span> + } + + /** + * Check the initialization status and throw exception if not valid yet + * @protected + */ +<span class="fstat-no" title="function not covered" > _checkInit() {</span> +<span class="cstat-no" title="statement not covered" > if (!this.initialized) {</span> +<span class="cstat-no" title="statement not covered" > let msg = `${this._subtype} object not initialized`;</span> +<span class="cstat-no" title="statement not covered" > alert(msg);</span> +<span class="cstat-no" title="statement not covered" > console.log(msg);</span> +<span class="cstat-no" title="statement not covered" > throw msg;</span> + } + } + + /** + * Check the initialization status and throw exception if not valid yet + */ +<span class="fstat-no" title="function not covered" > checkInit(){</span> +<span class="cstat-no" title="statement not covered" > this._checkInit();</span> + } +} + +nm.MapInteractionBase = MapInteractionBase; +export default MapInteractionBase; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapMove.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapMove.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..d054b3ab59a024f84f16d682c927174f44ce8975 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapMove.ts.html @@ -0,0 +1,104 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\mapMove.ts</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/olHelpers/</a> mapMove.ts + </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'>0/0</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">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</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-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-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 11/3/2015. + */ + +import MapMoveCls from './mapMoveCls'; + +/** + * The single map move object catch is that it is common to multimap pages + * @type {MapMoveCls} + */ + +export const mapMove = new MapMoveCls(); +export default mapMove; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapMoveCls.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapMoveCls.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..49b4d8ddabcfb835cabf1ddc737aa8e1ea816b6b --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapMoveCls.ts.html @@ -0,0 +1,947 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\mapMoveCls.ts</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/olHelpers/</a> mapMoveCls.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">25.81% </span> + <span class="quiet">Statements</span> + <span class='fraction'>32/124</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">3.23% </span> + <span class="quiet">Branches</span> + <span class='fraction'>2/62</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">11.76% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/17</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">24.79% </span> + <span class="quiet">Lines</span> + <span class='fraction'>30/121</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any 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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-yes">2×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any 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-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-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-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-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-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-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-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-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> +<span class="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-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-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-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-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-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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-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-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">import LayerBaseVector from "../layers/LayerBaseVector"; +import MapInteractionBase from './mapInteractionBase'; +import * as checkDefined from '../util/checkDefined'; +import provide from '../util/provide'; +import makeGuid from '../util/makeGuid'; +import ol = require('custom-ol'); +import $ = require('jquery'); +const nm = provide('olHelpers'); + + +export interface extentObject{ + minX: number; + minY: number; + maxX: number; + maxY: number; +} + +export interface mapMoveCallbackFunction{ + /** + * + * @param extent extent as predefined object minX, minX, maxX, maxY + * @param zoomLevel current zoom level + * @param evtType the event type 'change:center', 'change:resolution' + */ + (extent: extentObject, zoomLevel: number, evtType?: string): any +} + + +/** + * assists with map move interactions, trigger callback functions + * @augments MapInteractionBase + */ +export class MapMoveCls extends MapInteractionBase { + _mapExtent: extentObject; + _zoomLevel: number; + _lookupLayer: Object; + _arrLayer: Array<LayerBaseVector>; + _arrLyrTimeout: Array<number>; + _mapMoveCallbackTimeout: Array<number>; + _mapMoveCallbackDelays: Array<number>; + _mapMoveCallbacksLookup: Object; + _mapMoveCallbackContext: Array<Object>; + _mapMoveCallbacks: Array<mapMoveCallbackFunction>; + _arrLyrRequest: Array<any>; + + /** + * constructor called implicitly + */ + constructor() { + super('map move'); + this._arrLyrRequest = []; + this._arrLyrTimeout = []; + this._arrLayer = []; + this._lookupLayer = {}; + + this._mapMoveCallbacks = []; + this._mapMoveCallbacksLookup = {}; + this._mapMoveCallbackDelays = []; + this._mapMoveCallbackContext = []; + this._mapMoveCallbackTimeout = []; + + this._mapExtent = undefined; + this._zoomLevel = undefined; + + } + + /** + * initialize the map move object + * @param theMap - the ol map + */ +<span class="fstat-no" title="function not covered" > init(theMap: ol.Map)</span>{ +<span class="cstat-no" title="statement not covered" > super.init(theMap);</span> + +<span class="cstat-no" title="statement not covered" > this.map.getView().on(['change:center', 'change:resolution'], <span class="fstat-no" title="function not covered" >(e)</span> =>{</span> + +<span class="cstat-no" title="statement not covered" > this._updateMapExtent();</span> + + // trigger the layer updates +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < this._arrLayer.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > this.triggerLyrLoad(this._arrLayer[i], i, e.type);</span> + } + + // trigger the map callbacks +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < this._mapMoveCallbacks.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > this.triggerMoveCallback(i, e.type);</span> + } + }); + } + +<span class="fstat-no" title="function not covered" > _updateMapExtent() {</span> +<span class="cstat-no" title="statement not covered" > let theView = this.map.getView();</span> +<span class="cstat-no" title="statement not covered" > this._zoomLevel = theView.getZoom();</span> + +<span class="cstat-no" title="statement not covered" > let extentArray = theView.calculateExtent(this.map.getSize());</span> + +<span class="cstat-no" title="statement not covered" > this._mapExtent = {</span> + minX: extentArray[0], + minY: extentArray[1], + maxX: extentArray[2], + maxY: extentArray[3] + }; + } + + /** + * return the map extent + */ +<span class="fstat-no" title="function not covered" > get mapExtent() {</span> +<span class="cstat-no" title="statement not covered" > if (!this._mapExtent) {</span> +<span class="cstat-no" title="statement not covered" > this._updateMapExtent();</span> + } + +<span class="cstat-no" title="statement not covered" > return this._mapExtent;</span> + } + + /** + * Trigger the layer load + * @param lyr the layer being acted on + * @param index index of the layer + * @param eventType the event triggering the load, as 'change:center' or 'change:resolution' + */ +<span class="fstat-no" title="function not covered" > triggerLyrLoad(lyr: LayerBaseVector, index?: number, eventType?: string)</span> { + +<span class="cstat-no" title="statement not covered" > if (checkDefined.undefinedOrNull(lyr) && checkDefined.undefinedOrNull(index)) {</span> +<span class="cstat-no" title="statement not covered" > throw 'need to define lyr or index';</span> + } else <span class="cstat-no" title="statement not covered" >if (checkDefined.definedAndNotNull(lyr) && checkDefined.undefinedOrNull(index)) {</span> +<span class="cstat-no" title="statement not covered" > index = this._arrLayer.indexOf(lyr);</span> + } else <span class="cstat-no" title="statement not covered" >if (checkDefined.undefinedOrNull(lyr) && checkDefined.definedAndNotNull(index)) {</span> +<span class="cstat-no" title="statement not covered" > lyr = this._arrLayer[index];</span> + } + + // clear the timeout +<span class="cstat-no" title="statement not covered" > if (this._arrLyrTimeout[index] != null) {</span> +<span class="cstat-no" title="statement not covered" > clearTimeout(this._arrLyrTimeout[index]);</span> +<span class="cstat-no" title="statement not covered" > this._arrLyrTimeout[index] = null;</span> + } + + // abort if necessary and clear the request +<span class="cstat-no" title="statement not covered" > if (this._arrLyrRequest[index] != null && this._arrLyrRequest[index] != 4) {</span> +<span class="cstat-no" title="statement not covered" > this._arrLyrRequest[index].abort();</span> +<span class="cstat-no" title="statement not covered" > this._arrLyrRequest[index] = null;</span> + } + + // dummy callback used if before load returns false +<span class="cstat-no" title="statement not covered" > let callbackFunc = <span class="fstat-no" title="function not covered" >function () {</span>};</span> + +<span class="cstat-no" title="statement not covered" > if (lyr.mapMoveBefore(this._zoomLevel, eventType)) {</span> +<span class="cstat-no" title="statement not covered" > lyr.mapMoveMakeGetParams(this._mapExtent, this._zoomLevel);</span> + +<span class="cstat-no" title="statement not covered" > let __this = this;</span> + +<span class="cstat-no" title="statement not covered" > callbackFunc = <span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="fstat-no" title="function not covered" > function innerFunction(theLayer, theIndex)</span> { +<span class="cstat-no" title="statement not covered" > let _innerThis = this;</span> +<span class="cstat-no" title="statement not covered" > this._arrLyrRequest[theIndex] = $.get(</span> + theLayer.url, + theLayer.mapMoveParams, +<span class="fstat-no" title="function not covered" > function (d)</span> { + /** + * @type {LayerBaseVector} + */ +<span class="cstat-no" title="statement not covered" > theLayer.mapMoveCallback(d);</span> +<span class="cstat-no" title="statement not covered" > theLayer.loadCallback();</span> + }, 'json').fail( +<span class="fstat-no" title="function not covered" > function (jqXHR)</span> { +<span class="cstat-no" title="statement not covered" > if (jqXHR.statusText != 'abort') {</span> +<span class="cstat-no" title="statement not covered" > console.log('failed');</span> +<span class="cstat-no" title="statement not covered" > console.log(theLayer.url);</span> +<span class="cstat-no" title="statement not covered" > console.log(theLayer.mapMoveParams);</span> + } + }).always( +<span class="fstat-no" title="function not covered" > function () {</span> +<span class="cstat-no" title="statement not covered" > _innerThis._arrLyrTimeout[theIndex] = null;</span> +<span class="cstat-no" title="statement not covered" > _innerThis._arrLyrRequest[theIndex] = null;</span> + }); + } +<span class="cstat-no" title="statement not covered" > innerFunction.call(__this, lyr, index);</span> + }; + } else { +<span class="cstat-no" title="statement not covered" > lyr.clear();</span> + } +<span class="cstat-no" title="statement not covered" > this._arrLyrTimeout[index] = setTimeout(callbackFunc, lyr.onDemandDelay);</span> + } + + /** + * trigger the map move call back at the given index + * @param ind - the index of the layer + * @param eventType=undefined the event triggering the load as 'change:center' or 'change:resolution' + * @param functionId=undefined the function id used to reference the added callback function + */ +<span class="fstat-no" title="function not covered" > triggerMoveCallback(ind: number, eventType?: string, functionId?: string)</span> { + +<span class="cstat-no" title="statement not covered" > if (typeof ind == 'undefined' && typeof functionId == 'undefined'){</span> +<span class="cstat-no" title="statement not covered" > throw 'either the function index or the id must be defined';</span> + } + +<span class="cstat-no" title="statement not covered" > if (typeof ind !== 'number'){</span> +<span class="cstat-no" title="statement not covered" > ind = this._mapMoveCallbacks.indexOf(this._mapMoveCallbacksLookup[functionId]);</span> + } + +<span class="cstat-no" title="statement not covered" > if (ind < 0){</span> +<span class="cstat-no" title="statement not covered" > console.log('function not found');</span> + +<span class="cstat-no" title="statement not covered" > return;</span> + } + + // clear the timeout +<span class="cstat-no" title="statement not covered" > if (this._mapMoveCallbackTimeout[ind] != null) {</span> +<span class="cstat-no" title="statement not covered" > clearTimeout(this._mapMoveCallbackTimeout[ind]);</span> +<span class="cstat-no" title="statement not covered" > this._mapMoveCallbackTimeout[ind] = null;</span> + } + +<span class="cstat-no" title="statement not covered" > let ctx = this._mapMoveCallbackContext[ind];</span> +<span class="cstat-no" title="statement not covered" > let theFunc = this._mapMoveCallbacks[ind];</span> + +<span class="cstat-no" title="statement not covered" > let __this = this;</span> + +<span class="cstat-no" title="statement not covered" > let f = <span class="fstat-no" title="function not covered" >function () {</span></span> +<span class="cstat-no" title="statement not covered" > if (ctx !== null) {</span> +<span class="cstat-no" title="statement not covered" > theFunc.call(ctx, __this._mapExtent, __this._zoomLevel, eventType);</span> + } else { +<span class="cstat-no" title="statement not covered" > theFunc(__this._mapExtent, __this._zoomLevel, eventType);</span> + } + }; + +<span class="cstat-no" title="statement not covered" > this._mapMoveCallbackTimeout[ind] = setTimeout(f, this._mapMoveCallbackDelays[ind]);</span> + } + + /** + * Add a layer to the interaction + * @param lyr - layer to add + * @param triggerOnAdd - if the layer should be loaded on add + */ +<span class="fstat-no" title="function not covered" > addVectorLayer(lyr: LayerBaseVector, <span class="cstat-no" title="statement not covered" >triggerOnAdd: boolean = true)</span></span> { +<span class="cstat-no" title="statement not covered" > if (this._arrLayer.indexOf(lyr) > -1) {</span> +<span class="cstat-no" title="statement not covered" > console.log('already added ' + lyr.name + ' to map move');</span> + +<span class="cstat-no" title="statement not covered" > return;</span> + } +<span class="cstat-no" title="statement not covered" > this._checkInit();</span> + +<span class="cstat-no" title="statement not covered" > this._arrLyrRequest.push(null);</span> +<span class="cstat-no" title="statement not covered" > this._arrLyrTimeout.push(null);</span> +<span class="cstat-no" title="statement not covered" > this._arrLayer.push(lyr);</span> +<span class="cstat-no" title="statement not covered" > this._lookupLayer[lyr.id] = lyr;</span> + +<span class="cstat-no" title="statement not covered" > triggerOnAdd = typeof triggerOnAdd == 'boolean' ? triggerOnAdd : true;</span> + +<span class="cstat-no" title="statement not covered" > if (triggerOnAdd) {</span> +<span class="cstat-no" title="statement not covered" > if (this._mapExtent === undefined) {</span> +<span class="cstat-no" title="statement not covered" > this._updateMapExtent();</span> + } +<span class="cstat-no" title="statement not covered" > this.triggerLyrLoad(lyr, this._arrLayer.length - 1);</span> + } + } + + + /** + * add a callback to the map move event + * @param func - callback function + * @param context - the context to use for this function + * @param delay=50 the delay before call load + * @param triggerOnAdd if the layer should be loaded on add to mapMove + * @param functionId optional id to reference the function later for outside triggering + */ +<span class="fstat-no" title="function not covered" > addCallback(func: mapMoveCallbackFunction, context?: any, delay?: number, triggerOnAdd? : boolean, functionId?: string)</span> { + +<span class="cstat-no" title="statement not covered" > if (this._mapMoveCallbacks.indexOf(func) > -1) {</span> +<span class="cstat-no" title="statement not covered" > console.log('this function already added to map move');</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } +<span class="cstat-no" title="statement not covered" > this._checkInit();</span> +<span class="cstat-no" title="statement not covered" > if (!functionId){</span> +<span class="cstat-no" title="statement not covered" > functionId = makeGuid();</span> + } + +<span class="cstat-no" title="statement not covered" > this._mapMoveCallbacks.push(func);</span> +<span class="cstat-no" title="statement not covered" > this._mapMoveCallbacksLookup[functionId] = functionId;</span> +<span class="cstat-no" title="statement not covered" > this._mapMoveCallbackDelays.push(typeof delay == 'number' ? delay : 50);</span> +<span class="cstat-no" title="statement not covered" > this._mapMoveCallbackContext.push(checkDefined.definedAndNotNull(context) ? context : null);</span> +<span class="cstat-no" title="statement not covered" > this._mapMoveCallbackTimeout.push(null);</span> + +<span class="cstat-no" title="statement not covered" > triggerOnAdd = typeof triggerOnAdd == 'boolean' ? triggerOnAdd : true;</span> + +<span class="cstat-no" title="statement not covered" > if (triggerOnAdd) {</span> +<span class="cstat-no" title="statement not covered" > if (this._mapExtent === undefined) {</span> +<span class="cstat-no" title="statement not covered" > this._updateMapExtent();</span> + } +<span class="cstat-no" title="statement not covered" > this.triggerMoveCallback(this._mapMoveCallbacks.length - 1);</span> + } + } +} + +nm.MapMoveCls = MapMoveCls; +export default MapMoveCls; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapPopup.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapPopup.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..bf821d37471045095b67418439d2d05cb654e007 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapPopup.ts.html @@ -0,0 +1,101 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\mapPopup.ts</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/olHelpers/</a> mapPopup.ts + </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'>0/0</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">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</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-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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 11/3/2015. + */ + +import MapPopupCls from './mapPopupCls'; + +/** + * The single popup object catch is that it is common to multimap pages + * @type {MapPopupCls} + */ +export const mapPopup = new MapPopupCls() as MapPopupCls; +export default mapPopup; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapPopupCls.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapPopupCls.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..4b28b843ed5d76b8c0e6b2639911b34ac67912a7 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/mapPopupCls.ts.html @@ -0,0 +1,1676 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\mapPopupCls.ts</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/olHelpers/</a> mapPopupCls.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">22.22% </span> + <span class="quiet">Statements</span> + <span class='fraction'>48/216</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">4.35% </span> + <span class="quiet">Branches</span> + <span class='fraction'>2/46</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">15.38% </span> + <span class="quiet">Functions</span> + <span class='fraction'>4/26</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">21.53% </span> + <span class="quiet">Lines</span> + <span class='fraction'>45/209</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</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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-yes">2×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any 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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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-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-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-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-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-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-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-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-no"> </span> +<span class="cline-any cline-no"> </span> +<span class="cline-any cline-no"> </span> +<span class="cline-any cline-no"> </span> +<span class="cline-any cline-no"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-no"> </span> +<span class="cline-any cline-no"> </span> +<span class="cline-any cline-no"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-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-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-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-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-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-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-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-neutral"> </span> +<span class="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-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">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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="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-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-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-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-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-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-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-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">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-yes">1×</span> +<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 11/3/2015. + */ + +import MapInteractionBase from './mapInteractionBase'; +import propertiesZoomStyle from '../olHelpers/propertiesZoomStyle'; +import provide from '../util/provide'; +import ol = require('custom-ol'); +import {LayerBaseVector} from "../layers/LayerBaseVector"; +import LayerEsriMapServer from "../layers/LayerEsriMapServer"; +import $ = require('jquery'); + +const nm = provide('olHelpers'); + +export interface popupChangedFunction { + ($popContent: JQuery): any; +} + +/** + * + */ +export interface popupCallback { + /** + * Callback function for the popup + * @param featureProperties + * @param jqRef + */ + (featureProperties: Object, jqRef?: JQuery): string | boolean; +} + +interface mapEvent { + coordinate: ol.Coordinate; + pixel: ol.Pixel; + dragging: boolean|any; + originalEvent: Event; +} + + +export class FeatureLayerProperties { + + feature: ol.Feature; + layer: LayerBaseVector|LayerEsriMapServer; + layerIndex: number; + selectionLayer: ol.layer.Vector; + popupContent: string; + esriLayerName: string; + + /** + * + * @param feature the feature + * @param layer - the layer in the popup + * @param layerIndex - index of the layer + * @param selectionLayer - the ol selection layer + * @param [esriLayerName=undefined] - esri layer name + */ +<span class="fstat-no" title="function not covered" > constructor(feature: ol.Feature, layer: LayerBaseVector|LayerEsriMapServer, layerIndex: number, selectionLayer: ol.layer.Vector, esriLayerName?: string)</span> { +<span class="cstat-no" title="statement not covered" > this.feature = feature;</span> +<span class="cstat-no" title="statement not covered" > this.layer = layer;</span> +<span class="cstat-no" title="statement not covered" > this.layerIndex = layerIndex;</span> +<span class="cstat-no" title="statement not covered" > this.selectionLayer = selectionLayer;</span> +<span class="cstat-no" title="statement not covered" > this.popupContent = '';</span> +<span class="cstat-no" title="statement not covered" > this.esriLayerName = typeof esriLayerName == 'string' ? esriLayerName : undefined;</span> + } + +<span class="fstat-no" title="function not covered" > get layerName() {</span> +<span class="cstat-no" title="statement not covered" > if (typeof this.esriLayerName == 'string') {</span> +<span class="cstat-no" title="statement not covered" > return this.esriLayerName;</span> + } else { +<span class="cstat-no" title="statement not covered" > return this.layer.name;</span> + } + } +} + +/** + * map popup class + * @augments MapInteractionBase + */ +export class MapPopupCls extends MapInteractionBase { + private _popupOpen: boolean; + private _passThroughLayerFeatureArray: Array<FeatureLayerProperties>; + private _currentPopupIndex: number; + private _popupContentLength: number; + private _esriMapServiceLayers: Array<LayerEsriMapServer>; + private _$popupCloser: JQuery; + private _$popupContent: JQuery; + private _$popupContainer: JQuery; + private _popupOverlay: ol.Overlay; + private _arrPopupLayers: Array<LayerBaseVector>; + private _popupCoordinate: ol.Coordinate; + private _popupChangedFunctions: Array<popupChangedFunction>; + private _mapClickFunctions: Array<Function>; + private _selectionLayerLookup: Object; + private _arrPopupLayerIds: Array<string>; + private _arrPopupLayerNames: Array<string>; + private _arrPopupOlLayers: Array<ol.layer.Vector>; + private _arrPopupContentFunction: Array<popupCallback>; + private _selectionLayers: Array<ol.layer.Vector>; + + /** + * Definition for openlayers style function + * @callback olStyleFunction + * &param feature the openlayers vector feature + * $param + */ + + + /** + * map popup constructor + */ + constructor() { + super('map popup'); + this._arrPopupLayerIds = []; + this._arrPopupLayerNames = []; + this._arrPopupLayers = []; + this._arrPopupOlLayers = []; + this._arrPopupContentFunction = []; + this._$popupContainer = undefined; + this._$popupContent = undefined; + this._$popupCloser = undefined; + this._popupOverlay = undefined; + this._selectionLayers = []; + this._selectionLayerLookup = {}; + this._mapClickFunctions = []; + + //let a = function($jqueryContent){console.log($jqueryContent)}; + //this._popupChangedLookup = {'a': a}; + this._popupChangedFunctions = []; + this._esriMapServiceLayers = []; + + this._popupOpen = false; + this._popupCoordinate = null; + + this._passThroughLayerFeatureArray = []; + + this._currentPopupIndex = -1; + this._popupContentLength = 0; + + } + + /** + * map popup initialization + * @param {ol.Map} theMap - the ol map + */ +<span class="fstat-no" title="function not covered" > init(theMap: ol.Map)</span> { +<span class="cstat-no" title="statement not covered" > super.init(theMap);</span> + +<span class="cstat-no" title="statement not covered" > let $map;</span> +<span class="cstat-no" title="statement not covered" > let target = this.map.getTarget();</span> + +<span class="cstat-no" title="statement not covered" > if (typeof target == 'string') {</span> +<span class="cstat-no" title="statement not covered" > $map = $('#' + target);</span> + } + else { +<span class="cstat-no" title="statement not covered" > $map = $(target);</span> + } + +<span class="cstat-no" title="statement not covered" > $map.append(</span> + '<div class="ol-popup">' + + '<span class="ol-popup-closer">X</span>' + + '<div class="popup-content"></div>' + + '</div>' + ); + +<span class="cstat-no" title="statement not covered" > this._$popupContainer = $map.find('.ol-popup');</span> +<span class="cstat-no" title="statement not covered" > this._$popupContent = $map.find('.popup-content');</span> +<span class="cstat-no" title="statement not covered" > this._$popupCloser = $map.find('.ol-popup-closer');</span> + +<span class="cstat-no" title="statement not covered" > let _ease = <span class="fstat-no" title="function not covered" >(n: number)</span>: number => {</span> +<span class="cstat-no" title="statement not covered" > return ol.easing.inAndOut(n);</span> + }; + + +<span class="cstat-no" title="statement not covered" > this._popupOverlay = new ol.Overlay({</span> + element: this._$popupContainer[0], + autoPan: true, + autoPanAnimation: { + duration: 250, + source: theMap.getView().getCenter(), + easing: _ease + } + }); + +<span class="cstat-no" title="statement not covered" > this._map.addOverlay(this._popupOverlay);</span> + +<span class="cstat-no" title="statement not covered" > this._$popupCloser.click(<span class="fstat-no" title="function not covered" >(evt)</span> => {</span> +<span class="cstat-no" title="statement not covered" > this.closePopup();</span> + }); + + // display popup on click +<span class="cstat-no" title="statement not covered" > this._map.on('singleclick', <span class="fstat-no" title="function not covered" >(evt)</span> => {</span> + +<span class="cstat-no" title="statement not covered" > this.closePopup();</span> +<span class="cstat-no" title="statement not covered" > this._popupCoordinate = evt['coordinate'];</span> + + // esri map service layers +<span class="cstat-no" title="statement not covered" > if (this._esriMapServiceLayers.length > 0) {</span> + +<span class="cstat-no" title="statement not covered" > let queryParams = {</span> + geometry: evt['coordinate'].join(','), + geometryType: 'esriGeometryPoint', + layers: 'all', + sr: this._map.getView().getProjection().getCode().split(':')[1], + mapExtent: (this._map.getView().calculateExtent(this._map.getSize()) as number[]).join(','), + imageDisplay: (this._map.getSize() as number[]).join(',') + ',96', + returnGeometry: true, + tolerance: 15, + f: 'pjson' + }; + +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let l </span>of this._esriMapServiceLayers) {</span> +<span class="cstat-no" title="statement not covered" > l.getPopupInfo(queryParams);</span> + } + } + +<span class="cstat-no" title="statement not covered" > let layerFeatureObjectArray = this._featuresAtPixel(evt['pixel']);</span> + +<span class="cstat-no" title="statement not covered" > this._passThroughLayerFeatureArray = [];</span> +<span class="cstat-no" title="statement not covered" > this._currentPopupIndex = -1;</span> + +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < layerFeatureObjectArray.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > let featObj = layerFeatureObjectArray[i];</span> + +<span class="cstat-no" title="statement not covered" > let props = featObj.feature.getProperties();</span> + +<span class="cstat-no" title="statement not covered" > let popupContentResponse = this._arrPopupContentFunction[featObj.layerIndex](props, this._$popupContent);</span> + + //skip if return was false +<span class="cstat-no" title="statement not covered" > if (popupContentResponse === false) {</span> + //continue; + } else <span class="cstat-no" title="statement not covered" >if (typeof popupContentResponse == 'string') {</span> +<span class="cstat-no" title="statement not covered" > featObj.popupContent = popupContentResponse as string;</span> +<span class="cstat-no" title="statement not covered" > this._passThroughLayerFeatureArray.push(featObj);</span> + } else { +<span class="cstat-no" title="statement not covered" > featObj.selectionLayer.getSource().addFeature(featObj.feature);</span> + } + } + +<span class="cstat-no" title="statement not covered" > this._popupContentLength = this._passThroughLayerFeatureArray.length;</span> + +<span class="cstat-no" title="statement not covered" > this._currentPopupIndex = -1;</span> + +<span class="cstat-no" title="statement not covered" > let popupHtml = '<div class="ol-popup-nav">';</span> +<span class="cstat-no" title="statement not covered" > popupHtml += '<span class="previous-popup ol-popup-nav-arrow">&#9664;</span>';</span> +<span class="cstat-no" title="statement not covered" > popupHtml += '<span class="next-popup ol-popup-nav-arrow">&#9654;</span>';</span> +<span class="cstat-no" title="statement not covered" > popupHtml += `<span class="current-popup-item-number" style="font-weight: bold;"></span>`;</span> +<span class="cstat-no" title="statement not covered" > popupHtml += `<span>&nbsp;of&nbsp;</span>`;</span> +<span class="cstat-no" title="statement not covered" > popupHtml += `<span class="popup-content-length" style="font-weight: bold;">${this._popupContentLength}</span>`;</span> +<span class="cstat-no" title="statement not covered" > popupHtml += `<span>&nbsp;&nbsp;-&nbsp;&nbsp;</span>`;</span> +<span class="cstat-no" title="statement not covered" > popupHtml += `<span class="current-popup-layer-name"></span>`;</span> +<span class="cstat-no" title="statement not covered" > popupHtml += '</div>';</span> +<span class="cstat-no" title="statement not covered" > popupHtml += '<div class="ol-popup-inner">';</span> + +<span class="cstat-no" title="statement not covered" > popupHtml += '</div>';</span> + +<span class="cstat-no" title="statement not covered" > this._$popupContent.html(popupHtml);</span> + +<span class="cstat-no" title="statement not covered" > this._$popupContent.find('.previous-popup').click(<span class="fstat-no" title="function not covered" >() => {</span></span> +<span class="cstat-no" title="statement not covered" > if (this._popupContentLength == 1) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > if (this._currentPopupIndex == 0) {</span> +<span class="cstat-no" title="statement not covered" > this._currentPopupIndex = this._popupContentLength - 1;</span> + } else { +<span class="cstat-no" title="statement not covered" > this._currentPopupIndex--;</span> + } +<span class="cstat-no" title="statement not covered" > this._triggerFeatSelect();</span> + }); + +<span class="cstat-no" title="statement not covered" > let nextPopup = this._$popupContent.find('.next-popup');</span> + +<span class="cstat-no" title="statement not covered" > nextPopup.click(<span class="fstat-no" title="function not covered" >() => {</span></span> +<span class="cstat-no" title="statement not covered" > if (this._popupContentLength == 1 && this._currentPopupIndex > -1) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } + +<span class="cstat-no" title="statement not covered" > if (this._currentPopupIndex == this._popupContentLength - 1) {</span> +<span class="cstat-no" title="statement not covered" > this._currentPopupIndex = 0;</span> + } else { +<span class="cstat-no" title="statement not covered" > this._currentPopupIndex++;</span> + } +<span class="cstat-no" title="statement not covered" > this._triggerFeatSelect();</span> + }); + + +<span class="cstat-no" title="statement not covered" > if (this._popupContentLength > 0) {</span> +<span class="cstat-no" title="statement not covered" > nextPopup.trigger('click');</span> +<span class="cstat-no" title="statement not covered" > this._popupOverlay.setPosition(this._popupCoordinate);</span> +<span class="cstat-no" title="statement not covered" > this._$popupContent.scrollTop(0);</span> +<span class="cstat-no" title="statement not covered" > this._popupOpen = true;</span> + } + }); + + //change mouse cursor when over marker +<span class="cstat-no" title="statement not covered" > this._map.on('pointermove', <span class="fstat-no" title="function not covered" >(evt)</span> => {</span> +<span class="cstat-no" title="statement not covered" > if (evt['dragging']) {</span> +<span class="cstat-no" title="statement not covered" > return;</span> + } +<span class="cstat-no" title="statement not covered" > let pixel = this.map.getEventPixel(evt['originalEvent']);</span> +<span class="cstat-no" title="statement not covered" > let hit = this.map.hasFeatureAtPixel(pixel, <span class="fstat-no" title="function not covered" >(lyrCandidate)</span> => {</span> +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let olLayer </span>of this._arrPopupOlLayers) {</span> +<span class="cstat-no" title="statement not covered" > if (lyrCandidate == olLayer) {</span> +<span class="cstat-no" title="statement not covered" > return true;</span> + } + } + +<span class="cstat-no" title="statement not covered" > return false;</span> + }); +<span class="cstat-no" title="statement not covered" > let mapElement = this.map.getTargetElement() as HTMLElement;</span> +<span class="cstat-no" title="statement not covered" > mapElement.style.cursor = hit ? 'pointer' : '';</span> + }); + +<span class="cstat-no" title="statement not covered" > return true;</span> + } + + /** + * helper to select features + * @private + */ +<span class="fstat-no" title="function not covered" > _triggerFeatSelect() {</span> +<span class="cstat-no" title="statement not covered" > let $currentPopupItemNumber = this._$popupContent.find('.current-popup-item-number');</span> +<span class="cstat-no" title="statement not covered" > let $innerPopup = this._$popupContent.find('.ol-popup-inner');</span> +<span class="cstat-no" title="statement not covered" > let $layerNameSpan = this._$popupContent.find('.current-popup-layer-name');</span> +<span class="cstat-no" title="statement not covered" > this.clearSelection();</span> +<span class="cstat-no" title="statement not covered" > let lyrFeatObj = this._passThroughLayerFeatureArray[this._currentPopupIndex];</span> +<span class="cstat-no" title="statement not covered" > $currentPopupItemNumber.html((this._currentPopupIndex + 1).toFixed());</span> +<span class="cstat-no" title="statement not covered" > $layerNameSpan.html(lyrFeatObj.layerName);</span> +<span class="cstat-no" title="statement not covered" > $innerPopup.html(lyrFeatObj.popupContent);</span> +<span class="cstat-no" title="statement not covered" > lyrFeatObj.selectionLayer.getSource().addFeature(lyrFeatObj.feature);</span> +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let f </span>of this._popupChangedFunctions) {</span> +<span class="cstat-no" title="statement not covered" > f(this._$popupContent);</span> + } + } + + + /** + * + * @param feature - the ol feature + * @param {LayerEsriMapServer} lyr - the map server layer + * @param {string} popupContent - popup content + * @param {string} esriName - esri layer name + */ +<span class="fstat-no" title="function not covered" > addMapServicePopupContent(feature: ol.Feature, lyr: LayerEsriMapServer, popupContent: string, esriName: string)</span> { + +<span class="cstat-no" title="statement not covered" > let featLayerObject = new FeatureLayerProperties(</span> + feature, lyr, this._popupContentLength, this._selectionLayerLookup[lyr.id], esriName + ); +<span class="cstat-no" title="statement not covered" > featLayerObject.popupContent = popupContent;</span> + +<span class="cstat-no" title="statement not covered" > this._passThroughLayerFeatureArray.push(featLayerObject);</span> +<span class="cstat-no" title="statement not covered" > this._popupContentLength++;</span> + +<span class="cstat-no" title="statement not covered" > $('.popup-content-length').html(this._popupContentLength.toFixed());</span> + +<span class="cstat-no" title="statement not covered" > if (!this._popupOpen) {</span> +<span class="cstat-no" title="statement not covered" > this._$popupContent.find('.next-popup').trigger('click');</span> + +<span class="cstat-no" title="statement not covered" > this._popupOverlay.setPosition(this._popupCoordinate);</span> +<span class="cstat-no" title="statement not covered" > this._$popupContent.scrollTop(0);</span> +<span class="cstat-no" title="statement not covered" > this._popupOpen = true;</span> + } + } + + /** + * + * @param pixel - the ol pixel + * @returns feature layer properties + * @private + */ +<span class="fstat-no" title="function not covered" > _featuresAtPixel(pixel: ol.Pixel)</span>: Array<FeatureLayerProperties> { +<span class="cstat-no" title="statement not covered" > let layerFeatureObjectArray = [];</span> + +<span class="cstat-no" title="statement not covered" > this.map.forEachFeatureAtPixel(pixel, <span class="fstat-no" title="function not covered" >(feature: ol.Feature, layer: ol.layer.Vector)</span> => {</span> +<span class="cstat-no" title="statement not covered" > let lyrIndex = this._arrPopupOlLayers.indexOf(layer);</span> + +<span class="cstat-no" title="statement not covered" > if (lyrIndex > -1) {</span> +<span class="cstat-no" title="statement not covered" > layerFeatureObjectArray.push(</span> + new FeatureLayerProperties( + feature, this._arrPopupLayers[lyrIndex], lyrIndex, this._selectionLayers[lyrIndex])); + } + }); + +<span class="cstat-no" title="statement not covered" > return layerFeatureObjectArray;</span> + } + +<span class="fstat-no" title="function not covered" > closePopup() {</span> +<span class="cstat-no" title="statement not covered" > this._checkInit();</span> +<span class="cstat-no" title="statement not covered" > this._popupOpen = false;</span> +<span class="cstat-no" title="statement not covered" > this._popupOverlay.setPosition(undefined);</span> +<span class="cstat-no" title="statement not covered" > this._$popupCloser[0].blur();</span> +<span class="cstat-no" title="statement not covered" > this.clearSelection();</span> +<span class="cstat-no" title="statement not covered" > this._$popupContent.html('');</span> + +<span class="cstat-no" title="statement not covered" > return false;</span> + }; + + + /** + * + * @param chgFunction - popup change function + */ +<span class="fstat-no" title="function not covered" > addPopupChangedFunction(chgFunction: popupChangedFunction)</span> { +<span class="cstat-no" title="statement not covered" > this._popupChangedFunctions.push(chgFunction);</span> + } + + /** + * + * @param {LayerBase|*} lyr - the layer being acted on + * @param {object} [selectionStyle={}] the selection style configuration + * @param {string} [selectionStyle.color=rgba(255,170,0,0.5)] the selection color + * @param {number} [selectionStyle.width=10] the selection width for linear features + * @param {object|function} [selectionStyle.olStyle=undefined] an openlayers style object or function + * @returns the new selection layer + * @private + */ +<span class="fstat-no" title="function not covered" > _addPopupLayer(lyr: LayerBaseVector, selectionStyle: {color?: string, width?: number, olStyle?: ol.style.Style})</span>: ol.layer.Vector { +<span class="cstat-no" title="statement not covered" > this._checkInit();</span> + +<span class="cstat-no" title="statement not covered" > selectionStyle = selectionStyle || {};</span> +<span class="cstat-no" title="statement not covered" > selectionStyle.color = selectionStyle.color || 'rgba(255,170,0,0.5)';</span> +<span class="cstat-no" title="statement not covered" > selectionStyle.width = selectionStyle.width || 10;</span> + +<span class="cstat-no" title="statement not covered" > let theStyle;</span> + +<span class="cstat-no" title="statement not covered" > if (selectionStyle.olStyle) {</span> +<span class="cstat-no" title="statement not covered" > theStyle = selectionStyle.olStyle;</span> + } else { +<span class="cstat-no" title="statement not covered" > theStyle = new ol.style.Style({</span> + stroke: new ol.style.Stroke({ + color: selectionStyle.color, + width: selectionStyle.width + }), + image: new ol.style.Circle({ + radius: 7, + fill: new ol.style.Fill({color: selectionStyle.color}), + stroke: new ol.style.Stroke({color: selectionStyle.color, width: 1}) + }), + fill: new ol.style.Fill({ + color: selectionStyle.color + }) + }); + } + +<span class="cstat-no" title="statement not covered" > let selectionLayer = new ol.layer.Vector(</span> + { + source: new ol.source.Vector(), + style: theStyle + } + ); + +<span class="cstat-no" title="statement not covered" > selectionLayer.setZIndex(100);</span> + +<span class="cstat-no" title="statement not covered" > this._selectionLayers.push(selectionLayer);</span> +<span class="cstat-no" title="statement not covered" > this._selectionLayerLookup[lyr.id] = selectionLayer;</span> +<span class="cstat-no" title="statement not covered" > this.map.addLayer(selectionLayer);</span> + +<span class="cstat-no" title="statement not covered" > return selectionLayer;</span> + } + + + /** + * Add popup to the map + * @param {LayerBase|*} lyr The layer that the popup with act on + * @param {popupCallback} popupContentFunction - popup content function that makes popup info + * @param {object} [selectionStyle={}] the selection style configuration + * @param {string} [selectionStyle.color=rgba(255,170,0,0.5)] the selection color + * @param {number} [selectionStyle.width=10] the selection width for linear features + * @param {object|function} [selectionStyle.olStyle=undefined] an openlayers style object or function + * @returns {object} a reference to the ol selection layer + */ +<span class="fstat-no" title="function not covered" > addVectorPopup(lyr: LayerBaseVector, popupContentFunction: popupCallback,</span> + selectionStyle?: {color?: string, width?: number, olStyle?: ol.style.Style}) { +<span class="cstat-no" title="statement not covered" > let selectionLayer = this._addPopupLayer(lyr, selectionStyle);</span> +<span class="cstat-no" title="statement not covered" > this._arrPopupLayerIds.push(lyr.id);</span> +<span class="cstat-no" title="statement not covered" > this._arrPopupLayerNames.push(lyr.name);</span> +<span class="cstat-no" title="statement not covered" > this._arrPopupLayers.push(lyr);</span> +<span class="cstat-no" title="statement not covered" > this._arrPopupOlLayers.push(lyr.olLayer);</span> +<span class="cstat-no" title="statement not covered" > this._arrPopupContentFunction.push(popupContentFunction);</span> + +<span class="cstat-no" title="statement not covered" > return selectionLayer;</span> + }; + + + /** + * + * @param {LayerBase} lyr - layer + */ +<span class="fstat-no" title="function not covered" > removeVectorPopup(lyr)</span> { +<span class="cstat-no" title="statement not covered" > let idx = this._arrPopupLayerIds.indexOf(lyr.id);</span> + +<span class="cstat-no" title="statement not covered" > if (idx > -1) {</span> +<span class="cstat-no" title="statement not covered" > this._arrPopupLayerIds.splice(idx, 1);</span> +<span class="cstat-no" title="statement not covered" > this._arrPopupLayerNames.splice(idx, 1);</span> +<span class="cstat-no" title="statement not covered" > this._arrPopupLayers.splice(idx, 1);</span> +<span class="cstat-no" title="statement not covered" > this._arrPopupOlLayers.splice(idx, 1);</span> +<span class="cstat-no" title="statement not covered" > this._arrPopupContentFunction.splice(idx, 1);</span> +<span class="cstat-no" title="statement not covered" > this._selectionLayers.splice(idx, 1);</span> +<span class="cstat-no" title="statement not covered" > delete this._selectionLayerLookup[lyr.id];</span> + } + } + + /** + * + * @param {LayerEsriMapServer} lyr - map server layer + * @param {object} [selectionStyle={}] the selection style configuration + * @param {string} [selectionStyle.color=rgba(255,170,0,0.5)] the selection color + * @param {number} [selectionStyle.width=10] the selection width for linear features + * @param {object|function} [selectionStyle.olStyle=undefined] an openlayers style object or function + * @returns {object} a reference to the ol selection layer + */ +<span class="fstat-no" title="function not covered" > addMapServicePopup(lyr, selectionStyle?: ol.style.Style|Array<ol.style.Style>|ol.StyleFunction)</span> { +<span class="cstat-no" title="statement not covered" > let selectionLayer = this._addPopupLayer(lyr, selectionStyle);</span> +<span class="cstat-no" title="statement not covered" > this._esriMapServiceLayers.push(lyr);</span> + +<span class="cstat-no" title="statement not covered" > return selectionLayer;</span> + } + +<span class="fstat-no" title="function not covered" > clearSelection() {</span> +<span class="cstat-no" title="statement not covered" > this._checkInit();</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < this._selectionLayers.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > this._selectionLayers[i].getSource().clear();</span> + } +<span class="cstat-no" title="statement not covered" > for (<span class="cstat-no" title="statement not covered" >let f </span>of this._mapClickFunctions) {</span> +<span class="cstat-no" title="statement not covered" > f();</span> + } + }; + + /** + * Add a function to be called when the map is clicked but before any popups are implemented + * @param {function} func - the map click function + */ +<span class="fstat-no" title="function not covered" > addMapClickFunction(func: Function)</span> { +<span class="cstat-no" title="statement not covered" > this._mapClickFunctions.push(func);</span> + } +} +nm.MapPopupCls = MapPopupCls; +export default MapPopupCls; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/projections.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/projections.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..ad09a11fbe21d7d29ecf48562fd9b8b077c355df --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/projections.ts.html @@ -0,0 +1,95 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\projections.ts</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/olHelpers/</a> projections.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Statements</span> + <span class='fraction'>4/4</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'>4/4</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 10/3/2016. + */ +import ol = require('custom-ol'); + + +export const proj4326 = new ol.proj.Projection({code: 'EPSG:4326'}); +export const proj3857 = new ol.proj.Projection({code: 'EPSG:3857'}); +export const proj3070 = new ol.proj.Projection({code: 'EPSG:3070'}); + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/propertiesZoomStyle.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/propertiesZoomStyle.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..99f8e734df0a650efa09a621855a5e67a4cbcfbd --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/propertiesZoomStyle.ts.html @@ -0,0 +1,170 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\propertiesZoomStyle.ts</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/olHelpers/</a> propertiesZoomStyle.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">60% </span> + <span class="quiet">Statements</span> + <span class='fraction'>6/10</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'>1/3</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">60% </span> + <span class="quiet">Lines</span> + <span class='fraction'>6/10</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</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-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-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-yes">1×</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">/** + * Created by gavorhes on 12/14/2015. + */ + +import provide from '../util/provide'; +import * as zoomResolutionConvert from './zoomResolutionConvert'; +import ol = require('custom-ol'); +const nm = provide('olHelpers'); + + +/** + * A style function based on properties and zoom level, wraps normal feature, resolution function + * @callback propertiesZoomStyle + * @param {object} properties the feature properties + * @param {number} zoom level + * + */ + +/** + * wrapper to define a style function by properties and zoom level + * @param {propertiesZoomStyle|*} styleFunc - style function + * @returns {function|*} new function + */ +<span class="fstat-no" title="function not covered" >function propertiesZoomStyle(styleFunc)</span> { +<span class="cstat-no" title="statement not covered" > if (styleFunc == undefined){</span> +<span class="cstat-no" title="statement not covered" > return undefined;</span> + } + +<span class="cstat-no" title="statement not covered" > return <span class="fstat-no" title="function not covered" >function (feature: ol.Feature, resolution)</span> {</span> +<span class="cstat-no" title="statement not covered" > styleFunc(feature.getProperties(), zoomResolutionConvert.resolutionToZoom(resolution));</span> + }; +} + +nm.propertiesZoomStyle = propertiesZoomStyle; +export default propertiesZoomStyle; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/quickMap.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/quickMap.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..24b7a5a78b1bc6ddc247f3be0cffb436c4910c44 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/quickMap.ts.html @@ -0,0 +1,176 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\quickMap.ts</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/olHelpers/</a> quickMap.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">66.67% </span> + <span class="quiet">Statements</span> + <span class='fraction'>8/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">50% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/2</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">66.67% </span> + <span class="quiet">Lines</span> + <span class='fraction'>8/12</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</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-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any 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-yes">2×</span> +<span class="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-yes">1×</span> +<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/15/2015. + */ + +import {quickMapOptions, quickMapBase} from './quickMapBase'; +import provide from '../util/provide'; +import mapMove from './mapMove'; +import mapPopup from './mapPopup'; +import ol = require('custom-ol'); +let nm = provide('olHelpers'); + +/** + * Sets up a map with some default parameters and initializes + * mapMove and mapPopup + * + * @param {object} [options={}] config options + * @param {string} [options.divId=map] map div id + * @param {object} [options.center={}] center config object + * @param {number} [options.center.x=-10018378] center x, web mercator x or lon + * @param {number} [options.center.y=5574910] center y, web mercator y or lat + * @param {number} [options.zoom=7] zoom level + * @param {number} [options.minZoom=undefined] min zoom + * @param {number} [options.maxZoom=undefined] max zoom + * @param {boolean} [options.baseSwitcher=true] if add base map switcher + * @param {boolean} [options.fullScreen=false] if add base map switcher + * @returns {ol.Map} the ol map + */ +<span class="fstat-no" title="function not covered" >export function quickMap(options? : quickMapOptions)</span>: ol.Map { +<span class="cstat-no" title="statement not covered" > let m = quickMapBase(options);</span> +<span class="cstat-no" title="statement not covered" > mapMove.init(m);</span> +<span class="cstat-no" title="statement not covered" > mapPopup.init(m);</span> +<span class="cstat-no" title="statement not covered" > return m;</span> +} + + +nm.quickMap = quickMap; +export default quickMap; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/quickMapBase.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/quickMapBase.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..967c2f067a4466625bb28ca63482bc1ae676157c --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/quickMapBase.ts.html @@ -0,0 +1,410 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\quickMapBase.ts</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/olHelpers/</a> quickMapBase.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">20.59% </span> + <span class="quiet">Statements</span> + <span class='fraction'>7/34</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/26</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">50% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/2</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">20.59% </span> + <span class="quiet">Lines</span> + <span class='fraction'>7/34</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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any 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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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-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-yes">1×</span> +<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/15/2015. + */ + +import provide from '../util/provide'; +import ol = require('custom-ol'); +import $ = require('jquery'); +const nm = provide('olHelpers'); + +export interface quickMapOptions { + divId?: string; + center?: {x: number, y: number}; + zoom?: number; + minZoom?: number; + maxZoom?: number; + baseSwitcher?: boolean; + fullScreen?: boolean; +} + +/** + * Sets up a map with some default parameters and initializes + * mapMove and mapPopup + * + * @param [options={}] config options + * @param [options.divId=map] map div id + * @param [options.center={}] center config object + * @param [options.center.x=-10018378] center x, web mercator x or lon + * @param [options.center.y=5574910] center y, web mercator y or lat + * @param [options.zoom=7] zoom level + * @param [options.minZoom=undefined] min zoom + * @param [options.maxZoom=undefined] max zoom + * @param [options.baseSwitcher=true] if add base map switcher + * @param [options.fullScreen=false] if add base map switcher + * @returns the ol map + */ +<span class="fstat-no" title="function not covered" >export function quickMapBase(options?: quickMapOptions)</span>: ol.Map { +<span class="cstat-no" title="statement not covered" > options = options || {} as quickMapOptions;</span> +<span class="cstat-no" title="statement not covered" > options.divId = options.divId || 'map';</span> +<span class="cstat-no" title="statement not covered" > options.center = options.center || {x: -10018378, y: 5574910};</span> +<span class="cstat-no" title="statement not covered" > options.zoom = typeof options.zoom == 'number' ? options.zoom : 7;</span> +<span class="cstat-no" title="statement not covered" > options.baseSwitcher = typeof options.baseSwitcher == 'boolean' ? options.baseSwitcher : true;</span> +<span class="cstat-no" title="statement not covered" > options.fullScreen = typeof options.fullScreen == 'boolean' ? options.fullScreen : false;</span> + + +<span class="cstat-no" title="statement not covered" > let $mapDiv = $('#' + options.divId);</span> +<span class="cstat-no" title="statement not covered" > $mapDiv.css('position', 'relative');</span> + +<span class="cstat-no" title="statement not covered" > let osmLayer = new ol.layer.Tile({source: new ol.source.OSM()});</span> + // let satLayer = new ol.layer.Tile({visible: false, source: new ol.source.MapQuest({layer: 'sat'})}); + +<span class="cstat-no" title="statement not covered" > let osmCss = "url('_data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAMAAABg3Am1AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAMAUExURQAAADQ1NDk5OURFREtLS1FHSFlZWGJRVGJiYWdmZWxsbHRmaXBpanN0c3V0dHp5eX5+fIVzd4F3eeV0jud5juZ8k4aHhomHhoyGh5eGj5OVlJiVlZiYl5qZmJydnKOTlaKZmqKdnaOioaqqqKuzsbOvrrSysLa3tbW4uLm6ub27ub+/vbGXwbCZwbCgxLKlxrOqyLStybO3yrSxyrWzzbW2y7a1zbK4y7W6zbW8y760yrTAzbTFzrPKzrLOzrTJzrTOzr7CwbXC0LXK0LTO0L3I0bPQz7TQz7PS0bXQ0LnR0brW1bzT0r7U077V1Lzc2dqNqteUsdyXscaquuOHneaGmueHnOeJnuiBleiKn+eNoOiOoOWUpOiRo+iSpeiUpeqYpumaqOmdrPSynemgruSqtOmisOmlsuuqtequuOW1vOuxu+uxvOq1ve+xvPK0pvW3o/W5pfO5qvS7qfCwvMOuwc2/wNenxNyyzNe/0Nq31Nq51dy72Oy3wOu4wOu+xey4wO+6xO2+xfTAr/TCsvfFtPHLvvTJuMPDwMfHxcXKyc3DxMvFyMvLyM3PzcDV08DV1MTX1cbY1s7X1sjZ1sra2Mnd3M7b2c7c2tfH1tnB1t7F2d7M29fX1tLY1tDd2tHe3NTf3NnS19rZ1tva2Nnf3t3d28rh3tXg3Nnh3tzj393k39ni4N7k4N7n5uXDyOfLz+zAxu3CyOzEyezKzeDJ3eLM3uvP0u3P0ePf2+7R0u7Q1u/U0+7U1ezc0+7a2e/d2+3f3vbFzvLOwfHN0PPQw/TUx/LWyvLYzPDQ1fPe0ubc4vve4uHh3+nh3+/h2u/h3vHj2vHl3uHm4eTn4uDp5ebo4+Xo5ODq6ebq6OTv6+nl4+/j4O7l4e7n5ujp4+np5Ozq5e7s5urt6O7t6Orw6u7x6u3x7vPj5PDl4fDo4vDq5fDt5vDu6PDv7PTv6fDx6vHx7fH17fXw6fXy7fb07/bz8fT18vn38vr39fr48/r59Pr6+P3++//+/gAAALNTSk0AAAEAdFJOU////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////wBT9wclAAAACXBIWXMAAA7DAAAOwwHHb6hkAAAAGHRFWHRTb2Z0d2FyZQBwYWludC5uZXQgNC4wLjlsM35OAAAFNElEQVRIS1VVCZxVUxi/9l0UIUT2bMnY43bVI2c0Y01kSWIaS0j2JEtkN41piomZrPPKQ2aQ7JKImOZlnm2493TJzDufuU1Zi+v/fee+mZ//793vnPOd7zvfes5zDBEZkBBjAcIjb+Iiotqgdhat8AMK0vl7/R9N7GiWtshqIr+EZ5gYKibyUsXY1l/mfFpssvUlWQ0FkU3gy4+RB/+kwYcO8pRSnldcOU/r2lAHARSwk2ORgEmOdC1EsuRiYSqMPwwroMIraZk5V2fYJQjCKfZrRmh3gSAZi2i4b7wSylWu8EqZwS59JkFUaW96JbNSc+CEUmt4rorwuZmWdDaoc+uZETuQlTCU5xYzR7muUnVUVo+BcRhre/VwUpasgJwhH7JkYIYA0sNxhmCwUK+lw6vCKBZehw01dEiyw4Q4aE0Z4ahDhKaFQsGnJ2BgqKoTBsNjFy0SlW6whRAZTdm8DBJmkBZhDi1j4xJQBk6ywrWUTymaCxac8lROcdauRGzQSNtA7EHUYhXyEwhhgjFUqRuO+rauhF1awFpzCsmwUbjIFBR0u1bKtyGpulW/H/cVVzkyGaIWTIR9pFAV6GK2gPMXMX8gPk9zzxXgI1kimcAltEYr+cjio1imlKpEa9rOipLm+p+CZ6Bw//qd1/f/O+GwMxbSLpyoZEcwkyh2jIks+3hmdd2jWUw4scxNysnHxU7nSspTRcJjCZGL3IsjsYJMMg5mwgx7gaIOLBFCogAgBBoNa9w+DE6I+Bs7FTgwwrJbHjWDgpYo2KwtBTcYEDuloC9geQw+k2RGnPGpTaOlq7AS+YICUz4DZVaX2TiNDhuYfTtY4geLi0IoCm3XccwM9hx4kU28StQEljDs3ZEpFGA+8dKzLmV9ymIwF5FOGn2GdJM8KLHDJbXyiYVMG9MRTLiXGGg2QKaxM3khPSRrwM9zEIardxU2w/EiA0gOeYKHzDR0V7/QGV3lKIA9ktrDArxO3gdA+k6SKoBiVwcm7NjZb9+Hnztg282TuHVZ9LOISFNt9MgyCetZVczSxnyDbl17Penq6mqpg1IhRaEO2aVLUO4/r17H8tTv6f13h71dduvZI3Y+uMdWksNSauLovJw5hsqiPIUvt0ku7/iBeUR3sksmomYWtRbAjbiLfv2lX9/V7LVG4uYnUZXhQ7f2OPCZEx9wrYWTcePEQqPEML8pl4mMdr/jlXlvHiRiJ2+MSTFY4TTSYStuvz2R/JXh+PPeGXm055J+3/YDWuNu3R3DArPutyg0ZgykMVDU9Ndm22+wYalr2rse48CnsTIFcMn73vfhNrktx1EUcZnPv6ah3Yy5cDTRdBEoGoBeah71dqFyjZDJLkWk3N3v4uuktssjWpzciMPxQeHj8nMKzcGuB0tAyzFhdCKOYWv4HwOQVwIxLG99a6uvH3sJCyO3h+k4EZ+G7+xj5f4XXksoaGrdMRzSc8ARA8+cdOuk2x6fffNNt5x+Ro1omPlrT/CQDlcNlpx4NBIWXhkx7Y3Zp3ofNR7Uv89Om/beW0TLIynHv3vs1VsOFpSWSXvfuPUf9BrRFyxgXdHoKJnQFegPOovvzz59ntrzye240ig8UQ3lDI2VqwagrKIQcLXNFL3wglN2OHdBQ6/vI3kENDVBwRb3k1XtczFbjWn4EzMYi7CF3129+JTYuRSdrGuS92g5dpqn6qXoJQs5xmL8p+Wt4hLbt0mx2OLNZR2bbPy8zJNQGFM/f/CfXZekRYFjGCWjIJpM+WiCzGBPWHhoyaAsjRT/B2Gy5yzYJkwUAAAAAElFTkSuQmCC')";</span> +<span class="cstat-no" title="statement not covered" > let aerialCss = "url('_data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAMAAABg3Am1AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAMAUExURQALBgIMDQgOBwQOEQcTBwUSCwoVDAwdBw8ZDgUREwYUGAYZFQYZGgkTFQoVGQsZFAwZHBMeDhIbFBEbHAwWIA4bIREcIQ4hCQwjFw4lHBgkDB8sDxUiExIiGhAoGxohFRshGRorHQcrKQsiIQwmKgooJA0pKQ81Jw8yLRMiIxImKxUrJREuKhslJB0rIhooKRUuMBMyLhkwJhozKh48LxUzMRM9MBwzMiUvFCMtGiMwEiwzFCgzHDI+GSIsISkvJSQxIiM2LiY5Jic+Lyk0JSo0Ky49JSs9KSU1NSM7NCs2NS8+NDM1JzU9Ljg7IDJCHS1DLSNAMitCMSxIOjREITZLIDZJKDlFIjpFKztKJT1LKzJBMzpHMD1JMjpKPD1RKjlQNC1DQj5QQEA8MEJGJkBKJUJNK0lLLEJMMkVMPEpONENSLUdZL0pTLkpaLkRUMkRSPEVZMktUM0pVOklZMklZNEpcNU1ZMk1ZNUxfMk5dNkxcOVFUM1RUOFJbNVFZOVNYPVFdOVJdPFVaOVVaPVVdOlVdPVpaNlpdO0phN01hOlBiN1NhPFNoP1piPWFbPmRjPENOQEtPSURTQkJVS0xVQk1VSkxbQkxcS0heUVFXRFRcQlJfTFxeQlpeS05lQk1kSFRjQVRjSlZpQ1tkQlxlSlxpRF1rSVVnUVtlU1llXF9tU1xoXlxwSl9ramRfQmJlQ2FhSWFlSWFlTmVlSWRmTGFoQWFpRWFsRmVpRWVtRmNsSmtlRGpqRmpsS2BmWGRsUmFrW2ptUmZyR2RxTGpxTWVyU2RyW2d5V2tzUmt0WW15VG15WXFuTHNtVnFxTXF4T3h0TnJzUnJ1XHJ4VXN6Wnp0VHx1W315VXp8XGR0YGx0YHVzZXJ0aHR9ZXV+aHl9YHOCXXqBXXeCYHyCY3iEaHyIYn+JaXqKcYB5WIN6Y4SCXoCDZIGEaYCIZoOLa4iCaImJbIOOdYuMco6OeIuVcpOKbZKPc5aQb5eXe5ufg6KjhAAAAAAAAAAAAAAAAOGCeQgAAAEAdFJOU////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////wBT9wclAAAACXBIWXMAAA7DAAAOwwHHb6hkAAAAGHRFWHRTb2Z0d2FyZQBwYWludC5uZXQgNC4wLjlsM35OAAAH80lEQVRISy1WbXQUVxm+6wqnk3Zmpxl2FG2EGg92C8GDlWptVTwa+uF3xcKmDfFzCUzDsJNsunXipglJXJbrtJWmwZNSnHD3jojRgUIm2UumIZ0JZ7JByrALbMWW0IBW8aRa4+cf76TeX3Nm3uc+z/s+7/vugl4r/aMTrT4e1pPTqnnmJNn5AyUzRnrRle/qE33dsvrBtAQVoxtpZNK3zSzYjUjviWO2Ag+R77dl7W36n/1Ep9KBPG/S+Py0PkjU/gPKQGqwTHryiWYFAXSvMairsio7SjyNsnCzh0qKImV9/7mhfHQZx2yN1O+7rXUm33MUPaboOkAJHaoIdXfJj2xWeyD8jMFEXkvIu5qzpU988gWB5zl+GS+sFe55trEVPdWZB2miq8bBVkNFO2R0qnrfkiXhcJhtDNXE6tbW97/s9O9/7ZfVhx86/CwrROpfvvxboMqeLsuqPr1j44qEwDNMOBximUiYoU8sw7BC/a7T72uEnyJDlGxZ9KcglZRyuqqrv/tSZErgOI4NgRBTIw9EmHAoFGZZnp6aGaJ2GTxfxYs8kKVUQh7WB5hQeC3LsUxoxVKW14l3BX2WcoUYPiZyLLe8teZ+iuT4GGhvV5KpKWkpyzxEr2MZgQ1xdRjfRBoH+2k6lIHjKTHPPBo8CSJISqqq4wGGOcWylIGlgvgNX1Gd8vF5f+IUIwb30ng+Gg2QfBRIMvy0jG8SVkYo4N0zvUXVRztbJ/L6xL7lUZEXBEHkuZqlS6gEAUgKJurnhFtfpACOYd8b/hVbJPqwi44a6KA0sPVjIi/SIyxb3u8KlAJ0S8jRVgrlW+nVHPdrhiXCxu42d86ByksDc80P3MkJFBFQ8Ho1lQegpWJRWFGsDsRwwv7pIyvuQW0ZkrX6NDVFbqcvaQI8vbyqzt5AARrsbKx5yhQEGs+wPO56bOK+0rcwMrOKkpUbZWYxV04UeZZv/cBKFhRL6Qdv9y4LfEDA7/thg7tTmv1a5/GnO0wl0dQg80wglZaHUmxRvjwAHOfyN0mxrpqLUpcjsK3NHYMo4R1o6eho2ZyIb2FoeOC3ILK8kZ2HQMOuWywGXUkJBCeTbYFS0+ym1h2/6UgmvnrvKYZZtIEXGf75C2cIAp5LHNd71x7uPoTjakrWH9e3KFpaatjUvJUysFw0KrLMYMW2lTg4PeUQx6kJEALvxXEmCdVyPLHtCSjBhc01XCjIgafxou+PE6KC1dhxSCwoBCc+N4P3btM84pmdSSjJnjO/nvY4LQfVyz5/I+v6IwjUOMjy+MVCxIbKupTJaEktp7cTKU42Pvjh2m/8cSpC6aPsaX/MHSuUQLVVsIa4RUTs/r/BVAexNdjdnsNG7j/rV93xheLMzKnFrPeTEQchCyCcKb25aAIn7lrAertrZwyNXM8N6zfWrFo3d2SmOEcF83x/r+OOFgrAHYWF7cELjhV7UQo/6WAIUVl9JFl8a//HZ66VpbY3I9QKZqPru77lA+iOWAIr0hKxHCmmr0othSyeIl5y3qt4xT8gSNrKEZozs8Els67rgsLOZ+ygzwMfbtNhobfgzpEyGnz7htPtzUi6PuOoj7K0WF/MXiUFxwGajRD1hjYXHXI9p406qOyinp5/tiWcDHY0jIu4n64Qfq7kliB2gemag9QbOia0PbbDMbd43SHuvxFxrAocxins7MX5Kqbe1QixKBxoV4//PfAgGCu+Rlm4SvZizyDH+0reDHp92iO0BuX3bCfItl0PEwvYLqpwXG2MHlGsQ4S8pMJZv1JGmHiEoHQDdOjwmVlEP/nE9ADKjI8xLI0OOGITfy0SbeG/C2jKUDGSlDhM9I3IpK9iup6XnbRNC7yqueNsJCCIiXzdQhnaGN+46umnEdy5U5UbUJ48LFM9GkJo8BdDOiAZ7ZIQbKhYLMqvhU2wmNxjEAsS2AI7y4nWF64duePbk7YV3zvAVLEMD9AxJRNa3KDUibV7DjnkuprMEYjScFNcaR2ceP2u9R/5k1052Ryme5phAFRswlHjAudiP4dOy7CaxLgdJh9vUlU1702/+LPa1U9fvPi9qlA4XEUBJc3dFlpsR457IDl1iPqLp7o81NQgyV19iYU38uTiv975Pd3SiwQcsGjx+v4/6fl5T7EOOMTCtpbKxfemsQq/3olQZcminADAAI0cuGLHaHOFxbuGvRk/Z9u7CULqoVR6NE0yx1avj30oRhc/jWUoIALGxkz0dg1Dl9iaI7LqOOXKsXJFwjiuEAi70Jra2nW1PL08zLBhZsMABpW5csI7TPfew9ipFKcn5k1i+1KyCWKjC3W/8dF1d666+RaabBVTFTHacjoojBNDh0NDxk+IPTlwfqJkWpbnpFHXIbLbmpxEQ3ff/Z0g/mauXsoln9wDRjy/NHsQFw3P6vWuTJ43/+FZrk2cvAFRipCKdfD9y2+pjRj78s0KdCUDKJvdV91ChngV38T20TM+gghjpJaPlpFr2xbEz5g4A/NGt5rNwdwmYGeeeMXBSLHHUIc+6RsojRH9VTUm3/mLf/64b470XvoxoTKhlMBQ2jMEzo2PjxdGMppmn1RM24bWFJqaQv4BcuJa2Sam7Zokq1ldCsz06NCBHrhwqVQYpfFj42NZexz1EW9SR/kT58nEeQKJb2fPXjjp0u/YUkwHEgLeOnf2nOuf1TRTM02CLKLTPy60/x1CCztqn7Ev+BdsC3m+30decQvW/wBNTwU+CfUQAQAAAABJRU5ErkJggg==')";</span> + +<span class="cstat-no" title="statement not covered" > if (options.baseSwitcher) {</span> + // let switcherContent = '<div class="base-map-switcher" title="Toggle Base Layer" style="'; + // switcherContent += 'position: absolute; top: 70px; left: 4px; border: solid black 1px; '; + // switcherContent += `height: 50px; width: 50px; z-index: 10; border-radius: 4px; background: ${aerialCss};`; + // switcherContent += '"></div>'; + // $mapDiv.append(switcherContent); + // + // $mapDiv.find('.base-map-switcher').click(function() { + // "use strict"; + // osmLayer.setVisible(!osmLayer.getVisible()); + // satLayer.setVisible(!satLayer.getVisible()); + // + // if (osmLayer.getVisible()){ + // $(this).css('background', aerialCss); + // } else { + // $(this).css('background', osmCss); + // } + // }); + } + +<span class="cstat-no" title="statement not covered" > if (options.zoom < 0 || options.zoom > 28) {</span> +<span class="cstat-no" title="statement not covered" > throw 'zoom out of range';</span> + } + +<span class="cstat-no" title="statement not covered" > if (options.center.x >= -180 && options.center.x <= 180 && options.center.y >= -90 && options.center.y <= 90) {</span> +<span class="cstat-no" title="statement not covered" > let p = new ol.geom.Point([options.center.x, options.center.y]);</span> +<span class="cstat-no" title="statement not covered" > new ol.proj.Projection({code: "EPSG:4326"});</span> + +<span class="cstat-no" title="statement not covered" > p.transform(new ol.proj.Projection({code: "EPSG:4326"}), new ol.proj.Projection({code: "EPSG:3857"}));</span> +<span class="cstat-no" title="statement not covered" > let coordinates = p.getCoordinates();</span> +<span class="cstat-no" title="statement not covered" > options.center.x = coordinates[0];</span> +<span class="cstat-no" title="statement not covered" > options.center.y = coordinates[1];</span> + } + +<span class="cstat-no" title="statement not covered" > const controls = ol.control.defaults({</span> + attributionOptions: {collapsible: false} + } + ); + +<span class="cstat-no" title="statement not covered" > const view = new ol.View({</span> + center: [options.center.x, options.center.y], + zoom: options.zoom, + minZoom: options.minZoom, + maxZoom: options.maxZoom + }); + +<span class="cstat-no" title="statement not covered" > let map = new ol.Map({</span> + layers: [osmLayer], + target: options.divId, + controls: controls, + view: view + }); + +<span class="cstat-no" title="statement not covered" > if (options.fullScreen) {</span> +<span class="cstat-no" title="statement not covered" > map.addControl(new ol.control.FullScreen({}));</span> + } + +<span class="cstat-no" title="statement not covered" > return map;</span> +} + +nm.quickMapBase = quickMapBase; +export default quickMapBase; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/quickMapMulti.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/quickMapMulti.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..9159ef4c8ed31c05d363792bcceb94576c9008d5 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/quickMapMulti.ts.html @@ -0,0 +1,206 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\quickMapMulti.ts</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/olHelpers/</a> quickMapMulti.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">57.14% </span> + <span class="quiet">Statements</span> + <span class='fraction'>8/14</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">50% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/2</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">57.14% </span> + <span class="quiet">Lines</span> + <span class='fraction'>8/14</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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any 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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-yes">1×</span> +<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/15/2015. + */ + +import {quickMapBase, quickMapOptions} from './quickMapBase'; +import provide from '../util/provide'; +import MapMoveCls from './mapMoveCls'; +import MapPopupCls from './mapPopupCls'; +import ol = require('custom-ol'); +let nm = provide('olHelpers'); + + +/** + * @typedef {object} quickMapMultiReturn + * @property {ol.Map} map The X Coordinate + * @property {MapMoveCls} mapMove The Y Coordinate + * @property {MapPopupCls} mapPopup The Y Coordinate + */ + +/** + * Sets up a map with some default parameters and initializes + * mapMove and mapPopup + * + * @param {object} [options={}] config options + * @param {string} [options.divId=map] map div id + * @param {object} [options.center={}] center config object + * @param {number} [options.center.x=-10018378] center x, web mercator x or lon + * @param {number} [options.center.y=5574910] center y, web mercator y or lat + * @param {number} [options.zoom=7] zoom level + * @param {number} [options.minZoom=undefined] min zoom + * @param {number} [options.maxZoom=undefined] max zoom + * @param {boolean} [options.baseSwitcher=true] if add base map switcher + * @param {boolean} [options.fullScreen=false] if add base map switcher + * @returns return object with map, map move, and map popup objects + */ +<span class="fstat-no" title="function not covered" >function quickMapMulti(options: quickMapOptions)</span>: {map: ol.Map, mapMove: MapMoveCls, mapPopup: MapPopupCls} { +<span class="cstat-no" title="statement not covered" > let m = quickMapBase(options);</span> +<span class="cstat-no" title="statement not covered" > let mov = new MapMoveCls();</span> +<span class="cstat-no" title="statement not covered" > let pop = new MapPopupCls();</span> +<span class="cstat-no" title="statement not covered" > mov.init(m);</span> +<span class="cstat-no" title="statement not covered" > pop.init(m);</span> + +<span class="cstat-no" title="statement not covered" > return {map: m, mapMove: mov, mapPopup: pop};</span> +} + +nm.quickMapMulti = quickMapMulti; +export default quickMapMulti; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/zoomResolutionConvert.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/zoomResolutionConvert.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..64fe5b402bcc59c20a708afb15e36a7e5ac3f0db --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/olHelpers/zoomResolutionConvert.ts.html @@ -0,0 +1,299 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\olHelpers\zoomResolutionConvert.ts</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/olHelpers/</a> zoomResolutionConvert.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">52.94% </span> + <span class="quiet">Statements</span> + <span class='fraction'>9/17</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">11.11% </span> + <span class="quiet">Branches</span> + <span class='fraction'>1/9</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">66.67% </span> + <span class="quiet">Functions</span> + <span class='fraction'>2/3</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">52.94% </span> + <span class="quiet">Lines</span> + <span class='fraction'>9/17</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</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-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-yes">2×</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-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">18×</span> +<span class="cline-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">2×</span> +<span class="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-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/14/2015. + */ + +import provide from '../util/provide'; +const nm = provide('olHelpers.zoomResolutionConvert'); + +let _zoomResLookup = [ + 156543.03392804097, //0 + 78271.51696402048, //1 + 39135.75848201024, //2 + 19567.87924100512, //3 + 9783.93962050256, //4 + 4891.96981025128, //5 + 2445.98490512564, //6 + 1222.99245256282, //7 + 611.49622628141, //8 + 305.748113140705, //9 + 152.8740565703525, //10 + 76.43702828517625, //11 + 38.21851414258813, //12 + 19.109257071294063, //13 + 9.554628535647032, //14 + 4.777314267823516, //15 + 2.388657133911758, //16 + 1.194328566955879, //17 + 0.5971642834779395, //18 + 0.29858214173896974, //19 + 0.14929107086948487, //20 + 0.07464553543474244, //21 + 0.03732276771737122, //22 + 0.01866138385868561, //23 + 0.009330691929342804, //24 + 0.004665345964671402, //25 + 0.002332672982335701, //26 + 0.0011663364911678506, //27 + 0.0005831682455839253 //28 +]; + +/** + * Get the resolution given the zoom level + * @param {number} zoomLevel - the zoom level + * @returns {number|*} the map resolution + */ +export function zoomToResolution(zoomLevel) { + "use strict"; + + <span class="missing-if-branch" title="if path not taken" >I</span>if (typeof zoomLevel == 'number') { +<span class="cstat-no" title="statement not covered" > if (zoomLevel % 1 === 0 && zoomLevel >= 0 && zoomLevel <= 28) {</span> +<span class="cstat-no" title="statement not covered" > return _zoomResLookup[zoomLevel];</span> + } else { +<span class="cstat-no" title="statement not covered" > console.log(`invalid zoom level provided: ${zoomLevel}`);</span> + +<span class="cstat-no" title="statement not covered" > return undefined;</span> + } + } else { + return undefined; + } +} +nm.zoomToResolution = zoomToResolution; + + +/** + * Get resolution from the zoom level + * @param {number} resolution - the resolution + * @returns {number|*} the zoom level + */ +<span class="fstat-no" title="function not covered" >export function resolutionToZoom(resolution)</span>{ +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < _zoomResLookup.length; i++){</span> +<span class="cstat-no" title="statement not covered" > if (resolution >= _zoomResLookup[i] ){</span> +<span class="cstat-no" title="statement not covered" > return i;</span> + } + } + +<span class="cstat-no" title="statement not covered" > return 0;</span> +} + +nm.resolutionToZoom = resolutionToZoom; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/_index.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/_index.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..d8e92bb71f1cadd67de1e6fe46ef35a22e0a68ea --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/_index.ts.html @@ -0,0 +1,107 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\util\_index.ts</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/util/</a> _index.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Statements</span> + <span class='fraction'>4/4</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'>2/2</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Lines</span> + <span class='fraction'>4/4</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</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-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">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">/** + * Created by gavorhes on 9/22/2016. + */ + +import * as checkDefinedf from './checkDefined'; + + +export namespace checkDefined { + export const undefinedOrNull = checkDefinedf.undefinedOrNull; + export const definedAndNotNull = checkDefinedf.definedAndNotNull; +} + + + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/checkDefined.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/checkDefined.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..e22ca012fcc5038517ffaf193a8857cb8e380d9a --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/checkDefined.ts.html @@ -0,0 +1,155 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\util\checkDefined.ts</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/util/</a> checkDefined.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">75% </span> + <span class="quiet">Statements</span> + <span class='fraction'>6/8</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">0% </span> + <span class="quiet">Functions</span> + <span class='fraction'>0/2</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">75% </span> + <span class="quiet">Lines</span> + <span class='fraction'>6/8</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</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">2×</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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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></td><td class="text"><pre class="prettyprint lang-js">import provide from './provide'; +let nm = provide('util.checkDefined'); + +/** + * check if the input is undefined or null + * @param input - input pointer + * @returns true undefined or null + */ +<span class="fstat-no" title="function not covered" >export function undefinedOrNull (input)</span>: boolean{ + "use strict"; + +<span class="cstat-no" title="statement not covered" > return (typeof input === 'undefined' || input === null);</span> +} + +nm.undefinedOrNull = undefinedOrNull; + + +/** + * check if the input is defined and not null + * @param input - input pointer + * @returns true defined and not null + */ +<span class="fstat-no" title="function not covered" >export function definedAndNotNull (input: any)</span>: boolean{ + "use strict"; + +<span class="cstat-no" title="statement not covered" > return !(undefinedOrNull(input));</span> +} + +nm.definedAndNotNull = definedAndNotNull; + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/colors.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/colors.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..36632df288e8c869d9e039f6e7a80b8059e6d93e --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/colors.ts.html @@ -0,0 +1,593 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\util\colors.ts</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/util/</a> colors.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">25.97% </span> + <span class="quiet">Statements</span> + <span class='fraction'>20/77</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">16.67% </span> + <span class="quiet">Branches</span> + <span class='fraction'>5/30</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">12.5% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/8</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">25.97% </span> + <span class="quiet">Lines</span> + <span class='fraction'>20/77</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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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">2×</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">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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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-neutral"> </span> +<span class="cline-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">2×</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-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-yes">1×</span> +<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 11/3/2015. + */ +import provide from './provide'; +import * as chk from './checkDefined'; +let nm = provide('util.colors'); + + +/** + * helper function to convert to hex + * @param {number|string} x - the number to convert to hex + * @returns {string} number as hex + * @private + */ +<span class="fstat-no" title="function not covered" >function _hex(x)</span> { +<span class="cstat-no" title="statement not covered" > let hexDigits = ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f"];</span> + +<span class="cstat-no" title="statement not covered" > return isNaN(x) ? "00" : hexDigits[(x - x % 16) / 16] + hexDigits[x % 16];</span> +} + +/** + * converts an RGB string to hex + * @param {string} rgb - rgb color + * @returns {string} rbg as hex + */ +<span class="fstat-no" title="function not covered" >export function rgb2hex(rgb)</span> { +<span class="cstat-no" title="statement not covered" > let rgb1 = rgb.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);</span> + +<span class="cstat-no" title="statement not covered" > return ("#" + _hex(rgb1[1]) + _hex(rgb1[2]) + _hex(rgb1[3])).toUpperCase();</span> +} + +nm.rgb2hex = rgb2hex; + + +/** + * Convert hex string to RGB or RGBA string + * @param {string} hexString - hex color string + * @param {number} [alphaVal=undefined] Alpha value + * @returns {string} - rgb or rgba color + */ +export function hexAlphaToRgbOrRgba(hexString, alphaVal) { + hexString = ((hexString.charAt(0) == "#") ? hexString.substring(1, 7) : <span class="branch-1 cbranch-no" title="branch not covered" >hexString)</span>; + let r = parseInt(hexString.substring(0, 2), 16).toString() || <span class="branch-1 cbranch-no" title="branch not covered" >'0';</span> + let g = parseInt(hexString.substring(2, 4), 16).toString() || <span class="branch-1 cbranch-no" title="branch not covered" >'0';</span> + let b = parseInt(hexString.substring(4, 6), 16).toString() || <span class="branch-1 cbranch-no" title="branch not covered" >'0';</span> + <span class="missing-if-branch" title="else path not taken" >E</span>if (alphaVal) { + return `rgba(${r},${g},${b},${alphaVal})`; + } else { +<span class="cstat-no" title="statement not covered" > return `rgba(${r},${g},${b})`;</span> + } +} + +nm.hexAlphaToRgbOrRgba = hexAlphaToRgbOrRgba; + + +/** + * adds alpha value to rgb string 'rgb(r, b, g)', returns 'rgba(r, g, b, a)' + * @param {string} rgb - rgb color + * @param {number} alpha - alpha value 0 to 1 + * @returns {string} rgba color + */ +<span class="fstat-no" title="function not covered" >export function rgbToRgba(rgb, alpha)</span> { +<span class="cstat-no" title="statement not covered" > let pieces = rgb.split(',');</span> +<span class="cstat-no" title="statement not covered" > pieces[0] = pieces[0].replace('rgb', 'rgba');</span> +<span class="cstat-no" title="statement not covered" > pieces[2] = pieces[2].replace(')', '');</span> +<span class="cstat-no" title="statement not covered" > pieces.push(' ' + alpha.toFixed(1) + ')');</span> + +<span class="cstat-no" title="statement not covered" > return pieces.join(',');</span> +} + +nm.rgbToRgba = rgbToRgba; + + +/** + * @typedef {function} colorLookupByNumber + * @param {number} num - the number to use to retrieve the color + * @returns {string} rgb color + */ + + +/** + * Make a blue green red gradient + * @param {number} minVal - minimum value + * @param {number} maxVal - maximum value + * @param {boolean} flipColors - if the colors should be flipped + * @returns {colorLookupByNumber} color lookup function + */ +<span class="fstat-no" title="function not covered" >export function makeBlueGreenRedGradient(minVal, maxVal, flipColors)</span> { + +<span class="cstat-no" title="statement not covered" > if (typeof flipColors != "boolean") {</span> +<span class="cstat-no" title="statement not covered" > flipColors = false;</span> + } + +<span class="cstat-no" title="statement not covered" > return <span class="fstat-no" title="function not covered" >function (theVal)</span> {</span> +<span class="cstat-no" title="statement not covered" > let r, g, b;</span> +<span class="cstat-no" title="statement not covered" > let ratio;</span> + +<span class="cstat-no" title="statement not covered" > if (chk.undefinedOrNull(theVal)) {</span> +<span class="cstat-no" title="statement not covered" > return 'rgb(100,100,100)';</span> + } + +<span class="cstat-no" title="statement not covered" > let percent = (theVal - minVal) / (maxVal - minVal);</span> + +<span class="cstat-no" title="statement not covered" > if (flipColors == true) {</span> +<span class="cstat-no" title="statement not covered" > percent = 1 - percent;</span> + } + +<span class="cstat-no" title="statement not covered" > if (percent >= 1) {</span> +<span class="cstat-no" title="statement not covered" > r = 255;</span> +<span class="cstat-no" title="statement not covered" > g = 0;</span> +<span class="cstat-no" title="statement not covered" > b = 0;</span> + } else <span class="cstat-no" title="statement not covered" >if (percent <= 0) {</span> +<span class="cstat-no" title="statement not covered" > r = 0;</span> +<span class="cstat-no" title="statement not covered" > g = 0;</span> +<span class="cstat-no" title="statement not covered" > b = 255;</span> + } else <span class="cstat-no" title="statement not covered" >if (percent < .25) {</span> + // green up, blue constant +<span class="cstat-no" title="statement not covered" > r = 0;</span> +<span class="cstat-no" title="statement not covered" > g = Math.floor(255 * percent / 0.25);</span> +<span class="cstat-no" title="statement not covered" > b = 255;</span> + } else <span class="cstat-no" title="statement not covered" >if (percent < 0.50) {</span> + //blue down, green constant +<span class="cstat-no" title="statement not covered" > ratio = (percent - 0.25) / 0.25;</span> +<span class="cstat-no" title="statement not covered" > r = 0;</span> +<span class="cstat-no" title="statement not covered" > g = 255;</span> +<span class="cstat-no" title="statement not covered" > b = 255 - Math.floor(255 * ratio);</span> + } else <span class="cstat-no" title="statement not covered" >if (percent < 0.75) {</span> + // red up, green constant +<span class="cstat-no" title="statement not covered" > ratio = (percent - 0.5) / 0.25;</span> +<span class="cstat-no" title="statement not covered" > r = Math.floor(255 * ratio);</span> +<span class="cstat-no" title="statement not covered" > g = 255;</span> +<span class="cstat-no" title="statement not covered" > b = 0;</span> + } else { + // green down, red constant +<span class="cstat-no" title="statement not covered" > ratio = (percent - 0.75) / 0.25;</span> +<span class="cstat-no" title="statement not covered" > r = 255;</span> +<span class="cstat-no" title="statement not covered" > g = 255 - Math.floor(255 * ratio);</span> +<span class="cstat-no" title="statement not covered" > b = 0;</span> + } + +<span class="cstat-no" title="statement not covered" > r = r.toFixed();</span> +<span class="cstat-no" title="statement not covered" > g = g.toFixed();</span> +<span class="cstat-no" title="statement not covered" > b = b.toFixed();</span> + +<span class="cstat-no" title="statement not covered" > return 'rgb(' + r + ',' + g + ',' + b + ')';</span> + }; +} + +nm.makeBlueGreenRedGradient = makeBlueGreenRedGradient; + + +/** + * Create a function that will return colors based on a gradient + * @param {number} median - median value + * @param {number} stdDev - standard deviation + * @param {boolean} flipColors - if the colors should be flipped + * @returns {colorLookupByNumber} color lookup function + */ +<span class="fstat-no" title="function not covered" >export function makeBlueGreenRedGradientZScore(median, stdDev, flipColors)</span> { + +<span class="cstat-no" title="statement not covered" > let grd = makeBlueGreenRedGradient(-2.5, 2.5, flipColors);</span> + +<span class="cstat-no" title="statement not covered" > return <span class="fstat-no" title="function not covered" >function (theVal)</span> {</span> + +<span class="cstat-no" title="statement not covered" > let zScore;</span> +<span class="cstat-no" title="statement not covered" > if (theVal == null) {</span> +<span class="cstat-no" title="statement not covered" > zScore = null;</span> + } else { +<span class="cstat-no" title="statement not covered" > zScore = (theVal - median) / stdDev;</span> + } + +<span class="cstat-no" title="statement not covered" > return grd(zScore);</span> + }; +} + +nm.makeBlueGreenRedGradientZScore = makeBlueGreenRedGradientZScore; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/dateConvert.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/dateConvert.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..dc886bfc06dcdfb0ed38c28d8e8cfc5a7dd16903 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/dateConvert.ts.html @@ -0,0 +1,224 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\util\dateConvert.ts</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/util/</a> dateConvert.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">33.33% </span> + <span class="quiet">Statements</span> + <span class='fraction'>8/24</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">25% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/4</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">33.33% </span> + <span class="quiet">Lines</span> + <span class='fraction'>8/24</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</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-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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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">/** + * Created by gavorhes on 11/4/2015. + */ + +import provide from './provide'; +let nm = provide('util.dateConvert'); + +<span class="fstat-no" title="function not covered" >function leadingPad(inNum)</span> { +<span class="cstat-no" title="statement not covered" > let strNum = inNum.toFixed();</span> +<span class="cstat-no" title="statement not covered" > if (strNum.length < 2) {</span> +<span class="cstat-no" title="statement not covered" > strNum = '0' + strNum;</span> + } + +<span class="cstat-no" title="statement not covered" > return strNum;</span> +} + +nm.leadingPad = leadingPad; + +/** + * Given a date return a string in the format YYYY-mm-dd hh:MM:SS + * @param {Date} dte to convert + * @returns {string} the formatted date string + */ +<span class="fstat-no" title="function not covered" >export function dateToYyyyMmDdHhMmSs(dte: Date)</span>: string { +<span class="cstat-no" title="statement not covered" > let yr = dte.getFullYear();</span> +<span class="cstat-no" title="statement not covered" > let month = leadingPad(dte.getMonth() + 1);</span> +<span class="cstat-no" title="statement not covered" > let day = leadingPad(dte.getDate());</span> +<span class="cstat-no" title="statement not covered" > let hrs = leadingPad(dte.getHours());</span> +<span class="cstat-no" title="statement not covered" > let mns = leadingPad(dte.getMinutes());</span> +<span class="cstat-no" title="statement not covered" > let secs = leadingPad(dte.getSeconds());</span> + +<span class="cstat-no" title="statement not covered" > return `${yr}-${month}-${day} ${hrs}:${mns}:${secs}`;</span> +} + +nm.dateToYyyyMmDdHhMmSs = dateToYyyyMmDdHhMmSs; + + +/** + * Given a date return a string in the format YYYYmmdd_hh0000 + * @param {Date} dte the input date + * @returns {string} the formatted date string + */ +<span class="fstat-no" title="function not covered" >export function dateToYyyyMmDdHh000(dte: Date)</span>: string { + +<span class="cstat-no" title="statement not covered" > let yr = dte.getFullYear();</span> +<span class="cstat-no" title="statement not covered" > let month = leadingPad(dte.getMonth() + 1);</span> +<span class="cstat-no" title="statement not covered" > let day = leadingPad(dte.getDate());</span> +<span class="cstat-no" title="statement not covered" > let hrs = leadingPad(dte.getHours());</span> + +<span class="cstat-no" title="statement not covered" > return `${yr}${month}${day}_${hrs}0000`;</span> +} + +nm.dateToYyyyMmDdHh000 = dateToYyyyMmDdHh000; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/formatString.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/formatString.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..e97c621091c5a426fe980a4a695294d822fff831 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/formatString.ts.html @@ -0,0 +1,179 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\util\formatString.ts</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/util/</a> formatString.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">30% </span> + <span class="quiet">Statements</span> + <span class='fraction'>3/10</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">12.5% </span> + <span class="quiet">Branches</span> + <span class='fraction'>1/8</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">33.33% </span> + <span class="quiet">Functions</span> + <span class='fraction'>1/3</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">30% </span> + <span class="quiet">Lines</span> + <span class='fraction'>3/10</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</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-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-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-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-yes">1×</span> +<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 10/30/2015. + */ + +<span class="missing-if-branch" title="else path not taken" >E</span>if (!String.prototype['format']) { + /** + * helper function for string replacement to keep code clean + * usage + * var aString = 'some{0}stuff{1}replaced'; + * var c = 'cat'; + * var b = 'bird'; + * aString.format(c, b) returns 'somecatstuffbirdreplaced' + * prettier than + * 'some' + c + 'stuff' + b + 'replaced' + * but same effect + * adapted to take a single array that is used for replacement by position ie + * var arrReplacements = [c, b]; + * aString.format(arrReplacements) + * @returns {string} converted string + */ + String.prototype['format'] = <span class="fstat-no" title="function not covered" >function () {</span> +<span class="cstat-no" title="statement not covered" > let args = arguments;</span> +<span class="cstat-no" title="statement not covered" > for (let i = 0; i < args.length; i++) {</span> +<span class="cstat-no" title="statement not covered" > args[i] = (args[i] !== null ? args[i] : '');</span> + } + + //if the first argument is an array, use that +<span class="cstat-no" title="statement not covered" > if (args[0].constructor == Array) {</span> +<span class="cstat-no" title="statement not covered" > args = args[0];</span> + } + +<span class="cstat-no" title="statement not covered" > return this.replace(/{(\d+)}/g, <span class="fstat-no" title="function not covered" >function (match, number)</span> {</span> +<span class="cstat-no" title="statement not covered" > return typeof args[number] != 'undefined' ? args[number] : match;</span> + }); + }; +} + +export default undefined; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/getUrlParams.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/getUrlParams.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..7cb3177721961662624bb09632a4ed03cf74d1e5 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/getUrlParams.ts.html @@ -0,0 +1,248 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\util\getUrlParams.ts</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/util/</a> getUrlParams.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">18.52% </span> + <span class="quiet">Statements</span> + <span class='fraction'>5/27</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Branches</span> + <span class='fraction'>0/10</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">0% </span> + <span class="quiet">Functions</span> + <span class='fraction'>0/3</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">18.52% </span> + <span class="quiet">Lines</span> + <span class='fraction'>5/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</td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-yes">1×</span> +<span class="cline-any cline-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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-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-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-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-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-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">/** + * Created by gavorhes on 6/23/2016. + */ +import provide from './provide'; +let nm = provide('util'); + + +<span class="fstat-no" title="function not covered" >function isNumber(checkVal: any)</span>: boolean{ +<span class="cstat-no" title="statement not covered" > let returnVal = parseFloat(checkVal);</span> + +<span class="cstat-no" title="statement not covered" > return !isNaN(returnVal);</span> +} + +/** + * + * @returns {object} object representation of url params + */ +<span class="fstat-no" title="function not covered" >export default function getUrlParams() {</span> + "use strict"; + +<span class="cstat-no" title="statement not covered" > let match;</span> +<span class="cstat-no" title="statement not covered" > let pl = /\+/g; </span> // Regex for replacing addition symbol with a space +<span class="cstat-no" title="statement not covered" > let search = /([^&=]+)=?([^&]*)/g;</span> +<span class="cstat-no" title="statement not covered" > let decode = <span class="fstat-no" title="function not covered" >function (s)</span> {</span> +<span class="cstat-no" title="statement not covered" > return decodeURIComponent(s.replace(pl, " "));</span> + }; +<span class="cstat-no" title="statement not covered" > let query = window.location.search.substring(1);</span> + +<span class="cstat-no" title="statement not covered" > let urlParams = {};</span> +<span class="cstat-no" title="statement not covered" > while (match = search.exec(query)) {</span> + /** + * @type {string} + */ +<span class="cstat-no" title="statement not covered" > let val = decode(match[2]).trim();</span> + +<span class="cstat-no" title="statement not covered" > let typedVal = null;</span> +<span class="cstat-no" title="statement not covered" > if (val.length == 0){</span> + // pass + } + else <span class="cstat-no" title="statement not covered" >if (isNumber(val)){</span> +<span class="cstat-no" title="statement not covered" > if (val.indexOf('.') > -1){</span> +<span class="cstat-no" title="statement not covered" > typedVal = parseFloat(val);</span> + } else { +<span class="cstat-no" title="statement not covered" > typedVal = parseInt(val);</span> + } + } + else <span class="cstat-no" title="statement not covered" >if (val.toLowerCase() == 'false' || val.toLowerCase() == 'true'){</span> +<span class="cstat-no" title="statement not covered" > typedVal = val.toLowerCase() == 'true';</span> + } + else { +<span class="cstat-no" title="statement not covered" > typedVal = val;</span> + } +<span class="cstat-no" title="statement not covered" > urlParams[decode(match[1])] = typedVal;</span> + } + +<span class="cstat-no" title="statement not covered" > return urlParams;</span> +} + +nm.getUrlParams = getUrlParams; + + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/index.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/index.html new file mode 100644 index 0000000000000000000000000000000000000000..4627ab24063d7abb0d06e0e1c8208fc29f6d34ca --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/index.html @@ -0,0 +1,197 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\util\</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/util/ + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">43.17% </span> + <span class="quiet">Statements</span> + <span class='fraction'>79/183</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">24.19% </span> + <span class="quiet">Branches</span> + <span class='fraction'>15/62</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">43.33% </span> + <span class="quiet">Functions</span> + <span class='fraction'>13/30</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">42.86% </span> + <span class="quiet">Lines</span> + <span class='fraction'>78/182</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 high" data-value="_index.ts"><a href="_index.ts.html">_index.ts</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="4" class="abs high">4/4</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="2" class="abs high">2/2</td> + <td data-value="100" class="pct high">100%</td> + <td data-value="4" class="abs high">4/4</td> + </tr> + +<tr> + <td class="file medium" data-value="checkDefined.ts"><a href="checkDefined.ts.html">checkDefined.ts</a></td> + <td data-value="75" class="pic medium"><div class="chart"><div class="cover-fill" style="width: 75%;"></div><div class="cover-empty" style="width:25%;"></div></div></td> + <td data-value="75" class="pct medium">75%</td> + <td data-value="8" class="abs medium">6/8</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="2" class="abs low">0/2</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="2" class="abs low">0/2</td> + <td data-value="75" class="pct medium">75%</td> + <td data-value="8" class="abs medium">6/8</td> + </tr> + +<tr> + <td class="file low" data-value="colors.ts"><a href="colors.ts.html">colors.ts</a></td> + <td data-value="25.97" class="pic low"><div class="chart"><div class="cover-fill" style="width: 25%;"></div><div class="cover-empty" style="width:75%;"></div></div></td> + <td data-value="25.97" class="pct low">25.97%</td> + <td data-value="77" class="abs low">20/77</td> + <td data-value="16.67" class="pct low">16.67%</td> + <td data-value="30" class="abs low">5/30</td> + <td data-value="12.5" class="pct low">12.5%</td> + <td data-value="8" class="abs low">1/8</td> + <td data-value="25.97" class="pct low">25.97%</td> + <td data-value="77" class="abs low">20/77</td> + </tr> + +<tr> + <td class="file low" data-value="dateConvert.ts"><a href="dateConvert.ts.html">dateConvert.ts</a></td> + <td data-value="33.33" class="pic low"><div class="chart"><div class="cover-fill" style="width: 33%;"></div><div class="cover-empty" style="width:67%;"></div></div></td> + <td data-value="33.33" class="pct low">33.33%</td> + <td data-value="24" class="abs low">8/24</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="2" class="abs low">0/2</td> + <td data-value="25" class="pct low">25%</td> + <td data-value="4" class="abs low">1/4</td> + <td data-value="33.33" class="pct low">33.33%</td> + <td data-value="24" class="abs low">8/24</td> + </tr> + +<tr> + <td class="file low" data-value="formatString.ts"><a href="formatString.ts.html">formatString.ts</a></td> + <td data-value="30" class="pic low"><div class="chart"><div class="cover-fill" style="width: 30%;"></div><div class="cover-empty" style="width:70%;"></div></div></td> + <td data-value="30" class="pct low">30%</td> + <td data-value="10" class="abs low">3/10</td> + <td data-value="12.5" class="pct low">12.5%</td> + <td data-value="8" class="abs low">1/8</td> + <td data-value="33.33" class="pct low">33.33%</td> + <td data-value="3" class="abs low">1/3</td> + <td data-value="30" class="pct low">30%</td> + <td data-value="10" class="abs low">3/10</td> + </tr> + +<tr> + <td class="file low" data-value="getUrlParams.ts"><a href="getUrlParams.ts.html">getUrlParams.ts</a></td> + <td data-value="18.52" class="pic low"><div class="chart"><div class="cover-fill" style="width: 18%;"></div><div class="cover-empty" style="width:82%;"></div></div></td> + <td data-value="18.52" class="pct low">18.52%</td> + <td data-value="27" class="abs low">5/27</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="10" class="abs low">0/10</td> + <td data-value="0" class="pct low">0%</td> + <td data-value="3" class="abs low">0/3</td> + <td data-value="18.52" class="pct low">18.52%</td> + <td data-value="27" class="abs low">5/27</td> + </tr> + +<tr> + <td class="file high" data-value="makeGuid.ts"><a href="makeGuid.ts.html">makeGuid.ts</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="8" class="abs high">8/8</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="3" class="abs high">3/3</td> + <td data-value="100" class="pct high">100%</td> + <td data-value="8" class="abs high">8/8</td> + </tr> + +<tr> + <td class="file high" data-value="objectHelpers.ts"><a href="objectHelpers.ts.html">objectHelpers.ts</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="11" class="abs high">11/11</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="3" class="abs high">3/3</td> + <td data-value="100" class="pct high">100%</td> + <td data-value="10" class="abs high">10/10</td> + </tr> + +<tr> + <td class="file high" data-value="provide.ts"><a href="provide.ts.html">provide.ts</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="14" class="abs high">14/14</td> + <td data-value="100" class="pct high">100%</td> + <td data-value="4" class="abs high">4/4</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="14" class="abs high">14/14</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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/makeGuid.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/makeGuid.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..d81a8e4e4e3cd1ef101be3286570ad684a46d3b5 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/makeGuid.ts.html @@ -0,0 +1,140 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\util\makeGuid.ts</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/util/</a> makeGuid.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Statements</span> + <span class='fraction'>8/8</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'>3/3</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Lines</span> + <span class='fraction'>8/8</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-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">9×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">279×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">279×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any 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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 11/3/2015. + */ + +import provide from './provide'; +let nm = provide('util'); + + +/** + * guids are used to uniquely identify groups and features + * @returns {string} a new guid + */ +function makeGuid() { + return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx' + .replace(/[xy]/g, function (c) { + let r = Math.random() * 16 | 0, v = c == 'x' ? r : r & 0x3 | 0x8; + + return v.toString(16); + }); + +} +nm.makeGuid = makeGuid; +export default makeGuid; + + + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/objectHelpers.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/objectHelpers.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..c4040442b60d170e0b95d14fd71877218bb69b0a --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/objectHelpers.ts.html @@ -0,0 +1,179 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\util\objectHelpers.ts</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/util/</a> objectHelpers.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Statements</span> + <span class='fraction'>11/11</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'>3/3</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Lines</span> + <span class='fraction'>10/10</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</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-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-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-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">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-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-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">/** + * Created by gavorhes on 6/7/2016. + */ + +import provide from './provide'; +let nm = provide('util'); + + +export interface keyVals { + key: string; + value: Object +} + + + + +/** + * iterate over the key value pairs of an object + * @example for (let x:KeyValuePair of keyValPairs(object)){..} + * @param {object} obj - the input object + * @returns {Array<keyVals>} - array of key value pairs + */ +export function keyValPairs(obj): Array<keyVals> { + let outArray: Array<keyVals> = []; + for (let key of Object.keys(obj)) { + outArray.push({'key': key, 'value': obj[key]}); + + } + outArray.sort(function (a, b) { + "use strict"; + + return a > b ? <span class="branch-0 cbranch-no" title="branch not covered" >1 </span>: -1; + }); + + return outArray; +} + +nm.keyValPairs = keyValPairs; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/provide.ts.html b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/provide.ts.html new file mode 100644 index 0000000000000000000000000000000000000000..ef630a8d4c6ef4e026fd1bd3df27db0811966ce5 --- /dev/null +++ b/coverage/Chrome 56.0.2924 (Windows 7 0.0.0)/html/src/util/provide.ts.html @@ -0,0 +1,173 @@ +<!doctype html> +<html lang="en"> +<head> + <title>Code coverage report for src\util\provide.ts</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/util/</a> provide.ts + </h1> + <div class='clearfix'> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Statements</span> + <span class='fraction'>14/14</span> + </div> + <div class='fl pad1y space-right2'> + <span class="strong">100% </span> + <span class="quiet">Branches</span> + <span class='fraction'>4/4</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'>14/14</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</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-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">39×</span> +<span class="cline-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">39×</span> +<span class="cline-any cline-yes">39×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">39×</span> +<span class="cline-any cline-yes">45×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">45×</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-yes">45×</span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-neutral"> </span> +<span class="cline-any cline-yes">39×</span> +<span class="cline-any 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></td><td class="text"><pre class="prettyprint lang-js">/** + * Created by gavorhes on 12/10/2015. + */ + + +/** + * create a namespace on the gv object + * @param {string} namespace to create + * @returns {object} object representing the namespace + */ +function provide(namespace){ + "use strict"; + if (typeof window['gv'] == 'undefined'){ + window['gv'] = {}; + } + + let parts = namespace.split('.'); + let nameSpace = window['gv']; + + for (let i=0; i< parts.length; i++){ + let newObject = nameSpace[parts[i]]; + + if (typeof newObject == 'undefined'){ + nameSpace[parts[i]] = {}; + } + + nameSpace = nameSpace[parts[i]]; + } + + return nameSpace; +} + +provide('util'); +window['gv'].util.provide = provide; + +export default provide; + </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 Wed Mar 15 2017 01:55:33 GMT-0500 (Central Daylight Time) +</div> +</div> +<script src="../../prettify.js"></script> +<script> +window.onload = function () { + if (typeof prettyPrint === 'function') { + prettyPrint(); + } +}; +</script> +<script src="../../sorter.js"></script> +</body> +</html> diff --git a/doc/assets/js/main.js b/doc/assets/js/main.js index 3c2dcda0fe2fd3c75984ee40e45cf96ad55f7824..c8685450d906620bcd873e518bc65ff3d3ed74b0 100644 --- a/doc/assets/js/main.js +++ b/doc/assets/js/main.js @@ -1,5 +1,5 @@ -!function(a,b){"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){function s(a){var b=a.length,c=n.type(a);return"function"!==c&&!n.isWindow(a)&&(!(1!==a.nodeType||!b)||("array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a))}function x(a,b,c){if(n.isFunction(b))return n.grep(a,function(a,d){return!!b.call(a,d,a)!==c});if(b.nodeType)return n.grep(a,function(a){return a===b!==c});if("string"==typeof b){if(w.test(b))return n.filter(b,a,c);b=n.filter(b,a)}return n.grep(a,function(a){return g.call(b,a)>=0!==c})}function D(a,b){for(;(a=a[b])&&1!==a.nodeType;);return a}function G(a){var b=F[a]={};return n.each(a.match(E)||[],function(a,c){b[c]=!0}),b}function I(){l.removeEventListener("DOMContentLoaded",I,!1),a.removeEventListener("load",I,!1),n.ready()}function K(){Object.defineProperty(this.cache={},0,{get:function(){return{}}}),this.expando=n.expando+Math.random()}function P(a,b,c){var d;if(void 0===c&&1===a.nodeType)if(d="data-"+b.replace(O,"-$1").toLowerCase(),"string"==typeof(c=a.getAttribute(d))){try{c="true"===c||"false"!==c&&("null"===c?null:+c+""===c?+c:N.test(c)?n.parseJSON(c):c)}catch(e){}M.set(a,b,c)}else c=void 0;return c}function Z(){return!0}function $(){return!1}function _(){try{return l.activeElement}catch(a){}}function jb(a,b){return n.nodeName(a,"table")&&n.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function kb(a){return a.type=(null!==a.getAttribute("type"))+"/"+a.type,a}function lb(a){var b=gb.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function mb(a,b){for(var c=0,d=a.length;d>c;c++)L.set(a[c],"globalEval",!b||L.get(b[c],"globalEval"))}function nb(a,b){var c,d,e,f,g,h,i,j;if(1===b.nodeType){if(L.hasData(a)&&(f=L.access(a),g=L.set(b,f),j=f.events)){delete g.handle,g.events={};for(e in j)for(c=0,d=j[e].length;d>c;c++)n.event.add(b,e,j[e][c])}M.hasData(a)&&(h=M.access(a),i=n.extend({},h),M.set(b,i))}}function ob(a,b){var c=a.getElementsByTagName?a.getElementsByTagName(b||"*"):a.querySelectorAll?a.querySelectorAll(b||"*"):[];return void 0===b||b&&n.nodeName(a,b)?n.merge([a],c):c}function pb(a,b){var c=b.nodeName.toLowerCase();"input"===c&&T.test(a.type)?b.checked=a.checked:("input"===c||"textarea"===c)&&(b.defaultValue=a.defaultValue)}function sb(b,c){var d,e=n(c.createElement(b)).appendTo(c.body),f=a.getDefaultComputedStyle&&(d=a.getDefaultComputedStyle(e[0]))?d.display:n.css(e[0],"display");return e.detach(),f}function tb(a){var b=l,c=rb[a];return c||(c=sb(a,b),"none"!==c&&c||(qb=(qb||n("<iframe frameborder='0' width='0' height='0'/>")).appendTo(b.documentElement),b=qb[0].contentDocument,b.write(),b.close(),c=sb(a,b),qb.detach()),rb[a]=c),c}function xb(a,b,c){var d,e,f,g,h=a.style;return c=c||wb(a),c&&(g=c.getPropertyValue(b)||c[b]),c&&(""!==g||n.contains(a.ownerDocument,a)||(g=n.style(a,b)),vb.test(g)&&ub.test(b)&&(d=h.width,e=h.minWidth,f=h.maxWidth,h.minWidth=h.maxWidth=h.width=g,g=c.width,h.width=d,h.minWidth=e,h.maxWidth=f)),void 0!==g?g+"":g}function yb(a,b){return{get:function(){return a()?void delete this.get:(this.get=b).apply(this,arguments)}}}function Fb(a,b){if(b in a)return b;for(var c=b[0].toUpperCase()+b.slice(1),d=b,e=Eb.length;e--;)if((b=Eb[e]+c)in a)return b;return d}function Gb(a,b,c){var d=Ab.exec(b);return d?Math.max(0,d[1]-(c||0))+(d[2]||"px"):b}function Hb(a,b,c,d,e){for(var f=c===(d?"border":"content")?4:"width"===b?1:0,g=0;4>f;f+=2)"margin"===c&&(g+=n.css(a,c+R[f],!0,e)),d?("content"===c&&(g-=n.css(a,"padding"+R[f],!0,e)),"margin"!==c&&(g-=n.css(a,"border"+R[f]+"Width",!0,e))):(g+=n.css(a,"padding"+R[f],!0,e),"padding"!==c&&(g+=n.css(a,"border"+R[f]+"Width",!0,e)));return g}function Ib(a,b,c){var d=!0,e="width"===b?a.offsetWidth:a.offsetHeight,f=wb(a),g="border-box"===n.css(a,"boxSizing",!1,f);if(0>=e||null==e){if(e=xb(a,b,f),(0>e||null==e)&&(e=a.style[b]),vb.test(e))return e;d=g&&(k.boxSizingReliable()||e===a.style[b]),e=parseFloat(e)||0}return e+Hb(a,b,c||(g?"border":"content"),d,f)+"px"}function Jb(a,b){for(var c,d,e,f=[],g=0,h=a.length;h>g;g++)d=a[g],d.style&&(f[g]=L.get(d,"olddisplay"),c=d.style.display,b?(f[g]||"none"!==c||(d.style.display=""),""===d.style.display&&S(d)&&(f[g]=L.access(d,"olddisplay",tb(d.nodeName)))):(e=S(d),"none"===c&&e||L.set(d,"olddisplay",e?c:n.css(d,"display"))));for(g=0;h>g;g++)d=a[g],d.style&&(b&&"none"!==d.style.display&&""!==d.style.display||(d.style.display=b?f[g]||"":"none"));return a}function Kb(a,b,c,d,e){return new Kb.prototype.init(a,b,c,d,e)}function Sb(){return setTimeout(function(){Lb=void 0}),Lb=n.now()}function Tb(a,b){var c,d=0,e={height:a};for(b=b?1:0;4>d;d+=2-b)c=R[d],e["margin"+c]=e["padding"+c]=a;return b&&(e.opacity=e.width=a),e}function Ub(a,b,c){for(var d,e=(Rb[b]||[]).concat(Rb["*"]),f=0,g=e.length;g>f;f++)if(d=e[f].call(c,b,a))return d}function Vb(a,b,c){var d,e,f,g,h,i,j,l=this,m={},o=a.style,p=a.nodeType&&S(a),q=L.get(a,"fxshow");c.queue||(h=n._queueHooks(a,"fx"),null==h.unqueued&&(h.unqueued=0,i=h.empty.fire,h.empty.fire=function(){h.unqueued||i()}),h.unqueued++,l.always(function(){l.always(function(){h.unqueued--,n.queue(a,"fx").length||h.empty.fire()})})),1===a.nodeType&&("height"in b||"width"in b)&&(c.overflow=[o.overflow,o.overflowX,o.overflowY],j=n.css(a,"display"),"inline"===("none"===j?L.get(a,"olddisplay")||tb(a.nodeName):j)&&"none"===n.css(a,"float")&&(o.display="inline-block")),c.overflow&&(o.overflow="hidden",l.always(function(){o.overflow=c.overflow[0],o.overflowX=c.overflow[1],o.overflowY=c.overflow[2]}));for(d in b)if(e=b[d],Nb.exec(e)){if(delete b[d],f=f||"toggle"===e,e===(p?"hide":"show")){if("show"!==e||!q||void 0===q[d])continue;p=!0}m[d]=q&&q[d]||n.style(a,d)}else j=void 0;if(n.isEmptyObject(m))"inline"===("none"===j?tb(a.nodeName):j)&&(o.display=j);else{q?"hidden"in q&&(p=q.hidden):q=L.access(a,"fxshow",{}),f&&(q.hidden=!p),p?n(a).show():l.done(function(){n(a).hide()}),l.done(function(){var b;L.remove(a,"fxshow");for(b in m)n.style(a,b,m[b])});for(d in m)g=Ub(p?q[d]:0,d,l),d in q||(q[d]=g.start,p&&(g.end=g.start,g.start="width"===d||"height"===d?1:0))}}function Wb(a,b){var c,d,e,f,g;for(c in a)if(d=n.camelCase(c),e=b[d],f=a[c],n.isArray(f)&&(e=f[1],f=a[c]=f[0]),c!==d&&(a[d]=f,delete a[c]),(g=n.cssHooks[d])&&"expand"in g){f=g.expand(f),delete a[d];for(c in f)c in a||(a[c]=f[c],b[c]=e)}else b[d]=e}function Xb(a,b,c){var d,e,f=0,g=Qb.length,h=n.Deferred().always(function(){delete i.elem}),i=function(){if(e)return!1;for(var b=Lb||Sb(),c=Math.max(0,j.startTime+j.duration-b),d=c/j.duration||0,f=1-d,g=0,i=j.tweens.length;i>g;g++)j.tweens[g].run(f);return h.notifyWith(a,[j,f,c]),1>f&&i?c:(h.resolveWith(a,[j]),!1)},j=h.promise({elem:a,props:n.extend({},b),opts:n.extend(!0,{specialEasing:{}},c),originalProperties:b,originalOptions:c,startTime:Lb||Sb(),duration:c.duration,tweens:[],createTween:function(b,c){var d=n.Tween(a,j.opts,b,c,j.opts.specialEasing[b]||j.opts.easing);return j.tweens.push(d),d},stop:function(b){var c=0,d=b?j.tweens.length:0;if(e)return this;for(e=!0;d>c;c++)j.tweens[c].run(1);return b?h.resolveWith(a,[j,b]):h.rejectWith(a,[j,b]),this}}),k=j.props;for(Wb(k,j.opts.specialEasing);g>f;f++)if(d=Qb[f].call(j,a,k,j.opts))return d;return n.map(k,Ub,j),n.isFunction(j.opts.start)&&j.opts.start.call(a,j),n.fx.timer(n.extend(i,{elem:a,anim:j,queue:j.opts.queue})),j.progress(j.opts.progress).done(j.opts.done,j.opts.complete).fail(j.opts.fail).always(j.opts.always)}function rc(a){return function(b,c){"string"!=typeof b&&(c=b,b="*");var d,e=0,f=b.toLowerCase().match(E)||[];if(n.isFunction(c))for(;d=f[e++];)"+"===d[0]?(d=d.slice(1)||"*",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function sc(a,b,c,d){function g(h){var i;return e[h]=!0,n.each(a[h]||[],function(a,h){var j=h(b,c,d);return"string"!=typeof j||f||e[j]?f?!(i=j):void 0:(b.dataTypes.unshift(j),g(j),!1)}),i}var e={},f=a===oc;return g(b.dataTypes[0])||!e["*"]&&g("*")}function tc(a,b){var c,d,e=n.ajaxSettings.flatOptions||{};for(c in b)void 0!==b[c]&&((e[c]?a:d||(d={}))[c]=b[c]);return d&&n.extend(!0,a,d),a}function uc(a,b,c){for(var d,e,f,g,h=a.contents,i=a.dataTypes;"*"===i[0];)i.shift(),void 0===d&&(d=a.mimeType||b.getResponseHeader("Content-Type"));if(d)for(e in h)if(h[e]&&h[e].test(d)){i.unshift(e);break}if(i[0]in c)f=i[0];else{for(e in c){if(!i[0]||a.converters[e+" "+i[0]]){f=e;break}g||(g=e)}f=f||g}return f?(f!==i[0]&&i.unshift(f),c[f]):void 0}function vc(a,b,c,d){var e,f,g,h,i,j={},k=a.dataTypes.slice();if(k[1])for(g in a.converters)j[g.toLowerCase()]=a.converters[g];for(f=k.shift();f;)if(a.responseFields[f]&&(c[a.responseFields[f]]=b),!i&&d&&a.dataFilter&&(b=a.dataFilter(b,a.dataType)),i=f,f=k.shift())if("*"===f)f=i;else if("*"!==i&&i!==f){if(!(g=j[i+" "+f]||j["* "+f]))for(e in j)if(h=e.split(" "),h[1]===f&&(g=j[i+" "+h[0]]||j["* "+h[0]])){g===!0?g=j[e]:j[e]!==!0&&(f=h[0],k.unshift(h[1]));break}if(g!==!0)if(g&&a.throws)b=g(b);else try{b=g(b)}catch(l){return{state:"parsererror",error:g?l:"No conversion from "+i+" to "+f}}}return{state:"success",data:b}}function Bc(a,b,c,d){var e;if(n.isArray(b))n.each(b,function(b,e){c||xc.test(a)?d(a,e):Bc(a+"["+("object"==typeof e?b:"")+"]",e,c,d)});else if(c||"object"!==n.type(b))d(a,b);else for(e in b)Bc(a+"["+e+"]",b[e],c,d)}function Kc(a){return n.isWindow(a)?a:9===a.nodeType&&a.defaultView}var c=[],d=c.slice,e=c.concat,f=c.push,g=c.indexOf,h={},i=h.toString,j=h.hasOwnProperty,k={},l=a.document,m="2.1.1",n=function(a,b){return new n.fn.init(a,b)},r=function(a,b){return b.toUpperCase()};n.fn=n.prototype={jquery:m,constructor:n,selector:"",length:0,toArray:function(){return d.call(this)},get:function(a){return null!=a?0>a?this[a+this.length]:this[a]:d.call(this)},pushStack:function(a){var b=n.merge(this.constructor(),a);return b.prevObject=this,b.context=this.context,b},each:function(a,b){return n.each(this,a,b)},map:function(a){return this.pushStack(n.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(0>a?b:0);return this.pushStack(c>=0&&b>c?[this[c]]:[])},end:function(){return this.prevObject||this.constructor(null)},push:f,sort:c.sort,splice:c.splice},n.extend=n.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||n.isFunction(g)||(g={}),h===i&&(g=this,h--);i>h;h++)if(null!=(a=arguments[h]))for(b in a)c=g[b],d=a[b],g!==d&&(j&&d&&(n.isPlainObject(d)||(e=n.isArray(d)))?(e?(e=!1,f=c&&n.isArray(c)?c:[]):f=c&&n.isPlainObject(c)?c:{},g[b]=n.extend(j,f,d)):void 0!==d&&(g[b]=d));return g},n.extend({expando:"jQuery"+(m+Math.random()).replace(/\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===n.type(a)},isArray:Array.isArray,isWindow:function(a){return null!=a&&a===a.window},isNumeric:function(a){return!n.isArray(a)&&a-parseFloat(a)>=0},isPlainObject:function(a){return"object"===n.type(a)&&!a.nodeType&&!n.isWindow(a)&&!(a.constructor&&!j.call(a.constructor.prototype,"isPrototypeOf"))},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?h[i.call(a)]||"object":typeof a},globalEval:function(a){var b,c=eval;(a=n.trim(a))&&(1===a.indexOf("use strict")?(b=l.createElement("script"),b.text=a,l.head.appendChild(b).parentNode.removeChild(b)):c(a))},camelCase:function(a){return a.replace(/^-ms-/,"ms-").replace(/-([\da-z])/gi,r)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,b,c){var e=0,f=a.length,g=s(a);if(c){if(g)for(;f>e&&b.apply(a[e],c)!==!1;e++);else for(e in a)if(b.apply(a[e],c)===!1)break}else if(g)for(;f>e&&b.call(a[e],e,a[e])!==!1;e++);else for(e in a)if(b.call(a[e],e,a[e])===!1)break;return a},trim:function(a){return null==a?"":(a+"").replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")},makeArray:function(a,b){var c=b||[];return null!=a&&(s(Object(a))?n.merge(c,"string"==typeof a?[a]:a):f.call(c,a)),c},inArray:function(a,b,c){return null==b?-1:g.call(b,a,c)},merge:function(a,b){for(var c=+b.length,d=0,e=a.length;c>d;d++)a[e++]=b[d];return a.length=e,a},grep:function(a,b,c){for(var e=[],f=0,g=a.length,h=!c;g>f;f++)!b(a[f],f)!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,f=0,g=a.length,h=s(a),i=[];if(h)for(;g>f;f++)null!=(d=b(a[f],f,c))&&i.push(d);else for(f in a)null!=(d=b(a[f],f,c))&&i.push(d);return e.apply([],i)},guid:1,proxy:function(a,b){var c,e,f;return"string"==typeof b&&(c=a[b],b=a,a=c),n.isFunction(a)?(e=d.call(arguments,2),f=function(){return a.apply(b||this,e.concat(d.call(arguments)))},f.guid=a.guid=a.guid||n.guid++,f):void 0},now:Date.now,support:k}),n.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(a,b){h["[object "+b+"]"]=b.toLowerCase()});var t=function(a){function fb(a,b,d,e){var f,h,j,k,l,o,r,s,w,x;if((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,d=d||[],!a||"string"!=typeof a)return d;if(1!==(k=b.nodeType)&&9!==k)return[];if(p&&!e){if(f=_.exec(a))if(j=f[1]){if(9===k){if(!(h=b.getElementById(j))||!h.parentNode)return d;if(h.id===j)return d.push(h),d}else if(b.ownerDocument&&(h=b.ownerDocument.getElementById(j))&&t(b,h)&&h.id===j)return d.push(h),d}else{if(f[2])return I.apply(d,b.getElementsByTagName(a)),d;if((j=f[3])&&c.getElementsByClassName&&b.getElementsByClassName)return I.apply(d,b.getElementsByClassName(j)),d}if(c.qsa&&(!q||!q.test(a))){if(s=r=u,w=b,x=9===k&&a,1===k&&"object"!==b.nodeName.toLowerCase()){for(o=g(a),(r=b.getAttribute("id"))?s=r.replace(bb,"\\$&"):b.setAttribute("id",s),s="[id='"+s+"'] ",l=o.length;l--;)o[l]=s+qb(o[l]);w=ab.test(a)&&ob(b.parentNode)||b,x=o.join(",")}if(x)try{return I.apply(d,w.querySelectorAll(x)),d}catch(y){}finally{r||b.removeAttribute("id")}}}return i(a.replace(R,"$1"),b,d,e)}function gb(){function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}var a=[];return b}function hb(a){return a[u]=!0,a}function ib(a){var b=n.createElement("div");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function jb(a,b){for(var c=a.split("|"),e=a.length;e--;)d.attrHandle[c[e]]=b}function kb(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&(~b.sourceIndex||D)-(~a.sourceIndex||D);if(d)return d;if(c)for(;c=c.nextSibling;)if(c===b)return-1;return a?1:-1}function nb(a){return hb(function(b){return b=+b,hb(function(c,d){for(var e,f=a([],c.length,b),g=f.length;g--;)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function ob(a){return a&&typeof a.getElementsByTagName!==C&&a}function pb(){}function qb(a){for(var b=0,c=a.length,d="";c>b;b++)d+=a[b].value;return d}function rb(a,b,c){var d=b.dir,e=c&&"parentNode"===d,f=x++;return b.first?function(b,c,f){for(;b=b[d];)if(1===b.nodeType||e)return a(b,c,f)}:function(b,c,g){var h,i,j=[w,f];if(g){for(;b=b[d];)if((1===b.nodeType||e)&&a(b,c,g))return!0}else for(;b=b[d];)if(1===b.nodeType||e){if(i=b[u]||(b[u]={}),(h=i[d])&&h[0]===w&&h[1]===f)return j[2]=h[2];if(i[d]=j,j[2]=a(b,c,g))return!0}}}function sb(a){return a.length>1?function(b,c,d){for(var e=a.length;e--;)if(!a[e](b,c,d))return!1;return!0}:a[0]}function tb(a,b,c){for(var d=0,e=b.length;e>d;d++)fb(a,b[d],c);return c}function ub(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;i>h;h++)(f=a[h])&&(!c||c(f,d,e))&&(g.push(f),j&&b.push(h));return g}function vb(a,b,c,d,e,f){return d&&!d[u]&&(d=vb(d)),e&&!e[u]&&(e=vb(e,f)),hb(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||tb(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:ub(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d)for(j=ub(r,n),d(j,[],h,i),k=j.length;k--;)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l));if(f){if(e||a){if(e){for(j=[],k=r.length;k--;)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}for(k=r.length;k--;)(l=r[k])&&(j=e?K.call(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=ub(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):I.apply(g,r)})}function wb(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=rb(function(a){return a===b},h,!0),l=rb(function(a){return K.call(b,a)>-1},h,!0),m=[function(a,c,d){return!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d))}];f>i;i++)if(c=d.relative[a[i].type])m=[rb(sb(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;f>e&&!d.relative[a[e].type];e++);return vb(i>1&&sb(m),i>1&&qb(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(R,"$1"),c,e>i&&wb(a.slice(i,e)),f>e&&wb(a=a.slice(e)),f>e&&qb(a))}m.push(c)}return sb(m)}function xb(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,m,o,p=0,q="0",r=f&&[],s=[],t=j,u=f||e&&d.find.TAG("*",k),v=w+=null==t?1:Math.random()||.1,x=u.length;for(k&&(j=g!==n&&g);q!==x&&null!=(l=u[q]);q++){if(e&&l){for(m=0;o=a[m++];)if(o(l,g,h)){i.push(l);break}k&&(w=v)}c&&((l=!o&&l)&&p--,f&&r.push(l))}if(p+=q,c&&q!==p){for(m=0;o=b[m++];)o(r,s,g,h);if(f){if(p>0)for(;q--;)r[q]||s[q]||(s[q]=G.call(i));s=ub(s)}I.apply(i,s),k&&!f&&s.length>0&&p+b.length>1&&fb.uniqueSort(i)}return k&&(w=v,j=t),r};return c?hb(f):f}var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+-new Date,v=a.document,w=0,x=0,y=gb(),z=gb(),A=gb(),B=function(a,b){return a===b&&(l=!0),0},C="undefined",D=1<<31,E={}.hasOwnProperty,F=[],G=F.pop,H=F.push,I=F.push,J=F.slice,K=F.indexOf||function(a){for(var b=0,c=this.length;c>b;b++)if(this[b]===a)return b;return-1},L="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",N="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",O=N.replace("w","w#"),P="\\["+M+"*("+N+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+O+"))|)"+M+"*\\]",Q=":("+N+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+P+")*)|.*)\\)|)",R=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),S=new RegExp("^"+M+"*,"+M+"*"),T=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp("="+M+"*([^\\]'\"]*?)"+M+"*\\]","g"),V=new RegExp(Q),W=new RegExp("^"+O+"$"),X={ID:new RegExp("^#("+N+")"),CLASS:new RegExp("^\\.("+N+")"),TAG:new RegExp("^("+N.replace("w","w*")+")"),ATTR:new RegExp("^"+P),PSEUDO:new RegExp("^"+Q),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+L+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/^(?:input|select|textarea|button)$/i,Z=/^h\d$/i,$=/^[^{]+\{\s*\[native \w/,_=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ab=/[+~]/,bb=/'|\\/g,cb=new RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),db=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:0>d?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)};try{I.apply(F=J.call(v.childNodes),v.childNodes),F[v.childNodes.length].nodeType}catch(eb){I={apply:F.length?function(a,b){H.apply(a,J.call(b))}:function(a,b){for(var c=a.length,d=0;a[c++]=b[d++];);a.length=c-1}}}c=fb.support={},f=fb.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return!!b&&"HTML"!==b.nodeName},m=fb.setDocument=function(a){var b,e=a?a.ownerDocument||a:v,g=e.defaultView;return e!==n&&9===e.nodeType&&e.documentElement?(n=e,o=e.documentElement,p=!f(e),g&&g!==g.top&&(g.addEventListener?g.addEventListener("unload",function(){m()},!1):g.attachEvent&&g.attachEvent("onunload",function(){m()})),c.attributes=ib(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ib(function(a){return a.appendChild(e.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=$.test(e.getElementsByClassName)&&ib(function(a){return a.innerHTML="<div class='a'></div><div class='a i'></div>",a.firstChild.className="i",2===a.getElementsByClassName("i").length}),c.getById=ib(function(a){return o.appendChild(a).id=u,!e.getElementsByName||!e.getElementsByName(u).length}),c.getById?(d.find.ID=function(a,b){if(typeof b.getElementById!==C&&p){var c=b.getElementById(a);return c&&c.parentNode?[c]:[]}},d.filter.ID=function(a){var b=a.replace(cb,db);return function(a){return a.getAttribute("id")===b}}):(delete d.find.ID,d.filter.ID=function(a){var b=a.replace(cb,db);return function(a){var c=typeof a.getAttributeNode!==C&&a.getAttributeNode("id");return c&&c.value===b}}),d.find.TAG=c.getElementsByTagName?function(a,b){return typeof b.getElementsByTagName!==C?b.getElementsByTagName(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){for(;c=f[e++];)1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){return typeof b.getElementsByClassName!==C&&p?b.getElementsByClassName(a):void 0},r=[],q=[],(c.qsa=$.test(e.querySelectorAll))&&(ib(function(a){a.innerHTML="<select msallowclip=''><option selected=''></option></select>",a.querySelectorAll("[msallowclip^='']").length&&q.push("[*^$]="+M+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+M+"*(?:value|"+L+")"),a.querySelectorAll(":checked").length||q.push(":checked")}),ib(function(a){var b=e.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+M+"*[*^$|!~]?="),a.querySelectorAll(":enabled").length||q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=$.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ib(function(a){c.disconnectedMatch=s.call(a,"div"),s.call(a,"[s!='']:x"),r.push("!=",Q)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=$.test(o.compareDocumentPosition),t=b||$.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)for(;b=b.parentNode;)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===e||a.ownerDocument===v&&t(v,a)?-1:b===e||b.ownerDocument===v&&t(v,b)?1:k?K.call(k,a)-K.call(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,f=a.parentNode,g=b.parentNode,h=[a],i=[b];if(!f||!g)return a===e?-1:b===e?1:f?-1:g?1:k?K.call(k,a)-K.call(k,b):0;if(f===g)return kb(a,b);for(c=a;c=c.parentNode;)h.unshift(c);for(c=b;c=c.parentNode;)i.unshift(c);for(;h[d]===i[d];)d++;return d?kb(h[d],i[d]):h[d]===v?-1:i[d]===v?1:0},e):n},fb.matches=function(a,b){return fb(a,null,null,b)},fb.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(U,"='$1']"),!(!c.matchesSelector||!p||r&&r.test(b)||q&&q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return fb(b,n,null,[a]).length>0},fb.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},fb.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&E.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},fb.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},fb.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){for(;b=a[f++];)b===a[f]&&(e=d.push(f));for(;e--;)a.splice(d[e],1)}return k=null,a},e=fb.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else for(;b=a[d++];)c+=e(b);return c},d=fb.selectors={cacheLength:50,createPseudo:hb,match:X,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(cb,db),a[3]=(a[3]||a[4]||a[5]||"").replace(cb,db),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||fb.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&fb.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return X.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&V.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(cb,db).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+M+")"+a+"("+M+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||typeof a.getAttribute!==C&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=fb.attr(d,a);return null==e?"!="===b:!b||(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e+" ").indexOf(c)>-1:"|="===b&&(e===c||e.slice(0,c.length+1)===c+"-"))}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h;if(q){if(f){for(;p;){for(l=b;l=l[p];)if(h?l.nodeName.toLowerCase()===r:1===l.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){for(k=q[u]||(q[u]={}),j=k[a]||[],n=j[0]===w&&j[1],m=j[0]===w&&j[2],l=n&&q.childNodes[n];l=++n&&l&&l[p]||(m=n=0)||o.pop();)if(1===l.nodeType&&++m&&l===b){k[a]=[w,n,m];break}}else if(s&&(j=(b[u]||(b[u]={}))[a])&&j[0]===w)m=j[1];else for(;(l=++n&&l&&l[p]||(m=n=0)||o.pop())&&((h?l.nodeName.toLowerCase()!==r:1!==l.nodeType)||!++m||(s&&((l[u]||(l[u]={}))[a]=[w,m]),l!==b)););return(m-=e)===d||m%d==0&&m/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||fb.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?hb(function(a,c){for(var d,f=e(a,b),g=f.length;g--;)d=K.call(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:hb(function(a){var b=[],c=[],d=h(a.replace(R,"$1"));return d[u]?hb(function(a,b,c,e){for(var f,g=d(a,null,e,[]),h=a.length;h--;)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),!c.pop()}}),has:hb(function(a){return function(b){return fb(a,b).length>0}}),contains:hb(function(a){return function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:hb(function(a){return W.test(a||"")||fb.error("unsupported lang: "+a),a=a.replace(cb,db).toLowerCase(),function(b){var c;do{if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return(c=c.toLowerCase())===a||0===c.indexOf(a+"-")}while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return Z.test(a.nodeName)},input:function(a){return Y.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:nb(function(){return[0]}),last:nb(function(a,b){return[b-1]}),eq:nb(function(a,b,c){return[0>c?c+b:c]}),even:nb(function(a,b){for(var c=0;b>c;c+=2)a.push(c);return a}),odd:nb(function(a,b){for(var c=1;b>c;c+=2)a.push(c);return a}),lt:nb(function(a,b,c){for(var d=0>c?c+b:c;--d>=0;)a.push(d);return a}),gt:nb(function(a,b,c){for(var d=0>c?c+b:c;++d<b;)a.push(d);return a})}},d.pseudos.nth=d.pseudos.eq;for(b in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})d.pseudos[b]=function(a){return function(b){return"input"===b.nodeName.toLowerCase()&&b.type===a}}(b);for(b in{submit:!0,reset:!0})d.pseudos[b]=function(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}(b);return pb.prototype=d.filters=d.pseudos,d.setFilters=new pb,g=fb.tokenize=function(a,b){var c,e,f,g,h,i,j,k=z[a+" "];if(k)return b?0:k.slice(0);for(h=a,i=[],j=d.preFilter;h;){(!c||(e=S.exec(h)))&&(e&&(h=h.slice(e[0].length)||h),i.push(f=[])),c=!1,(e=T.exec(h))&&(c=e.shift(),f.push({value:c,type:e[0].replace(R," ")}),h=h.slice(c.length));for(g in d.filter)!(e=X[g].exec(h))||j[g]&&!(e=j[g](e))||(c=e.shift(),f.push({value:c,type:g,matches:e}),h=h.slice(c.length));if(!c)break}return b?h.length:h?fb.error(a):z(a,i).slice(0)},h=fb.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){for(b||(b=g(a)),c=b.length;c--;)f=wb(b[c]),f[u]?d.push(f):e.push(f);f=A(a,xb(e,d)),f.selector=a}return f},i=fb.select=function(a,b,e,f){var i,j,k,l,m,n="function"==typeof a&&a,o=!f&&g(a=n.selector||a);if(e=e||[],1===o.length){if(j=o[0]=o[0].slice(0),j.length>2&&"ID"===(k=j[0]).type&&c.getById&&9===b.nodeType&&p&&d.relative[j[1].type]){if(!(b=(d.find.ID(k.matches[0].replace(cb,db),b)||[])[0]))return e;n&&(b=b.parentNode),a=a.slice(j.shift().value.length)}for(i=X.needsContext.test(a)?0:j.length;i--&&(k=j[i],!d.relative[l=k.type]);)if((m=d.find[l])&&(f=m(k.matches[0].replace(cb,db),ab.test(j[0].type)&&ob(b.parentNode)||b))){if(j.splice(i,1),!(a=f.length&&qb(j)))return I.apply(e,f),e;break}}return(n||h(a,o))(f,b,!p,e,ab.test(a)&&ob(b.parentNode)||b),e},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ib(function(a){return 1&a.compareDocumentPosition(n.createElement("div"))}),ib(function(a){return a.innerHTML="<a href='#'></a>","#"===a.firstChild.getAttribute("href")})||jb("type|href|height|width",function(a,b,c){return c?void 0:a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ib(function(a){return a.innerHTML="<input/>",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||jb("value",function(a,b,c){return c||"input"!==a.nodeName.toLowerCase()?void 0:a.defaultValue}),ib(function(a){return null==a.getAttribute("disabled")})||jb(L,function(a,b,c){var d;return c?void 0:a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),fb}(a);n.find=t,n.expr=t.selectors,n.expr[":"]=n.expr.pseudos,n.unique=t.uniqueSort,n.text=t.getText,n.isXMLDoc=t.isXML,n.contains=t.contains;var u=n.expr.match.needsContext,v=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,w=/^.[^:#\[\.,]*$/;n.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?n.find.matchesSelector(d,a)?[d]:[]:n.find.matches(a,n.grep(b,function(a){return 1===a.nodeType}))},n.fn.extend({find:function(a){var b,c=this.length,d=[],e=this;if("string"!=typeof a)return this.pushStack(n(a).filter(function(){ -for(b=0;c>b;b++)if(n.contains(e[b],this))return!0}));for(b=0;c>b;b++)n.find(a,e[b],d);return d=this.pushStack(c>1?n.unique(d):d),d.selector=this.selector?this.selector+" "+a:a,d},filter:function(a){return this.pushStack(x(this,a||[],!1))},not:function(a){return this.pushStack(x(this,a||[],!0))},is:function(a){return!!x(this,"string"==typeof a&&u.test(a)?n(a):a||[],!1).length}});var y,z=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/;(n.fn.init=function(a,b){var c,d;if(!a)return this;if("string"==typeof a){if(!(c="<"===a[0]&&">"===a[a.length-1]&&a.length>=3?[null,a,null]:z.exec(a))||!c[1]&&b)return!b||b.jquery?(b||y).find(a):this.constructor(b).find(a);if(c[1]){if(b=b instanceof n?b[0]:b,n.merge(this,n.parseHTML(c[1],b&&b.nodeType?b.ownerDocument||b:l,!0)),v.test(c[1])&&n.isPlainObject(b))for(c in b)n.isFunction(this[c])?this[c](b[c]):this.attr(c,b[c]);return this}return d=l.getElementById(c[2]),d&&d.parentNode&&(this.length=1,this[0]=d),this.context=l,this.selector=a,this}return a.nodeType?(this.context=this[0]=a,this.length=1,this):n.isFunction(a)?void 0!==y.ready?y.ready(a):a(n):(void 0!==a.selector&&(this.selector=a.selector,this.context=a.context),n.makeArray(a,this))}).prototype=n.fn,y=n(l);var B=/^(?:parents|prev(?:Until|All))/,C={children:!0,contents:!0,next:!0,prev:!0};n.extend({dir:function(a,b,c){for(var d=[],e=void 0!==c;(a=a[b])&&9!==a.nodeType;)if(1===a.nodeType){if(e&&n(a).is(c))break;d.push(a)}return d},sibling:function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c}}),n.fn.extend({has:function(a){var b=n(a,this),c=b.length;return this.filter(function(){for(var a=0;c>a;a++)if(n.contains(this,b[a]))return!0})},closest:function(a,b){for(var c,d=0,e=this.length,f=[],g=u.test(a)||"string"!=typeof a?n(a,b||this.context):0;e>d;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&n.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?n.unique(f):f)},index:function(a){return a?"string"==typeof a?g.call(n(a),this[0]):g.call(this,a.jquery?a[0]:a):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(n.unique(n.merge(this.get(),n(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}}),n.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return n.dir(a,"parentNode")},parentsUntil:function(a,b,c){return n.dir(a,"parentNode",c)},next:function(a){return D(a,"nextSibling")},prev:function(a){return D(a,"previousSibling")},nextAll:function(a){return n.dir(a,"nextSibling")},prevAll:function(a){return n.dir(a,"previousSibling")},nextUntil:function(a,b,c){return n.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return n.dir(a,"previousSibling",c)},siblings:function(a){return n.sibling((a.parentNode||{}).firstChild,a)},children:function(a){return n.sibling(a.firstChild)},contents:function(a){return a.contentDocument||n.merge([],a.childNodes)}},function(a,b){n.fn[a]=function(c,d){var e=n.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=n.filter(d,e)),this.length>1&&(C[a]||n.unique(e),B.test(a)&&e.reverse()),this.pushStack(e)}});var E=/\S+/g,F={};n.Callbacks=function(a){a="string"==typeof a?F[a]||G(a):n.extend({},a);var b,c,d,e,f,g,h=[],i=!a.once&&[],j=function(l){for(b=a.memory&&l,c=!0,g=e||0,e=0,f=h.length,d=!0;h&&f>g;g++)if(h[g].apply(l[0],l[1])===!1&&a.stopOnFalse){b=!1;break}d=!1,h&&(i?i.length&&j(i.shift()):b?h=[]:k.disable())},k={add:function(){if(h){var c=h.length;!function g(b){n.each(b,function(b,c){var d=n.type(c);"function"===d?a.unique&&k.has(c)||h.push(c):c&&c.length&&"string"!==d&&g(c)})}(arguments),d?f=h.length:b&&(e=c,j(b))}return this},remove:function(){return h&&n.each(arguments,function(a,b){for(var c;(c=n.inArray(b,h,c))>-1;)h.splice(c,1),d&&(f>=c&&f--,g>=c&&g--)}),this},has:function(a){return a?n.inArray(a,h)>-1:!(!h||!h.length)},empty:function(){return h=[],f=0,this},disable:function(){return h=i=b=void 0,this},disabled:function(){return!h},lock:function(){return i=void 0,b||k.disable(),this},locked:function(){return!i},fireWith:function(a,b){return!h||c&&!i||(b=b||[],b=[a,b.slice?b.slice():b],d?i.push(b):j(b)),this},fire:function(){return k.fireWith(this,arguments),this},fired:function(){return!!c}};return k},n.extend({Deferred:function(a){var b=[["resolve","done",n.Callbacks("once memory"),"resolved"],["reject","fail",n.Callbacks("once memory"),"rejected"],["notify","progress",n.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return n.Deferred(function(c){n.each(b,function(b,f){var g=n.isFunction(a[b])&&a[b];e[f[1]](function(){var a=g&&g.apply(this,arguments);a&&n.isFunction(a.promise)?a.promise().done(c.resolve).fail(c.reject).progress(c.notify):c[f[0]+"With"](this===d?c.promise():this,g?[a]:arguments)})}),a=null}).promise()},promise:function(a){return null!=a?n.extend(a,d):d}},e={};return d.pipe=d.then,n.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[1^a][2].disable,b[2][2].lock),e[f[0]]=function(){return e[f[0]+"With"](this===e?d:this,arguments),this},e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var i,j,k,b=0,c=d.call(arguments),e=c.length,f=1!==e||a&&n.isFunction(a.promise)?e:0,g=1===f?a:n.Deferred(),h=function(a,b,c){return function(e){b[a]=this,c[a]=arguments.length>1?d.call(arguments):e,c===i?g.notifyWith(b,c):--f||g.resolveWith(b,c)}};if(e>1)for(i=new Array(e),j=new Array(e),k=new Array(e);e>b;b++)c[b]&&n.isFunction(c[b].promise)?c[b].promise().done(h(b,k,c)).fail(g.reject).progress(h(b,j,i)):--f;return f||g.resolveWith(k,c),g.promise()}});var H;n.fn.ready=function(a){return n.ready.promise().done(a),this},n.extend({isReady:!1,readyWait:1,holdReady:function(a){a?n.readyWait++:n.ready(!0)},ready:function(a){(a===!0?--n.readyWait:n.isReady)||(n.isReady=!0,a!==!0&&--n.readyWait>0||(H.resolveWith(l,[n]),n.fn.triggerHandler&&(n(l).triggerHandler("ready"),n(l).off("ready"))))}}),n.ready.promise=function(b){return H||(H=n.Deferred(),"complete"===l.readyState?setTimeout(n.ready):(l.addEventListener("DOMContentLoaded",I,!1),a.addEventListener("load",I,!1))),H.promise(b)},n.ready.promise();var J=n.access=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===n.type(c)){e=!0;for(h in c)n.access(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,n.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(n(a),c)})),b))for(;i>h;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f};n.acceptData=function(a){return 1===a.nodeType||9===a.nodeType||!+a.nodeType},K.uid=1,K.accepts=n.acceptData,K.prototype={key:function(a){if(!K.accepts(a))return 0;var b={},c=a[this.expando];if(!c){c=K.uid++;try{b[this.expando]={value:c},Object.defineProperties(a,b)}catch(d){b[this.expando]=c,n.extend(a,b)}}return this.cache[c]||(this.cache[c]={}),c},set:function(a,b,c){var d,e=this.key(a),f=this.cache[e];if("string"==typeof b)f[b]=c;else if(n.isEmptyObject(f))n.extend(this.cache[e],b);else for(d in b)f[d]=b[d];return f},get:function(a,b){var c=this.cache[this.key(a)];return void 0===b?c:c[b]},access:function(a,b,c){var d;return void 0===b||b&&"string"==typeof b&&void 0===c?(d=this.get(a,b),void 0!==d?d:this.get(a,n.camelCase(b))):(this.set(a,b,c),void 0!==c?c:b)},remove:function(a,b){var c,d,e,f=this.key(a),g=this.cache[f];if(void 0===b)this.cache[f]={};else{n.isArray(b)?d=b.concat(b.map(n.camelCase)):(e=n.camelCase(b),b in g?d=[b,e]:(d=e,d=d in g?[d]:d.match(E)||[])),c=d.length;for(;c--;)delete g[d[c]]}},hasData:function(a){return!n.isEmptyObject(this.cache[a[this.expando]]||{})},discard:function(a){a[this.expando]&&delete this.cache[a[this.expando]]}};var L=new K,M=new K,N=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,O=/([A-Z])/g;n.extend({hasData:function(a){return M.hasData(a)||L.hasData(a)},data:function(a,b,c){return M.access(a,b,c)},removeData:function(a,b){M.remove(a,b)},_data:function(a,b,c){return L.access(a,b,c)},_removeData:function(a,b){L.remove(a,b)}}),n.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=M.get(f),1===f.nodeType&&!L.get(f,"hasDataAttrs"))){for(c=g.length;c--;)g[c]&&(d=g[c].name,0===d.indexOf("data-")&&(d=n.camelCase(d.slice(5)),P(f,d,e[d])));L.set(f,"hasDataAttrs",!0)}return e}return"object"==typeof a?this.each(function(){M.set(this,a)}):J(this,function(b){var c,d=n.camelCase(a);if(f&&void 0===b){if(void 0!==(c=M.get(f,a)))return c;if(void 0!==(c=M.get(f,d)))return c;if(void 0!==(c=P(f,d,void 0)))return c}else this.each(function(){var c=M.get(this,d);M.set(this,d,b),-1!==a.indexOf("-")&&void 0!==c&&M.set(this,a,b)})},null,b,arguments.length>1,null,!0)},removeData:function(a){return this.each(function(){M.remove(this,a)})}}),n.extend({queue:function(a,b,c){var d;return a?(b=(b||"fx")+"queue",d=L.get(a,b),c&&(!d||n.isArray(c)?d=L.access(a,b,n.makeArray(c)):d.push(c)),d||[]):void 0},dequeue:function(a,b){b=b||"fx";var c=n.queue(a,b),d=c.length,e=c.shift(),f=n._queueHooks(a,b),g=function(){n.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return L.get(a,c)||L.access(a,c,{empty:n.Callbacks("once memory").add(function(){L.remove(a,[b+"queue",c])})})}}),n.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length<c?n.queue(this[0],a):void 0===b?this:this.each(function(){var c=n.queue(this,a,b);n._queueHooks(this,a),"fx"===a&&"inprogress"!==c[0]&&n.dequeue(this,a)})},dequeue:function(a){return this.each(function(){n.dequeue(this,a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,b){var c,d=1,e=n.Deferred(),f=this,g=this.length,h=function(){--d||e.resolveWith(f,[f])};for("string"!=typeof a&&(b=a,a=void 0),a=a||"fx";g--;)(c=L.get(f[g],a+"queueHooks"))&&c.empty&&(d++,c.empty.add(h));return h(),e.promise(b)}});var Q=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,R=["Top","Right","Bottom","Left"],S=function(a,b){return a=b||a,"none"===n.css(a,"display")||!n.contains(a.ownerDocument,a)},T=/^(?:checkbox|radio)$/i;!function(){var a=l.createDocumentFragment(),b=a.appendChild(l.createElement("div")),c=l.createElement("input");c.setAttribute("type","radio"),c.setAttribute("checked","checked"),c.setAttribute("name","t"),b.appendChild(c),k.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,b.innerHTML="<textarea>x</textarea>",k.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue}();var U="undefined";k.focusinBubbles="onfocusin"in a;var V=/^key/,W=/^(?:mouse|pointer|contextmenu)|click/,X=/^(?:focusinfocus|focusoutblur)$/,Y=/^([^.]*)(?:\.(.+)|)$/;n.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,o,p,q,r=L.get(a);if(r)for(c.handler&&(f=c,c=f.handler,e=f.selector),c.guid||(c.guid=n.guid++),(i=r.events)||(i=r.events={}),(g=r.handle)||(g=r.handle=function(b){return typeof n!==U&&n.event.triggered!==b.type?n.event.dispatch.apply(a,arguments):void 0}),b=(b||"").match(E)||[""],j=b.length;j--;)h=Y.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o&&(l=n.event.special[o]||{},o=(e?l.delegateType:l.bindType)||o,l=n.event.special[o]||{},k=n.extend({type:o,origType:q,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&n.expr.match.needsContext.test(e),namespace:p.join(".")},f),(m=i[o])||(m=i[o]=[],m.delegateCount=0,l.setup&&l.setup.call(a,d,p,g)!==!1||a.addEventListener&&a.addEventListener(o,g,!1)),l.add&&(l.add.call(a,k),k.handler.guid||(k.handler.guid=c.guid)),e?m.splice(m.delegateCount++,0,k):m.push(k),n.event.global[o]=!0)},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,o,p,q,r=L.hasData(a)&&L.get(a);if(r&&(i=r.events)){for(b=(b||"").match(E)||[""],j=b.length;j--;)if(h=Y.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o){for(l=n.event.special[o]||{},o=(d?l.delegateType:l.bindType)||o,m=i[o]||[],h=h[2]&&new RegExp("(^|\\.)"+p.join("\\.(?:.*\\.|)")+"(\\.|$)"),g=f=m.length;f--;)k=m[f],!e&&q!==k.origType||c&&c.guid!==k.guid||h&&!h.test(k.namespace)||d&&d!==k.selector&&("**"!==d||!k.selector)||(m.splice(f,1),k.selector&&m.delegateCount--,l.remove&&l.remove.call(a,k));g&&!m.length&&(l.teardown&&l.teardown.call(a,p,r.handle)!==!1||n.removeEvent(a,o,r.handle),delete i[o])}else for(o in i)n.event.remove(a,o+b[j],c,d,!0);n.isEmptyObject(i)&&(delete r.handle,L.remove(a,"events"))}},trigger:function(b,c,d,e){var f,g,h,i,k,m,o,p=[d||l],q=j.call(b,"type")?b.type:b,r=j.call(b,"namespace")?b.namespace.split("."):[];if(g=h=d=d||l,3!==d.nodeType&&8!==d.nodeType&&!X.test(q+n.event.triggered)&&(q.indexOf(".")>=0&&(r=q.split("."),q=r.shift(),r.sort()),k=q.indexOf(":")<0&&"on"+q,b=b[n.expando]?b:new n.Event(q,"object"==typeof b&&b),b.isTrigger=e?2:3,b.namespace=r.join("."),b.namespace_re=b.namespace?new RegExp("(^|\\.)"+r.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=d),c=null==c?[b]:n.makeArray(c,[b]),o=n.event.special[q]||{},e||!o.trigger||o.trigger.apply(d,c)!==!1)){if(!e&&!o.noBubble&&!n.isWindow(d)){for(i=o.delegateType||q,X.test(i+q)||(g=g.parentNode);g;g=g.parentNode)p.push(g),h=g;h===(d.ownerDocument||l)&&p.push(h.defaultView||h.parentWindow||a)}for(f=0;(g=p[f++])&&!b.isPropagationStopped();)b.type=f>1?i:o.bindType||q,m=(L.get(g,"events")||{})[b.type]&&L.get(g,"handle"),m&&m.apply(g,c),(m=k&&g[k])&&m.apply&&n.acceptData(g)&&(b.result=m.apply(g,c),b.result===!1&&b.preventDefault());return b.type=q,e||b.isDefaultPrevented()||o._default&&o._default.apply(p.pop(),c)!==!1||!n.acceptData(d)||k&&n.isFunction(d[q])&&!n.isWindow(d)&&(h=d[k],h&&(d[k]=null),n.event.triggered=q,d[q](),n.event.triggered=void 0,h&&(d[k]=h)),b.result}},dispatch:function(a){a=n.event.fix(a);var b,c,e,f,g,h=[],i=d.call(arguments),j=(L.get(this,"events")||{})[a.type]||[],k=n.event.special[a.type]||{};if(i[0]=a,a.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,a)!==!1){for(h=n.event.handlers.call(this,a,j),b=0;(f=h[b++])&&!a.isPropagationStopped();)for(a.currentTarget=f.elem,c=0;(g=f.handlers[c++])&&!a.isImmediatePropagationStopped();)(!a.namespace_re||a.namespace_re.test(g.namespace))&&(a.handleObj=g,a.data=g.data,void 0!==(e=((n.event.special[g.origType]||{}).handle||g.handler).apply(f.elem,i))&&(a.result=e)===!1&&(a.preventDefault(),a.stopPropagation()));return k.postDispatch&&k.postDispatch.call(this,a),a.result}},handlers:function(a,b){var c,d,e,f,g=[],h=b.delegateCount,i=a.target;if(h&&i.nodeType&&(!a.button||"click"!==a.type))for(;i!==this;i=i.parentNode||this)if(i.disabled!==!0||"click"!==a.type){for(d=[],c=0;h>c;c++)f=b[c],e=f.selector+" ",void 0===d[e]&&(d[e]=f.needsContext?n(e,this).index(i)>=0:n.find(e,this,null,[i]).length),d[e]&&d.push(f);d.length&&g.push({elem:i,handlers:d})}return h<b.length&&g.push({elem:this,handlers:b.slice(h)}),g},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(a,b){return null==a.which&&(a.which=null!=b.charCode?b.charCode:b.keyCode),a}},mouseHooks:{props:"button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(a,b){var c,d,e,f=b.button;return null==a.pageX&&null!=b.clientX&&(c=a.target.ownerDocument||l,d=c.documentElement,e=c.body,a.pageX=b.clientX+(d&&d.scrollLeft||e&&e.scrollLeft||0)-(d&&d.clientLeft||e&&e.clientLeft||0),a.pageY=b.clientY+(d&&d.scrollTop||e&&e.scrollTop||0)-(d&&d.clientTop||e&&e.clientTop||0)),a.which||void 0===f||(a.which=1&f?1:2&f?3:4&f?2:0),a}},fix:function(a){if(a[n.expando])return a;var b,c,d,e=a.type,f=a,g=this.fixHooks[e];for(g||(this.fixHooks[e]=g=W.test(e)?this.mouseHooks:V.test(e)?this.keyHooks:{}),d=g.props?this.props.concat(g.props):this.props,a=new n.Event(f),b=d.length;b--;)c=d[b],a[c]=f[c];return a.target||(a.target=l),3===a.target.nodeType&&(a.target=a.target.parentNode),g.filter?g.filter(a,f):a},special:{load:{noBubble:!0},focus:{trigger:function(){return this!==_()&&this.focus?(this.focus(),!1):void 0},delegateType:"focusin"},blur:{trigger:function(){return this===_()&&this.blur?(this.blur(),!1):void 0},delegateType:"focusout"},click:{trigger:function(){return"checkbox"===this.type&&this.click&&n.nodeName(this,"input")?(this.click(),!1):void 0},_default:function(a){return n.nodeName(a.target,"a")}},beforeunload:{postDispatch:function(a){void 0!==a.result&&a.originalEvent&&(a.originalEvent.returnValue=a.result)}}},simulate:function(a,b,c,d){var e=n.extend(new n.Event,c,{type:a,isSimulated:!0,originalEvent:{}});d?n.event.trigger(e,null,b):n.event.dispatch.call(b,e),e.isDefaultPrevented()&&c.preventDefault()}},n.removeEvent=function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c,!1)},n.Event=function(a,b){return this instanceof n.Event?(a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||void 0===a.defaultPrevented&&a.returnValue===!1?Z:$):this.type=a,b&&n.extend(this,b),this.timeStamp=a&&a.timeStamp||n.now(),void(this[n.expando]=!0)):new n.Event(a,b)},n.Event.prototype={isDefaultPrevented:$,isPropagationStopped:$,isImmediatePropagationStopped:$,preventDefault:function(){var a=this.originalEvent;this.isDefaultPrevented=Z,a&&a.preventDefault&&a.preventDefault()},stopPropagation:function(){var a=this.originalEvent;this.isPropagationStopped=Z,a&&a.stopPropagation&&a.stopPropagation()},stopImmediatePropagation:function(){var a=this.originalEvent;this.isImmediatePropagationStopped=Z,a&&a.stopImmediatePropagation&&a.stopImmediatePropagation(),this.stopPropagation()}},n.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(a,b){n.event.special[a]={delegateType:b,bindType:b,handle:function(a){var c,d=this,e=a.relatedTarget,f=a.handleObj;return(!e||e!==d&&!n.contains(d,e))&&(a.type=f.origType,c=f.handler.apply(this,arguments),a.type=b),c}}}),k.focusinBubbles||n.each({focus:"focusin",blur:"focusout"},function(a,b){var c=function(a){n.event.simulate(b,a.target,n.event.fix(a),!0)};n.event.special[b]={setup:function(){var d=this.ownerDocument||this,e=L.access(d,b);e||d.addEventListener(a,c,!0),L.access(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=L.access(d,b)-1;e?L.access(d,b,e):(d.removeEventListener(a,c,!0),L.remove(d,b))}}}),n.fn.extend({on:function(a,b,c,d,e){var f,g;if("object"==typeof a){"string"!=typeof b&&(c=c||b,b=void 0);for(g in a)this.on(g,b,c,a[g],e);return this}if(null==c&&null==d?(d=b,c=b=void 0):null==d&&("string"==typeof b?(d=c,c=void 0):(d=c,c=b,b=void 0)),d===!1)d=$;else if(!d)return this;return 1===e&&(f=d,d=function(a){return n().off(a),f.apply(this,arguments)},d.guid=f.guid||(f.guid=n.guid++)),this.each(function(){n.event.add(this,a,d,c,b)})},one:function(a,b,c,d){return this.on(a,b,c,d,1)},off:function(a,b,c){var d,e;if(a&&a.preventDefault&&a.handleObj)return d=a.handleObj,n(a.delegateTarget).off(d.namespace?d.origType+"."+d.namespace:d.origType,d.selector,d.handler),this;if("object"==typeof a){for(e in a)this.off(e,b,a[e]);return this}return(b===!1||"function"==typeof b)&&(c=b,b=void 0),c===!1&&(c=$),this.each(function(){n.event.remove(this,a,c,b)})},trigger:function(a,b){return this.each(function(){n.event.trigger(a,b,this)})},triggerHandler:function(a,b){var c=this[0];return c?n.event.trigger(a,b,c,!0):void 0}});var ab=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,bb=/<([\w:]+)/,cb=/<|&#?\w+;/,db=/<(?:script|style|link)/i,eb=/checked\s*(?:[^=]|=\s*.checked.)/i,fb=/^$|\/(?:java|ecma)script/i,gb=/^true\/(.*)/,ib={option:[1,"<select multiple='multiple'>","</select>"],thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};ib.optgroup=ib.option,ib.tbody=ib.tfoot=ib.colgroup=ib.caption=ib.thead,ib.th=ib.td,n.extend({clone:function(a,b,c){var d,e,f,g,h=a.cloneNode(!0),i=n.contains(a.ownerDocument,a);if(!(k.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||n.isXMLDoc(a)))for(g=ob(h),f=ob(a),d=0,e=f.length;e>d;d++)pb(f[d],g[d]);if(b)if(c)for(f=f||ob(a),g=g||ob(h),d=0,e=f.length;e>d;d++)nb(f[d],g[d]);else nb(a,h);return g=ob(h,"script"),g.length>0&&mb(g,!i&&ob(a,"script")),h},buildFragment:function(a,b,c,d){for(var e,f,g,h,i,j,k=b.createDocumentFragment(),l=[],m=0,o=a.length;o>m;m++)if((e=a[m])||0===e)if("object"===n.type(e))n.merge(l,e.nodeType?[e]:e);else if(cb.test(e)){for(f=f||k.appendChild(b.createElement("div")),g=(bb.exec(e)||["",""])[1].toLowerCase(),h=ib[g]||ib._default,f.innerHTML=h[1]+e.replace(ab,"<$1></$2>")+h[2],j=h[0];j--;)f=f.lastChild;n.merge(l,f.childNodes),f=k.firstChild,f.textContent=""}else l.push(b.createTextNode(e));for(k.textContent="",m=0;e=l[m++];)if((!d||-1===n.inArray(e,d))&&(i=n.contains(e.ownerDocument,e),f=ob(k.appendChild(e),"script"),i&&mb(f),c))for(j=0;e=f[j++];)fb.test(e.type||"")&&c.push(e);return k},cleanData:function(a){for(var b,c,d,e,f=n.event.special,g=0;void 0!==(c=a[g]);g++){if(n.acceptData(c)&&(e=c[L.expando])&&(b=L.cache[e])){if(b.events)for(d in b.events)f[d]?n.event.remove(c,d):n.removeEvent(c,d,b.handle);L.cache[e]&&delete L.cache[e]}delete M.cache[c[M.expando]]}}}),n.fn.extend({text:function(a){return J(this,function(a){return void 0===a?n.text(this):this.empty().each(function(){(1===this.nodeType||11===this.nodeType||9===this.nodeType)&&(this.textContent=a)})},null,a,arguments.length)},append:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){jb(this,a).appendChild(a)}})},prepend:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=jb(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},remove:function(a,b){for(var c,d=a?n.filter(a,this):this,e=0;null!=(c=d[e]);e++)b||1!==c.nodeType||n.cleanData(ob(c)),c.parentNode&&(b&&n.contains(c.ownerDocument,c)&&mb(ob(c,"script")),c.parentNode.removeChild(c));return this},empty:function(){for(var a,b=0;null!=(a=this[b]);b++)1===a.nodeType&&(n.cleanData(ob(a,!1)),a.textContent="");return this},clone:function(a,b){return a=null!=a&&a,b=null==b?a:b,this.map(function(){return n.clone(this,a,b)})},html:function(a){return J(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a&&1===b.nodeType)return b.innerHTML;if("string"==typeof a&&!db.test(a)&&!ib[(bb.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(ab,"<$1></$2>");try{for(;d>c;c++)b=this[c]||{},1===b.nodeType&&(n.cleanData(ob(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=arguments[0];return this.domManip(arguments,function(b){a=this.parentNode,n.cleanData(ob(this)),a&&a.replaceChild(b,this)}),a&&(a.length||a.nodeType)?this:this.remove()},detach:function(a){return this.remove(a,!0)},domManip:function(a,b){a=e.apply([],a);var c,d,f,g,h,i,j=0,l=this.length,m=this,o=l-1,p=a[0],q=n.isFunction(p);if(q||l>1&&"string"==typeof p&&!k.checkClone&&eb.test(p))return this.each(function(c){var d=m.eq(c);q&&(a[0]=p.call(this,c,d.html())),d.domManip(a,b)});if(l&&(c=n.buildFragment(a,this[0].ownerDocument,!1,this),d=c.firstChild,1===c.childNodes.length&&(c=d),d)){for(f=n.map(ob(c,"script"),kb),g=f.length;l>j;j++)h=c,j!==o&&(h=n.clone(h,!0,!0),g&&n.merge(f,ob(h,"script"))),b.call(this[j],h,j);if(g)for(i=f[f.length-1].ownerDocument,n.map(f,lb),j=0;g>j;j++)h=f[j],fb.test(h.type||"")&&!L.access(h,"globalEval")&&n.contains(i,h)&&(h.src?n._evalUrl&&n._evalUrl(h.src):n.globalEval(h.textContent.replace(/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,"")))}return this}}),n.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){n.fn[a]=function(a){for(var c,d=[],e=n(a),g=e.length-1,h=0;g>=h;h++)c=h===g?this:this.clone(!0),n(e[h])[b](c),f.apply(d,c.get());return this.pushStack(d)}});var qb,rb={},ub=/^margin/,vb=new RegExp("^("+Q+")(?!px)[a-z%]+$","i"),wb=function(a){return a.ownerDocument.defaultView.getComputedStyle(a,null)};!function(){function g(){f.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:block;margin-top:1%;top:1%;border:1px;padding:1px;width:4px;position:absolute",f.innerHTML="",d.appendChild(e);var g=a.getComputedStyle(f,null);b="1%"!==g.top,c="4px"===g.width,d.removeChild(e)}var b,c,d=l.documentElement,e=l.createElement("div"),f=l.createElement("div");f.style&&(f.style.backgroundClip="content-box",f.cloneNode(!0).style.backgroundClip="",k.clearCloneStyle="content-box"===f.style.backgroundClip,e.style.cssText="border:0;width:0;height:0;top:0;left:-9999px;margin-top:1px;position:absolute",e.appendChild(f),a.getComputedStyle&&n.extend(k,{pixelPosition:function(){return g(),b},boxSizingReliable:function(){return null==c&&g(),c},reliableMarginRight:function(){var b,c=f.appendChild(l.createElement("div"));return c.style.cssText=f.style.cssText="-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0",c.style.marginRight=c.style.width="0",f.style.width="1px",d.appendChild(e),b=!parseFloat(a.getComputedStyle(c,null).marginRight),d.removeChild(e),b}}))}(),n.swap=function(a,b,c,d){var e,f,g={};for(f in b)g[f]=a.style[f],a.style[f]=b[f];e=c.apply(a,d||[]);for(f in b)a.style[f]=g[f];return e};var zb=/^(none|table(?!-c[ea]).+)/,Ab=new RegExp("^("+Q+")(.*)$","i"),Bb=new RegExp("^([+-])=("+Q+")","i"),Cb={position:"absolute",visibility:"hidden",display:"block"},Db={letterSpacing:"0",fontWeight:"400"},Eb=["Webkit","O","Moz","ms"];n.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=xb(a,"opacity");return""===c?"1":c}}}},cssNumber:{columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{float:"cssFloat"},style:function(a,b,c,d){if(a&&3!==a.nodeType&&8!==a.nodeType&&a.style){var e,f,g,h=n.camelCase(b),i=a.style;return b=n.cssProps[h]||(n.cssProps[h]=Fb(i,h)),g=n.cssHooks[b]||n.cssHooks[h],void 0===c?g&&"get"in g&&void 0!==(e=g.get(a,!1,d))?e:i[b]:(f=typeof c,"string"===f&&(e=Bb.exec(c))&&(c=(e[1]+1)*e[2]+parseFloat(n.css(a,b)),f="number"),void(null!=c&&c===c&&("number"!==f||n.cssNumber[h]||(c+="px"),k.clearCloneStyle||""!==c||0!==b.indexOf("background")||(i[b]="inherit"),g&&"set"in g&&void 0===(c=g.set(a,c,d))||(i[b]=c))))}},css:function(a,b,c,d){var e,f,g,h=n.camelCase(b);return b=n.cssProps[h]||(n.cssProps[h]=Fb(a.style,h)),g=n.cssHooks[b]||n.cssHooks[h],g&&"get"in g&&(e=g.get(a,!0,c)),void 0===e&&(e=xb(a,b,d)),"normal"===e&&b in Db&&(e=Db[b]),""===c||c?(f=parseFloat(e),c===!0||n.isNumeric(f)?f||0:e):e}}),n.each(["height","width"],function(a,b){n.cssHooks[b]={get:function(a,c,d){return c?zb.test(n.css(a,"display"))&&0===a.offsetWidth?n.swap(a,Cb,function(){return Ib(a,b,d)}):Ib(a,b,d):void 0},set:function(a,c,d){var e=d&&wb(a);return Gb(a,c,d?Hb(a,b,d,"border-box"===n.css(a,"boxSizing",!1,e),e):0)}}}),n.cssHooks.marginRight=yb(k.reliableMarginRight,function(a,b){return b?n.swap(a,{display:"inline-block"},xb,[a,"marginRight"]):void 0}),n.each({margin:"",padding:"",border:"Width"},function(a,b){n.cssHooks[a+b]={expand:function(c){for(var d=0,e={},f="string"==typeof c?c.split(" "):[c];4>d;d++)e[a+R[d]+b]=f[d]||f[d-2]||f[0];return e}},ub.test(a)||(n.cssHooks[a+b].set=Gb)}),n.fn.extend({css:function(a,b){return J(this,function(a,b,c){var d,e,f={},g=0;if(n.isArray(b)){for(d=wb(a),e=b.length;e>g;g++)f[b[g]]=n.css(a,b[g],!1,d);return f}return void 0!==c?n.style(a,b,c):n.css(a,b)},a,b,arguments.length>1)},show:function(){return Jb(this,!0)},hide:function(){return Jb(this)},toggle:function(a){return"boolean"==typeof a?a?this.show():this.hide():this.each(function(){S(this)?n(this).show():n(this).hide()})}}),n.Tween=Kb,Kb.prototype={constructor:Kb,init:function(a,b,c,d,e,f){this.elem=a,this.prop=c,this.easing=e||"swing",this.options=b,this.start=this.now=this.cur(),this.end=d,this.unit=f||(n.cssNumber[c]?"":"px")},cur:function(){var a=Kb.propHooks[this.prop];return a&&a.get?a.get(this):Kb.propHooks._default.get(this)},run:function(a){var b,c=Kb.propHooks[this.prop];return this.pos=b=this.options.duration?n.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):a,this.now=(this.end-this.start)*b+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),c&&c.set?c.set(this):Kb.propHooks._default.set(this),this}},Kb.prototype.init.prototype=Kb.prototype,Kb.propHooks={_default:{get:function(a){var b;return null==a.elem[a.prop]||a.elem.style&&null!=a.elem.style[a.prop]?(b=n.css(a.elem,a.prop,""),b&&"auto"!==b?b:0):a.elem[a.prop]},set:function(a){n.fx.step[a.prop]?n.fx.step[a.prop](a):a.elem.style&&(null!=a.elem.style[n.cssProps[a.prop]]||n.cssHooks[a.prop])?n.style(a.elem,a.prop,a.now+a.unit):a.elem[a.prop]=a.now}}},Kb.propHooks.scrollTop=Kb.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},n.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2}},n.fx=Kb.prototype.init,n.fx.step={};var Lb,Mb,Nb=/^(?:toggle|show|hide)$/,Ob=new RegExp("^(?:([+-])=|)("+Q+")([a-z%]*)$","i"),Pb=/queueHooks$/,Qb=[Vb],Rb={"*":[function(a,b){var c=this.createTween(a,b),d=c.cur(),e=Ob.exec(b),f=e&&e[3]||(n.cssNumber[a]?"":"px"),g=(n.cssNumber[a]||"px"!==f&&+d)&&Ob.exec(n.css(c.elem,a)),h=1,i=20;if(g&&g[3]!==f){f=f||g[3],e=e||[],g=+d||1;do{h=h||".5",g/=h,n.style(c.elem,a,g+f)}while(h!==(h=c.cur()/d)&&1!==h&&--i)}return e&&(g=c.start=+g||+d||0,c.unit=f,c.end=e[1]?g+(e[1]+1)*e[2]:+e[2]),c}]};n.Animation=n.extend(Xb,{tweener:function(a,b){n.isFunction(a)?(b=a,a=["*"]):a=a.split(" ");for(var c,d=0,e=a.length;e>d;d++)c=a[d],Rb[c]=Rb[c]||[],Rb[c].unshift(b)},prefilter:function(a,b){b?Qb.unshift(a):Qb.push(a)}}),n.speed=function(a,b,c){var d=a&&"object"==typeof a?n.extend({},a):{complete:c||!c&&b||n.isFunction(a)&&a,duration:a,easing:c&&b||b&&!n.isFunction(b)&&b};return d.duration=n.fx.off?0:"number"==typeof d.duration?d.duration:d.duration in n.fx.speeds?n.fx.speeds[d.duration]:n.fx.speeds._default,(null==d.queue||d.queue===!0)&&(d.queue="fx"),d.old=d.complete,d.complete=function(){n.isFunction(d.old)&&d.old.call(this),d.queue&&n.dequeue(this,d.queue)},d},n.fn.extend({fadeTo:function(a,b,c,d){return this.filter(S).css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=n.isEmptyObject(a),f=n.speed(b,c,d),g=function(){var b=Xb(this,n.extend({},a),f);(e||L.get(this,"finish"))&&b.stop(!0)};return g.finish=g,e||f.queue===!1?this.each(g):this.queue(f.queue,g)},stop:function(a,b,c){var d=function(a){var b=a.stop;delete a.stop,b(c)};return"string"!=typeof a&&(c=b,b=a,a=void 0),b&&a!==!1&&this.queue(a||"fx",[]),this.each(function(){var b=!0,e=null!=a&&a+"queueHooks",f=n.timers,g=L.get(this);if(e)g[e]&&g[e].stop&&d(g[e]);else for(e in g)g[e]&&g[e].stop&&Pb.test(e)&&d(g[e]);for(e=f.length;e--;)f[e].elem!==this||null!=a&&f[e].queue!==a||(f[e].anim.stop(c),b=!1,f.splice(e,1));(b||!c)&&n.dequeue(this,a)})},finish:function(a){return a!==!1&&(a=a||"fx"),this.each(function(){var b,c=L.get(this),d=c[a+"queue"],e=c[a+"queueHooks"],f=n.timers,g=d?d.length:0;for(c.finish=!0,n.queue(this,a,[]),e&&e.stop&&e.stop.call(this,!0),b=f.length;b--;)f[b].elem===this&&f[b].queue===a&&(f[b].anim.stop(!0),f.splice(b,1));for(b=0;g>b;b++)d[b]&&d[b].finish&&d[b].finish.call(this);delete c.finish})}}), +!function(a,b){"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){function s(a){var b=a.length,c=n.type(a);return"function"!==c&&!n.isWindow(a)&&(!(1!==a.nodeType||!b)||("array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a))}function x(a,b,c){if(n.isFunction(b))return n.grep(a,function(a,d){return!!b.call(a,d,a)!==c});if(b.nodeType)return n.grep(a,function(a){return a===b!==c});if("string"==typeof b){if(w.test(b))return n.filter(b,a,c);b=n.filter(b,a)}return n.grep(a,function(a){return g.call(b,a)>=0!==c})}function D(a,b){for(;(a=a[b])&&1!==a.nodeType;);return a}function G(a){var b=F[a]={};return n.each(a.match(E)||[],function(a,c){b[c]=!0}),b}function I(){l.removeEventListener("DOMContentLoaded",I,!1),a.removeEventListener("load",I,!1),n.ready()}function K(){Object.defineProperty(this.cache={},0,{get:function(){return{}}}),this.expando=n.expando+Math.random()}function P(a,b,c){var d;if(void 0===c&&1===a.nodeType)if(d="_data-"+b.replace(O,"-$1").toLowerCase(),"string"==typeof(c=a.getAttribute(d))){try{c="true"===c||"false"!==c&&("null"===c?null:+c+""===c?+c:N.test(c)?n.parseJSON(c):c)}catch(e){}M.set(a,b,c)}else c=void 0;return c}function Z(){return!0}function $(){return!1}function _(){try{return l.activeElement}catch(a){}}function jb(a,b){return n.nodeName(a,"table")&&n.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function kb(a){return a.type=(null!==a.getAttribute("type"))+"/"+a.type,a}function lb(a){var b=gb.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function mb(a,b){for(var c=0,d=a.length;d>c;c++)L.set(a[c],"globalEval",!b||L.get(b[c],"globalEval"))}function nb(a,b){var c,d,e,f,g,h,i,j;if(1===b.nodeType){if(L.hasData(a)&&(f=L.access(a),g=L.set(b,f),j=f.events)){delete g.handle,g.events={};for(e in j)for(c=0,d=j[e].length;d>c;c++)n.event.add(b,e,j[e][c])}M.hasData(a)&&(h=M.access(a),i=n.extend({},h),M.set(b,i))}}function ob(a,b){var c=a.getElementsByTagName?a.getElementsByTagName(b||"*"):a.querySelectorAll?a.querySelectorAll(b||"*"):[];return void 0===b||b&&n.nodeName(a,b)?n.merge([a],c):c}function pb(a,b){var c=b.nodeName.toLowerCase();"input"===c&&T.test(a.type)?b.checked=a.checked:("input"===c||"textarea"===c)&&(b.defaultValue=a.defaultValue)}function sb(b,c){var d,e=n(c.createElement(b)).appendTo(c.body),f=a.getDefaultComputedStyle&&(d=a.getDefaultComputedStyle(e[0]))?d.display:n.css(e[0],"display");return e.detach(),f}function tb(a){var b=l,c=rb[a];return c||(c=sb(a,b),"none"!==c&&c||(qb=(qb||n("<iframe frameborder='0' width='0' height='0'/>")).appendTo(b.documentElement),b=qb[0].contentDocument,b.write(),b.close(),c=sb(a,b),qb.detach()),rb[a]=c),c}function xb(a,b,c){var d,e,f,g,h=a.style;return c=c||wb(a),c&&(g=c.getPropertyValue(b)||c[b]),c&&(""!==g||n.contains(a.ownerDocument,a)||(g=n.style(a,b)),vb.test(g)&&ub.test(b)&&(d=h.width,e=h.minWidth,f=h.maxWidth,h.minWidth=h.maxWidth=h.width=g,g=c.width,h.width=d,h.minWidth=e,h.maxWidth=f)),void 0!==g?g+"":g}function yb(a,b){return{get:function(){return a()?void delete this.get:(this.get=b).apply(this,arguments)}}}function Fb(a,b){if(b in a)return b;for(var c=b[0].toUpperCase()+b.slice(1),d=b,e=Eb.length;e--;)if((b=Eb[e]+c)in a)return b;return d}function Gb(a,b,c){var d=Ab.exec(b);return d?Math.max(0,d[1]-(c||0))+(d[2]||"px"):b}function Hb(a,b,c,d,e){for(var f=c===(d?"border":"content")?4:"width"===b?1:0,g=0;4>f;f+=2)"margin"===c&&(g+=n.css(a,c+R[f],!0,e)),d?("content"===c&&(g-=n.css(a,"padding"+R[f],!0,e)),"margin"!==c&&(g-=n.css(a,"border"+R[f]+"Width",!0,e))):(g+=n.css(a,"padding"+R[f],!0,e),"padding"!==c&&(g+=n.css(a,"border"+R[f]+"Width",!0,e)));return g}function Ib(a,b,c){var d=!0,e="width"===b?a.offsetWidth:a.offsetHeight,f=wb(a),g="border-box"===n.css(a,"boxSizing",!1,f);if(0>=e||null==e){if(e=xb(a,b,f),(0>e||null==e)&&(e=a.style[b]),vb.test(e))return e;d=g&&(k.boxSizingReliable()||e===a.style[b]),e=parseFloat(e)||0}return e+Hb(a,b,c||(g?"border":"content"),d,f)+"px"}function Jb(a,b){for(var c,d,e,f=[],g=0,h=a.length;h>g;g++)d=a[g],d.style&&(f[g]=L.get(d,"olddisplay"),c=d.style.display,b?(f[g]||"none"!==c||(d.style.display=""),""===d.style.display&&S(d)&&(f[g]=L.access(d,"olddisplay",tb(d.nodeName)))):(e=S(d),"none"===c&&e||L.set(d,"olddisplay",e?c:n.css(d,"display"))));for(g=0;h>g;g++)d=a[g],d.style&&(b&&"none"!==d.style.display&&""!==d.style.display||(d.style.display=b?f[g]||"":"none"));return a}function Kb(a,b,c,d,e){return new Kb.prototype.init(a,b,c,d,e)}function Sb(){return setTimeout(function(){Lb=void 0}),Lb=n.now()}function Tb(a,b){var c,d=0,e={height:a};for(b=b?1:0;4>d;d+=2-b)c=R[d],e["margin"+c]=e["padding"+c]=a;return b&&(e.opacity=e.width=a),e}function Ub(a,b,c){for(var d,e=(Rb[b]||[]).concat(Rb["*"]),f=0,g=e.length;g>f;f++)if(d=e[f].call(c,b,a))return d}function Vb(a,b,c){var d,e,f,g,h,i,j,l=this,m={},o=a.style,p=a.nodeType&&S(a),q=L.get(a,"fxshow");c.queue||(h=n._queueHooks(a,"fx"),null==h.unqueued&&(h.unqueued=0,i=h.empty.fire,h.empty.fire=function(){h.unqueued||i()}),h.unqueued++,l.always(function(){l.always(function(){h.unqueued--,n.queue(a,"fx").length||h.empty.fire()})})),1===a.nodeType&&("height"in b||"width"in b)&&(c.overflow=[o.overflow,o.overflowX,o.overflowY],j=n.css(a,"display"),"inline"===("none"===j?L.get(a,"olddisplay")||tb(a.nodeName):j)&&"none"===n.css(a,"float")&&(o.display="inline-block")),c.overflow&&(o.overflow="hidden",l.always(function(){o.overflow=c.overflow[0],o.overflowX=c.overflow[1],o.overflowY=c.overflow[2]}));for(d in b)if(e=b[d],Nb.exec(e)){if(delete b[d],f=f||"toggle"===e,e===(p?"hide":"show")){if("show"!==e||!q||void 0===q[d])continue;p=!0}m[d]=q&&q[d]||n.style(a,d)}else j=void 0;if(n.isEmptyObject(m))"inline"===("none"===j?tb(a.nodeName):j)&&(o.display=j);else{q?"hidden"in q&&(p=q.hidden):q=L.access(a,"fxshow",{}),f&&(q.hidden=!p),p?n(a).show():l.done(function(){n(a).hide()}),l.done(function(){var b;L.remove(a,"fxshow");for(b in m)n.style(a,b,m[b])});for(d in m)g=Ub(p?q[d]:0,d,l),d in q||(q[d]=g.start,p&&(g.end=g.start,g.start="width"===d||"height"===d?1:0))}}function Wb(a,b){var c,d,e,f,g;for(c in a)if(d=n.camelCase(c),e=b[d],f=a[c],n.isArray(f)&&(e=f[1],f=a[c]=f[0]),c!==d&&(a[d]=f,delete a[c]),(g=n.cssHooks[d])&&"expand"in g){f=g.expand(f),delete a[d];for(c in f)c in a||(a[c]=f[c],b[c]=e)}else b[d]=e}function Xb(a,b,c){var d,e,f=0,g=Qb.length,h=n.Deferred().always(function(){delete i.elem}),i=function(){if(e)return!1;for(var b=Lb||Sb(),c=Math.max(0,j.startTime+j.duration-b),d=c/j.duration||0,f=1-d,g=0,i=j.tweens.length;i>g;g++)j.tweens[g].run(f);return h.notifyWith(a,[j,f,c]),1>f&&i?c:(h.resolveWith(a,[j]),!1)},j=h.promise({elem:a,props:n.extend({},b),opts:n.extend(!0,{specialEasing:{}},c),originalProperties:b,originalOptions:c,startTime:Lb||Sb(),duration:c.duration,tweens:[],createTween:function(b,c){var d=n.Tween(a,j.opts,b,c,j.opts.specialEasing[b]||j.opts.easing);return j.tweens.push(d),d},stop:function(b){var c=0,d=b?j.tweens.length:0;if(e)return this;for(e=!0;d>c;c++)j.tweens[c].run(1);return b?h.resolveWith(a,[j,b]):h.rejectWith(a,[j,b]),this}}),k=j.props;for(Wb(k,j.opts.specialEasing);g>f;f++)if(d=Qb[f].call(j,a,k,j.opts))return d;return n.map(k,Ub,j),n.isFunction(j.opts.start)&&j.opts.start.call(a,j),n.fx.timer(n.extend(i,{elem:a,anim:j,queue:j.opts.queue})),j.progress(j.opts.progress).done(j.opts.done,j.opts.complete).fail(j.opts.fail).always(j.opts.always)}function rc(a){return function(b,c){"string"!=typeof b&&(c=b,b="*");var d,e=0,f=b.toLowerCase().match(E)||[];if(n.isFunction(c))for(;d=f[e++];)"+"===d[0]?(d=d.slice(1)||"*",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function sc(a,b,c,d){function g(h){var i;return e[h]=!0,n.each(a[h]||[],function(a,h){var j=h(b,c,d);return"string"!=typeof j||f||e[j]?f?!(i=j):void 0:(b.dataTypes.unshift(j),g(j),!1)}),i}var e={},f=a===oc;return g(b.dataTypes[0])||!e["*"]&&g("*")}function tc(a,b){var c,d,e=n.ajaxSettings.flatOptions||{};for(c in b)void 0!==b[c]&&((e[c]?a:d||(d={}))[c]=b[c]);return d&&n.extend(!0,a,d),a}function uc(a,b,c){for(var d,e,f,g,h=a.contents,i=a.dataTypes;"*"===i[0];)i.shift(),void 0===d&&(d=a.mimeType||b.getResponseHeader("Content-Type"));if(d)for(e in h)if(h[e]&&h[e].test(d)){i.unshift(e);break}if(i[0]in c)f=i[0];else{for(e in c){if(!i[0]||a.converters[e+" "+i[0]]){f=e;break}g||(g=e)}f=f||g}return f?(f!==i[0]&&i.unshift(f),c[f]):void 0}function vc(a,b,c,d){var e,f,g,h,i,j={},k=a.dataTypes.slice();if(k[1])for(g in a.converters)j[g.toLowerCase()]=a.converters[g];for(f=k.shift();f;)if(a.responseFields[f]&&(c[a.responseFields[f]]=b),!i&&d&&a.dataFilter&&(b=a.dataFilter(b,a.dataType)),i=f,f=k.shift())if("*"===f)f=i;else if("*"!==i&&i!==f){if(!(g=j[i+" "+f]||j["* "+f]))for(e in j)if(h=e.split(" "),h[1]===f&&(g=j[i+" "+h[0]]||j["* "+h[0]])){g===!0?g=j[e]:j[e]!==!0&&(f=h[0],k.unshift(h[1]));break}if(g!==!0)if(g&&a.throws)b=g(b);else try{b=g(b)}catch(l){return{state:"parsererror",error:g?l:"No conversion from "+i+" to "+f}}}return{state:"success",data:b}}function Bc(a,b,c,d){var e;if(n.isArray(b))n.each(b,function(b,e){c||xc.test(a)?d(a,e):Bc(a+"["+("object"==typeof e?b:"")+"]",e,c,d)});else if(c||"object"!==n.type(b))d(a,b);else for(e in b)Bc(a+"["+e+"]",b[e],c,d)}function Kc(a){return n.isWindow(a)?a:9===a.nodeType&&a.defaultView}var c=[],d=c.slice,e=c.concat,f=c.push,g=c.indexOf,h={},i=h.toString,j=h.hasOwnProperty,k={},l=a.document,m="2.1.1",n=function(a,b){return new n.fn.init(a,b)},r=function(a,b){return b.toUpperCase()};n.fn=n.prototype={jquery:m,constructor:n,selector:"",length:0,toArray:function(){return d.call(this)},get:function(a){return null!=a?0>a?this[a+this.length]:this[a]:d.call(this)},pushStack:function(a){var b=n.merge(this.constructor(),a);return b.prevObject=this,b.context=this.context,b},each:function(a,b){return n.each(this,a,b)},map:function(a){return this.pushStack(n.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(0>a?b:0);return this.pushStack(c>=0&&b>c?[this[c]]:[])},end:function(){return this.prevObject||this.constructor(null)},push:f,sort:c.sort,splice:c.splice},n.extend=n.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||n.isFunction(g)||(g={}),h===i&&(g=this,h--);i>h;h++)if(null!=(a=arguments[h]))for(b in a)c=g[b],d=a[b],g!==d&&(j&&d&&(n.isPlainObject(d)||(e=n.isArray(d)))?(e?(e=!1,f=c&&n.isArray(c)?c:[]):f=c&&n.isPlainObject(c)?c:{},g[b]=n.extend(j,f,d)):void 0!==d&&(g[b]=d));return g},n.extend({expando:"jQuery"+(m+Math.random()).replace(/\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===n.type(a)},isArray:Array.isArray,isWindow:function(a){return null!=a&&a===a.window},isNumeric:function(a){return!n.isArray(a)&&a-parseFloat(a)>=0},isPlainObject:function(a){return"object"===n.type(a)&&!a.nodeType&&!n.isWindow(a)&&!(a.constructor&&!j.call(a.constructor.prototype,"isPrototypeOf"))},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?h[i.call(a)]||"object":typeof a},globalEval:function(a){var b,c=eval;(a=n.trim(a))&&(1===a.indexOf("use strict")?(b=l.createElement("script"),b.text=a,l.head.appendChild(b).parentNode.removeChild(b)):c(a))},camelCase:function(a){return a.replace(/^-ms-/,"ms-").replace(/-([\da-z])/gi,r)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,b,c){var e=0,f=a.length,g=s(a);if(c){if(g)for(;f>e&&b.apply(a[e],c)!==!1;e++);else for(e in a)if(b.apply(a[e],c)===!1)break}else if(g)for(;f>e&&b.call(a[e],e,a[e])!==!1;e++);else for(e in a)if(b.call(a[e],e,a[e])===!1)break;return a},trim:function(a){return null==a?"":(a+"").replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,"")},makeArray:function(a,b){var c=b||[];return null!=a&&(s(Object(a))?n.merge(c,"string"==typeof a?[a]:a):f.call(c,a)),c},inArray:function(a,b,c){return null==b?-1:g.call(b,a,c)},merge:function(a,b){for(var c=+b.length,d=0,e=a.length;c>d;d++)a[e++]=b[d];return a.length=e,a},grep:function(a,b,c){for(var e=[],f=0,g=a.length,h=!c;g>f;f++)!b(a[f],f)!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,f=0,g=a.length,h=s(a),i=[];if(h)for(;g>f;f++)null!=(d=b(a[f],f,c))&&i.push(d);else for(f in a)null!=(d=b(a[f],f,c))&&i.push(d);return e.apply([],i)},guid:1,proxy:function(a,b){var c,e,f;return"string"==typeof b&&(c=a[b],b=a,a=c),n.isFunction(a)?(e=d.call(arguments,2),f=function(){return a.apply(b||this,e.concat(d.call(arguments)))},f.guid=a.guid=a.guid||n.guid++,f):void 0},now:Date.now,support:k}),n.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(a,b){h["[object "+b+"]"]=b.toLowerCase()});var t=function(a){function fb(a,b,d,e){var f,h,j,k,l,o,r,s,w,x;if((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,d=d||[],!a||"string"!=typeof a)return d;if(1!==(k=b.nodeType)&&9!==k)return[];if(p&&!e){if(f=_.exec(a))if(j=f[1]){if(9===k){if(!(h=b.getElementById(j))||!h.parentNode)return d;if(h.id===j)return d.push(h),d}else if(b.ownerDocument&&(h=b.ownerDocument.getElementById(j))&&t(b,h)&&h.id===j)return d.push(h),d}else{if(f[2])return I.apply(d,b.getElementsByTagName(a)),d;if((j=f[3])&&c.getElementsByClassName&&b.getElementsByClassName)return I.apply(d,b.getElementsByClassName(j)),d}if(c.qsa&&(!q||!q.test(a))){if(s=r=u,w=b,x=9===k&&a,1===k&&"object"!==b.nodeName.toLowerCase()){for(o=g(a),(r=b.getAttribute("id"))?s=r.replace(bb,"\\$&"):b.setAttribute("id",s),s="[id='"+s+"'] ",l=o.length;l--;)o[l]=s+qb(o[l]);w=ab.test(a)&&ob(b.parentNode)||b,x=o.join(",")}if(x)try{return I.apply(d,w.querySelectorAll(x)),d}catch(y){}finally{r||b.removeAttribute("id")}}}return i(a.replace(R,"$1"),b,d,e)}function gb(){function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}var a=[];return b}function hb(a){return a[u]=!0,a}function ib(a){var b=n.createElement("div");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function jb(a,b){for(var c=a.split("|"),e=a.length;e--;)d.attrHandle[c[e]]=b}function kb(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&(~b.sourceIndex||D)-(~a.sourceIndex||D);if(d)return d;if(c)for(;c=c.nextSibling;)if(c===b)return-1;return a?1:-1}function nb(a){return hb(function(b){return b=+b,hb(function(c,d){for(var e,f=a([],c.length,b),g=f.length;g--;)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function ob(a){return a&&typeof a.getElementsByTagName!==C&&a}function pb(){}function qb(a){for(var b=0,c=a.length,d="";c>b;b++)d+=a[b].value;return d}function rb(a,b,c){var d=b.dir,e=c&&"parentNode"===d,f=x++;return b.first?function(b,c,f){for(;b=b[d];)if(1===b.nodeType||e)return a(b,c,f)}:function(b,c,g){var h,i,j=[w,f];if(g){for(;b=b[d];)if((1===b.nodeType||e)&&a(b,c,g))return!0}else for(;b=b[d];)if(1===b.nodeType||e){if(i=b[u]||(b[u]={}),(h=i[d])&&h[0]===w&&h[1]===f)return j[2]=h[2];if(i[d]=j,j[2]=a(b,c,g))return!0}}}function sb(a){return a.length>1?function(b,c,d){for(var e=a.length;e--;)if(!a[e](b,c,d))return!1;return!0}:a[0]}function tb(a,b,c){for(var d=0,e=b.length;e>d;d++)fb(a,b[d],c);return c}function ub(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;i>h;h++)(f=a[h])&&(!c||c(f,d,e))&&(g.push(f),j&&b.push(h));return g}function vb(a,b,c,d,e,f){return d&&!d[u]&&(d=vb(d)),e&&!e[u]&&(e=vb(e,f)),hb(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||tb(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:ub(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d)for(j=ub(r,n),d(j,[],h,i),k=j.length;k--;)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l));if(f){if(e||a){if(e){for(j=[],k=r.length;k--;)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}for(k=r.length;k--;)(l=r[k])&&(j=e?K.call(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=ub(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):I.apply(g,r)})}function wb(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=rb(function(a){return a===b},h,!0),l=rb(function(a){return K.call(b,a)>-1},h,!0),m=[function(a,c,d){return!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d))}];f>i;i++)if(c=d.relative[a[i].type])m=[rb(sb(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;f>e&&!d.relative[a[e].type];e++);return vb(i>1&&sb(m),i>1&&qb(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(R,"$1"),c,e>i&&wb(a.slice(i,e)),f>e&&wb(a=a.slice(e)),f>e&&qb(a))}m.push(c)}return sb(m)}function xb(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,m,o,p=0,q="0",r=f&&[],s=[],t=j,u=f||e&&d.find.TAG("*",k),v=w+=null==t?1:Math.random()||.1,x=u.length;for(k&&(j=g!==n&&g);q!==x&&null!=(l=u[q]);q++){if(e&&l){for(m=0;o=a[m++];)if(o(l,g,h)){i.push(l);break}k&&(w=v)}c&&((l=!o&&l)&&p--,f&&r.push(l))}if(p+=q,c&&q!==p){for(m=0;o=b[m++];)o(r,s,g,h);if(f){if(p>0)for(;q--;)r[q]||s[q]||(s[q]=G.call(i));s=ub(s)}I.apply(i,s),k&&!f&&s.length>0&&p+b.length>1&&fb.uniqueSort(i)}return k&&(w=v,j=t),r};return c?hb(f):f}var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+-new Date,v=a.document,w=0,x=0,y=gb(),z=gb(),A=gb(),B=function(a,b){return a===b&&(l=!0),0},C="undefined",D=1<<31,E={}.hasOwnProperty,F=[],G=F.pop,H=F.push,I=F.push,J=F.slice,K=F.indexOf||function(a){for(var b=0,c=this.length;c>b;b++)if(this[b]===a)return b;return-1},L="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",N="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",O=N.replace("w","w#"),P="\\["+M+"*("+N+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+O+"))|)"+M+"*\\]",Q=":("+N+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+P+")*)|.*)\\)|)",R=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),S=new RegExp("^"+M+"*,"+M+"*"),T=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp("="+M+"*([^\\]'\"]*?)"+M+"*\\]","g"),V=new RegExp(Q),W=new RegExp("^"+O+"$"),X={ID:new RegExp("^#("+N+")"),CLASS:new RegExp("^\\.("+N+")"),TAG:new RegExp("^("+N.replace("w","w*")+")"),ATTR:new RegExp("^"+P),PSEUDO:new RegExp("^"+Q),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+L+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/^(?:input|select|textarea|button)$/i,Z=/^h\d$/i,$=/^[^{]+\{\s*\[native \w/,_=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ab=/[+~]/,bb=/'|\\/g,cb=new RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),db=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:0>d?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)};try{I.apply(F=J.call(v.childNodes),v.childNodes),F[v.childNodes.length].nodeType}catch(eb){I={apply:F.length?function(a,b){H.apply(a,J.call(b))}:function(a,b){for(var c=a.length,d=0;a[c++]=b[d++];);a.length=c-1}}}c=fb.support={},f=fb.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return!!b&&"HTML"!==b.nodeName},m=fb.setDocument=function(a){var b,e=a?a.ownerDocument||a:v,g=e.defaultView;return e!==n&&9===e.nodeType&&e.documentElement?(n=e,o=e.documentElement,p=!f(e),g&&g!==g.top&&(g.addEventListener?g.addEventListener("unload",function(){m()},!1):g.attachEvent&&g.attachEvent("onunload",function(){m()})),c.attributes=ib(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ib(function(a){return a.appendChild(e.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=$.test(e.getElementsByClassName)&&ib(function(a){return a.innerHTML="<div class='a'></div><div class='a i'></div>",a.firstChild.className="i",2===a.getElementsByClassName("i").length}),c.getById=ib(function(a){return o.appendChild(a).id=u,!e.getElementsByName||!e.getElementsByName(u).length}),c.getById?(d.find.ID=function(a,b){if(typeof b.getElementById!==C&&p){var c=b.getElementById(a);return c&&c.parentNode?[c]:[]}},d.filter.ID=function(a){var b=a.replace(cb,db);return function(a){return a.getAttribute("id")===b}}):(delete d.find.ID,d.filter.ID=function(a){var b=a.replace(cb,db);return function(a){var c=typeof a.getAttributeNode!==C&&a.getAttributeNode("id");return c&&c.value===b}}),d.find.TAG=c.getElementsByTagName?function(a,b){return typeof b.getElementsByTagName!==C?b.getElementsByTagName(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){for(;c=f[e++];)1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){return typeof b.getElementsByClassName!==C&&p?b.getElementsByClassName(a):void 0},r=[],q=[],(c.qsa=$.test(e.querySelectorAll))&&(ib(function(a){a.innerHTML="<select msallowclip=''><option selected=''></option></select>",a.querySelectorAll("[msallowclip^='']").length&&q.push("[*^$]="+M+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+M+"*(?:value|"+L+")"),a.querySelectorAll(":checked").length||q.push(":checked")}),ib(function(a){var b=e.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+M+"*[*^$|!~]?="),a.querySelectorAll(":enabled").length||q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=$.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ib(function(a){c.disconnectedMatch=s.call(a,"div"),s.call(a,"[s!='']:x"),r.push("!=",Q)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=$.test(o.compareDocumentPosition),t=b||$.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)for(;b=b.parentNode;)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===e||a.ownerDocument===v&&t(v,a)?-1:b===e||b.ownerDocument===v&&t(v,b)?1:k?K.call(k,a)-K.call(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,f=a.parentNode,g=b.parentNode,h=[a],i=[b];if(!f||!g)return a===e?-1:b===e?1:f?-1:g?1:k?K.call(k,a)-K.call(k,b):0;if(f===g)return kb(a,b);for(c=a;c=c.parentNode;)h.unshift(c);for(c=b;c=c.parentNode;)i.unshift(c);for(;h[d]===i[d];)d++;return d?kb(h[d],i[d]):h[d]===v?-1:i[d]===v?1:0},e):n},fb.matches=function(a,b){return fb(a,null,null,b)},fb.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(U,"='$1']"),!(!c.matchesSelector||!p||r&&r.test(b)||q&&q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return fb(b,n,null,[a]).length>0},fb.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},fb.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&E.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},fb.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},fb.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){for(;b=a[f++];)b===a[f]&&(e=d.push(f));for(;e--;)a.splice(d[e],1)}return k=null,a},e=fb.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else for(;b=a[d++];)c+=e(b);return c},d=fb.selectors={cacheLength:50,createPseudo:hb,match:X,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(cb,db),a[3]=(a[3]||a[4]||a[5]||"").replace(cb,db),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||fb.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&fb.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return X.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&V.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(cb,db).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+M+")"+a+"("+M+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||typeof a.getAttribute!==C&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=fb.attr(d,a);return null==e?"!="===b:!b||(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e+" ").indexOf(c)>-1:"|="===b&&(e===c||e.slice(0,c.length+1)===c+"-"))}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h;if(q){if(f){for(;p;){for(l=b;l=l[p];)if(h?l.nodeName.toLowerCase()===r:1===l.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){for(k=q[u]||(q[u]={}),j=k[a]||[],n=j[0]===w&&j[1],m=j[0]===w&&j[2],l=n&&q.childNodes[n];l=++n&&l&&l[p]||(m=n=0)||o.pop();)if(1===l.nodeType&&++m&&l===b){k[a]=[w,n,m];break}}else if(s&&(j=(b[u]||(b[u]={}))[a])&&j[0]===w)m=j[1];else for(;(l=++n&&l&&l[p]||(m=n=0)||o.pop())&&((h?l.nodeName.toLowerCase()!==r:1!==l.nodeType)||!++m||(s&&((l[u]||(l[u]={}))[a]=[w,m]),l!==b)););return(m-=e)===d||m%d==0&&m/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||fb.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?hb(function(a,c){for(var d,f=e(a,b),g=f.length;g--;)d=K.call(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:hb(function(a){var b=[],c=[],d=h(a.replace(R,"$1"));return d[u]?hb(function(a,b,c,e){for(var f,g=d(a,null,e,[]),h=a.length;h--;)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),!c.pop()}}),has:hb(function(a){return function(b){return fb(a,b).length>0}}),contains:hb(function(a){return function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:hb(function(a){return W.test(a||"")||fb.error("unsupported lang: "+a),a=a.replace(cb,db).toLowerCase(),function(b){var c;do{if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return(c=c.toLowerCase())===a||0===c.indexOf(a+"-")}while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return Z.test(a.nodeName)},input:function(a){return Y.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:nb(function(){return[0]}),last:nb(function(a,b){return[b-1]}),eq:nb(function(a,b,c){return[0>c?c+b:c]}),even:nb(function(a,b){for(var c=0;b>c;c+=2)a.push(c);return a}),odd:nb(function(a,b){for(var c=1;b>c;c+=2)a.push(c);return a}),lt:nb(function(a,b,c){for(var d=0>c?c+b:c;--d>=0;)a.push(d);return a}),gt:nb(function(a,b,c){for(var d=0>c?c+b:c;++d<b;)a.push(d);return a})}},d.pseudos.nth=d.pseudos.eq;for(b in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})d.pseudos[b]=function(a){return function(b){return"input"===b.nodeName.toLowerCase()&&b.type===a}}(b);for(b in{submit:!0,reset:!0})d.pseudos[b]=function(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}(b);return pb.prototype=d.filters=d.pseudos,d.setFilters=new pb,g=fb.tokenize=function(a,b){var c,e,f,g,h,i,j,k=z[a+" "];if(k)return b?0:k.slice(0);for(h=a,i=[],j=d.preFilter;h;){(!c||(e=S.exec(h)))&&(e&&(h=h.slice(e[0].length)||h),i.push(f=[])),c=!1,(e=T.exec(h))&&(c=e.shift(),f.push({value:c,type:e[0].replace(R," ")}),h=h.slice(c.length));for(g in d.filter)!(e=X[g].exec(h))||j[g]&&!(e=j[g](e))||(c=e.shift(),f.push({value:c,type:g,matches:e}),h=h.slice(c.length));if(!c)break}return b?h.length:h?fb.error(a):z(a,i).slice(0)},h=fb.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){for(b||(b=g(a)),c=b.length;c--;)f=wb(b[c]),f[u]?d.push(f):e.push(f);f=A(a,xb(e,d)),f.selector=a}return f},i=fb.select=function(a,b,e,f){var i,j,k,l,m,n="function"==typeof a&&a,o=!f&&g(a=n.selector||a);if(e=e||[],1===o.length){if(j=o[0]=o[0].slice(0),j.length>2&&"ID"===(k=j[0]).type&&c.getById&&9===b.nodeType&&p&&d.relative[j[1].type]){if(!(b=(d.find.ID(k.matches[0].replace(cb,db),b)||[])[0]))return e;n&&(b=b.parentNode),a=a.slice(j.shift().value.length)}for(i=X.needsContext.test(a)?0:j.length;i--&&(k=j[i],!d.relative[l=k.type]);)if((m=d.find[l])&&(f=m(k.matches[0].replace(cb,db),ab.test(j[0].type)&&ob(b.parentNode)||b))){if(j.splice(i,1),!(a=f.length&&qb(j)))return I.apply(e,f),e;break}}return(n||h(a,o))(f,b,!p,e,ab.test(a)&&ob(b.parentNode)||b),e},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ib(function(a){return 1&a.compareDocumentPosition(n.createElement("div"))}),ib(function(a){return a.innerHTML="<a href='#'></a>","#"===a.firstChild.getAttribute("href")})||jb("type|href|height|width",function(a,b,c){return c?void 0:a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ib(function(a){return a.innerHTML="<input/>",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||jb("value",function(a,b,c){return c||"input"!==a.nodeName.toLowerCase()?void 0:a.defaultValue}),ib(function(a){return null==a.getAttribute("disabled")})||jb(L,function(a,b,c){var d;return c?void 0:a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),fb}(a);n.find=t,n.expr=t.selectors,n.expr[":"]=n.expr.pseudos,n.unique=t.uniqueSort,n.text=t.getText,n.isXMLDoc=t.isXML,n.contains=t.contains;var u=n.expr.match.needsContext,v=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,w=/^.[^:#\[\.,]*$/;n.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?n.find.matchesSelector(d,a)?[d]:[]:n.find.matches(a,n.grep(b,function(a){return 1===a.nodeType}))},n.fn.extend({find:function(a){var b,c=this.length,d=[],e=this;if("string"!=typeof a)return this.pushStack(n(a).filter(function(){ +for(b=0;c>b;b++)if(n.contains(e[b],this))return!0}));for(b=0;c>b;b++)n.find(a,e[b],d);return d=this.pushStack(c>1?n.unique(d):d),d.selector=this.selector?this.selector+" "+a:a,d},filter:function(a){return this.pushStack(x(this,a||[],!1))},not:function(a){return this.pushStack(x(this,a||[],!0))},is:function(a){return!!x(this,"string"==typeof a&&u.test(a)?n(a):a||[],!1).length}});var y,z=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/;(n.fn.init=function(a,b){var c,d;if(!a)return this;if("string"==typeof a){if(!(c="<"===a[0]&&">"===a[a.length-1]&&a.length>=3?[null,a,null]:z.exec(a))||!c[1]&&b)return!b||b.jquery?(b||y).find(a):this.constructor(b).find(a);if(c[1]){if(b=b instanceof n?b[0]:b,n.merge(this,n.parseHTML(c[1],b&&b.nodeType?b.ownerDocument||b:l,!0)),v.test(c[1])&&n.isPlainObject(b))for(c in b)n.isFunction(this[c])?this[c](b[c]):this.attr(c,b[c]);return this}return d=l.getElementById(c[2]),d&&d.parentNode&&(this.length=1,this[0]=d),this.context=l,this.selector=a,this}return a.nodeType?(this.context=this[0]=a,this.length=1,this):n.isFunction(a)?void 0!==y.ready?y.ready(a):a(n):(void 0!==a.selector&&(this.selector=a.selector,this.context=a.context),n.makeArray(a,this))}).prototype=n.fn,y=n(l);var B=/^(?:parents|prev(?:Until|All))/,C={children:!0,contents:!0,next:!0,prev:!0};n.extend({dir:function(a,b,c){for(var d=[],e=void 0!==c;(a=a[b])&&9!==a.nodeType;)if(1===a.nodeType){if(e&&n(a).is(c))break;d.push(a)}return d},sibling:function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c}}),n.fn.extend({has:function(a){var b=n(a,this),c=b.length;return this.filter(function(){for(var a=0;c>a;a++)if(n.contains(this,b[a]))return!0})},closest:function(a,b){for(var c,d=0,e=this.length,f=[],g=u.test(a)||"string"!=typeof a?n(a,b||this.context):0;e>d;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&n.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?n.unique(f):f)},index:function(a){return a?"string"==typeof a?g.call(n(a),this[0]):g.call(this,a.jquery?a[0]:a):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(n.unique(n.merge(this.get(),n(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}}),n.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return n.dir(a,"parentNode")},parentsUntil:function(a,b,c){return n.dir(a,"parentNode",c)},next:function(a){return D(a,"nextSibling")},prev:function(a){return D(a,"previousSibling")},nextAll:function(a){return n.dir(a,"nextSibling")},prevAll:function(a){return n.dir(a,"previousSibling")},nextUntil:function(a,b,c){return n.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return n.dir(a,"previousSibling",c)},siblings:function(a){return n.sibling((a.parentNode||{}).firstChild,a)},children:function(a){return n.sibling(a.firstChild)},contents:function(a){return a.contentDocument||n.merge([],a.childNodes)}},function(a,b){n.fn[a]=function(c,d){var e=n.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=n.filter(d,e)),this.length>1&&(C[a]||n.unique(e),B.test(a)&&e.reverse()),this.pushStack(e)}});var E=/\S+/g,F={};n.Callbacks=function(a){a="string"==typeof a?F[a]||G(a):n.extend({},a);var b,c,d,e,f,g,h=[],i=!a.once&&[],j=function(l){for(b=a.memory&&l,c=!0,g=e||0,e=0,f=h.length,d=!0;h&&f>g;g++)if(h[g].apply(l[0],l[1])===!1&&a.stopOnFalse){b=!1;break}d=!1,h&&(i?i.length&&j(i.shift()):b?h=[]:k.disable())},k={add:function(){if(h){var c=h.length;!function g(b){n.each(b,function(b,c){var d=n.type(c);"function"===d?a.unique&&k.has(c)||h.push(c):c&&c.length&&"string"!==d&&g(c)})}(arguments),d?f=h.length:b&&(e=c,j(b))}return this},remove:function(){return h&&n.each(arguments,function(a,b){for(var c;(c=n.inArray(b,h,c))>-1;)h.splice(c,1),d&&(f>=c&&f--,g>=c&&g--)}),this},has:function(a){return a?n.inArray(a,h)>-1:!(!h||!h.length)},empty:function(){return h=[],f=0,this},disable:function(){return h=i=b=void 0,this},disabled:function(){return!h},lock:function(){return i=void 0,b||k.disable(),this},locked:function(){return!i},fireWith:function(a,b){return!h||c&&!i||(b=b||[],b=[a,b.slice?b.slice():b],d?i.push(b):j(b)),this},fire:function(){return k.fireWith(this,arguments),this},fired:function(){return!!c}};return k},n.extend({Deferred:function(a){var b=[["resolve","done",n.Callbacks("once memory"),"resolved"],["reject","fail",n.Callbacks("once memory"),"rejected"],["notify","progress",n.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return n.Deferred(function(c){n.each(b,function(b,f){var g=n.isFunction(a[b])&&a[b];e[f[1]](function(){var a=g&&g.apply(this,arguments);a&&n.isFunction(a.promise)?a.promise().done(c.resolve).fail(c.reject).progress(c.notify):c[f[0]+"With"](this===d?c.promise():this,g?[a]:arguments)})}),a=null}).promise()},promise:function(a){return null!=a?n.extend(a,d):d}},e={};return d.pipe=d.then,n.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[1^a][2].disable,b[2][2].lock),e[f[0]]=function(){return e[f[0]+"With"](this===e?d:this,arguments),this},e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var i,j,k,b=0,c=d.call(arguments),e=c.length,f=1!==e||a&&n.isFunction(a.promise)?e:0,g=1===f?a:n.Deferred(),h=function(a,b,c){return function(e){b[a]=this,c[a]=arguments.length>1?d.call(arguments):e,c===i?g.notifyWith(b,c):--f||g.resolveWith(b,c)}};if(e>1)for(i=new Array(e),j=new Array(e),k=new Array(e);e>b;b++)c[b]&&n.isFunction(c[b].promise)?c[b].promise().done(h(b,k,c)).fail(g.reject).progress(h(b,j,i)):--f;return f||g.resolveWith(k,c),g.promise()}});var H;n.fn.ready=function(a){return n.ready.promise().done(a),this},n.extend({isReady:!1,readyWait:1,holdReady:function(a){a?n.readyWait++:n.ready(!0)},ready:function(a){(a===!0?--n.readyWait:n.isReady)||(n.isReady=!0,a!==!0&&--n.readyWait>0||(H.resolveWith(l,[n]),n.fn.triggerHandler&&(n(l).triggerHandler("ready"),n(l).off("ready"))))}}),n.ready.promise=function(b){return H||(H=n.Deferred(),"complete"===l.readyState?setTimeout(n.ready):(l.addEventListener("DOMContentLoaded",I,!1),a.addEventListener("load",I,!1))),H.promise(b)},n.ready.promise();var J=n.access=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===n.type(c)){e=!0;for(h in c)n.access(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,n.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(n(a),c)})),b))for(;i>h;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f};n.acceptData=function(a){return 1===a.nodeType||9===a.nodeType||!+a.nodeType},K.uid=1,K.accepts=n.acceptData,K.prototype={key:function(a){if(!K.accepts(a))return 0;var b={},c=a[this.expando];if(!c){c=K.uid++;try{b[this.expando]={value:c},Object.defineProperties(a,b)}catch(d){b[this.expando]=c,n.extend(a,b)}}return this.cache[c]||(this.cache[c]={}),c},set:function(a,b,c){var d,e=this.key(a),f=this.cache[e];if("string"==typeof b)f[b]=c;else if(n.isEmptyObject(f))n.extend(this.cache[e],b);else for(d in b)f[d]=b[d];return f},get:function(a,b){var c=this.cache[this.key(a)];return void 0===b?c:c[b]},access:function(a,b,c){var d;return void 0===b||b&&"string"==typeof b&&void 0===c?(d=this.get(a,b),void 0!==d?d:this.get(a,n.camelCase(b))):(this.set(a,b,c),void 0!==c?c:b)},remove:function(a,b){var c,d,e,f=this.key(a),g=this.cache[f];if(void 0===b)this.cache[f]={};else{n.isArray(b)?d=b.concat(b.map(n.camelCase)):(e=n.camelCase(b),b in g?d=[b,e]:(d=e,d=d in g?[d]:d.match(E)||[])),c=d.length;for(;c--;)delete g[d[c]]}},hasData:function(a){return!n.isEmptyObject(this.cache[a[this.expando]]||{})},discard:function(a){a[this.expando]&&delete this.cache[a[this.expando]]}};var L=new K,M=new K,N=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,O=/([A-Z])/g;n.extend({hasData:function(a){return M.hasData(a)||L.hasData(a)},data:function(a,b,c){return M.access(a,b,c)},removeData:function(a,b){M.remove(a,b)},_data:function(a,b,c){return L.access(a,b,c)},_removeData:function(a,b){L.remove(a,b)}}),n.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=M.get(f),1===f.nodeType&&!L.get(f,"hasDataAttrs"))){for(c=g.length;c--;)g[c]&&(d=g[c].name,0===d.indexOf("_data-")&&(d=n.camelCase(d.slice(5)),P(f,d,e[d])));L.set(f,"hasDataAttrs",!0)}return e}return"object"==typeof a?this.each(function(){M.set(this,a)}):J(this,function(b){var c,d=n.camelCase(a);if(f&&void 0===b){if(void 0!==(c=M.get(f,a)))return c;if(void 0!==(c=M.get(f,d)))return c;if(void 0!==(c=P(f,d,void 0)))return c}else this.each(function(){var c=M.get(this,d);M.set(this,d,b),-1!==a.indexOf("-")&&void 0!==c&&M.set(this,a,b)})},null,b,arguments.length>1,null,!0)},removeData:function(a){return this.each(function(){M.remove(this,a)})}}),n.extend({queue:function(a,b,c){var d;return a?(b=(b||"fx")+"queue",d=L.get(a,b),c&&(!d||n.isArray(c)?d=L.access(a,b,n.makeArray(c)):d.push(c)),d||[]):void 0},dequeue:function(a,b){b=b||"fx";var c=n.queue(a,b),d=c.length,e=c.shift(),f=n._queueHooks(a,b),g=function(){n.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return L.get(a,c)||L.access(a,c,{empty:n.Callbacks("once memory").add(function(){L.remove(a,[b+"queue",c])})})}}),n.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length<c?n.queue(this[0],a):void 0===b?this:this.each(function(){var c=n.queue(this,a,b);n._queueHooks(this,a),"fx"===a&&"inprogress"!==c[0]&&n.dequeue(this,a)})},dequeue:function(a){return this.each(function(){n.dequeue(this,a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,b){var c,d=1,e=n.Deferred(),f=this,g=this.length,h=function(){--d||e.resolveWith(f,[f])};for("string"!=typeof a&&(b=a,a=void 0),a=a||"fx";g--;)(c=L.get(f[g],a+"queueHooks"))&&c.empty&&(d++,c.empty.add(h));return h(),e.promise(b)}});var Q=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,R=["Top","Right","Bottom","Left"],S=function(a,b){return a=b||a,"none"===n.css(a,"display")||!n.contains(a.ownerDocument,a)},T=/^(?:checkbox|radio)$/i;!function(){var a=l.createDocumentFragment(),b=a.appendChild(l.createElement("div")),c=l.createElement("input");c.setAttribute("type","radio"),c.setAttribute("checked","checked"),c.setAttribute("name","t"),b.appendChild(c),k.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,b.innerHTML="<textarea>x</textarea>",k.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue}();var U="undefined";k.focusinBubbles="onfocusin"in a;var V=/^key/,W=/^(?:mouse|pointer|contextmenu)|click/,X=/^(?:focusinfocus|focusoutblur)$/,Y=/^([^.]*)(?:\.(.+)|)$/;n.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,o,p,q,r=L.get(a);if(r)for(c.handler&&(f=c,c=f.handler,e=f.selector),c.guid||(c.guid=n.guid++),(i=r.events)||(i=r.events={}),(g=r.handle)||(g=r.handle=function(b){return typeof n!==U&&n.event.triggered!==b.type?n.event.dispatch.apply(a,arguments):void 0}),b=(b||"").match(E)||[""],j=b.length;j--;)h=Y.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o&&(l=n.event.special[o]||{},o=(e?l.delegateType:l.bindType)||o,l=n.event.special[o]||{},k=n.extend({type:o,origType:q,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&n.expr.match.needsContext.test(e),namespace:p.join(".")},f),(m=i[o])||(m=i[o]=[],m.delegateCount=0,l.setup&&l.setup.call(a,d,p,g)!==!1||a.addEventListener&&a.addEventListener(o,g,!1)),l.add&&(l.add.call(a,k),k.handler.guid||(k.handler.guid=c.guid)),e?m.splice(m.delegateCount++,0,k):m.push(k),n.event.global[o]=!0)},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,o,p,q,r=L.hasData(a)&&L.get(a);if(r&&(i=r.events)){for(b=(b||"").match(E)||[""],j=b.length;j--;)if(h=Y.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o){for(l=n.event.special[o]||{},o=(d?l.delegateType:l.bindType)||o,m=i[o]||[],h=h[2]&&new RegExp("(^|\\.)"+p.join("\\.(?:.*\\.|)")+"(\\.|$)"),g=f=m.length;f--;)k=m[f],!e&&q!==k.origType||c&&c.guid!==k.guid||h&&!h.test(k.namespace)||d&&d!==k.selector&&("**"!==d||!k.selector)||(m.splice(f,1),k.selector&&m.delegateCount--,l.remove&&l.remove.call(a,k));g&&!m.length&&(l.teardown&&l.teardown.call(a,p,r.handle)!==!1||n.removeEvent(a,o,r.handle),delete i[o])}else for(o in i)n.event.remove(a,o+b[j],c,d,!0);n.isEmptyObject(i)&&(delete r.handle,L.remove(a,"events"))}},trigger:function(b,c,d,e){var f,g,h,i,k,m,o,p=[d||l],q=j.call(b,"type")?b.type:b,r=j.call(b,"namespace")?b.namespace.split("."):[];if(g=h=d=d||l,3!==d.nodeType&&8!==d.nodeType&&!X.test(q+n.event.triggered)&&(q.indexOf(".")>=0&&(r=q.split("."),q=r.shift(),r.sort()),k=q.indexOf(":")<0&&"on"+q,b=b[n.expando]?b:new n.Event(q,"object"==typeof b&&b),b.isTrigger=e?2:3,b.namespace=r.join("."),b.namespace_re=b.namespace?new RegExp("(^|\\.)"+r.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=d),c=null==c?[b]:n.makeArray(c,[b]),o=n.event.special[q]||{},e||!o.trigger||o.trigger.apply(d,c)!==!1)){if(!e&&!o.noBubble&&!n.isWindow(d)){for(i=o.delegateType||q,X.test(i+q)||(g=g.parentNode);g;g=g.parentNode)p.push(g),h=g;h===(d.ownerDocument||l)&&p.push(h.defaultView||h.parentWindow||a)}for(f=0;(g=p[f++])&&!b.isPropagationStopped();)b.type=f>1?i:o.bindType||q,m=(L.get(g,"events")||{})[b.type]&&L.get(g,"handle"),m&&m.apply(g,c),(m=k&&g[k])&&m.apply&&n.acceptData(g)&&(b.result=m.apply(g,c),b.result===!1&&b.preventDefault());return b.type=q,e||b.isDefaultPrevented()||o._default&&o._default.apply(p.pop(),c)!==!1||!n.acceptData(d)||k&&n.isFunction(d[q])&&!n.isWindow(d)&&(h=d[k],h&&(d[k]=null),n.event.triggered=q,d[q](),n.event.triggered=void 0,h&&(d[k]=h)),b.result}},dispatch:function(a){a=n.event.fix(a);var b,c,e,f,g,h=[],i=d.call(arguments),j=(L.get(this,"events")||{})[a.type]||[],k=n.event.special[a.type]||{};if(i[0]=a,a.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,a)!==!1){for(h=n.event.handlers.call(this,a,j),b=0;(f=h[b++])&&!a.isPropagationStopped();)for(a.currentTarget=f.elem,c=0;(g=f.handlers[c++])&&!a.isImmediatePropagationStopped();)(!a.namespace_re||a.namespace_re.test(g.namespace))&&(a.handleObj=g,a.data=g.data,void 0!==(e=((n.event.special[g.origType]||{}).handle||g.handler).apply(f.elem,i))&&(a.result=e)===!1&&(a.preventDefault(),a.stopPropagation()));return k.postDispatch&&k.postDispatch.call(this,a),a.result}},handlers:function(a,b){var c,d,e,f,g=[],h=b.delegateCount,i=a.target;if(h&&i.nodeType&&(!a.button||"click"!==a.type))for(;i!==this;i=i.parentNode||this)if(i.disabled!==!0||"click"!==a.type){for(d=[],c=0;h>c;c++)f=b[c],e=f.selector+" ",void 0===d[e]&&(d[e]=f.needsContext?n(e,this).index(i)>=0:n.find(e,this,null,[i]).length),d[e]&&d.push(f);d.length&&g.push({elem:i,handlers:d})}return h<b.length&&g.push({elem:this,handlers:b.slice(h)}),g},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(a,b){return null==a.which&&(a.which=null!=b.charCode?b.charCode:b.keyCode),a}},mouseHooks:{props:"button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(a,b){var c,d,e,f=b.button;return null==a.pageX&&null!=b.clientX&&(c=a.target.ownerDocument||l,d=c.documentElement,e=c.body,a.pageX=b.clientX+(d&&d.scrollLeft||e&&e.scrollLeft||0)-(d&&d.clientLeft||e&&e.clientLeft||0),a.pageY=b.clientY+(d&&d.scrollTop||e&&e.scrollTop||0)-(d&&d.clientTop||e&&e.clientTop||0)),a.which||void 0===f||(a.which=1&f?1:2&f?3:4&f?2:0),a}},fix:function(a){if(a[n.expando])return a;var b,c,d,e=a.type,f=a,g=this.fixHooks[e];for(g||(this.fixHooks[e]=g=W.test(e)?this.mouseHooks:V.test(e)?this.keyHooks:{}),d=g.props?this.props.concat(g.props):this.props,a=new n.Event(f),b=d.length;b--;)c=d[b],a[c]=f[c];return a.target||(a.target=l),3===a.target.nodeType&&(a.target=a.target.parentNode),g.filter?g.filter(a,f):a},special:{load:{noBubble:!0},focus:{trigger:function(){return this!==_()&&this.focus?(this.focus(),!1):void 0},delegateType:"focusin"},blur:{trigger:function(){return this===_()&&this.blur?(this.blur(),!1):void 0},delegateType:"focusout"},click:{trigger:function(){return"checkbox"===this.type&&this.click&&n.nodeName(this,"input")?(this.click(),!1):void 0},_default:function(a){return n.nodeName(a.target,"a")}},beforeunload:{postDispatch:function(a){void 0!==a.result&&a.originalEvent&&(a.originalEvent.returnValue=a.result)}}},simulate:function(a,b,c,d){var e=n.extend(new n.Event,c,{type:a,isSimulated:!0,originalEvent:{}});d?n.event.trigger(e,null,b):n.event.dispatch.call(b,e),e.isDefaultPrevented()&&c.preventDefault()}},n.removeEvent=function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c,!1)},n.Event=function(a,b){return this instanceof n.Event?(a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||void 0===a.defaultPrevented&&a.returnValue===!1?Z:$):this.type=a,b&&n.extend(this,b),this.timeStamp=a&&a.timeStamp||n.now(),void(this[n.expando]=!0)):new n.Event(a,b)},n.Event.prototype={isDefaultPrevented:$,isPropagationStopped:$,isImmediatePropagationStopped:$,preventDefault:function(){var a=this.originalEvent;this.isDefaultPrevented=Z,a&&a.preventDefault&&a.preventDefault()},stopPropagation:function(){var a=this.originalEvent;this.isPropagationStopped=Z,a&&a.stopPropagation&&a.stopPropagation()},stopImmediatePropagation:function(){var a=this.originalEvent;this.isImmediatePropagationStopped=Z,a&&a.stopImmediatePropagation&&a.stopImmediatePropagation(),this.stopPropagation()}},n.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(a,b){n.event.special[a]={delegateType:b,bindType:b,handle:function(a){var c,d=this,e=a.relatedTarget,f=a.handleObj;return(!e||e!==d&&!n.contains(d,e))&&(a.type=f.origType,c=f.handler.apply(this,arguments),a.type=b),c}}}),k.focusinBubbles||n.each({focus:"focusin",blur:"focusout"},function(a,b){var c=function(a){n.event.simulate(b,a.target,n.event.fix(a),!0)};n.event.special[b]={setup:function(){var d=this.ownerDocument||this,e=L.access(d,b);e||d.addEventListener(a,c,!0),L.access(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=L.access(d,b)-1;e?L.access(d,b,e):(d.removeEventListener(a,c,!0),L.remove(d,b))}}}),n.fn.extend({on:function(a,b,c,d,e){var f,g;if("object"==typeof a){"string"!=typeof b&&(c=c||b,b=void 0);for(g in a)this.on(g,b,c,a[g],e);return this}if(null==c&&null==d?(d=b,c=b=void 0):null==d&&("string"==typeof b?(d=c,c=void 0):(d=c,c=b,b=void 0)),d===!1)d=$;else if(!d)return this;return 1===e&&(f=d,d=function(a){return n().off(a),f.apply(this,arguments)},d.guid=f.guid||(f.guid=n.guid++)),this.each(function(){n.event.add(this,a,d,c,b)})},one:function(a,b,c,d){return this.on(a,b,c,d,1)},off:function(a,b,c){var d,e;if(a&&a.preventDefault&&a.handleObj)return d=a.handleObj,n(a.delegateTarget).off(d.namespace?d.origType+"."+d.namespace:d.origType,d.selector,d.handler),this;if("object"==typeof a){for(e in a)this.off(e,b,a[e]);return this}return(b===!1||"function"==typeof b)&&(c=b,b=void 0),c===!1&&(c=$),this.each(function(){n.event.remove(this,a,c,b)})},trigger:function(a,b){return this.each(function(){n.event.trigger(a,b,this)})},triggerHandler:function(a,b){var c=this[0];return c?n.event.trigger(a,b,c,!0):void 0}});var ab=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,bb=/<([\w:]+)/,cb=/<|&#?\w+;/,db=/<(?:script|style|link)/i,eb=/checked\s*(?:[^=]|=\s*.checked.)/i,fb=/^$|\/(?:java|ecma)script/i,gb=/^true\/(.*)/,ib={option:[1,"<select multiple='multiple'>","</select>"],thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};ib.optgroup=ib.option,ib.tbody=ib.tfoot=ib.colgroup=ib.caption=ib.thead,ib.th=ib.td,n.extend({clone:function(a,b,c){var d,e,f,g,h=a.cloneNode(!0),i=n.contains(a.ownerDocument,a);if(!(k.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||n.isXMLDoc(a)))for(g=ob(h),f=ob(a),d=0,e=f.length;e>d;d++)pb(f[d],g[d]);if(b)if(c)for(f=f||ob(a),g=g||ob(h),d=0,e=f.length;e>d;d++)nb(f[d],g[d]);else nb(a,h);return g=ob(h,"script"),g.length>0&&mb(g,!i&&ob(a,"script")),h},buildFragment:function(a,b,c,d){for(var e,f,g,h,i,j,k=b.createDocumentFragment(),l=[],m=0,o=a.length;o>m;m++)if((e=a[m])||0===e)if("object"===n.type(e))n.merge(l,e.nodeType?[e]:e);else if(cb.test(e)){for(f=f||k.appendChild(b.createElement("div")),g=(bb.exec(e)||["",""])[1].toLowerCase(),h=ib[g]||ib._default,f.innerHTML=h[1]+e.replace(ab,"<$1></$2>")+h[2],j=h[0];j--;)f=f.lastChild;n.merge(l,f.childNodes),f=k.firstChild,f.textContent=""}else l.push(b.createTextNode(e));for(k.textContent="",m=0;e=l[m++];)if((!d||-1===n.inArray(e,d))&&(i=n.contains(e.ownerDocument,e),f=ob(k.appendChild(e),"script"),i&&mb(f),c))for(j=0;e=f[j++];)fb.test(e.type||"")&&c.push(e);return k},cleanData:function(a){for(var b,c,d,e,f=n.event.special,g=0;void 0!==(c=a[g]);g++){if(n.acceptData(c)&&(e=c[L.expando])&&(b=L.cache[e])){if(b.events)for(d in b.events)f[d]?n.event.remove(c,d):n.removeEvent(c,d,b.handle);L.cache[e]&&delete L.cache[e]}delete M.cache[c[M.expando]]}}}),n.fn.extend({text:function(a){return J(this,function(a){return void 0===a?n.text(this):this.empty().each(function(){(1===this.nodeType||11===this.nodeType||9===this.nodeType)&&(this.textContent=a)})},null,a,arguments.length)},append:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){jb(this,a).appendChild(a)}})},prepend:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=jb(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},remove:function(a,b){for(var c,d=a?n.filter(a,this):this,e=0;null!=(c=d[e]);e++)b||1!==c.nodeType||n.cleanData(ob(c)),c.parentNode&&(b&&n.contains(c.ownerDocument,c)&&mb(ob(c,"script")),c.parentNode.removeChild(c));return this},empty:function(){for(var a,b=0;null!=(a=this[b]);b++)1===a.nodeType&&(n.cleanData(ob(a,!1)),a.textContent="");return this},clone:function(a,b){return a=null!=a&&a,b=null==b?a:b,this.map(function(){return n.clone(this,a,b)})},html:function(a){return J(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a&&1===b.nodeType)return b.innerHTML;if("string"==typeof a&&!db.test(a)&&!ib[(bb.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(ab,"<$1></$2>");try{for(;d>c;c++)b=this[c]||{},1===b.nodeType&&(n.cleanData(ob(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=arguments[0];return this.domManip(arguments,function(b){a=this.parentNode,n.cleanData(ob(this)),a&&a.replaceChild(b,this)}),a&&(a.length||a.nodeType)?this:this.remove()},detach:function(a){return this.remove(a,!0)},domManip:function(a,b){a=e.apply([],a);var c,d,f,g,h,i,j=0,l=this.length,m=this,o=l-1,p=a[0],q=n.isFunction(p);if(q||l>1&&"string"==typeof p&&!k.checkClone&&eb.test(p))return this.each(function(c){var d=m.eq(c);q&&(a[0]=p.call(this,c,d.html())),d.domManip(a,b)});if(l&&(c=n.buildFragment(a,this[0].ownerDocument,!1,this),d=c.firstChild,1===c.childNodes.length&&(c=d),d)){for(f=n.map(ob(c,"script"),kb),g=f.length;l>j;j++)h=c,j!==o&&(h=n.clone(h,!0,!0),g&&n.merge(f,ob(h,"script"))),b.call(this[j],h,j);if(g)for(i=f[f.length-1].ownerDocument,n.map(f,lb),j=0;g>j;j++)h=f[j],fb.test(h.type||"")&&!L.access(h,"globalEval")&&n.contains(i,h)&&(h.src?n._evalUrl&&n._evalUrl(h.src):n.globalEval(h.textContent.replace(/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,"")))}return this}}),n.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){n.fn[a]=function(a){for(var c,d=[],e=n(a),g=e.length-1,h=0;g>=h;h++)c=h===g?this:this.clone(!0),n(e[h])[b](c),f.apply(d,c.get());return this.pushStack(d)}});var qb,rb={},ub=/^margin/,vb=new RegExp("^("+Q+")(?!px)[a-z%]+$","i"),wb=function(a){return a.ownerDocument.defaultView.getComputedStyle(a,null)};!function(){function g(){f.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:block;margin-top:1%;top:1%;border:1px;padding:1px;width:4px;position:absolute",f.innerHTML="",d.appendChild(e);var g=a.getComputedStyle(f,null);b="1%"!==g.top,c="4px"===g.width,d.removeChild(e)}var b,c,d=l.documentElement,e=l.createElement("div"),f=l.createElement("div");f.style&&(f.style.backgroundClip="content-box",f.cloneNode(!0).style.backgroundClip="",k.clearCloneStyle="content-box"===f.style.backgroundClip,e.style.cssText="border:0;width:0;height:0;top:0;left:-9999px;margin-top:1px;position:absolute",e.appendChild(f),a.getComputedStyle&&n.extend(k,{pixelPosition:function(){return g(),b},boxSizingReliable:function(){return null==c&&g(),c},reliableMarginRight:function(){var b,c=f.appendChild(l.createElement("div"));return c.style.cssText=f.style.cssText="-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0",c.style.marginRight=c.style.width="0",f.style.width="1px",d.appendChild(e),b=!parseFloat(a.getComputedStyle(c,null).marginRight),d.removeChild(e),b}}))}(),n.swap=function(a,b,c,d){var e,f,g={};for(f in b)g[f]=a.style[f],a.style[f]=b[f];e=c.apply(a,d||[]);for(f in b)a.style[f]=g[f];return e};var zb=/^(none|table(?!-c[ea]).+)/,Ab=new RegExp("^("+Q+")(.*)$","i"),Bb=new RegExp("^([+-])=("+Q+")","i"),Cb={position:"absolute",visibility:"hidden",display:"block"},Db={letterSpacing:"0",fontWeight:"400"},Eb=["Webkit","O","Moz","ms"];n.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=xb(a,"opacity");return""===c?"1":c}}}},cssNumber:{columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{float:"cssFloat"},style:function(a,b,c,d){if(a&&3!==a.nodeType&&8!==a.nodeType&&a.style){var e,f,g,h=n.camelCase(b),i=a.style;return b=n.cssProps[h]||(n.cssProps[h]=Fb(i,h)),g=n.cssHooks[b]||n.cssHooks[h],void 0===c?g&&"get"in g&&void 0!==(e=g.get(a,!1,d))?e:i[b]:(f=typeof c,"string"===f&&(e=Bb.exec(c))&&(c=(e[1]+1)*e[2]+parseFloat(n.css(a,b)),f="number"),void(null!=c&&c===c&&("number"!==f||n.cssNumber[h]||(c+="px"),k.clearCloneStyle||""!==c||0!==b.indexOf("background")||(i[b]="inherit"),g&&"set"in g&&void 0===(c=g.set(a,c,d))||(i[b]=c))))}},css:function(a,b,c,d){var e,f,g,h=n.camelCase(b);return b=n.cssProps[h]||(n.cssProps[h]=Fb(a.style,h)),g=n.cssHooks[b]||n.cssHooks[h],g&&"get"in g&&(e=g.get(a,!0,c)),void 0===e&&(e=xb(a,b,d)),"normal"===e&&b in Db&&(e=Db[b]),""===c||c?(f=parseFloat(e),c===!0||n.isNumeric(f)?f||0:e):e}}),n.each(["height","width"],function(a,b){n.cssHooks[b]={get:function(a,c,d){return c?zb.test(n.css(a,"display"))&&0===a.offsetWidth?n.swap(a,Cb,function(){return Ib(a,b,d)}):Ib(a,b,d):void 0},set:function(a,c,d){var e=d&&wb(a);return Gb(a,c,d?Hb(a,b,d,"border-box"===n.css(a,"boxSizing",!1,e),e):0)}}}),n.cssHooks.marginRight=yb(k.reliableMarginRight,function(a,b){return b?n.swap(a,{display:"inline-block"},xb,[a,"marginRight"]):void 0}),n.each({margin:"",padding:"",border:"Width"},function(a,b){n.cssHooks[a+b]={expand:function(c){for(var d=0,e={},f="string"==typeof c?c.split(" "):[c];4>d;d++)e[a+R[d]+b]=f[d]||f[d-2]||f[0];return e}},ub.test(a)||(n.cssHooks[a+b].set=Gb)}),n.fn.extend({css:function(a,b){return J(this,function(a,b,c){var d,e,f={},g=0;if(n.isArray(b)){for(d=wb(a),e=b.length;e>g;g++)f[b[g]]=n.css(a,b[g],!1,d);return f}return void 0!==c?n.style(a,b,c):n.css(a,b)},a,b,arguments.length>1)},show:function(){return Jb(this,!0)},hide:function(){return Jb(this)},toggle:function(a){return"boolean"==typeof a?a?this.show():this.hide():this.each(function(){S(this)?n(this).show():n(this).hide()})}}),n.Tween=Kb,Kb.prototype={constructor:Kb,init:function(a,b,c,d,e,f){this.elem=a,this.prop=c,this.easing=e||"swing",this.options=b,this.start=this.now=this.cur(),this.end=d,this.unit=f||(n.cssNumber[c]?"":"px")},cur:function(){var a=Kb.propHooks[this.prop];return a&&a.get?a.get(this):Kb.propHooks._default.get(this)},run:function(a){var b,c=Kb.propHooks[this.prop];return this.pos=b=this.options.duration?n.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):a,this.now=(this.end-this.start)*b+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),c&&c.set?c.set(this):Kb.propHooks._default.set(this),this}},Kb.prototype.init.prototype=Kb.prototype,Kb.propHooks={_default:{get:function(a){var b;return null==a.elem[a.prop]||a.elem.style&&null!=a.elem.style[a.prop]?(b=n.css(a.elem,a.prop,""),b&&"auto"!==b?b:0):a.elem[a.prop]},set:function(a){n.fx.step[a.prop]?n.fx.step[a.prop](a):a.elem.style&&(null!=a.elem.style[n.cssProps[a.prop]]||n.cssHooks[a.prop])?n.style(a.elem,a.prop,a.now+a.unit):a.elem[a.prop]=a.now}}},Kb.propHooks.scrollTop=Kb.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},n.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2}},n.fx=Kb.prototype.init,n.fx.step={};var Lb,Mb,Nb=/^(?:toggle|show|hide)$/,Ob=new RegExp("^(?:([+-])=|)("+Q+")([a-z%]*)$","i"),Pb=/queueHooks$/,Qb=[Vb],Rb={"*":[function(a,b){var c=this.createTween(a,b),d=c.cur(),e=Ob.exec(b),f=e&&e[3]||(n.cssNumber[a]?"":"px"),g=(n.cssNumber[a]||"px"!==f&&+d)&&Ob.exec(n.css(c.elem,a)),h=1,i=20;if(g&&g[3]!==f){f=f||g[3],e=e||[],g=+d||1;do{h=h||".5",g/=h,n.style(c.elem,a,g+f)}while(h!==(h=c.cur()/d)&&1!==h&&--i)}return e&&(g=c.start=+g||+d||0,c.unit=f,c.end=e[1]?g+(e[1]+1)*e[2]:+e[2]),c}]};n.Animation=n.extend(Xb,{tweener:function(a,b){n.isFunction(a)?(b=a,a=["*"]):a=a.split(" ");for(var c,d=0,e=a.length;e>d;d++)c=a[d],Rb[c]=Rb[c]||[],Rb[c].unshift(b)},prefilter:function(a,b){b?Qb.unshift(a):Qb.push(a)}}),n.speed=function(a,b,c){var d=a&&"object"==typeof a?n.extend({},a):{complete:c||!c&&b||n.isFunction(a)&&a,duration:a,easing:c&&b||b&&!n.isFunction(b)&&b};return d.duration=n.fx.off?0:"number"==typeof d.duration?d.duration:d.duration in n.fx.speeds?n.fx.speeds[d.duration]:n.fx.speeds._default,(null==d.queue||d.queue===!0)&&(d.queue="fx"),d.old=d.complete,d.complete=function(){n.isFunction(d.old)&&d.old.call(this),d.queue&&n.dequeue(this,d.queue)},d},n.fn.extend({fadeTo:function(a,b,c,d){return this.filter(S).css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=n.isEmptyObject(a),f=n.speed(b,c,d),g=function(){var b=Xb(this,n.extend({},a),f);(e||L.get(this,"finish"))&&b.stop(!0)};return g.finish=g,e||f.queue===!1?this.each(g):this.queue(f.queue,g)},stop:function(a,b,c){var d=function(a){var b=a.stop;delete a.stop,b(c)};return"string"!=typeof a&&(c=b,b=a,a=void 0),b&&a!==!1&&this.queue(a||"fx",[]),this.each(function(){var b=!0,e=null!=a&&a+"queueHooks",f=n.timers,g=L.get(this);if(e)g[e]&&g[e].stop&&d(g[e]);else for(e in g)g[e]&&g[e].stop&&Pb.test(e)&&d(g[e]);for(e=f.length;e--;)f[e].elem!==this||null!=a&&f[e].queue!==a||(f[e].anim.stop(c),b=!1,f.splice(e,1));(b||!c)&&n.dequeue(this,a)})},finish:function(a){return a!==!1&&(a=a||"fx"),this.each(function(){var b,c=L.get(this),d=c[a+"queue"],e=c[a+"queueHooks"],f=n.timers,g=d?d.length:0;for(c.finish=!0,n.queue(this,a,[]),e&&e.stop&&e.stop.call(this,!0),b=f.length;b--;)f[b].elem===this&&f[b].queue===a&&(f[b].anim.stop(!0),f.splice(b,1));for(b=0;g>b;b++)d[b]&&d[b].finish&&d[b].finish.call(this);delete c.finish})}}), n.each(["toggle","show","hide"],function(a,b){var c=n.fn[b];n.fn[b]=function(a,d,e){return null==a||"boolean"==typeof a?c.apply(this,arguments):this.animate(Tb(b,!0),a,d,e)}}),n.each({slideDown:Tb("show"),slideUp:Tb("hide"),slideToggle:Tb("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){n.fn[a]=function(a,c,d){return this.animate(b,a,c,d)}}),n.timers=[],n.fx.tick=function(){var a,b=0,c=n.timers;for(Lb=n.now();b<c.length;b++)(a=c[b])()||c[b]!==a||c.splice(b--,1);c.length||n.fx.stop(),Lb=void 0},n.fx.timer=function(a){n.timers.push(a),a()?n.fx.start():n.timers.pop()},n.fx.interval=13,n.fx.start=function(){Mb||(Mb=setInterval(n.fx.tick,n.fx.interval))},n.fx.stop=function(){clearInterval(Mb),Mb=null},n.fx.speeds={slow:600,fast:200,_default:400},n.fn.delay=function(a,b){return a=n.fx?n.fx.speeds[a]||a:a,b=b||"fx",this.queue(b,function(b,c){var d=setTimeout(b,a);c.stop=function(){clearTimeout(d)}})},function(){var a=l.createElement("input"),b=l.createElement("select"),c=b.appendChild(l.createElement("option"));a.type="checkbox",k.checkOn=""!==a.value,k.optSelected=c.selected,b.disabled=!0,k.optDisabled=!c.disabled,a=l.createElement("input"),a.value="t",a.type="radio",k.radioValue="t"===a.value}();var Zb,$b=n.expr.attrHandle;n.fn.extend({attr:function(a,b){return J(this,n.attr,a,b,arguments.length>1)},removeAttr:function(a){return this.each(function(){n.removeAttr(this,a)})}}),n.extend({attr:function(a,b,c){var d,e,f=a.nodeType;if(a&&3!==f&&8!==f&&2!==f)return typeof a.getAttribute===U?n.prop(a,b,c):(1===f&&n.isXMLDoc(a)||(b=b.toLowerCase(),d=n.attrHooks[b]||(n.expr.match.bool.test(b)?Zb:void 0)),void 0===c?d&&"get"in d&&null!==(e=d.get(a,b))?e:(e=n.find.attr(a,b),null==e?void 0:e):null!==c?d&&"set"in d&&void 0!==(e=d.set(a,c,b))?e:(a.setAttribute(b,c+""),c):void n.removeAttr(a,b))},removeAttr:function(a,b){var c,d,e=0,f=b&&b.match(E);if(f&&1===a.nodeType)for(;c=f[e++];)d=n.propFix[c]||c,n.expr.match.bool.test(c)&&(a[d]=!1),a.removeAttribute(c)},attrHooks:{type:{set:function(a,b){if(!k.radioValue&&"radio"===b&&n.nodeName(a,"input")){var c=a.value;return a.setAttribute("type",b),c&&(a.value=c),b}}}}}),Zb={set:function(a,b,c){return b===!1?n.removeAttr(a,c):a.setAttribute(c,c),c}},n.each(n.expr.match.bool.source.match(/\w+/g),function(a,b){var c=$b[b]||n.find.attr;$b[b]=function(a,b,d){var e,f;return d||(f=$b[b],$b[b]=e,e=null!=c(a,b,d)?b.toLowerCase():null,$b[b]=f),e}});var _b=/^(?:input|select|textarea|button)$/i;n.fn.extend({prop:function(a,b){return J(this,n.prop,a,b,arguments.length>1)},removeProp:function(a){return this.each(function(){delete this[n.propFix[a]||a]})}}),n.extend({propFix:{for:"htmlFor",class:"className"},prop:function(a,b,c){var d,e,f,g=a.nodeType;if(a&&3!==g&&8!==g&&2!==g)return f=1!==g||!n.isXMLDoc(a),f&&(b=n.propFix[b]||b,e=n.propHooks[b]),void 0!==c?e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:a[b]=c:e&&"get"in e&&null!==(d=e.get(a,b))?d:a[b]},propHooks:{tabIndex:{get:function(a){return a.hasAttribute("tabindex")||_b.test(a.nodeName)||a.href?a.tabIndex:-1}}}}),k.optSelected||(n.propHooks.selected={get:function(a){var b=a.parentNode;return b&&b.parentNode&&b.parentNode.selectedIndex,null}}),n.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){n.propFix[this.toLowerCase()]=this});var ac=/[\t\r\n\f]/g;n.fn.extend({addClass:function(a){var b,c,d,e,f,g,h="string"==typeof a&&a,i=0,j=this.length;if(n.isFunction(a))return this.each(function(b){n(this).addClass(a.call(this,b,this.className))});if(h)for(b=(a||"").match(E)||[];j>i;i++)if(c=this[i],d=1===c.nodeType&&(c.className?(" "+c.className+" ").replace(ac," "):" ")){for(f=0;e=b[f++];)d.indexOf(" "+e+" ")<0&&(d+=e+" ");g=n.trim(d),c.className!==g&&(c.className=g)}return this},removeClass:function(a){var b,c,d,e,f,g,h=0===arguments.length||"string"==typeof a&&a,i=0,j=this.length;if(n.isFunction(a))return this.each(function(b){n(this).removeClass(a.call(this,b,this.className))});if(h)for(b=(a||"").match(E)||[];j>i;i++)if(c=this[i],d=1===c.nodeType&&(c.className?(" "+c.className+" ").replace(ac," "):"")){for(f=0;e=b[f++];)for(;d.indexOf(" "+e+" ")>=0;)d=d.replace(" "+e+" "," ");g=a?n.trim(d):"",c.className!==g&&(c.className=g)}return this},toggleClass:function(a,b){var c=typeof a;return"boolean"==typeof b&&"string"===c?b?this.addClass(a):this.removeClass(a):this.each(n.isFunction(a)?function(c){n(this).toggleClass(a.call(this,c,this.className,b),b)}:function(){if("string"===c)for(var b,d=0,e=n(this),f=a.match(E)||[];b=f[d++];)e.hasClass(b)?e.removeClass(b):e.addClass(b);else(c===U||"boolean"===c)&&(this.className&&L.set(this,"__className__",this.className),this.className=this.className||a===!1?"":L.get(this,"__className__")||"")})},hasClass:function(a){for(var b=" "+a+" ",c=0,d=this.length;d>c;c++)if(1===this[c].nodeType&&(" "+this[c].className+" ").replace(ac," ").indexOf(b)>=0)return!0;return!1}});n.fn.extend({val:function(a){var b,c,d,e=this[0];return arguments.length?(d=n.isFunction(a),this.each(function(c){var e;1===this.nodeType&&(e=d?a.call(this,c,n(this).val()):a,null==e?e="":"number"==typeof e?e+="":n.isArray(e)&&(e=n.map(e,function(a){return null==a?"":a+""})),(b=n.valHooks[this.type]||n.valHooks[this.nodeName.toLowerCase()])&&"set"in b&&void 0!==b.set(this,e,"value")||(this.value=e))})):e?(b=n.valHooks[e.type]||n.valHooks[e.nodeName.toLowerCase()],b&&"get"in b&&void 0!==(c=b.get(e,"value"))?c:(c=e.value,"string"==typeof c?c.replace(/\r/g,""):null==c?"":c)):void 0}}),n.extend({valHooks:{option:{get:function(a){var b=n.find.attr(a,"value");return null!=b?b:n.trim(n.text(a))}},select:{get:function(a){for(var b,c,d=a.options,e=a.selectedIndex,f="select-one"===a.type||0>e,g=f?null:[],h=f?e+1:d.length,i=0>e?h:f?e:0;h>i;i++)if(c=d[i],!(!c.selected&&i!==e||(k.optDisabled?c.disabled:null!==c.getAttribute("disabled"))||c.parentNode.disabled&&n.nodeName(c.parentNode,"optgroup"))){if(b=n(c).val(),f)return b;g.push(b)}return g},set:function(a,b){for(var c,d,e=a.options,f=n.makeArray(b),g=e.length;g--;)d=e[g],(d.selected=n.inArray(d.value,f)>=0)&&(c=!0);return c||(a.selectedIndex=-1),f}}}}),n.each(["radio","checkbox"],function(){n.valHooks[this]={set:function(a,b){return n.isArray(b)?a.checked=n.inArray(n(a).val(),b)>=0:void 0}},k.checkOn||(n.valHooks[this].get=function(a){return null===a.getAttribute("value")?"on":a.value})}),n.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),function(a,b){n.fn[b]=function(a,c){return arguments.length>0?this.on(b,null,a,c):this.trigger(b)}}),n.fn.extend({hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)},bind:function(a,b,c){return this.on(a,null,b,c)},unbind:function(a,b){return this.off(a,null,b)},delegate:function(a,b,c,d){return this.on(b,a,c,d)},undelegate:function(a,b,c){return 1===arguments.length?this.off(a,"**"):this.off(b,a||"**",c)}});var cc=n.now(),dc=/\?/;n.parseJSON=function(a){return JSON.parse(a+"")},n.parseXML=function(a){var b,c;if(!a||"string"!=typeof a)return null;try{c=new DOMParser,b=c.parseFromString(a,"text/xml")}catch(d){b=void 0}return(!b||b.getElementsByTagName("parsererror").length)&&n.error("Invalid XML: "+a),b};var ec,fc,hc=/([?&])_=[^&]*/,ic=/^(.*?):[ \t]*([^\r\n]*)$/gm,jc=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,kc=/^(?:GET|HEAD)$/,mc=/^([\w.+-]+:)(?:\/\/(?:[^\/?#]*@|)([^\/?#:]*)(?::(\d+)|)|)/,nc={},oc={},pc="*/".concat("*");try{fc=location.href}catch(qc){fc=l.createElement("a"),fc.href="",fc=fc.href}ec=mc.exec(fc.toLowerCase())||[],n.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:fc,type:"GET",isLocal:jc.test(ec[1]),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":pc,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":n.parseJSON,"text xml":n.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(a,b){return b?tc(tc(a,n.ajaxSettings),b):tc(n.ajaxSettings,a)},ajaxPrefilter:rc(nc),ajaxTransport:rc(oc),ajax:function(a,b){function x(a,b,f,h){var j,r,s,u,w,x=b;2!==t&&(t=2,g&&clearTimeout(g),c=void 0,e=h||"",v.readyState=a>0?4:0,j=a>=200&&300>a||304===a,f&&(u=uc(k,v,f)),u=vc(k,u,v,j),j?(k.ifModified&&(w=v.getResponseHeader("Last-Modified"),w&&(n.lastModified[d]=w),(w=v.getResponseHeader("etag"))&&(n.etag[d]=w)),204===a||"HEAD"===k.type?x="nocontent":304===a?x="notmodified":(x=u.loadingState,r=u.data,s=u.error,j=!s)):(s=x,(a||!x)&&(x="error",0>a&&(a=0))),v.status=a,v.statusText=(b||x)+"",j?o.resolveWith(l,[r,x,v]):o.rejectWith(l,[v,x,s]),v.statusCode(q),q=void 0,i&&m.trigger(j?"ajaxSuccess":"ajaxError",[v,k,j?r:s]),p.fireWith(l,[v,x]),i&&(m.trigger("ajaxComplete",[v,k]),--n.active||n.event.trigger("ajaxStop")))}"object"==typeof a&&(b=a,a=void 0),b=b||{};var c,d,e,f,g,h,i,j,k=n.ajaxSetup({},b),l=k.context||k,m=k.context&&(l.nodeType||l.jquery)?n(l):n.event,o=n.Deferred(),p=n.Callbacks("once memory"),q=k.statusCode||{},r={},s={},t=0,u="canceled",v={readyState:0,getResponseHeader:function(a){var b;if(2===t){if(!f)for(f={};b=ic.exec(e);)f[b[1].toLowerCase()]=b[2];b=f[a.toLowerCase()]}return null==b?null:b},getAllResponseHeaders:function(){return 2===t?e:null},setRequestHeader:function(a,b){var c=a.toLowerCase();return t||(a=s[c]=s[c]||a,r[a]=b),this},overrideMimeType:function(a){return t||(k.mimeType=a),this},statusCode:function(a){var b;if(a)if(2>t)for(b in a)q[b]=[q[b],a[b]];else v.always(a[v.status]);return this},abort:function(a){var b=a||u;return c&&c.abort(b),x(0,b),this}};if(o.promise(v).complete=p.add,v.success=v.done,v.error=v.fail,k.url=((a||k.url||fc)+"").replace(/#.*$/,"").replace(/^\/\//,ec[1]+"//"),k.type=b.method||b.type||k.method||k.type,k.dataTypes=n.trim(k.dataType||"*").toLowerCase().match(E)||[""],null==k.crossDomain&&(h=mc.exec(k.url.toLowerCase()),k.crossDomain=!(!h||h[1]===ec[1]&&h[2]===ec[2]&&(h[3]||("http:"===h[1]?"80":"443"))===(ec[3]||("http:"===ec[1]?"80":"443")))),k.data&&k.processData&&"string"!=typeof k.data&&(k.data=n.param(k.data,k.traditional)),sc(nc,k,b,v),2===t)return v;i=k.global,i&&0==n.active++&&n.event.trigger("ajaxStart"),k.type=k.type.toUpperCase(),k.hasContent=!kc.test(k.type),d=k.url,k.hasContent||(k.data&&(d=k.url+=(dc.test(d)?"&":"?")+k.data,delete k.data),k.cache===!1&&(k.url=hc.test(d)?d.replace(hc,"$1_="+cc++):d+(dc.test(d)?"&":"?")+"_="+cc++)),k.ifModified&&(n.lastModified[d]&&v.setRequestHeader("If-Modified-Since",n.lastModified[d]),n.etag[d]&&v.setRequestHeader("If-None-Match",n.etag[d])),(k.data&&k.hasContent&&k.contentType!==!1||b.contentType)&&v.setRequestHeader("Content-Type",k.contentType),v.setRequestHeader("Accept",k.dataTypes[0]&&k.accepts[k.dataTypes[0]]?k.accepts[k.dataTypes[0]]+("*"!==k.dataTypes[0]?", "+pc+"; q=0.01":""):k.accepts["*"]);for(j in k.headers)v.setRequestHeader(j,k.headers[j]);if(k.beforeSend&&(k.beforeSend.call(l,v,k)===!1||2===t))return v.abort();u="abort";for(j in{success:1,error:1,complete:1})v[j](k[j]);if(c=sc(oc,k,b,v)){v.readyState=1,i&&m.trigger("ajaxSend",[v,k]),k.async&&k.timeout>0&&(g=setTimeout(function(){v.abort("timeout")},k.timeout));try{t=1,c.send(r,x)}catch(w){if(!(2>t))throw w;x(-1,w)}}else x(-1,"No Transport");return v},getJSON:function(a,b,c){return n.get(a,b,c,"json")},getScript:function(a,b){return n.get(a,void 0,b,"script")}}),n.each(["get","post"],function(a,b){n[b]=function(a,c,d,e){return n.isFunction(c)&&(e=e||d,d=c,c=void 0),n.ajax({url:a,type:b,dataType:e,data:c,success:d})}}),n.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(a,b){n.fn[b]=function(a){return this.on(b,a)}}),n._evalUrl=function(a){return n.ajax({url:a,type:"GET",dataType:"script",async:!1,global:!1,throws:!0})},n.fn.extend({wrapAll:function(a){var b;return n.isFunction(a)?this.each(function(b){n(this).wrapAll(a.call(this,b))}):(this[0]&&(b=n(a,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){for(var a=this;a.firstElementChild;)a=a.firstElementChild;return a}).append(this)),this)},wrapInner:function(a){return this.each(n.isFunction(a)?function(b){n(this).wrapInner(a.call(this,b))}:function(){var b=n(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=n.isFunction(a);return this.each(function(c){n(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(){return this.parent().each(function(){n.nodeName(this,"body")||n(this).replaceWith(this.childNodes)}).end()}}),n.expr.filters.hidden=function(a){return a.offsetWidth<=0&&a.offsetHeight<=0},n.expr.filters.visible=function(a){return!n.expr.filters.hidden(a)};var xc=/\[\]$/,zc=/^(?:submit|button|image|reset|file)$/i,Ac=/^(?:input|select|textarea|keygen)/i;n.param=function(a,b){var c,d=[],e=function(a,b){b=n.isFunction(b)?b():null==b?"":b,d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};if(void 0===b&&(b=n.ajaxSettings&&n.ajaxSettings.traditional),n.isArray(a)||a.jquery&&!n.isPlainObject(a))n.each(a,function(){e(this.name,this.value)});else for(c in a)Bc(c,a[c],b,e);return d.join("&").replace(/%20/g,"+")},n.fn.extend({serialize:function(){return n.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var a=n.prop(this,"elements");return a?n.makeArray(a):this}).filter(function(){var a=this.type;return this.name&&!n(this).is(":disabled")&&Ac.test(this.nodeName)&&!zc.test(a)&&(this.checked||!T.test(a))}).map(function(a,b){var c=n(this).val();return null==c?null:n.isArray(c)?n.map(c,function(a){return{name:b.name,value:a.replace(/\r?\n/g,"\r\n")}}):{name:b.name,value:c.replace(/\r?\n/g,"\r\n")}}).get()}}),n.ajaxSettings.xhr=function(){try{return new XMLHttpRequest}catch(a){}};var Cc=0,Dc={},Ec={0:200,1223:204},Fc=n.ajaxSettings.xhr();a.ActiveXObject&&n(a).on("unload",function(){for(var a in Dc)Dc[a]()}),k.cors=!!Fc&&"withCredentials"in Fc,k.ajax=Fc=!!Fc,n.ajaxTransport(function(a){var b;return k.cors||Fc&&!a.crossDomain?{send:function(c,d){var e,f=a.xhr(),g=++Cc;if(f.open(a.type,a.url,a.async,a.username,a.password),a.xhrFields)for(e in a.xhrFields)f[e]=a.xhrFields[e];a.mimeType&&f.overrideMimeType&&f.overrideMimeType(a.mimeType),a.crossDomain||c["X-Requested-With"]||(c["X-Requested-With"]="XMLHttpRequest");for(e in c)f.setRequestHeader(e,c[e]);b=function(a){return function(){b&&(delete Dc[g],b=f.onload=f.onerror=null,"abort"===a?f.abort():"error"===a?d(f.status,f.statusText):d(Ec[f.status]||f.status,f.statusText,"string"==typeof f.responseText?{text:f.responseText}:void 0,f.getAllResponseHeaders()))}},f.onload=b(),f.onerror=b("error"),b=Dc[g]=b("abort");try{f.send(a.hasContent&&a.data||null)}catch(h){if(b)throw h}},abort:function(){b&&b()}}:void 0}),n.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/(?:java|ecma)script/},converters:{"text script":function(a){return n.globalEval(a),a}}}),n.ajaxPrefilter("script",function(a){void 0===a.cache&&(a.cache=!1),a.crossDomain&&(a.type="GET")}),n.ajaxTransport("script",function(a){if(a.crossDomain){var b,c;return{send:function(d,e){b=n("<script>").prop({async:!0,charset:a.scriptCharset,src:a.url}).on("load error",c=function(a){b.remove(),c=null,a&&e("error"===a.type?404:200,a.type)}),l.head.appendChild(b[0])},abort:function(){c&&c()}}}});var Gc=[],Hc=/(=)\?(?=&|$)|\?\?/;n.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var a=Gc.pop()||n.expando+"_"+cc++;return this[a]=!0,a}}),n.ajaxPrefilter("json jsonp",function(b,c,d){var e,f,g,h=b.jsonp!==!1&&(Hc.test(b.url)?"url":"string"==typeof b.data&&!(b.contentType||"").indexOf("application/x-www-form-urlencoded")&&Hc.test(b.data)&&"data");return h||"jsonp"===b.dataTypes[0]?(e=b.jsonpCallback=n.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,h?b[h]=b[h].replace(Hc,"$1"+e):b.jsonp!==!1&&(b.url+=(dc.test(b.url)?"&":"?")+b.jsonp+"="+e),b.converters["script json"]=function(){return g||n.error(e+" was not called"),g[0]},b.dataTypes[0]="json",f=a[e],a[e]=function(){g=arguments},d.always(function(){a[e]=f,b[e]&&(b.jsonpCallback=c.jsonpCallback,Gc.push(e)),g&&n.isFunction(f)&&f(g[0]),g=f=void 0}),"script"):void 0}),n.parseHTML=function(a,b,c){if(!a||"string"!=typeof a)return null;"boolean"==typeof b&&(c=b,b=!1),b=b||l;var d=v.exec(a),e=!c&&[];return d?[b.createElement(d[1])]:(d=n.buildFragment([a],b,e),e&&e.length&&n(e).remove(),n.merge([],d.childNodes))};var Ic=n.fn.load;n.fn.load=function(a,b,c){if("string"!=typeof a&&Ic)return Ic.apply(this,arguments);var d,e,f,g=this,h=a.indexOf(" ");return h>=0&&(d=n.trim(a.slice(h)),a=a.slice(0,h)),n.isFunction(b)?(c=b,b=void 0):b&&"object"==typeof b&&(e="POST"),g.length>0&&n.ajax({url:a,type:e,dataType:"html",data:b}).done(function(a){f=arguments,g.html(d?n("<div>").append(n.parseHTML(a)).find(d):a)}).complete(c&&function(a,b){g.each(c,f||[a.responseText,b,a])}),this},n.expr.filters.animated=function(a){return n.grep(n.timers,function(b){return a===b.elem}).length};var Jc=a.document.documentElement;n.offset={setOffset:function(a,b,c){var d,e,f,g,h,i,j,k=n.css(a,"position"),l=n(a),m={};"static"===k&&(a.style.position="relative"),h=l.offset(),f=n.css(a,"top"),i=n.css(a,"left"),j=("absolute"===k||"fixed"===k)&&(f+i).indexOf("auto")>-1,j?(d=l.position(),g=d.top,e=d.left):(g=parseFloat(f)||0,e=parseFloat(i)||0),n.isFunction(b)&&(b=b.call(a,c,h)),null!=b.top&&(m.top=b.top-h.top+g),null!=b.left&&(m.left=b.left-h.left+e),"using"in b?b.using.call(a,m):l.css(m)}},n.fn.extend({offset:function(a){if(arguments.length)return void 0===a?this:this.each(function(b){n.offset.setOffset(this,a,b)});var b,c,d=this[0],e={top:0,left:0},f=d&&d.ownerDocument;return f?(b=f.documentElement,n.contains(b,d)?(typeof d.getBoundingClientRect!==U&&(e=d.getBoundingClientRect()),c=Kc(f),{top:e.top+c.pageYOffset-b.clientTop,left:e.left+c.pageXOffset-b.clientLeft}):e):void 0},position:function(){if(this[0]){var a,b,c=this[0],d={top:0,left:0};return"fixed"===n.css(c,"position")?b=c.getBoundingClientRect():(a=this.offsetParent(),b=this.offset(),n.nodeName(a[0],"html")||(d=a.offset()),d.top+=n.css(a[0],"borderTopWidth",!0),d.left+=n.css(a[0],"borderLeftWidth",!0)),{top:b.top-d.top-n.css(c,"marginTop",!0),left:b.left-d.left-n.css(c,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){for(var a=this.offsetParent||Jc;a&&!n.nodeName(a,"html")&&"static"===n.css(a,"position");)a=a.offsetParent;return a||Jc})}}),n.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(b,c){var d="pageYOffset"===c;n.fn[b]=function(e){return J(this,function(b,e,f){var g=Kc(b);return void 0===f?g?g[c]:b[e]:void(g?g.scrollTo(d?a.pageXOffset:f,d?f:a.pageYOffset):b[e]=f)},b,e,arguments.length,null)}}),n.each(["top","left"],function(a,b){n.cssHooks[b]=yb(k.pixelPosition,function(a,c){return c?(c=xb(a,b),vb.test(c)?n(a).position()[b]+"px":c):void 0})}),n.each({Height:"height",Width:"width"},function(a,b){n.each({padding:"inner"+a,content:b,"":"outer"+a},function(c,d){n.fn[d]=function(d,e){var f=arguments.length&&(c||"boolean"!=typeof d),g=c||(d===!0||e===!0?"margin":"border");return J(this,function(b,c,d){var e;return n.isWindow(b)?b.document.documentElement["client"+a]:9===b.nodeType?(e=b.documentElement,Math.max(b.body["scroll"+a],e["scroll"+a],b.body["offset"+a],e["offset"+a],e["client"+a])):void 0===d?n.css(b,c,g):n.style(b,c,d,g)},b,f?d:void 0,f,null)}})}),n.fn.size=function(){return this.length},n.fn.andSelf=n.fn.addBack,"function"==typeof define&&define.amd&&define("jquery",[],function(){return n});var Lc=a.jQuery,Mc=a.$;return n.noConflict=function(b){return a.$===n&&(a.$=Mc),b&&a.jQuery===n&&(a.jQuery=Lc),n},typeof b===U&&(a.jQuery=a.$=n),n}),function(){var n=this,t=n._,r={},e=Array.prototype,u=Object.prototype,i=Function.prototype,a=e.push,o=e.slice,c=e.concat,l=u.toString,f=u.hasOwnProperty,s=e.forEach,p=e.map,h=e.reduce,v=e.reduceRight,g=e.filter,d=e.every,m=e.some,y=e.indexOf,b=e.lastIndexOf,x=Array.isArray,w=Object.keys,_=i.bind,j=function(n){return n instanceof j?n:this instanceof j?void(this._wrapped=n):new j(n)};"undefined"!=typeof exports?("undefined"!=typeof module&&module.exports&&(exports=module.exports=j),exports._=j):n._=j,j.VERSION="1.6.0";var A=j.each=j.forEach=function(n,t,e){if(null==n)return n;if(s&&n.forEach===s)n.forEach(t,e);else if(n.length===+n.length){for(var u=0,i=n.length;i>u;u++)if(t.call(e,n[u],u,n)===r)return}else for(var a=j.keys(n),u=0,i=a.length;i>u;u++)if(t.call(e,n[a[u]],a[u],n)===r)return;return n};j.map=j.collect=function(n,t,r){var e=[];return null==n?e:p&&n.map===p?n.map(t,r):(A(n,function(n,u,i){e.push(t.call(r,n,u,i))}),e)};var O="Reduce of empty array with no initial value";j.reduce=j.foldl=j.inject=function(n,t,r,e){var u=arguments.length>2;if(null==n&&(n=[]),h&&n.reduce===h)return e&&(t=j.bind(t,e)),u?n.reduce(t,r):n.reduce(t);if(A(n,function(n,i,a){u?r=t.call(e,r,n,i,a):(r=n,u=!0)}),!u)throw new TypeError(O);return r},j.reduceRight=j.foldr=function(n,t,r,e){var u=arguments.length>2;if(null==n&&(n=[]),v&&n.reduceRight===v)return e&&(t=j.bind(t,e)),u?n.reduceRight(t,r):n.reduceRight(t);var i=n.length;if(i!==+i){var a=j.keys(n);i=a.length}if(A(n,function(o,c,l){c=a?a[--i]:--i,u?r=t.call(e,r,n[c],c,l):(r=n[c],u=!0)}),!u)throw new TypeError(O);return r},j.find=j.detect=function(n,t,r){var e;return k(n,function(n,u,i){return t.call(r,n,u,i)?(e=n,!0):void 0}),e},j.filter=j.select=function(n,t,r){var e=[];return null==n?e:g&&n.filter===g?n.filter(t,r):(A(n,function(n,u,i){t.call(r,n,u,i)&&e.push(n)}),e)},j.reject=function(n,t,r){return j.filter(n,function(n,e,u){return!t.call(r,n,e,u)},r)},j.every=j.all=function(n,t,e){t||(t=j.identity);var u=!0;return null==n?u:d&&n.every===d?n.every(t,e):(A(n,function(n,i,a){return(u=u&&t.call(e,n,i,a))?void 0:r}),!!u)};var k=j.some=j.any=function(n,t,e){t||(t=j.identity);var u=!1;return null==n?u:m&&n.some===m?n.some(t,e):(A(n,function(n,i,a){return u||(u=t.call(e,n,i,a))?r:void 0}),!!u)};j.contains=j.include=function(n,t){return null!=n&&(y&&n.indexOf===y?n.indexOf(t)!=-1:k(n,function(n){return n===t}))},j.invoke=function(n,t){var r=o.call(arguments,2),e=j.isFunction(t);return j.map(n,function(n){return(e?t:n[t]).apply(n,r)})},j.pluck=function(n,t){return j.map(n,j.property(t))},j.where=function(n,t){return j.filter(n,j.matches(t))},j.findWhere=function(n,t){return j.find(n,j.matches(t))},j.max=function(n,t,r){if(!t&&j.isArray(n)&&n[0]===+n[0]&&n.length<65535)return Math.max.apply(Math,n);var e=-1/0,u=-1/0;return A(n,function(n,i,a){var o=t?t.call(r,n,i,a):n;o>u&&(e=n,u=o)}),e},j.min=function(n,t,r){if(!t&&j.isArray(n)&&n[0]===+n[0]&&n.length<65535)return Math.min.apply(Math,n);var e=1/0,u=1/0;return A(n,function(n,i,a){var o=t?t.call(r,n,i,a):n;u>o&&(e=n,u=o)}),e},j.shuffle=function(n){var t,r=0,e=[];return A(n,function(n){t=j.random(r++),e[r-1]=e[t],e[t]=n}),e},j.sample=function(n,t,r){return null==t||r?(n.length!==+n.length&&(n=j.values(n)),n[j.random(n.length-1)]):j.shuffle(n).slice(0,Math.max(0,t))};var E=function(n){return null==n?j.identity:j.isFunction(n)?n:j.property(n)};j.sortBy=function(n,t,r){return t=E(t),j.pluck(j.map(n,function(n,e,u){return{value:n,index:e,criteria:t.call(r,n,e,u)}}).sort(function(n,t){var r=n.criteria,e=t.criteria;if(r!==e){if(r>e||void 0===r)return 1;if(e>r||void 0===e)return-1}return n.index-t.index}),"value")};var F=function(n){return function(t,r,e){var u={};return r=E(r),A(t,function(i,a){n(u,r.call(e,i,a,t),i)}),u}};j.groupBy=F(function(n,t,r){j.has(n,t)?n[t].push(r):n[t]=[r]}),j.indexBy=F(function(n,t,r){n[t]=r}),j.countBy=F(function(n,t){j.has(n,t)?n[t]++:n[t]=1}),j.sortedIndex=function(n,t,r,e){r=E(r);for(var u=r.call(e,t),i=0,a=n.length;a>i;){var o=i+a>>>1;r.call(e,n[o])<u?i=o+1:a=o}return i},j.toArray=function(n){return n?j.isArray(n)?o.call(n):n.length===+n.length?j.map(n,j.identity):j.values(n):[]},j.size=function(n){return null==n?0:n.length===+n.length?n.length:j.keys(n).length},j.first=j.head=j.take=function(n,t,r){return null==n?void 0:null==t||r?n[0]:0>t?[]:o.call(n,0,t)},j.initial=function(n,t,r){return o.call(n,0,n.length-(null==t||r?1:t))},j.last=function(n,t,r){return null==n?void 0:null==t||r?n[n.length-1]:o.call(n,Math.max(n.length-t,0))},j.rest=j.tail=j.drop=function(n,t,r){return o.call(n,null==t||r?1:t)},j.compact=function(n){return j.filter(n,j.identity)};var M=function(n,t,r){return t&&j.every(n,j.isArray)?c.apply(r,n):(A(n,function(n){j.isArray(n)||j.isArguments(n)?t?a.apply(r,n):M(n,t,r):r.push(n)}),r)};j.flatten=function(n,t){return M(n,t,[])},j.without=function(n){return j.difference(n,o.call(arguments,1))},j.partition=function(n,t){var r=[],e=[];return A(n,function(n){(t(n)?r:e).push(n)}),[r,e]},j.uniq=j.unique=function(n,t,r,e){j.isFunction(t)&&(e=r,r=t,t=!1);var u=r?j.map(n,r,e):n,i=[],a=[];return A(u,function(r,e){(t?e&&a[a.length-1]===r:j.contains(a,r))||(a.push(r),i.push(n[e]))}),i},j.union=function(){return j.uniq(j.flatten(arguments,!0))},j.intersection=function(n){var t=o.call(arguments,1);return j.filter(j.uniq(n),function(n){return j.every(t,function(t){return j.contains(t,n)})})},j.difference=function(n){var t=c.apply(e,o.call(arguments,1));return j.filter(n,function(n){return!j.contains(t,n)})},j.zip=function(){for(var n=j.max(j.pluck(arguments,"length").concat(0)),t=new Array(n),r=0;n>r;r++)t[r]=j.pluck(arguments,""+r);return t},j.object=function(n,t){if(null==n)return{};for(var r={},e=0,u=n.length;u>e;e++)t?r[n[e]]=t[e]:r[n[e][0]]=n[e][1];return r},j.indexOf=function(n,t,r){if(null==n)return-1;var e=0,u=n.length;if(r){if("number"!=typeof r)return e=j.sortedIndex(n,t),n[e]===t?e:-1;e=0>r?Math.max(0,u+r):r}if(y&&n.indexOf===y)return n.indexOf(t,r);for(;u>e;e++)if(n[e]===t)return e;return-1},j.lastIndexOf=function(n,t,r){if(null==n)return-1;var e=null!=r;if(b&&n.lastIndexOf===b)return e?n.lastIndexOf(t,r):n.lastIndexOf(t);for(var u=e?r:n.length;u--;)if(n[u]===t)return u;return-1},j.range=function(n,t,r){arguments.length<=1&&(t=n||0,n=0),r=arguments[2]||1;for(var e=Math.max(Math.ceil((t-n)/r),0),u=0,i=new Array(e);e>u;)i[u++]=n,n+=r;return i};var R=function(){};j.bind=function(n,t){var r,e;if(_&&n.bind===_)return _.apply(n,o.call(arguments,1));if(!j.isFunction(n))throw new TypeError;return r=o.call(arguments,2),e=function(){if(!(this instanceof e))return n.apply(t,r.concat(o.call(arguments)));R.prototype=n.prototype;var u=new R;R.prototype=null;var i=n.apply(u,r.concat(o.call(arguments)));return Object(i)===i?i:u}},j.partial=function(n){var t=o.call(arguments,1);return function(){for(var r=0,e=t.slice(),u=0,i=e.length;i>u;u++)e[u]===j&&(e[u]=arguments[r++]);for(;r<arguments.length;)e.push(arguments[r++]);return n.apply(this,e)}},j.bindAll=function(n){var t=o.call(arguments,1);if(0===t.length)throw new Error("bindAll must be passed function names");return A(t,function(t){n[t]=j.bind(n[t],n)}),n},j.memoize=function(n,t){var r={};return t||(t=j.identity),function(){var e=t.apply(this,arguments);return j.has(r,e)?r[e]:r[e]=n.apply(this,arguments)}},j.delay=function(n,t){var r=o.call(arguments,2);return setTimeout(function(){return n.apply(null,r)},t)},j.defer=function(n){return j.delay.apply(j,[n,1].concat(o.call(arguments,1)))},j.throttle=function(n,t,r){var e,u,i,a=null,o=0;r||(r={});var c=function(){o=r.leading===!1?0:j.now(),a=null,i=n.apply(e,u),e=u=null};return function(){var l=j.now();o||r.leading!==!1||(o=l);var f=t-(l-o);return e=this,u=arguments,0>=f?(clearTimeout(a),a=null,o=l,i=n.apply(e,u),e=u=null):a||r.trailing===!1||(a=setTimeout(c,f)),i}},j.debounce=function(n,t,r){var e,u,i,a,o,c=function(){var l=j.now()-a;t>l?e=setTimeout(c,t-l):(e=null,r||(o=n.apply(i,u),i=u=null))};return function(){i=this,u=arguments,a=j.now();var l=r&&!e;return e||(e=setTimeout(c,t)),l&&(o=n.apply(i,u),i=u=null),o}},j.once=function(n){var t,r=!1;return function(){return r?t:(r=!0,t=n.apply(this,arguments),n=null,t)}},j.wrap=function(n,t){return j.partial(t,n)},j.compose=function(){var n=arguments;return function(){for(var t=arguments,r=n.length-1;r>=0;r--)t=[n[r].apply(this,t)];return t[0]}},j.after=function(n,t){return function(){return--n<1?t.apply(this,arguments):void 0}},j.keys=function(n){if(!j.isObject(n))return[];if(w)return w(n);var t=[];for(var r in n)j.has(n,r)&&t.push(r);return t},j.values=function(n){for(var t=j.keys(n),r=t.length,e=new Array(r),u=0;r>u;u++)e[u]=n[t[u]];return e},j.pairs=function(n){for(var t=j.keys(n),r=t.length,e=new Array(r),u=0;r>u;u++)e[u]=[t[u],n[t[u]]];return e},j.invert=function(n){for(var t={},r=j.keys(n),e=0,u=r.length;u>e;e++)t[n[r[e]]]=r[e];return t},j.functions=j.methods=function(n){var t=[];for(var r in n)j.isFunction(n[r])&&t.push(r);return t.sort()},j.extend=function(n){return A(o.call(arguments,1),function(t){if(t)for(var r in t)n[r]=t[r]}),n},j.pick=function(n){var t={};return A(c.apply(e,o.call(arguments,1)),function(r){r in n&&(t[r]=n[r])}),t},j.omit=function(n){var t={},r=c.apply(e,o.call(arguments,1));for(var u in n)j.contains(r,u)||(t[u]=n[u]);return t},j.defaults=function(n){return A(o.call(arguments,1),function(t){if(t)for(var r in t)void 0===n[r]&&(n[r]=t[r])}),n},j.clone=function(n){return j.isObject(n)?j.isArray(n)?n.slice():j.extend({},n):n},j.tap=function(n,t){return t(n),n};var S=function(n,t,r,e){if(n===t)return 0!==n||1/n==1/t;if(null==n||null==t)return n===t;n instanceof j&&(n=n._wrapped),t instanceof j&&(t=t._wrapped);var u=l.call(n);if(u!=l.call(t))return!1;switch(u){case"[object String]":return n==String(t);case"[object Number]":return n!=+n?t!=+t:0==n?1/n==1/t:n==+t;case"[object Date]":case"[object Boolean]":return+n==+t;case"[object RegExp]":return n.source==t.source&&n.global==t.global&&n.multiline==t.multiline&&n.ignoreCase==t.ignoreCase}if("object"!=typeof n||"object"!=typeof t)return!1;for(var i=r.length;i--;)if(r[i]==n)return e[i]==t;var a=n.constructor,o=t.constructor;if(a!==o&&!(j.isFunction(a)&&a instanceof a&&j.isFunction(o)&&o instanceof o)&&"constructor"in n&&"constructor"in t)return!1;r.push(n),e.push(t);var c=0,f=!0;if("[object Array]"==u){if(c=n.length,f=c==t.length)for(;c--&&(f=S(n[c],t[c],r,e)););}else{for(var s in n)if(j.has(n,s)&&(c++,!(f=j.has(t,s)&&S(n[s],t[s],r,e))))break;if(f){for(s in t)if(j.has(t,s)&&!c--)break;f=!c}}return r.pop(),e.pop(),f};j.isEqual=function(n,t){return S(n,t,[],[])},j.isEmpty=function(n){if(null==n)return!0;if(j.isArray(n)||j.isString(n))return 0===n.length;for(var t in n)if(j.has(n,t))return!1;return!0},j.isElement=function(n){return!(!n||1!==n.nodeType)},j.isArray=x||function(n){return"[object Array]"==l.call(n)},j.isObject=function(n){return n===Object(n)},A(["Arguments","Function","String","Number","Date","RegExp"],function(n){j["is"+n]=function(t){return l.call(t)=="[object "+n+"]"}}),j.isArguments(arguments)||(j.isArguments=function(n){return!(!n||!j.has(n,"callee"))}),"function"!=typeof/./&&(j.isFunction=function(n){return"function"==typeof n}),j.isFinite=function(n){return isFinite(n)&&!isNaN(parseFloat(n))},j.isNaN=function(n){return j.isNumber(n)&&n!=+n},j.isBoolean=function(n){return n===!0||n===!1||"[object Boolean]"==l.call(n)},j.isNull=function(n){return null===n},j.isUndefined=function(n){return void 0===n},j.has=function(n,t){return f.call(n,t)},j.noConflict=function(){return n._=t,this},j.identity=function(n){return n},j.constant=function(n){return function(){return n}},j.property=function(n){return function(t){return t[n]}},j.matches=function(n){return function(t){if(t===n)return!0;for(var r in n)if(n[r]!==t[r])return!1;return!0}},j.times=function(n,t,r){for(var e=Array(Math.max(0,n)),u=0;n>u;u++)e[u]=t.call(r,u);return e},j.random=function(n,t){return null==t&&(t=n,n=0),n+Math.floor(Math.random()*(t-n+1))}, j.now=Date.now||function(){return(new Date).getTime()};var T={escape:{"&":"&","<":"<",">":">",'"':""","'":"'"}};T.unescape=j.invert(T.escape);var I={escape:new RegExp("["+j.keys(T.escape).join("")+"]","g"),unescape:new RegExp("("+j.keys(T.unescape).join("|")+")","g")};j.each(["escape","unescape"],function(n){j[n]=function(t){return null==t?"":(""+t).replace(I[n],function(t){return T[n][t]})}}),j.result=function(n,t){if(null!=n){var r=n[t];return j.isFunction(r)?r.call(n):r}},j.mixin=function(n){A(j.functions(n),function(t){var r=j[t]=n[t];j.prototype[t]=function(){var n=[this._wrapped];return a.apply(n,arguments),z.call(this,r.apply(j,n))}})};var N=0;j.uniqueId=function(n){var t=++N+"";return n?n+t:t},j.templateSettings={evaluate:/<%([\s\S]+?)%>/g,interpolate:/<%=([\s\S]+?)%>/g,escape:/<%-([\s\S]+?)%>/g};var q=/(.)^/,B={"'":"'","\\":"\\","\r":"r","\n":"n","\t":"t","\u2028":"u2028","\u2029":"u2029"};j.template=function(n,t,r){var e;r=j.defaults({},r,j.templateSettings);var u=new RegExp([(r.escape||q).source,(r.interpolate||q).source,(r.evaluate||q).source].join("|")+"|$","g"),i=0,a="__p+='";n.replace(u,function(t,r,e,u,o){return a+=n.slice(i,o).replace(/\\|'|\r|\n|\t|\u2028|\u2029/g,function(n){return"\\"+B[n]}),r&&(a+="'+\n((__t=("+r+"))==null?'':_.escape(__t))+\n'"),e&&(a+="'+\n((__t=("+e+"))==null?'':__t)+\n'"),u&&(a+="';\n"+u+"\n__p+='"),i=o+t.length,t}),a+="';\n",r.variable||(a="with(obj||{}){\n"+a+"}\n"),a="var __t,__p='',__j=Array.prototype.join,print=function(){__p+=__j.call(arguments,'');};\n"+a+"return __p;\n";try{e=new Function(r.variable||"obj","_",a)}catch(o){throw o.source=a,o}if(t)return e(t,j);var c=function(n){return e.call(this,n,j)};return c.source="function("+(r.variable||"obj")+"){\n"+a+"}",c},j.chain=function(n){return j(n).chain()};var z=function(n){return this._chain?j(n).chain():n};j.mixin(j),A(["pop","push","reverse","shift","sort","splice","unshift"],function(n){var t=e[n];j.prototype[n]=function(){var r=this._wrapped;return t.apply(r,arguments),"shift"!=n&&"splice"!=n||0!==r.length||delete r[0],z.call(this,r)}}),A(["concat","join","slice"],function(n){var t=e[n];j.prototype[n]=function(){return z.call(this,t.apply(this._wrapped,arguments))}}),j.extend(j.prototype,{chain:function(){return this._chain=!0,this},value:function(){return this._wrapped}}),"function"==typeof define&&define.amd&&define("underscore",[],function(){return j})}.call(this),function(t,e){if("function"==typeof define&&define.amd)define(["underscore","jquery","exports"],function(i,r,s){t.Backbone=e(t,s,i,r)});else if("undefined"!=typeof exports){var i=require("underscore");e(t,exports,i)}else t.Backbone=e(t,{},t._,t.jQuery||t.Zepto||t.ender||t.$)}(this,function(t,e,i,r){var s=t.Backbone,n=[],o=(n.push,n.slice);n.splice;e.VERSION="1.1.2",e.$=r,e.noConflict=function(){return t.Backbone=s,this},e.emulateHTTP=!1,e.emulateJSON=!1;var u=e.Events={on:function(t,e,i){return c(this,"on",t,[e,i])&&e?(this._events||(this._events={}),(this._events[t]||(this._events[t]=[])).push({callback:e,context:i,ctx:i||this}),this):this},once:function(t,e,r){if(!c(this,"once",t,[e,r])||!e)return this;var s=this,n=i.once(function(){s.off(t,n),e.apply(this,arguments)});return n._callback=e,this.on(t,n,r)},off:function(t,e,r){var s,n,a,o,h,u,l,f;if(!this._events||!c(this,"off",t,[e,r]))return this;if(!t&&!e&&!r)return this._events=void 0,this;for(o=t?[t]:i.keys(this._events),h=0,u=o.length;h<u;h++)if(t=o[h],a=this._events[t]){if(this._events[t]=s=[],e||r)for(l=0,f=a.length;l<f;l++)n=a[l],(e&&e!==n.callback&&e!==n.callback._callback||r&&r!==n.context)&&s.push(n);s.length||delete this._events[t]}return this},trigger:function(t){if(!this._events)return this;var e=o.call(arguments,1);if(!c(this,"trigger",t,e))return this;var i=this._events[t],r=this._events.all;return i&&f(i,e),r&&f(r,arguments),this},stopListening:function(t,e,r){var s=this._listeningTo;if(!s)return this;var n=!e&&!r;r||"object"!=typeof e||(r=this),t&&((s={})[t._listenId]=t);for(var a in s)t=s[a],t.off(e,r,this),(n||i.isEmpty(t._events))&&delete this._listeningTo[a];return this}},l=/\s+/,c=function(t,e,i,r){if(!i)return!0;if("object"==typeof i){for(var s in i)t[e].apply(t,[s,i[s]].concat(r));return!1}if(l.test(i)){for(var n=i.split(l),a=0,o=n.length;a<o;a++)t[e].apply(t,[n[a]].concat(r));return!1}return!0},f=function(t,e){var i,r=-1,s=t.length,n=e[0],a=e[1],o=e[2];switch(e.length){case 0:for(;++r<s;)(i=t[r]).callback.call(i.ctx);return;case 1:for(;++r<s;)(i=t[r]).callback.call(i.ctx,n);return;case 2:for(;++r<s;)(i=t[r]).callback.call(i.ctx,n,a);return;case 3:for(;++r<s;)(i=t[r]).callback.call(i.ctx,n,a,o);return;default:for(;++r<s;)(i=t[r]).callback.apply(i.ctx,e);return}},d={listenTo:"on",listenToOnce:"once"};i.each(d,function(t,e){u[e]=function(e,r,s){return(this._listeningTo||(this._listeningTo={}))[e._listenId||(e._listenId=i.uniqueId("l"))]=e,s||"object"!=typeof r||(s=this),e[t](r,s,this),this}}),u.bind=u.on,u.unbind=u.off,i.extend(e,u);var p=e.Model=function(t,e){var r=t||{};e||(e={}),this.cid=i.uniqueId("c"),this.attributes={},e.collection&&(this.collection=e.collection),e.parse&&(r=this.parse(r,e)||{}),r=i.defaults({},r,i.result(this,"defaults")),this.set(r,e),this.changed={},this.initialize.apply(this,arguments)};i.extend(p.prototype,u,{changed:null,validationError:null,idAttribute:"id",initialize:function(){},toJSON:function(t){return i.clone(this.attributes)},sync:function(){return e.sync.apply(this,arguments)},get:function(t){return this.attributes[t]},escape:function(t){return i.escape(this.get(t))},has:function(t){return null!=this.get(t)},set:function(t,e,r){var s,n,a,o,h,u,l,c;if(null==t)return this;if("object"==typeof t?(n=t,r=e):(n={})[t]=e,r||(r={}),!this._validate(n,r))return!1;a=r.unset,h=r.silent,o=[],u=this._changing,this._changing=!0,u||(this._previousAttributes=i.clone(this.attributes),this.changed={}),c=this.attributes,l=this._previousAttributes,this.idAttribute in n&&(this.id=n[this.idAttribute]);for(s in n)e=n[s],i.isEqual(c[s],e)||o.push(s),i.isEqual(l[s],e)?delete this.changed[s]:this.changed[s]=e,a?delete c[s]:c[s]=e;if(!h){o.length&&(this._pending=r);for(var f=0,d=o.length;f<d;f++)this.trigger("change:"+o[f],this,c[o[f]],r)}if(u)return this;if(!h)for(;this._pending;)r=this._pending,this._pending=!1,this.trigger("change",this,r);return this._pending=!1,this._changing=!1,this},unset:function(t,e){return this.set(t,void 0,i.extend({},e,{unset:!0}))},clear:function(t){var e={};for(var r in this.attributes)e[r]=void 0;return this.set(e,i.extend({},t,{unset:!0}))},hasChanged:function(t){return null==t?!i.isEmpty(this.changed):i.has(this.changed,t)},changedAttributes:function(t){if(!t)return!!this.hasChanged()&&i.clone(this.changed);var e,r=!1,s=this._changing?this._previousAttributes:this.attributes;for(var n in t)i.isEqual(s[n],e=t[n])||((r||(r={}))[n]=e);return r},previous:function(t){return null!=t&&this._previousAttributes?this._previousAttributes[t]:null},previousAttributes:function(){return i.clone(this._previousAttributes)},fetch:function(t){t=t?i.clone(t):{},void 0===t.parse&&(t.parse=!0);var e=this,r=t.success;return t.success=function(i){if(!e.set(e.parse(i,t),t))return!1;r&&r(e,i,t),e.trigger("sync",e,i,t)},q(this,t),this.sync("read",this,t)},save:function(t,e,r){var s,n,a,o=this.attributes;if(null==t||"object"==typeof t?(s=t,r=e):(s={})[t]=e,r=i.extend({validate:!0},r),s&&!r.wait){if(!this.set(s,r))return!1}else if(!this._validate(s,r))return!1;s&&r.wait&&(this.attributes=i.extend({},o,s)),void 0===r.parse&&(r.parse=!0);var h=this,u=r.success;return r.success=function(t){h.attributes=o;var e=h.parse(t,r);if(r.wait&&(e=i.extend(s||{},e)),i.isObject(e)&&!h.set(e,r))return!1;u&&u(h,t,r),h.trigger("sync",h,t,r)},q(this,r),n=this.isNew()?"create":r.patch?"patch":"update","patch"===n&&(r.attrs=s),a=this.sync(n,this,r),s&&r.wait&&(this.attributes=o),a},destroy:function(t){t=t?i.clone(t):{};var e=this,r=t.success,s=function(){e.trigger("destroy",e,e.collection,t)};if(t.success=function(i){(t.wait||e.isNew())&&s(),r&&r(e,i,t),e.isNew()||e.trigger("sync",e,i,t)},this.isNew())return t.success(),!1;q(this,t);var n=this.sync("delete",this,t);return t.wait||s(),n},url:function(){var t=i.result(this,"urlRoot")||i.result(this.collection,"url")||M();return this.isNew()?t:t.replace(/([^\/])$/,"$1/")+encodeURIComponent(this.id)},parse:function(t,e){return t},clone:function(){return new this.constructor(this.attributes)},isNew:function(){return!this.has(this.idAttribute)},isValid:function(t){return this._validate({},i.extend(t||{},{validate:!0}))},_validate:function(t,e){if(!e.validate||!this.validate)return!0;t=i.extend({},this.attributes,t);var r=this.validationError=this.validate(t,e)||null;return!r||(this.trigger("invalid",this,r,i.extend(e,{validationError:r})),!1)}});var v=["keys","values","pairs","invert","pick","omit"];i.each(v,function(t){p.prototype[t]=function(){var e=o.call(arguments);return e.unshift(this.attributes),i[t].apply(i,e)}});var g=e.Collection=function(t,e){e||(e={}),e.model&&(this.model=e.model),void 0!==e.comparator&&(this.comparator=e.comparator),this._reset(),this.initialize.apply(this,arguments),t&&this.reset(t,i.extend({silent:!0},e))},m={add:!0,remove:!0,merge:!0},y={add:!0,remove:!1};i.extend(g.prototype,u,{model:p,initialize:function(){},toJSON:function(t){return this.map(function(e){return e.toJSON(t)})},sync:function(){return e.sync.apply(this,arguments)},add:function(t,e){return this.set(t,i.extend({merge:!1},e,y))},remove:function(t,e){var r=!i.isArray(t);t=r?[t]:i.clone(t),e||(e={});var s,n,a,o;for(s=0,n=t.length;s<n;s++)(o=t[s]=this.get(t[s]))&&(delete this._byId[o.id],delete this._byId[o.cid],a=this.indexOf(o),this.models.splice(a,1),this.length--,e.silent||(e.index=a,o.trigger("remove",o,this,e)),this._removeReference(o,e));return r?t[0]:t},set:function(t,e){e=i.defaults({},e,m),e.parse&&(t=this.parse(t,e));var r=!i.isArray(t);t=r?t?[t]:[]:i.clone(t);var s,n,a,o,h,u,l,c=e.at,f=this.model,d=this.comparator&&null==c&&e.sort!==!1,v=i.isString(this.comparator)?this.comparator:null,g=[],y=[],_={},b=e.add,w=e.merge,x=e.remove,E=!(d||!b||!x)&&[];for(s=0,n=t.length;s<n;s++){if(h=t[s]||{},a=h instanceof p?o=h:h[f.prototype.idAttribute||"id"],u=this.get(a))x&&(_[u.cid]=!0),w&&(h=h===o?o.attributes:h,e.parse&&(h=u.parse(h,e)),u.set(h,e),d&&!l&&u.hasChanged(v)&&(l=!0)),t[s]=u;else if(b){if(!(o=t[s]=this._prepareModel(h,e)))continue;g.push(o),this._addReference(o,e)}o=u||o,!E||!o.isNew()&&_[o.id]||E.push(o),_[o.id]=!0}if(x){for(s=0,n=this.length;s<n;++s)_[(o=this.models[s]).cid]||y.push(o);y.length&&this.remove(y,e)}if(g.length||E&&E.length)if(d&&(l=!0),this.length+=g.length,null!=c)for(s=0,n=g.length;s<n;s++)this.models.splice(c+s,0,g[s]);else{E&&(this.models.length=0);var k=E||g;for(s=0,n=k.length;s<n;s++)this.models.push(k[s])}if(l&&this.sort({silent:!0}),!e.silent){for(s=0,n=g.length;s<n;s++)(o=g[s]).trigger("add",o,this,e);(l||E&&E.length)&&this.trigger("sort",this,e)}return r?t[0]:t},reset:function(t,e){e||(e={});for(var r=0,s=this.models.length;r<s;r++)this._removeReference(this.models[r],e);return e.previousModels=this.models,this._reset(),t=this.add(t,i.extend({silent:!0},e)),e.silent||this.trigger("reset",this,e),t},push:function(t,e){return this.add(t,i.extend({at:this.length},e))},pop:function(t){var e=this.at(this.length-1);return this.remove(e,t),e},unshift:function(t,e){return this.add(t,i.extend({at:0},e))},shift:function(t){var e=this.at(0);return this.remove(e,t),e},slice:function(){return o.apply(this.models,arguments)},get:function(t){if(null!=t)return this._byId[t]||this._byId[t.id]||this._byId[t.cid]},at:function(t){return this.models[t]},where:function(t,e){return i.isEmpty(t)?e?void 0:[]:this[e?"find":"filter"](function(e){for(var i in t)if(t[i]!==e.get(i))return!1;return!0})},findWhere:function(t){return this.where(t,!0)},sort:function(t){if(!this.comparator)throw new Error("Cannot sort a set without a comparator");return t||(t={}),i.isString(this.comparator)||1===this.comparator.length?this.models=this.sortBy(this.comparator,this):this.models.sort(i.bind(this.comparator,this)),t.silent||this.trigger("sort",this,t),this},pluck:function(t){return i.invoke(this.models,"get",t)},fetch:function(t){t=t?i.clone(t):{},void 0===t.parse&&(t.parse=!0);var e=t.success,r=this;return t.success=function(i){r[t.reset?"reset":"set"](i,t),e&&e(r,i,t),r.trigger("sync",r,i,t)},q(this,t),this.sync("read",this,t)},create:function(t,e){if(e=e?i.clone(e):{},!(t=this._prepareModel(t,e)))return!1;e.wait||this.add(t,e);var r=this,s=e.success;return e.success=function(t,i){e.wait&&r.add(t,e),s&&s(t,i,e)},t.save(null,e),t},parse:function(t,e){return t},clone:function(){return new this.constructor(this.models)},_reset:function(){this.length=0,this.models=[],this._byId={}},_prepareModel:function(t,e){if(t instanceof p)return t;e=e?i.clone(e):{},e.collection=this;var r=new this.model(t,e);return r.validationError?(this.trigger("invalid",this,r.validationError,e),!1):r},_addReference:function(t,e){this._byId[t.cid]=t,null!=t.id&&(this._byId[t.id]=t),t.collection||(t.collection=this),t.on("all",this._onModelEvent,this)},_removeReference:function(t,e){this===t.collection&&delete t.collection,t.off("all",this._onModelEvent,this)},_onModelEvent:function(t,e,i,r){("add"!==t&&"remove"!==t||i===this)&&("destroy"===t&&this.remove(e,r),e&&t==="change:"+e.idAttribute&&(delete this._byId[e.previous(e.idAttribute)],null!=e.id&&(this._byId[e.id]=e)),this.trigger.apply(this,arguments))}});var _=["forEach","each","map","collect","reduce","foldl","inject","reduceRight","foldr","find","detect","filter","select","reject","every","all","some","any","include","contains","invoke","max","min","toArray","size","first","head","take","initial","rest","tail","drop","last","without","difference","indexOf","shuffle","lastIndexOf","isEmpty","chain","sample"];i.each(_,function(t){g.prototype[t]=function(){var e=o.call(arguments);return e.unshift(this.models),i[t].apply(i,e)}});var b=["groupBy","countBy","sortBy","indexBy"];i.each(b,function(t){g.prototype[t]=function(e,r){var s=i.isFunction(e)?e:function(t){return t.get(e)};return i[t](this.models,s,r)}});var w=e.View=function(t){this.cid=i.uniqueId("view"),t||(t={}),i.extend(this,i.pick(t,E)),this._ensureElement(),this.initialize.apply(this,arguments),this.delegateEvents()},E=["model","collection","el","id","attributes","className","tagName","events"];i.extend(w.prototype,u,{tagName:"div",$:function(t){return this.$el.find(t)},initialize:function(){},render:function(){return this},remove:function(){return this.$el.remove(),this.stopListening(),this},setElement:function(t,i){return this.$el&&this.undelegateEvents(),this.$el=t instanceof e.$?t:e.$(t),this.el=this.$el[0],i!==!1&&this.delegateEvents(),this},delegateEvents:function(t){if(!t&&!(t=i.result(this,"events")))return this;this.undelegateEvents();for(var e in t){var r=t[e];if(i.isFunction(r)||(r=this[t[e]]),r){var s=e.match(/^(\S+)\s*(.*)$/),n=s[1],a=s[2];r=i.bind(r,this),n+=".delegateEvents"+this.cid,""===a?this.$el.on(n,r):this.$el.on(n,a,r)}}return this},undelegateEvents:function(){return this.$el.off(".delegateEvents"+this.cid),this},_ensureElement:function(){if(this.el)this.setElement(i.result(this,"el"),!1);else{var t=i.extend({},i.result(this,"attributes"));this.id&&(t.id=i.result(this,"id")),this.className&&(t.class=i.result(this,"className"));var r=e.$("<"+i.result(this,"tagName")+">").attr(t);this.setElement(r,!1)}}}),e.sync=function(t,r,s){var n=T[t];i.defaults(s||(s={}),{emulateHTTP:e.emulateHTTP,emulateJSON:e.emulateJSON});var a={type:n,dataType:"json"};if(s.url||(a.url=i.result(r,"url")||M()),null!=s.data||!r||"create"!==t&&"update"!==t&&"patch"!==t||(a.contentType="application/json",a.data=JSON.stringify(s.attrs||r.toJSON(s))),s.emulateJSON&&(a.contentType="application/x-www-form-urlencoded",a.data=a.data?{model:a.data}:{}),s.emulateHTTP&&("PUT"===n||"DELETE"===n||"PATCH"===n)){a.type="POST",s.emulateJSON&&(a.data._method=n);var o=s.beforeSend;s.beforeSend=function(t){if(t.setRequestHeader("X-HTTP-Method-Override",n),o)return o.apply(this,arguments)}}"GET"===a.type||s.emulateJSON||(a.processData=!1),"PATCH"===a.type&&k&&(a.xhr=function(){return new ActiveXObject("Microsoft.XMLHTTP")});var h=s.xhr=e.ajax(i.extend(a,s));return r.trigger("request",r,h,s),h};var k=!("undefined"==typeof window||!window.ActiveXObject||window.XMLHttpRequest&&(new XMLHttpRequest).dispatchEvent),T={create:"POST",update:"PUT",patch:"PATCH",delete:"DELETE",read:"GET"};e.ajax=function(){return e.$.ajax.apply(e.$,arguments)};var $=e.Router=function(t){t||(t={}),t.routes&&(this.routes=t.routes),this._bindRoutes(),this.initialize.apply(this,arguments)};i.extend($.prototype,u,{initialize:function(){},route:function(t,r,s){i.isRegExp(t)||(t=this._routeToRegExp(t)),i.isFunction(r)&&(s=r,r=""),s||(s=this[r]);var n=this;return e.history.route(t,function(i){var a=n._extractParameters(t,i);n.execute(s,a),n.trigger.apply(n,["route:"+r].concat(a)),n.trigger("route",r,a),e.history.trigger("route",n,r,a)}),this},execute:function(t,e){t&&t.apply(this,e)},navigate:function(t,i){return e.history.navigate(t,i),this},_bindRoutes:function(){if(this.routes){this.routes=i.result(this,"routes");for(var t,e=i.keys(this.routes);null!=(t=e.pop());)this.route(t,this.routes[t])}},_routeToRegExp:function(t){return t=t.replace(/[\-{}\[\]+?.,\\\^$|#\s]/g,"\\$&").replace(/\((.*?)\)/g,"(?:$1)?").replace(/(\(\?)?:\w+/g,function(t,e){return e?t:"([^/?]+)"}).replace(/\*\w+/g,"([^?]*?)"),new RegExp("^"+t+"(?:\\?([\\s\\S]*))?$")},_extractParameters:function(t,e){var r=t.exec(e).slice(1);return i.map(r,function(t,e){return e===r.length-1?t||null:t?decodeURIComponent(t):null})}});var N=e.History=function(){this.handlers=[],i.bindAll(this,"checkUrl"),"undefined"!=typeof window&&(this.location=window.location,this.history=window.history)},R=/^[#\/]|\s+$/g,P=/msie [\w.]+/;N.started=!1,i.extend(N.prototype,u,{interval:50,atRoot:function(){return this.location.pathname.replace(/[^\/]$/,"$&/")===this.root},getHash:function(t){var e=(t||this).location.href.match(/#(.*)$/);return e?e[1]:""},getFragment:function(t,e){if(null==t)if(this._hasPushState||!this._wantsHashChange||e){t=decodeURI(this.location.pathname+this.location.search);var i=this.root.replace(/\/$/,"");t.indexOf(i)||(t=t.slice(i.length))}else t=this.getHash();return t.replace(R,"")},start:function(t){if(N.started)throw new Error("Backbone.history has already been started");N.started=!0,this.options=i.extend({root:"/"},this.options,t),this.root=this.options.root,this._wantsHashChange=this.options.hashChange!==!1,this._wantsPushState=!!this.options.pushState,this._hasPushState=!!(this.options.pushState&&this.history&&this.history.pushState);var r=this.getFragment(),s=document.documentMode,n=P.exec(navigator.userAgent.toLowerCase())&&(!s||s<=7);if(this.root=("/"+this.root+"/").replace(/^\/+|\/+$/g,"/"),n&&this._wantsHashChange){var a=e.$('<iframe src="javascript:0" tabindex="-1">');this.iframe=a.hide().appendTo("body")[0].contentWindow,this.navigate(r)}this._hasPushState?e.$(window).on("popstate",this.checkUrl):this._wantsHashChange&&"onhashchange"in window&&!n?e.$(window).on("hashchange",this.checkUrl):this._wantsHashChange&&(this._checkUrlInterval=setInterval(this.checkUrl,this.interval)),this.fragment=r;var o=this.location;if(this._wantsHashChange&&this._wantsPushState){if(!this._hasPushState&&!this.atRoot())return this.fragment=this.getFragment(null,!0),this.location.replace(this.root+"#"+this.fragment),!0;this._hasPushState&&this.atRoot()&&o.hash&&(this.fragment=this.getHash().replace(R,""),this.history.replaceState({},document.title,this.root+this.fragment))}if(!this.options.silent)return this.loadUrl()},stop:function(){e.$(window).off("popstate",this.checkUrl).off("hashchange",this.checkUrl),this._checkUrlInterval&&clearInterval(this._checkUrlInterval),N.started=!1},route:function(t,e){this.handlers.unshift({route:t,callback:e})},checkUrl:function(t){var e=this.getFragment();if(e===this.fragment&&this.iframe&&(e=this.getFragment(this.getHash(this.iframe))),e===this.fragment)return!1;this.iframe&&this.navigate(e),this.loadUrl()},loadUrl:function(t){return t=this.fragment=this.getFragment(t),i.any(this.handlers,function(e){if(e.route.test(t))return e.callback(t),!0})},navigate:function(t,e){if(!N.started)return!1;e&&e!==!0||(e={trigger:!!e});var i=this.root+(t=this.getFragment(t||""));if(t=t.replace(/#.*$/,""),this.fragment!==t){if(this.fragment=t,""===t&&"/"!==i&&(i=i.slice(0,-1)),this._hasPushState)this.history[e.replace?"replaceState":"pushState"]({},document.title,i);else{if(!this._wantsHashChange)return this.location.assign(i);this._updateHash(this.location,t,e.replace),this.iframe&&t!==this.getFragment(this.getHash(this.iframe))&&(e.replace||this.iframe.document.open().close(),this._updateHash(this.iframe.location,t,e.replace))}return e.trigger?this.loadUrl(t):void 0}},_updateHash:function(t,e,i){if(i){var r=t.href.replace(/(javascript:|#).*$/,"");t.replace(r+"#"+e)}else t.hash="#"+e}}),e.history=new N;var U=function(t,e){var s,r=this;s=t&&i.has(t,"constructor")?t.constructor:function(){return r.apply(this,arguments)},i.extend(s,r,e);var n=function(){this.constructor=s};return n.prototype=r.prototype,s.prototype=new n,t&&i.extend(s.prototype,t),s.__super__=r.prototype,s};p.extend=g.extend=$.extend=w.extend=N.extend=U;var M=function(){throw new Error('A "url" property or function must be specified')},q=function(t,e){var i=e.error;e.error=function(r){i&&i(t,r,e),t.trigger("error",t,r,e)}};return e}),function(){var t=function(e){var n=new t.Index;return n.pipeline.add(t.trimmer,t.stopWordFilter,t.stemmer),e&&e.call(n,n),n};t.version="0.5.3",t.utils={},t.utils.warn=function(t){return function(e){t.console&&console.warn&&console.warn(e)}}(this),t.EventEmitter=function(){this.events={}},t.EventEmitter.prototype.addListener=function(){var t=Array.prototype.slice.call(arguments),e=t.pop(),n=t;if("function"!=typeof e)throw new TypeError("last argument must be a function");n.forEach(function(t){this.hasHandler(t)||(this.events[t]=[]),this.events[t].push(e)},this)},t.EventEmitter.prototype.removeListener=function(t,e){if(this.hasHandler(t)){var n=this.events[t].indexOf(e);this.events[t].splice(n,1),this.events[t].length||delete this.events[t]}},t.EventEmitter.prototype.emit=function(t){if(this.hasHandler(t)){var e=Array.prototype.slice.call(arguments,1);this.events[t].forEach(function(t){t.apply(void 0,e)})}},t.EventEmitter.prototype.hasHandler=function(t){return t in this.events},t.tokenizer=function(t){if(!arguments.length||null==t||void 0==t)return[];if(Array.isArray(t))return t.map(function(t){return t.toLowerCase()});for(var e=t.toString().replace(/^\s+/,""),n=e.length-1;n>=0;n--)if(/\S/.test(e.charAt(n))){e=e.substring(0,n+1);break}return e.split(/\s+/).map(function(t){return t.toLowerCase()})},t.Pipeline=function(){this._stack=[]},t.Pipeline.registeredFunctions={},t.Pipeline.registerFunction=function(e,n){n in this.registeredFunctions&&t.utils.warn("Overwriting existing registered function: "+n),e.label=n,t.Pipeline.registeredFunctions[e.label]=e},t.Pipeline.warnIfFunctionNotRegistered=function(e){e.label&&e.label in this.registeredFunctions||t.utils.warn("Function is not registered with pipeline. This may cause problems when serialising the index.\n",e)},t.Pipeline.load=function(e){var n=new t.Pipeline;return e.forEach(function(e){var i=t.Pipeline.registeredFunctions[e];if(!i)throw new Error("Cannot load un-registered function: "+e);n.add(i)}),n},t.Pipeline.prototype.add=function(){Array.prototype.slice.call(arguments).forEach(function(e){t.Pipeline.warnIfFunctionNotRegistered(e),this._stack.push(e)},this)},t.Pipeline.prototype.after=function(e,n){t.Pipeline.warnIfFunctionNotRegistered(n);var i=this._stack.indexOf(e)+1;this._stack.splice(i,0,n)},t.Pipeline.prototype.before=function(e,n){t.Pipeline.warnIfFunctionNotRegistered(n);var i=this._stack.indexOf(e);this._stack.splice(i,0,n)},t.Pipeline.prototype.remove=function(t){var e=this._stack.indexOf(t);this._stack.splice(e,1)},t.Pipeline.prototype.run=function(t){for(var e=[],n=t.length,i=this._stack.length,o=0;n>o;o++){for(var r=t[o],s=0;i>s&&void 0!==(r=this._stack[s](r,o,t));s++);void 0!==r&&e.push(r)}return e},t.Pipeline.prototype.reset=function(){this._stack=[]},t.Pipeline.prototype.toJSON=function(){return this._stack.map(function(e){return t.Pipeline.warnIfFunctionNotRegistered(e),e.label})},t.Vector=function(){this._magnitude=null,this.list=void 0,this.length=0},t.Vector.Node=function(t,e,n){this.idx=t,this.val=e,this.next=n},t.Vector.prototype.insert=function(e,n){var i=this.list;if(!i)return this.list=new t.Vector.Node(e,n,i),this.length++;for(var o=i,r=i.next;void 0!=r;){if(e<r.idx)return o.next=new t.Vector.Node(e,n,r),this.length++;o=r,r=r.next}return o.next=new t.Vector.Node(e,n,r),this.length++},t.Vector.prototype.magnitude=function(){if(this._magniture)return this._magnitude;for(var t,e=this.list,n=0;e;)t=e.val,n+=t*t,e=e.next;return this._magnitude=Math.sqrt(n)},t.Vector.prototype.dot=function(t){for(var e=this.list,n=t.list,i=0;e&&n;)e.idx<n.idx?e=e.next:e.idx>n.idx?n=n.next:(i+=e.val*n.val,e=e.next,n=n.next);return i},t.Vector.prototype.similarity=function(t){return this.dot(t)/(this.magnitude()*t.magnitude())},t.SortedSet=function(){this.length=0,this.elements=[]},t.SortedSet.load=function(t){var e=new this;return e.elements=t,e.length=t.length,e},t.SortedSet.prototype.add=function(){Array.prototype.slice.call(arguments).forEach(function(t){~this.indexOf(t)||this.elements.splice(this.locationFor(t),0,t)},this),this.length=this.elements.length},t.SortedSet.prototype.toArray=function(){return this.elements.slice()},t.SortedSet.prototype.map=function(t,e){return this.elements.map(t,e)},t.SortedSet.prototype.forEach=function(t,e){return this.elements.forEach(t,e)},t.SortedSet.prototype.indexOf=function(t,e,n){var e=e||0,n=n||this.elements.length,i=n-e,o=e+Math.floor(i/2),r=this.elements[o];return 1>=i?r===t?o:-1:t>r?this.indexOf(t,o,n):r>t?this.indexOf(t,e,o):r===t?o:void 0},t.SortedSet.prototype.locationFor=function(t,e,n){var e=e||0,n=n||this.elements.length,i=n-e,o=e+Math.floor(i/2),r=this.elements[o];if(1>=i){if(r>t)return o;if(t>r)return o+1}return t>r?this.locationFor(t,o,n):r>t?this.locationFor(t,e,o):void 0},t.SortedSet.prototype.intersect=function(e){for(var n=new t.SortedSet,i=0,o=0,r=this.length,s=e.length,a=this.elements,h=e.elements;!(i>r-1||o>s-1);)a[i]!==h[o]?a[i]<h[o]?i++:a[i]>h[o]&&o++:(n.add(a[i]),i++,o++);return n},t.SortedSet.prototype.clone=function(){var e=new t.SortedSet;return e.elements=this.toArray(),e.length=e.elements.length,e},t.SortedSet.prototype.union=function(t){var e,n,i;return this.length>=t.length?(e=this,n=t):(e=t,n=this),i=e.clone(),i.add.apply(i,n.toArray()),i},t.SortedSet.prototype.toJSON=function(){return this.toArray()},t.Index=function(){this._fields=[],this._ref="id",this.pipeline=new t.Pipeline,this.documentStore=new t.Store,this.tokenStore=new t.TokenStore,this.corpusTokens=new t.SortedSet,this.eventEmitter=new t.EventEmitter,this._idfCache={},this.on("add","remove","update",function(){this._idfCache={}}.bind(this))},t.Index.prototype.on=function(){var t=Array.prototype.slice.call(arguments);return this.eventEmitter.addListener.apply(this.eventEmitter,t)},t.Index.prototype.off=function(t,e){return this.eventEmitter.removeListener(t,e)},t.Index.load=function(e){e.version!==t.version&&t.utils.warn("version mismatch: current "+t.version+" importing "+e.version);var n=new this;return n._fields=e.fields,n._ref=e.ref,n.documentStore=t.Store.load(e.documentStore),n.tokenStore=t.TokenStore.load(e.tokenStore),n.corpusTokens=t.SortedSet.load(e.corpusTokens),n.pipeline=t.Pipeline.load(e.pipeline),n},t.Index.prototype.field=function(t,e){var e=e||{},n={name:t,boost:e.boost||1};return this._fields.push(n),this},t.Index.prototype.ref=function(t){return this._ref=t,this},t.Index.prototype.add=function(e,n){var i={},o=new t.SortedSet,r=e[this._ref],n=void 0===n||n;this._fields.forEach(function(n){var r=this.pipeline.run(t.tokenizer(e[n.name]));i[n.name]=r,t.SortedSet.prototype.add.apply(o,r)},this),this.documentStore.set(r,o),t.SortedSet.prototype.add.apply(this.corpusTokens,o.toArray());for(var s=0;s<o.length;s++){var a=o.elements[s],h=this._fields.reduce(function(t,e){var n=i[e.name].length;return n?t+i[e.name].filter(function(t){return t===a}).length/n*e.boost:t},0);this.tokenStore.add(a,{ref:r,tf:h})}n&&this.eventEmitter.emit("add",e,this)},t.Index.prototype.remove=function(t,e){var n=t[this._ref],e=void 0===e||e;if(this.documentStore.has(n)){var i=this.documentStore.get(n);this.documentStore.remove(n),i.forEach(function(t){this.tokenStore.remove(t,n)},this),e&&this.eventEmitter.emit("remove",t,this)}},t.Index.prototype.update=function(t,e){var e=void 0===e||e;this.remove(t,!1),this.add(t,!1),e&&this.eventEmitter.emit("update",t,this)},t.Index.prototype.idf=function(t){var e="@"+t;if(Object.prototype.hasOwnProperty.call(this._idfCache,e))return this._idfCache[e];var n=this.tokenStore.count(t),i=1;return n>0&&(i=1+Math.log(this.tokenStore.length/n)),this._idfCache[e]=i},t.Index.prototype.search=function(e){var n=this.pipeline.run(t.tokenizer(e)),i=new t.Vector,o=[],r=this._fields.reduce(function(t,e){return t+e.boost},0);return n.some(function(t){return this.tokenStore.has(t)},this)?(n.forEach(function(e,n,s){var a=1/s.length*this._fields.length*r,h=this,l=this.tokenStore.expand(e).reduce(function(n,o){var r=h.corpusTokens.indexOf(o),s=h.idf(o),l=1,u=new t.SortedSet;if(o!==e){var c=Math.max(3,o.length-e.length);l=1/Math.log(c)}return r>-1&&i.insert(r,a*s*l),Object.keys(h.tokenStore.get(o)).forEach(function(t){u.add(t)}),n.union(u)},new t.SortedSet);o.push(l)},this),o.reduce(function(t,e){return t.intersect(e)}).map(function(t){return{ref:t,score:i.similarity(this.documentVector(t))}},this).sort(function(t,e){return e.score-t.score})):[]},t.Index.prototype.documentVector=function(e){for(var n=this.documentStore.get(e),i=n.length,o=new t.Vector,r=0;i>r;r++){var s=n.elements[r],a=this.tokenStore.get(s)[e].tf,h=this.idf(s);o.insert(this.corpusTokens.indexOf(s),a*h)}return o},t.Index.prototype.toJSON=function(){return{version:t.version,fields:this._fields,ref:this._ref,documentStore:this.documentStore.toJSON(),tokenStore:this.tokenStore.toJSON(),corpusTokens:this.corpusTokens.toJSON(),pipeline:this.pipeline.toJSON()}},t.Index.prototype.use=function(t){var e=Array.prototype.slice.call(arguments,1);e.unshift(this),t.apply(this,e)},t.Store=function(){this.store={},this.length=0},t.Store.load=function(e){var n=new this;return n.length=e.length,n.store=Object.keys(e.store).reduce(function(n,i){return n[i]=t.SortedSet.load(e.store[i]),n},{}),n},t.Store.prototype.set=function(t,e){this.store[t]=e,this.length=Object.keys(this.store).length},t.Store.prototype.get=function(t){return this.store[t]},t.Store.prototype.has=function(t){return t in this.store},t.Store.prototype.remove=function(t){this.has(t)&&(delete this.store[t],this.length--)},t.Store.prototype.toJSON=function(){return{store:this.store,length:this.length}},t.stemmer=function(){var t={ational:"ate",tional:"tion",enci:"ence",anci:"ance",izer:"ize",bli:"ble",alli:"al",entli:"ent",eli:"e",ousli:"ous",ization:"ize",ation:"ate",ator:"ate",alism:"al",iveness:"ive",fulness:"ful",ousness:"ous",aliti:"al",iviti:"ive",biliti:"ble",logi:"log"},e={icate:"ic",ative:"",alize:"al",iciti:"ic",ical:"ic",ful:"",ness:""},i="[aeiouy]",o="[^aeiou][^aeiouy]*",r=i+"[aeiou]*",s="^("+o+")?"+r+o,h="^("+o+")?"+r+o+r+o;return function(n){var r,u,c,p,f,d,v;if(n.length<3)return n;if(c=n.substr(0,1),"y"==c&&(n=c.toUpperCase()+n.substr(1)),p=/^(.+?)(ss|i)es$/,f=/^(.+?)([^s])s$/,p.test(n)?n=n.replace(p,"$1$2"):f.test(n)&&(n=n.replace(f,"$1$2")),p=/^(.+?)eed$/,f=/^(.+?)(ed|ing)$/,p.test(n)){var m=p.exec(n);p=new RegExp(s),p.test(m[1])&&(p=/.$/,n=n.replace(p,""))}else if(f.test(n)){var m=f.exec(n) -;r=m[1],f=new RegExp("^("+o+")?"+i),f.test(r)&&(n=r,f=/(at|bl|iz)$/,d=new RegExp("([^aeiouylsz])\\1$"),v=new RegExp("^"+o+i+"[^aeiouwxy]$"),f.test(n)?n+="e":d.test(n)?(p=/.$/,n=n.replace(p,"")):v.test(n)&&(n+="e"))}if(p=/^(.+?[^aeiou])y$/,p.test(n)){var m=p.exec(n);r=m[1],n=r+"i"}if(p=/^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/,p.test(n)){var m=p.exec(n);r=m[1],u=m[2],p=new RegExp(s),p.test(r)&&(n=r+t[u])}if(p=/^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/,p.test(n)){var m=p.exec(n);r=m[1],u=m[2],p=new RegExp(s),p.test(r)&&(n=r+e[u])}if(p=/^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/,f=/^(.+?)(s|t)(ion)$/,p.test(n)){var m=p.exec(n);r=m[1],p=new RegExp(h),p.test(r)&&(n=r)}else if(f.test(n)){var m=f.exec(n);r=m[1]+m[2],f=new RegExp(h),f.test(r)&&(n=r)}if(p=/^(.+?)e$/,p.test(n)){var m=p.exec(n);r=m[1],p=new RegExp(h),f=new RegExp("^("+o+")?"+r+o+"("+r+")?$"),d=new RegExp("^"+o+i+"[^aeiouwxy]$"),(p.test(r)||f.test(r)&&!d.test(r))&&(n=r)}return p=/ll$/,f=new RegExp(h),p.test(n)&&f.test(n)&&(p=/.$/,n=n.replace(p,"")),"y"==c&&(n=c.toLowerCase()+n.substr(1)),n}}(),t.Pipeline.registerFunction(t.stemmer,"stemmer"),t.stopWordFilter=function(e){return-1===t.stopWordFilter.stopWords.indexOf(e)?e:void 0},t.stopWordFilter.stopWords=new t.SortedSet,t.stopWordFilter.stopWords.length=119,t.stopWordFilter.stopWords.elements=["","a","able","about","across","after","all","almost","also","am","among","an","and","any","are","as","at","be","because","been","but","by","can","cannot","could","dear","did","do","does","either","else","ever","every","for","from","get","got","had","has","have","he","her","hers","him","his","how","however","i","if","in","into","is","it","its","just","least","let","like","likely","may","me","might","most","must","my","neither","no","nor","not","of","off","often","on","only","or","other","our","own","rather","said","say","says","she","should","since","so","some","than","that","the","their","them","then","there","these","they","this","tis","to","too","twas","us","wants","was","we","were","what","when","where","which","while","who","whom","why","will","with","would","yet","you","your"],t.Pipeline.registerFunction(t.stopWordFilter,"stopWordFilter"),t.trimmer=function(t){return t.replace(/^\W+/,"").replace(/\W+$/,"")},t.Pipeline.registerFunction(t.trimmer,"trimmer"),t.TokenStore=function(){this.root={docs:{}},this.length=0},t.TokenStore.load=function(t){var e=new this;return e.root=t.root,e.length=t.length,e},t.TokenStore.prototype.add=function(t,e,n){var n=n||this.root,i=t[0],o=t.slice(1);return i in n||(n[i]={docs:{}}),0===o.length?(n[i].docs[e.ref]=e,void(this.length+=1)):this.add(o,e,n[i])},t.TokenStore.prototype.has=function(t){if(!t)return!1;for(var e=this.root,n=0;n<t.length;n++){if(!e[t[n]])return!1;e=e[t[n]]}return!0},t.TokenStore.prototype.getNode=function(t){if(!t)return{};for(var e=this.root,n=0;n<t.length;n++){if(!e[t[n]])return{};e=e[t[n]]}return e},t.TokenStore.prototype.get=function(t,e){return this.getNode(t,e).docs||{}},t.TokenStore.prototype.count=function(t,e){return Object.keys(this.get(t,e)).length},t.TokenStore.prototype.remove=function(t,e){if(t){for(var n=this.root,i=0;i<t.length;i++){if(!(t[i]in n))return;n=n[t[i]]}delete n.docs[e]}},t.TokenStore.prototype.expand=function(t,e){var n=this.getNode(t),i=n.docs||{},e=e||[];return Object.keys(i).length&&e.push(t),Object.keys(n).forEach(function(n){"docs"!==n&&e.concat(this.expand(t+n,e))},this),e},t.TokenStore.prototype.toJSON=function(){return{root:this.root,length:this.length}},function(t,e){"function"==typeof define&&define.amd?define(e):"object"==typeof exports?module.exports=e():t.lunr=e()}(this,function(){return t})}();var __extends=this&&this.__extends||function(){var extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(d,b){d.__proto__=b}||function(d,b){for(var p in b)b.hasOwnProperty(p)&&(d[p]=b[p])};return function(d,b){function __(){this.constructor=d}extendStatics(d,b),d.prototype=null===b?Object.create(b):(__.prototype=b.prototype,new __)}}(),typedoc;!function(typedoc){function registerService(constructor,name,priority){void 0===priority&&(priority=0),services.push({constructor:constructor,name:name,priority:priority,instance:null}),services.sort(function(a,b){return a.priority-b.priority})}function registerComponent(constructor,selector,priority,namespace){void 0===priority&&(priority=0),void 0===namespace&&(namespace="*"),components.push({selector:selector,constructor:constructor,priority:priority,namespace:namespace}),components.sort(function(a,b){return a.priority-b.priority})}typedoc.$html=$("html");var services=[],components=[];typedoc.$document=$(document),typedoc.$window=$(window),typedoc.$body=$("body"),typedoc.registerService=registerService,typedoc.registerComponent=registerComponent,"undefined"!=typeof Backbone&&(typedoc.Events=function(){var res=function(){};return _.extend(res.prototype,Backbone.Events),res}());var Application=function(_super){function Application(){var _this=_super.call(this)||this;return _this.createServices(),_this.createComponents(typedoc.$body),_this}return __extends(Application,_super),Application.prototype.createServices=function(){_(services).forEach(function(c){c.instance=new c.constructor,typedoc[c.name]=c.instance})},Application.prototype.createComponents=function($context,namespace){void 0===namespace&&(namespace="default");var result=[];return _(components).forEach(function(c){c.namespace!=namespace&&"*"!=c.namespace||$context.find(c.selector).each(function(m,el){var instance,$el=$(el);(instance=$el.data("component"))?_(result).indexOf(instance)==-1&&result.push(instance):(instance=new c.constructor({el:el}),$el.data("component",instance),result.push(instance))})}),result},Application}(typedoc.Events);typedoc.Application=Application}(typedoc||(typedoc={}));var typedoc;!function(typedoc){typedoc.app=new typedoc.Application}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var FilterItem=function(){function FilterItem(key,value){this.key=key,this.value=value,this.defaultValue=value,this.initialize(),window.localStorage[this.key]&&this.setValue(this.fromLocalStorage(window.localStorage[this.key]))}return FilterItem.prototype.initialize=function(){},FilterItem.prototype.handleValueChange=function(oldValue,newValue){},FilterItem.prototype.fromLocalStorage=function(value){return value},FilterItem.prototype.toLocalStorage=function(value){return value},FilterItem.prototype.setValue=function(value){if(this.value!=value){var oldValue=this.value;this.value=value,window.localStorage[this.key]=this.toLocalStorage(value),this.handleValueChange(oldValue,value)}},FilterItem}(),FilterItemCheckbox=function(_super){function FilterItemCheckbox(){return null!==_super&&_super.apply(this,arguments)||this}return __extends(FilterItemCheckbox,_super),FilterItemCheckbox.prototype.initialize=function(){var _this=this;this.$checkbox=$("#tsd-filter-"+this.key),this.$checkbox.on("change",function(){_this.setValue(_this.$checkbox.prop("checked"))})},FilterItemCheckbox.prototype.handleValueChange=function(oldValue,newValue){this.$checkbox.prop("checked",this.value),typedoc.$html.toggleClass("toggle-"+this.key,this.value!=this.defaultValue)},FilterItemCheckbox.prototype.fromLocalStorage=function(value){return"true"==value},FilterItemCheckbox.prototype.toLocalStorage=function(value){return value?"true":"false"},FilterItemCheckbox}(FilterItem),FilterItemSelect=function(_super){function FilterItemSelect(){return null!==_super&&_super.apply(this,arguments)||this}return __extends(FilterItemSelect,_super),FilterItemSelect.prototype.initialize=function(){var _this=this;typedoc.$html.addClass("toggle-"+this.key+this.value),this.$select=$("#tsd-filter-"+this.key),this.$select.on(typedoc.pointerDown+" mouseover",function(){_this.$select.addClass("active")}).on("mouseleave",function(){_this.$select.removeClass("active")}).on(typedoc.pointerUp,"li",function(e){_this.$select.removeClass("active"),_this.setValue($(e.target).attr("data-value"))}),typedoc.$document.on(typedoc.pointerDown,function(e){$(e.target).parents().addBack().is(_this.$select)||_this.$select.removeClass("active")})},FilterItemSelect.prototype.handleValueChange=function(oldValue,newValue){this.$select.find("li.selected").removeClass("selected"),this.$select.find(".tsd-select-label").text(this.$select.find('li[data-value="'+newValue+'"]').addClass("selected").text()),typedoc.$html.removeClass("toggle-"+oldValue),typedoc.$html.addClass("toggle-"+newValue)},FilterItemSelect}(FilterItem),Filter=function(_super){function Filter(options){var _this=_super.call(this,options)||this;return _this.optionVisibility=new FilterItemSelect("visibility","private"),_this.optionInherited=new FilterItemCheckbox("inherited",!0),_this.optionExternals=new FilterItemCheckbox("externals",!0),_this.optionOnlyExported=new FilterItemCheckbox("only-exported",!1),_this}return __extends(Filter,_super),Filter.isSupported=function(){try{return void 0!==window.localStorage}catch(e){return!1}},Filter}(Backbone.View);Filter.isSupported()?typedoc.registerComponent(Filter,"#tsd-filter"):typedoc.$html.addClass("no-filter")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var MenuHighlight=function(_super){function MenuHighlight(options){var _this=_super.call(this,options)||this;return _this.index=0,_this.listenTo(typedoc.viewport,"resize",_this.onResize),_this.listenTo(typedoc.viewport,"scroll",_this.onScroll),_this.createAnchors(),_this}return __extends(MenuHighlight,_super),MenuHighlight.prototype.createAnchors=function(){var _this=this;this.index=0,this.anchors=[{position:0}];var base=window.location.href;base.indexOf("#")!=-1&&(base=base.substr(0,base.indexOf("#"))),this.$el.find("a").each(function(index,el){var href=el.href;if(href.indexOf("#")!=-1&&href.substr(0,base.length)==base){var hash=href.substr(href.indexOf("#")+1),$anchor=$("a.tsd-anchor[name="+hash+"]");0!=$anchor.length&&_this.anchors.push({$link:$(el.parentNode),$anchor:$anchor,position:0})}}),this.onResize()},MenuHighlight.prototype.onResize=function(){for(var anchor,index=1,count=this.anchors.length;index<count;index++)anchor=this.anchors[index],anchor.position=anchor.$anchor.offset().top;this.anchors.sort(function(a,b){return a.position-b.position}),this.onScroll(typedoc.viewport.scrollTop)},MenuHighlight.prototype.onScroll=function(scrollTop){var anchors=this.anchors,index=this.index,count=anchors.length-1;for(scrollTop+=5;index>0&&anchors[index].position>scrollTop;)index-=1;for(;index<count&&anchors[index+1].position<scrollTop;)index+=1;this.index!=index&&(this.index>0&&this.anchors[this.index].$link.removeClass("focus"),this.index=index,this.index>0&&this.anchors[this.index].$link.addClass("focus"))},MenuHighlight}(Backbone.View);typedoc.MenuHighlight=MenuHighlight,typedoc.registerComponent(MenuHighlight,".menu-highlight")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var StickyMode,hasPositionSticky=typedoc.$html.hasClass("csspositionsticky");!function(StickyMode){StickyMode[StickyMode.None=0]="None",StickyMode[StickyMode.Secondary=1]="Secondary",StickyMode[StickyMode.Current=2]="Current"}(StickyMode||(StickyMode={}));var MenuSticky=function(_super){function MenuSticky(options){var _this=_super.call(this,options)||this;return _this.state="",_this.stickyMode=StickyMode.None,_this.$current=_this.$el.find("> ul.current"),_this.$navigation=_this.$el.parents(".menu-sticky-wrap"),_this.$container=_this.$el.parents(".row"),_this.listenTo(typedoc.viewport,"resize",_this.onResize),hasPositionSticky||_this.listenTo(typedoc.viewport,"scroll",_this.onScroll),_this.onResize(typedoc.viewport.width,typedoc.viewport.height),_this}return __extends(MenuSticky,_super),MenuSticky.prototype.setState=function(state){this.state!=state&&(""!=this.state&&this.$navigation.removeClass(this.state),this.state=state,""!=this.state&&this.$navigation.addClass(this.state))},MenuSticky.prototype.onResize=function(width,height){this.stickyMode=StickyMode.None,this.setState("");var containerTop=this.$container.offset().top,containerHeight=this.$container.height(),bottom=containerTop+containerHeight;if(this.$navigation.height()<containerHeight){var elHeight=this.$el.height(),elTop=this.$el.offset().top;if(this.$current.length){var currentHeight=this.$current.height(),currentTop=this.$current.offset().top;this.$navigation.css("top",containerTop-currentTop+20),currentHeight<height&&(this.stickyMode=StickyMode.Current,this.stickyTop=currentTop,this.stickyBottom=bottom-elHeight+(currentTop-elTop)-20)}elHeight<height&&(this.$navigation.css("top",containerTop-elTop+20),this.stickyMode=StickyMode.Secondary,this.stickyTop=elTop,this.stickyBottom=bottom-elHeight-20)}hasPositionSticky?this.stickyMode==StickyMode.Current?this.setState("sticky-current"):this.stickyMode==StickyMode.Secondary?this.setState("sticky"):this.setState(""):(this.$navigation.css("left",this.$navigation.offset().left),this.onScroll(typedoc.viewport.scrollTop))},MenuSticky.prototype.onScroll=function(scrollTop){this.stickyMode==StickyMode.Current?scrollTop>this.stickyBottom?this.setState("sticky-bottom"):this.setState(scrollTop+20>this.stickyTop?"sticky-current":""):this.stickyMode==StickyMode.Secondary&&(scrollTop>this.stickyBottom?this.setState("sticky-bottom"):this.setState(scrollTop+20>this.stickyTop?"sticky":""))},MenuSticky}(Backbone.View);typedoc.MenuSticky=MenuSticky,typedoc.registerComponent(MenuSticky,".menu-sticky")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var search;!function(search){function createIndex(){function batch(){for(var cycles=0;cycles++<100;)if(index.add(rows[pos]),++pos==length)return setLoadingState(SearchLoadingState.Ready);setTimeout(batch,10)}index=new lunr.Index,index.pipeline.add(lunr.trimmer),index.field("name",{boost:10}),index.field("parent"),index.ref("id");var rows=search.data.rows,pos=0,length=rows.length;batch()}function loadIndex(){loadingState==SearchLoadingState.Idle&&(setTimeout(function(){loadingState==SearchLoadingState.Idle&&setLoadingState(SearchLoadingState.Loading)},500),void 0!==search.data?createIndex():$.get($el.attr("data-index")).done(function(source){eval(source),createIndex()}).fail(function(){setLoadingState(SearchLoadingState.Failure)}))}function updateResults(){if(loadingState==SearchLoadingState.Ready){$results.empty();for(var res=index.search(query),i=0,c=Math.min(10,res.length);i<c;i++){var row=search.data.rows[res[i].ref],name=row.name;row.parent&&(name='<span class="parent">'+row.parent+".</span>"+name),$results.append('<li class="'+row.classes+'"><a href="'+base+row.url+'" class="tsd-kind-icon">'+name+"</li>")}}}function setLoadingState(value){loadingState!=value&&($el.removeClass(SearchLoadingState[loadingState].toLowerCase()),loadingState=value,$el.addClass(SearchLoadingState[loadingState].toLowerCase()),value==SearchLoadingState.Ready&&updateResults())}function setHasFocus(value){hasFocus!=value&&(hasFocus=value,$el.toggleClass("has-focus"),value?(setQuery(""),$field.val("")):$field.val(query))}function setQuery(value){query=$.trim(value),updateResults()}function setCurrentResult(dir){var $current=$results.find(".current");if(0==$current.length)$results.find(1==dir?"li:first-child":"li:last-child").addClass("current");else{var $rel=1==dir?$current.next("li"):$current.prev("li");$rel.length>0&&($current.removeClass("current"),$rel.addClass("current"))}}function gotoCurrentResult(){var $current=$results.find(".current");0==$current.length&&($current=$results.find("li:first-child")),$current.length>0&&(window.location.href=$current.find("a").prop("href"),$field.blur())}var SearchLoadingState;!function(SearchLoadingState){SearchLoadingState[SearchLoadingState.Idle=0]="Idle",SearchLoadingState[SearchLoadingState.Loading=1]="Loading",SearchLoadingState[SearchLoadingState.Ready=2]="Ready",SearchLoadingState[SearchLoadingState.Failure=3]="Failure"}(SearchLoadingState||(SearchLoadingState={}));var $el=$("#tsd-search"),$field=$("#tsd-search-field"),$results=$(".results"),base=$el.attr("data-base")+"/",query="",loadingState=SearchLoadingState.Idle,hasFocus=!1,preventPress=!1,index;$field.on("focusin",function(){setHasFocus(!0),loadIndex()}).on("focusout",function(){setTimeout(function(){return setHasFocus(!1)},100)}).on("input",function(){setQuery($.trim($field.val()))}).on("keydown",function(e){13==e.keyCode||27==e.keyCode||38==e.keyCode||40==e.keyCode?(preventPress=!0,e.preventDefault(),13==e.keyCode?gotoCurrentResult():27==e.keyCode?$field.blur():38==e.keyCode?setCurrentResult(-1):40==e.keyCode&&setCurrentResult(1)):preventPress=!1}).on("keypress",function(e){preventPress&&e.preventDefault()}),$("body").on("keydown",function(e){e.altKey||e.ctrlKey||e.metaKey||!hasFocus&&e.keyCode>47&&e.keyCode<112&&$field.focus()})}(search=typedoc.search||(typedoc.search={}))}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var SignatureGroup=function(){function SignatureGroup($signature,$description){this.$signature=$signature,this.$description=$description}return SignatureGroup.prototype.addClass=function(className){return this.$signature.addClass(className),this.$description.addClass(className),this},SignatureGroup.prototype.removeClass=function(className){return this.$signature.removeClass(className),this.$description.removeClass(className),this},SignatureGroup}(),Signature=function(_super){function Signature(options){var _this=_super.call(this,options)||this;return _this.index=-1,_this.createGroups(),_this.groups&&(_this.$el.addClass("active").on("touchstart",".tsd-signature",function(event){return _this.onClick(event)}).on("click",".tsd-signature",function(event){return _this.onClick(event)}),_this.$container.addClass("active"),_this.setIndex(0)),_this}return __extends(Signature,_super),Signature.prototype.setIndex=function(index){if(index<0&&(index=0),index>this.groups.length-1&&(index=this.groups.length-1),this.index!=index){var to=this.groups[index];if(this.index>-1){var from=this.groups[this.index];typedoc.animateHeight(this.$container,function(){from.removeClass("current").addClass("fade-out"),to.addClass("current fade-in"),typedoc.viewport.triggerResize()}),setTimeout(function(){from.removeClass("fade-out"),to.removeClass("fade-in")},300)}else to.addClass("current"),typedoc.viewport.triggerResize();this.index=index}},Signature.prototype.createGroups=function(){var _this=this,$signatures=this.$el.find("> .tsd-signature");if(!($signatures.length<2)){this.$container=this.$el.siblings(".tsd-descriptions");var $descriptions=this.$container.find("> .tsd-description");this.groups=[],$signatures.each(function(index,el){_this.groups.push(new SignatureGroup($(el),$descriptions.eq(index)))})}},Signature.prototype.onClick=function(e){var _this=this;e.preventDefault(),_(this.groups).forEach(function(group,index){group.$signature.is(e.currentTarget)&&_this.setIndex(index)})},Signature}(Backbone.View);typedoc.registerComponent(Signature,".tsd-signatures")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var Toggle=function(_super){function Toggle(options){var _this=_super.call(this,options)||this;return _this.className=_this.$el.attr("data-toggle"),_this.$el.on(typedoc.pointerUp,function(e){return _this.onPointerUp(e)}),_this.$el.on("click",function(e){return e.preventDefault()}),typedoc.$document.on(typedoc.pointerDown,function(e){return _this.onDocumentPointerDown(e)}),typedoc.$document.on(typedoc.pointerUp,function(e){return _this.onDocumentPointerUp(e)}),_this}return __extends(Toggle,_super),Toggle.prototype.setActive=function(value){if(this.active!=value){this.active=value,typedoc.$html.toggleClass("has-"+this.className,value),this.$el.toggleClass("active",value);var transition=(this.active?"to-has-":"from-has-")+this.className;typedoc.$html.addClass(transition),setTimeout(function(){return typedoc.$html.removeClass(transition)},500)}},Toggle.prototype.onPointerUp=function(event){typedoc.hasPointerMoved||(this.setActive(!0),event.preventDefault())},Toggle.prototype.onDocumentPointerDown=function(e){if(this.active){var $path=$(e.target).parents().addBack();if($path.hasClass("col-menu"))return;if($path.hasClass("tsd-filter-group"))return;this.setActive(!1)}},Toggle.prototype.onDocumentPointerUp=function(e){var _this=this;if(!typedoc.hasPointerMoved&&this.active){var $path=$(e.target).parents().addBack();if($path.hasClass("col-menu")){var $link=$path.filter("a");if($link.length){var href=window.location.href;href.indexOf("#")!=-1&&(href=href.substr(0,href.indexOf("#"))),$link.prop("href").substr(0,href.length)==href&&setTimeout(function(){return _this.setActive(!1)},250)}}}},Toggle}(Backbone.View);typedoc.registerComponent(Toggle,"a[data-toggle]")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var Viewport=function(_super){function Viewport(){var _this=_super.call(this)||this;return _this.scrollTop=0,_this.width=0,_this.height=0,typedoc.$window.on("scroll",_(function(){return _this.onScroll()}).throttle(10)),typedoc.$window.on("resize",_(function(){return _this.onResize()}).throttle(10)),_this.onResize(),_this.onScroll(),_this}return __extends(Viewport,_super),Viewport.prototype.triggerResize=function(){this.trigger("resize",this.width,this.height)},Viewport.prototype.onResize=function(){this.width=typedoc.$window.width(),this.height=typedoc.$window.height(),this.trigger("resize",this.width,this.height)},Viewport.prototype.onScroll=function(){this.scrollTop=typedoc.$window.scrollTop(),this.trigger("scroll",this.scrollTop)},Viewport}(typedoc.Events);typedoc.Viewport=Viewport,typedoc.registerService(Viewport,"viewport")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){typedoc.pointerDown="mousedown",typedoc.pointerMove="mousemove",typedoc.pointerUp="mouseup",typedoc.pointerDownPosition={x:0,y:0},typedoc.preventNextClick=!1,typedoc.isPointerDown=!1,typedoc.isPointerTouch=!1,typedoc.hasPointerMoved=!1,typedoc.isMobile=/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent),typedoc.$html.addClass(typedoc.isMobile?"is-mobile":"not-mobile"),typedoc.isMobile&&"ontouchstart"in document.documentElement&&(typedoc.isPointerTouch=!0,typedoc.pointerDown="touchstart",typedoc.pointerMove="touchmove",typedoc.pointerUp="touchend"),typedoc.$document.on(typedoc.pointerDown,function(e){typedoc.isPointerDown=!0,typedoc.hasPointerMoved=!1;var t="touchstart"==typedoc.pointerDown?e.originalEvent.targetTouches[0]:e;typedoc.pointerDownPosition.x=t.pageX,typedoc.pointerDownPosition.y=t.pageY}).on(typedoc.pointerMove,function(e){if(typedoc.isPointerDown&&!typedoc.hasPointerMoved){var t="touchstart"==typedoc.pointerDown?e.originalEvent.targetTouches[0]:e,x=typedoc.pointerDownPosition.x-t.pageX,y=typedoc.pointerDownPosition.y-t.pageY;typedoc.hasPointerMoved=Math.sqrt(x*x+y*y)>10}}).on(typedoc.pointerUp,function(e){typedoc.isPointerDown=!1}).on("click",function(e){typedoc.preventNextClick&&(e.preventDefault(),e.stopImmediatePropagation(),typedoc.preventNextClick=!1)})}(typedoc||(typedoc={}));var typedoc;!function(typedoc){function noTransition($el,callback){$el.addClass("no-transition"),callback(),$el.offset(),$el.removeClass("no-transition")}function animateHeight($el,callback,success){var to,from=$el.height();noTransition($el,function(){callback(),$el.css("height",""),to=$el.height(),from!=to&&typedoc.transition&&$el.css("height",from)}),from!=to&&typedoc.transition?($el.css("height",to),$el.on(typedoc.transition.endEvent,function(){noTransition($el,function(){$el.off(typedoc.transition.endEvent).css("height",""),success&&success()})})):success&&success()}typedoc.transition=function(tuples){for(var name in tuples)if(tuples.hasOwnProperty(name)&&void 0!==document.body.style[name])return{name:name,endEvent:tuples[name]};return null}({transition:"transitionend",OTransition:"oTransitionEnd",msTransition:"msTransitionEnd",MozTransition:"transitionend",WebkitTransition:"webkitTransitionEnd"}),typedoc.noTransition=noTransition,typedoc.animateHeight=animateHeight}(typedoc||(typedoc={})); \ No newline at end of file +;r=m[1],f=new RegExp("^("+o+")?"+i),f.test(r)&&(n=r,f=/(at|bl|iz)$/,d=new RegExp("([^aeiouylsz])\\1$"),v=new RegExp("^"+o+i+"[^aeiouwxy]$"),f.test(n)?n+="e":d.test(n)?(p=/.$/,n=n.replace(p,"")):v.test(n)&&(n+="e"))}if(p=/^(.+?[^aeiou])y$/,p.test(n)){var m=p.exec(n);r=m[1],n=r+"i"}if(p=/^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/,p.test(n)){var m=p.exec(n);r=m[1],u=m[2],p=new RegExp(s),p.test(r)&&(n=r+t[u])}if(p=/^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/,p.test(n)){var m=p.exec(n);r=m[1],u=m[2],p=new RegExp(s),p.test(r)&&(n=r+e[u])}if(p=/^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/,f=/^(.+?)(s|t)(ion)$/,p.test(n)){var m=p.exec(n);r=m[1],p=new RegExp(h),p.test(r)&&(n=r)}else if(f.test(n)){var m=f.exec(n);r=m[1]+m[2],f=new RegExp(h),f.test(r)&&(n=r)}if(p=/^(.+?)e$/,p.test(n)){var m=p.exec(n);r=m[1],p=new RegExp(h),f=new RegExp("^("+o+")?"+r+o+"("+r+")?$"),d=new RegExp("^"+o+i+"[^aeiouwxy]$"),(p.test(r)||f.test(r)&&!d.test(r))&&(n=r)}return p=/ll$/,f=new RegExp(h),p.test(n)&&f.test(n)&&(p=/.$/,n=n.replace(p,"")),"y"==c&&(n=c.toLowerCase()+n.substr(1)),n}}(),t.Pipeline.registerFunction(t.stemmer,"stemmer"),t.stopWordFilter=function(e){return-1===t.stopWordFilter.stopWords.indexOf(e)?e:void 0},t.stopWordFilter.stopWords=new t.SortedSet,t.stopWordFilter.stopWords.length=119,t.stopWordFilter.stopWords.elements=["","a","able","about","across","after","all","almost","also","am","among","an","and","any","are","as","at","be","because","been","but","by","can","cannot","could","dear","did","do","does","either","else","ever","every","for","from","get","got","had","has","have","he","her","hers","him","his","how","however","i","if","in","into","is","it","its","just","least","let","like","likely","may","me","might","most","must","my","neither","no","nor","not","of","off","often","on","only","or","other","our","own","rather","said","say","says","she","should","since","so","some","than","that","the","their","them","then","there","these","they","this","tis","to","too","twas","us","wants","was","we","were","what","when","where","which","while","who","whom","why","will","with","would","yet","you","your"],t.Pipeline.registerFunction(t.stopWordFilter,"stopWordFilter"),t.trimmer=function(t){return t.replace(/^\W+/,"").replace(/\W+$/,"")},t.Pipeline.registerFunction(t.trimmer,"trimmer"),t.TokenStore=function(){this.root={docs:{}},this.length=0},t.TokenStore.load=function(t){var e=new this;return e.root=t.root,e.length=t.length,e},t.TokenStore.prototype.add=function(t,e,n){var n=n||this.root,i=t[0],o=t.slice(1);return i in n||(n[i]={docs:{}}),0===o.length?(n[i].docs[e.ref]=e,void(this.length+=1)):this.add(o,e,n[i])},t.TokenStore.prototype.has=function(t){if(!t)return!1;for(var e=this.root,n=0;n<t.length;n++){if(!e[t[n]])return!1;e=e[t[n]]}return!0},t.TokenStore.prototype.getNode=function(t){if(!t)return{};for(var e=this.root,n=0;n<t.length;n++){if(!e[t[n]])return{};e=e[t[n]]}return e},t.TokenStore.prototype.get=function(t,e){return this.getNode(t,e).docs||{}},t.TokenStore.prototype.count=function(t,e){return Object.keys(this.get(t,e)).length},t.TokenStore.prototype.remove=function(t,e){if(t){for(var n=this.root,i=0;i<t.length;i++){if(!(t[i]in n))return;n=n[t[i]]}delete n.docs[e]}},t.TokenStore.prototype.expand=function(t,e){var n=this.getNode(t),i=n.docs||{},e=e||[];return Object.keys(i).length&&e.push(t),Object.keys(n).forEach(function(n){"docs"!==n&&e.concat(this.expand(t+n,e))},this),e},t.TokenStore.prototype.toJSON=function(){return{root:this.root,length:this.length}},function(t,e){"function"==typeof define&&define.amd?define(e):"object"==typeof exports?module.exports=e():t.lunr=e()}(this,function(){return t})}();var __extends=this&&this.__extends||function(){var extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(d,b){d.__proto__=b}||function(d,b){for(var p in b)b.hasOwnProperty(p)&&(d[p]=b[p])};return function(d,b){function __(){this.constructor=d}extendStatics(d,b),d.prototype=null===b?Object.create(b):(__.prototype=b.prototype,new __)}}(),typedoc;!function(typedoc){function registerService(constructor,name,priority){void 0===priority&&(priority=0),services.push({constructor:constructor,name:name,priority:priority,instance:null}),services.sort(function(a,b){return a.priority-b.priority})}function registerComponent(constructor,selector,priority,namespace){void 0===priority&&(priority=0),void 0===namespace&&(namespace="*"),components.push({selector:selector,constructor:constructor,priority:priority,namespace:namespace}),components.sort(function(a,b){return a.priority-b.priority})}typedoc.$html=$("html");var services=[],components=[];typedoc.$document=$(document),typedoc.$window=$(window),typedoc.$body=$("body"),typedoc.registerService=registerService,typedoc.registerComponent=registerComponent,"undefined"!=typeof Backbone&&(typedoc.Events=function(){var res=function(){};return _.extend(res.prototype,Backbone.Events),res}());var Application=function(_super){function Application(){var _this=_super.call(this)||this;return _this.createServices(),_this.createComponents(typedoc.$body),_this}return __extends(Application,_super),Application.prototype.createServices=function(){_(services).forEach(function(c){c.instance=new c.constructor,typedoc[c.name]=c.instance})},Application.prototype.createComponents=function($context,namespace){void 0===namespace&&(namespace="default");var result=[];return _(components).forEach(function(c){c.namespace!=namespace&&"*"!=c.namespace||$context.find(c.selector).each(function(m,el){var instance,$el=$(el);(instance=$el.data("component"))?_(result).indexOf(instance)==-1&&result.push(instance):(instance=new c.constructor({el:el}),$el.data("component",instance),result.push(instance))})}),result},Application}(typedoc.Events);typedoc.Application=Application}(typedoc||(typedoc={}));var typedoc;!function(typedoc){typedoc.app=new typedoc.Application}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var FilterItem=function(){function FilterItem(key,value){this.key=key,this.value=value,this.defaultValue=value,this.initialize(),window.localStorage[this.key]&&this.setValue(this.fromLocalStorage(window.localStorage[this.key]))}return FilterItem.prototype.initialize=function(){},FilterItem.prototype.handleValueChange=function(oldValue,newValue){},FilterItem.prototype.fromLocalStorage=function(value){return value},FilterItem.prototype.toLocalStorage=function(value){return value},FilterItem.prototype.setValue=function(value){if(this.value!=value){var oldValue=this.value;this.value=value,window.localStorage[this.key]=this.toLocalStorage(value),this.handleValueChange(oldValue,value)}},FilterItem}(),FilterItemCheckbox=function(_super){function FilterItemCheckbox(){return null!==_super&&_super.apply(this,arguments)||this}return __extends(FilterItemCheckbox,_super),FilterItemCheckbox.prototype.initialize=function(){var _this=this;this.$checkbox=$("#tsd-filter-"+this.key),this.$checkbox.on("change",function(){_this.setValue(_this.$checkbox.prop("checked"))})},FilterItemCheckbox.prototype.handleValueChange=function(oldValue,newValue){this.$checkbox.prop("checked",this.value),typedoc.$html.toggleClass("toggle-"+this.key,this.value!=this.defaultValue)},FilterItemCheckbox.prototype.fromLocalStorage=function(value){return"true"==value},FilterItemCheckbox.prototype.toLocalStorage=function(value){return value?"true":"false"},FilterItemCheckbox}(FilterItem),FilterItemSelect=function(_super){function FilterItemSelect(){return null!==_super&&_super.apply(this,arguments)||this}return __extends(FilterItemSelect,_super),FilterItemSelect.prototype.initialize=function(){var _this=this;typedoc.$html.addClass("toggle-"+this.key+this.value),this.$select=$("#tsd-filter-"+this.key),this.$select.on(typedoc.pointerDown+" mouseover",function(){_this.$select.addClass("active")}).on("mouseleave",function(){_this.$select.removeClass("active")}).on(typedoc.pointerUp,"li",function(e){_this.$select.removeClass("active"),_this.setValue($(e.target).attr("_data-value"))}),typedoc.$document.on(typedoc.pointerDown,function(e){$(e.target).parents().addBack().is(_this.$select)||_this.$select.removeClass("active")})},FilterItemSelect.prototype.handleValueChange=function(oldValue,newValue){this.$select.find("li.selected").removeClass("selected"),this.$select.find(".tsd-select-label").text(this.$select.find('li[_data-value="'+newValue+'"]').addClass("selected").text()),typedoc.$html.removeClass("toggle-"+oldValue),typedoc.$html.addClass("toggle-"+newValue)},FilterItemSelect}(FilterItem),Filter=function(_super){function Filter(options){var _this=_super.call(this,options)||this;return _this.optionVisibility=new FilterItemSelect("visibility","private"),_this.optionInherited=new FilterItemCheckbox("inherited",!0),_this.optionExternals=new FilterItemCheckbox("externals",!0),_this.optionOnlyExported=new FilterItemCheckbox("only-exported",!1),_this}return __extends(Filter,_super),Filter.isSupported=function(){try{return void 0!==window.localStorage}catch(e){return!1}},Filter}(Backbone.View);Filter.isSupported()?typedoc.registerComponent(Filter,"#tsd-filter"):typedoc.$html.addClass("no-filter")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var MenuHighlight=function(_super){function MenuHighlight(options){var _this=_super.call(this,options)||this;return _this.index=0,_this.listenTo(typedoc.viewport,"resize",_this.onResize),_this.listenTo(typedoc.viewport,"scroll",_this.onScroll),_this.createAnchors(),_this}return __extends(MenuHighlight,_super),MenuHighlight.prototype.createAnchors=function(){var _this=this;this.index=0,this.anchors=[{position:0}];var base=window.location.href;base.indexOf("#")!=-1&&(base=base.substr(0,base.indexOf("#"))),this.$el.find("a").each(function(index,el){var href=el.href;if(href.indexOf("#")!=-1&&href.substr(0,base.length)==base){var hash=href.substr(href.indexOf("#")+1),$anchor=$("a.tsd-anchor[name="+hash+"]");0!=$anchor.length&&_this.anchors.push({$link:$(el.parentNode),$anchor:$anchor,position:0})}}),this.onResize()},MenuHighlight.prototype.onResize=function(){for(var anchor,index=1,count=this.anchors.length;index<count;index++)anchor=this.anchors[index],anchor.position=anchor.$anchor.offset().top;this.anchors.sort(function(a,b){return a.position-b.position}),this.onScroll(typedoc.viewport.scrollTop)},MenuHighlight.prototype.onScroll=function(scrollTop){var anchors=this.anchors,index=this.index,count=anchors.length-1;for(scrollTop+=5;index>0&&anchors[index].position>scrollTop;)index-=1;for(;index<count&&anchors[index+1].position<scrollTop;)index+=1;this.index!=index&&(this.index>0&&this.anchors[this.index].$link.removeClass("focus"),this.index=index,this.index>0&&this.anchors[this.index].$link.addClass("focus"))},MenuHighlight}(Backbone.View);typedoc.MenuHighlight=MenuHighlight,typedoc.registerComponent(MenuHighlight,".menu-highlight")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var StickyMode,hasPositionSticky=typedoc.$html.hasClass("csspositionsticky");!function(StickyMode){StickyMode[StickyMode.None=0]="None",StickyMode[StickyMode.Secondary=1]="Secondary",StickyMode[StickyMode.Current=2]="Current"}(StickyMode||(StickyMode={}));var MenuSticky=function(_super){function MenuSticky(options){var _this=_super.call(this,options)||this;return _this.state="",_this.stickyMode=StickyMode.None,_this.$current=_this.$el.find("> ul.current"),_this.$navigation=_this.$el.parents(".menu-sticky-wrap"),_this.$container=_this.$el.parents(".row"),_this.listenTo(typedoc.viewport,"resize",_this.onResize),hasPositionSticky||_this.listenTo(typedoc.viewport,"scroll",_this.onScroll),_this.onResize(typedoc.viewport.width,typedoc.viewport.height),_this}return __extends(MenuSticky,_super),MenuSticky.prototype.setState=function(state){this.state!=state&&(""!=this.state&&this.$navigation.removeClass(this.state),this.state=state,""!=this.state&&this.$navigation.addClass(this.state))},MenuSticky.prototype.onResize=function(width,height){this.stickyMode=StickyMode.None,this.setState("");var containerTop=this.$container.offset().top,containerHeight=this.$container.height(),bottom=containerTop+containerHeight;if(this.$navigation.height()<containerHeight){var elHeight=this.$el.height(),elTop=this.$el.offset().top;if(this.$current.length){var currentHeight=this.$current.height(),currentTop=this.$current.offset().top;this.$navigation.css("top",containerTop-currentTop+20),currentHeight<height&&(this.stickyMode=StickyMode.Current,this.stickyTop=currentTop,this.stickyBottom=bottom-elHeight+(currentTop-elTop)-20)}elHeight<height&&(this.$navigation.css("top",containerTop-elTop+20),this.stickyMode=StickyMode.Secondary,this.stickyTop=elTop,this.stickyBottom=bottom-elHeight-20)}hasPositionSticky?this.stickyMode==StickyMode.Current?this.setState("sticky-current"):this.stickyMode==StickyMode.Secondary?this.setState("sticky"):this.setState(""):(this.$navigation.css("left",this.$navigation.offset().left),this.onScroll(typedoc.viewport.scrollTop))},MenuSticky.prototype.onScroll=function(scrollTop){this.stickyMode==StickyMode.Current?scrollTop>this.stickyBottom?this.setState("sticky-bottom"):this.setState(scrollTop+20>this.stickyTop?"sticky-current":""):this.stickyMode==StickyMode.Secondary&&(scrollTop>this.stickyBottom?this.setState("sticky-bottom"):this.setState(scrollTop+20>this.stickyTop?"sticky":""))},MenuSticky}(Backbone.View);typedoc.MenuSticky=MenuSticky,typedoc.registerComponent(MenuSticky,".menu-sticky")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var search;!function(search){function createIndex(){function batch(){for(var cycles=0;cycles++<100;)if(index.add(rows[pos]),++pos==length)return setLoadingState(SearchLoadingState.Ready);setTimeout(batch,10)}index=new lunr.Index,index.pipeline.add(lunr.trimmer),index.field("name",{boost:10}),index.field("parent"),index.ref("id");var rows=search.data.rows,pos=0,length=rows.length;batch()}function loadIndex(){loadingState==SearchLoadingState.Idle&&(setTimeout(function(){loadingState==SearchLoadingState.Idle&&setLoadingState(SearchLoadingState.Loading)},500),void 0!==search.data?createIndex():$.get($el.attr("_data-index")).done(function(source){eval(source),createIndex()}).fail(function(){setLoadingState(SearchLoadingState.Failure)}))}function updateResults(){if(loadingState==SearchLoadingState.Ready){$results.empty();for(var res=index.search(query),i=0,c=Math.min(10,res.length);i<c;i++){var row=search.data.rows[res[i].ref],name=row.name;row.parent&&(name='<span class="parent">'+row.parent+".</span>"+name),$results.append('<li class="'+row.classes+'"><a href="'+base+row.url+'" class="tsd-kind-icon">'+name+"</li>")}}}function setLoadingState(value){loadingState!=value&&($el.removeClass(SearchLoadingState[loadingState].toLowerCase()),loadingState=value,$el.addClass(SearchLoadingState[loadingState].toLowerCase()),value==SearchLoadingState.Ready&&updateResults())}function setHasFocus(value){hasFocus!=value&&(hasFocus=value,$el.toggleClass("has-focus"),value?(setQuery(""),$field.val("")):$field.val(query))}function setQuery(value){query=$.trim(value),updateResults()}function setCurrentResult(dir){var $current=$results.find(".current");if(0==$current.length)$results.find(1==dir?"li:first-child":"li:last-child").addClass("current");else{var $rel=1==dir?$current.next("li"):$current.prev("li");$rel.length>0&&($current.removeClass("current"),$rel.addClass("current"))}}function gotoCurrentResult(){var $current=$results.find(".current");0==$current.length&&($current=$results.find("li:first-child")),$current.length>0&&(window.location.href=$current.find("a").prop("href"),$field.blur())}var SearchLoadingState;!function(SearchLoadingState){SearchLoadingState[SearchLoadingState.Idle=0]="Idle",SearchLoadingState[SearchLoadingState.Loading=1]="Loading",SearchLoadingState[SearchLoadingState.Ready=2]="Ready",SearchLoadingState[SearchLoadingState.Failure=3]="Failure"}(SearchLoadingState||(SearchLoadingState={}));var $el=$("#tsd-search"),$field=$("#tsd-search-field"),$results=$(".results"),base=$el.attr("_data-base")+"/",query="",loadingState=SearchLoadingState.Idle,hasFocus=!1,preventPress=!1,index;$field.on("focusin",function(){setHasFocus(!0),loadIndex()}).on("focusout",function(){setTimeout(function(){return setHasFocus(!1)},100)}).on("input",function(){setQuery($.trim($field.val()))}).on("keydown",function(e){13==e.keyCode||27==e.keyCode||38==e.keyCode||40==e.keyCode?(preventPress=!0,e.preventDefault(),13==e.keyCode?gotoCurrentResult():27==e.keyCode?$field.blur():38==e.keyCode?setCurrentResult(-1):40==e.keyCode&&setCurrentResult(1)):preventPress=!1}).on("keypress",function(e){preventPress&&e.preventDefault()}),$("body").on("keydown",function(e){e.altKey||e.ctrlKey||e.metaKey||!hasFocus&&e.keyCode>47&&e.keyCode<112&&$field.focus()})}(search=typedoc.search||(typedoc.search={}))}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var SignatureGroup=function(){function SignatureGroup($signature,$description){this.$signature=$signature,this.$description=$description}return SignatureGroup.prototype.addClass=function(className){return this.$signature.addClass(className),this.$description.addClass(className),this},SignatureGroup.prototype.removeClass=function(className){return this.$signature.removeClass(className),this.$description.removeClass(className),this},SignatureGroup}(),Signature=function(_super){function Signature(options){var _this=_super.call(this,options)||this;return _this.index=-1,_this.createGroups(),_this.groups&&(_this.$el.addClass("active").on("touchstart",".tsd-signature",function(event){return _this.onClick(event)}).on("click",".tsd-signature",function(event){return _this.onClick(event)}),_this.$container.addClass("active"),_this.setIndex(0)),_this}return __extends(Signature,_super),Signature.prototype.setIndex=function(index){if(index<0&&(index=0),index>this.groups.length-1&&(index=this.groups.length-1),this.index!=index){var to=this.groups[index];if(this.index>-1){var from=this.groups[this.index];typedoc.animateHeight(this.$container,function(){from.removeClass("current").addClass("fade-out"),to.addClass("current fade-in"),typedoc.viewport.triggerResize()}),setTimeout(function(){from.removeClass("fade-out"),to.removeClass("fade-in")},300)}else to.addClass("current"),typedoc.viewport.triggerResize();this.index=index}},Signature.prototype.createGroups=function(){var _this=this,$signatures=this.$el.find("> .tsd-signature");if(!($signatures.length<2)){this.$container=this.$el.siblings(".tsd-descriptions");var $descriptions=this.$container.find("> .tsd-description");this.groups=[],$signatures.each(function(index,el){_this.groups.push(new SignatureGroup($(el),$descriptions.eq(index)))})}},Signature.prototype.onClick=function(e){var _this=this;e.preventDefault(),_(this.groups).forEach(function(group,index){group.$signature.is(e.currentTarget)&&_this.setIndex(index)})},Signature}(Backbone.View);typedoc.registerComponent(Signature,".tsd-signatures")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var Toggle=function(_super){function Toggle(options){var _this=_super.call(this,options)||this;return _this.className=_this.$el.attr("_data-toggle"),_this.$el.on(typedoc.pointerUp,function(e){return _this.onPointerUp(e)}),_this.$el.on("click",function(e){return e.preventDefault()}),typedoc.$document.on(typedoc.pointerDown,function(e){return _this.onDocumentPointerDown(e)}),typedoc.$document.on(typedoc.pointerUp,function(e){return _this.onDocumentPointerUp(e)}),_this}return __extends(Toggle,_super),Toggle.prototype.setActive=function(value){if(this.active!=value){this.active=value,typedoc.$html.toggleClass("has-"+this.className,value),this.$el.toggleClass("active",value);var transition=(this.active?"to-has-":"from-has-")+this.className;typedoc.$html.addClass(transition),setTimeout(function(){return typedoc.$html.removeClass(transition)},500)}},Toggle.prototype.onPointerUp=function(event){typedoc.hasPointerMoved||(this.setActive(!0),event.preventDefault())},Toggle.prototype.onDocumentPointerDown=function(e){if(this.active){var $path=$(e.target).parents().addBack();if($path.hasClass("col-menu"))return;if($path.hasClass("tsd-filter-group"))return;this.setActive(!1)}},Toggle.prototype.onDocumentPointerUp=function(e){var _this=this;if(!typedoc.hasPointerMoved&&this.active){var $path=$(e.target).parents().addBack();if($path.hasClass("col-menu")){var $link=$path.filter("a");if($link.length){var href=window.location.href;href.indexOf("#")!=-1&&(href=href.substr(0,href.indexOf("#"))),$link.prop("href").substr(0,href.length)==href&&setTimeout(function(){return _this.setActive(!1)},250)}}}},Toggle}(Backbone.View);typedoc.registerComponent(Toggle,"a[_data-toggle]")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){var Viewport=function(_super){function Viewport(){var _this=_super.call(this)||this;return _this.scrollTop=0,_this.width=0,_this.height=0,typedoc.$window.on("scroll",_(function(){return _this.onScroll()}).throttle(10)),typedoc.$window.on("resize",_(function(){return _this.onResize()}).throttle(10)),_this.onResize(),_this.onScroll(),_this}return __extends(Viewport,_super),Viewport.prototype.triggerResize=function(){this.trigger("resize",this.width,this.height)},Viewport.prototype.onResize=function(){this.width=typedoc.$window.width(),this.height=typedoc.$window.height(),this.trigger("resize",this.width,this.height)},Viewport.prototype.onScroll=function(){this.scrollTop=typedoc.$window.scrollTop(),this.trigger("scroll",this.scrollTop)},Viewport}(typedoc.Events);typedoc.Viewport=Viewport,typedoc.registerService(Viewport,"viewport")}(typedoc||(typedoc={}));var typedoc;!function(typedoc){typedoc.pointerDown="mousedown",typedoc.pointerMove="mousemove",typedoc.pointerUp="mouseup",typedoc.pointerDownPosition={x:0,y:0},typedoc.preventNextClick=!1,typedoc.isPointerDown=!1,typedoc.isPointerTouch=!1,typedoc.hasPointerMoved=!1,typedoc.isMobile=/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent),typedoc.$html.addClass(typedoc.isMobile?"is-mobile":"not-mobile"),typedoc.isMobile&&"ontouchstart"in document.documentElement&&(typedoc.isPointerTouch=!0,typedoc.pointerDown="touchstart",typedoc.pointerMove="touchmove",typedoc.pointerUp="touchend"),typedoc.$document.on(typedoc.pointerDown,function(e){typedoc.isPointerDown=!0,typedoc.hasPointerMoved=!1;var t="touchstart"==typedoc.pointerDown?e.originalEvent.targetTouches[0]:e;typedoc.pointerDownPosition.x=t.pageX,typedoc.pointerDownPosition.y=t.pageY}).on(typedoc.pointerMove,function(e){if(typedoc.isPointerDown&&!typedoc.hasPointerMoved){var t="touchstart"==typedoc.pointerDown?e.originalEvent.targetTouches[0]:e,x=typedoc.pointerDownPosition.x-t.pageX,y=typedoc.pointerDownPosition.y-t.pageY;typedoc.hasPointerMoved=Math.sqrt(x*x+y*y)>10}}).on(typedoc.pointerUp,function(e){typedoc.isPointerDown=!1}).on("click",function(e){typedoc.preventNextClick&&(e.preventDefault(),e.stopImmediatePropagation(),typedoc.preventNextClick=!1)})}(typedoc||(typedoc={}));var typedoc;!function(typedoc){function noTransition($el,callback){$el.addClass("no-transition"),callback(),$el.offset(),$el.removeClass("no-transition")}function animateHeight($el,callback,success){var to,from=$el.height();noTransition($el,function(){callback(),$el.css("height",""),to=$el.height(),from!=to&&typedoc.transition&&$el.css("height",from)}),from!=to&&typedoc.transition?($el.css("height",to),$el.on(typedoc.transition.endEvent,function(){noTransition($el,function(){$el.off(typedoc.transition.endEvent).css("height",""),success&&success()})})):success&&success()}typedoc.transition=function(tuples){for(var name in tuples)if(tuples.hasOwnProperty(name)&&void 0!==document.body.style[name])return{name:name,endEvent:tuples[name]};return null}({transition:"transitionend",OTransition:"oTransitionEnd",msTransition:"msTransitionEnd",MozTransition:"transitionend",WebkitTransition:"webkitTransitionEnd"}),typedoc.noTransition=noTransition,typedoc.animateHeight=animateHeight}(typedoc||(typedoc={})); \ No newline at end of file