comparison test-data/test1_report.html @ 0:5367786dc871 draft default tip

Uploaded
author greg
date Tue, 14 Mar 2023 15:21:14 +0000
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:5367786dc871
1 <!DOCTYPE html>
2 <html lang="en">
3 <head>
4 <meta http-equiv="Content-Type" content="text/html;charset=utf-8" >
5
6 <style rel="stylesheet">
7 /*!
8 * Bootstrap v2.0.4
9 *
10 * Copyright 2012 Twitter, Inc
11 * Licensed under the Apache License v2.0
12 * http://www.apache.org/licenses/LICENSE-2.0
13 *
14 * Designed and built with all the love in the world @twitter by @mdo and @fat.
15 */
16 .clearfix{*zoom:1;}.clearfix:before,.clearfix:after{display:table;content:"";}
17 .clearfix:after{clear:both;}
18 .hide-text{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0;}
19 .input-block-level{display:block;width:100%;min-height:28px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;}
20 .tooltip{position:absolute;z-index:1020;display:block;visibility:visible;padding:5px;font-size:11px;opacity:0;filter:alpha(opacity=0);}.tooltip.in{opacity:0.8;filter:alpha(opacity=80);}
21 .tooltip.top{margin-top:-2px;}
22 .tooltip.right{margin-left:2px;}
23 .tooltip.bottom{margin-top:2px;}
24 .tooltip.left{margin-left:-2px;}
25 .tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid #000000;}
26 .tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:5px solid #000000;}
27 .tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:5px solid #000000;}
28 .tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-right:5px solid #000000;}
29 .tooltip-inner{max-width:200px;padding:3px 8px;color:#ffffff;text-align:center;text-decoration:none;background-color:#000000;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;}
30 .tooltip-arrow{position:absolute;width:0;height:0;}
31
32 </style>
33
34 <style rel="stylesheet">
35 /* Main things */
36 html, body, div, span, h1, h3, h4, h5, h6, blockquote, pre,
37 em, sub, sup, dl, dt, dd, ol, ul, li,
38 fieldset, form, label,
39 table, caption, tbody, tfoot, thead,
40 article, aside, canvas, details, figure, figcaption, footer, header, hgroup,
41 menu, nav, output, section, time {
42 margin: 0;
43 padding: 0;
44 border: 0;
45 font-size: 100%;
46 font: inherit;
47 vertical-align: baseline;
48 }
49 body {
50 margin: 0;
51 font-family: Lucida Grande, Verdana, Arial, sans-serif;
52 font-size: 12px;
53 color: black;
54 padding-bottom: 30px;
55 }
56 a {
57 text-decoration: none;
58 /*color: #0c4f72;*/
59 color: #0077B5;
60 border-bottom: 1px solid #487b95;
61 border-color: #487b95; /* #487b95 */
62 border-color: rgba(12, 79, 114, 0.2); /* #0c4f72; */ /* #a0d2eb; */ /*rgba(0, 88, cc, 0.3);*/
63 }
64 a:visited {
65 text-decoration: none;
66 color: #8C66B2;
67 border-bottom: 1px solid #8c66b2;
68 border-color: #8c66b2;
69 border-color: rgba(102, 51, 153, 0.2);
70 }
71 a:hover {
72 text-decoration: none;
73 color: #b33; /* #0088cc; */
74 border-bottom: 1px solid #ffcccc;
75 border-color: #ffcccc;
76 border-color: rgba(255, 0, 0, 0.2); /* #55b2e0; */ /*#005580;*/
77 }
78 a.dark_bg_link {
79 color: white; /* #0088cc; */
80 border-bottom: 1px solid #cccccc;
81 border-color: #cccccc;
82 }
83 a.dark_bg_link:hover {
84 color: white; /* #0088cc; */
85 border-bottom: 1px solid white;
86 }
87
88 .leading_link_dot {
89 border-bottom: white solid 1px;
90 }
91
92 a.header_link, a.header_link:hover, a.header_link:visited {
93 color: black;
94 border-bottom: 1px solid #bbb;
95 }
96
97
98 .dotted-link {
99 cursor: pointer;
100 text-decoration: none;
101 /*color: #0c4f72;*/
102 color: #0077B5;
103 border-bottom: 1px dashed #487b95;
104 border-color: #487b95; /* #487b95 */
105 border-color: rgba(12, 79, 114, 0.2);
106 }
107 .dotted-link:hover {
108 text-decoration: none;
109 color: #b33 !important;
110 border-bottom: 1px dashed #b33 !important;
111 border-color: rgba(255, 0, 0, 0.2) !important;
112 }
113 .js:visited {
114 color: #0077B5;
115 border-bottom: 1px dashed #487b95;
116 border-color: #487b95;
117 border-color: rgba(12, 79, 114, 0.2);
118 }
119
120 .selected-switch {
121 background-color: #fafad2;
122 }
123
124 .json-code {
125 display: none;
126 }
127 .smallcapitals {
128 font-size: .875em;
129 letter-spacing: .15em;
130 margin-right: -.15em;
131 }
132 .highlight {
133 background-color:#FFF9B5;
134 padding: 0 3px;
135 margin-left: -3px;
136 }
137
138 ul.list {
139 list-style-type: none;
140 padding: 0 0 0 2em;
141 margin: -0.5em 0 0 0;
142 }
143 ul.list li {
144 margin-bottom: 0.7em;
145 }
146
147 ul.mdash {
148 margin: -1em 0 0 0;
149 padding: 0 0 0 2em;
150 }
151 ul.mdash li {
152 margin-bottom: 0.7em;
153 list-style-type: none;
154 text-indent: -1.3em;
155 behavior: expression(!this.before ? this.before = this.innerHTML = '&mdash;&nbsp;' + this.innerHTML : '');
156 }
157 ul.mdash li:before {
158 content: '\2014\a0';
159 }
160
161 .small_line_indent {
162 height: 0;
163 margin-top: -7px;
164 }
165 /************/
166
167 /* Tooltips */
168 .tooltip {
169 font-size: 0.9em;
170 margin-bottom: 5px;
171 }
172 .tooltip.in {
173 opacity: 1;
174 }
175 .tooltip-inner {
176 text-align: left;
177 }
178 .tooltip-link,
179 .tooltip-link:visited {
180 text-decoration: none;
181 color: #000;
182 border-bottom: 1px dashed #bbb;
183 cursor: hand;
184 }
185 .tooltip-link:hover {
186 text-decoration: none;
187 color: #b33;
188 border-bottom: 1px dashed #b33;
189 }
190 /************/
191
192 /*********/
193
194 .hs {
195 /* Полупробел для
196 разделения разрядов чисел:
197 10<span class="hs"></span>000 */
198 margin-left: .2em;
199 }
200
201 .rhs {
202 /* Полупробел на случай,
203 если реальный пробел важен,
204 например между ценой и валютой:
205 1<span class="rhs">&nbsp;</span>$ */
206 font-size: 50%;
207 line-height: 1;
208 }
209
210 /*9490<span class="rhs"> </span>€<br/>*/
211 /*12<span class="hs"></span>650<span class="rhs"> </span>$<br/>*/
212 /*379<span class="hs"></span>000<span*/
213 /*class="rhs"> </span><span class="b-rub">Р</span><br/>*/
214 /*100<span class="hs"></span>500<span class="rhs"> </span>+*/
215
216 /* for wrapping long words with no spaces */
217 /* http://stackoverflow.com/questions/3247358/css-how-do-i-wrap-text-with-no-whitespace-inside-a-td */
218 .wrapword {
219 white-space: -moz-pre-wrap !important; /* Mozilla, since 1999 */
220 white-space: -pre-wrap; /* Opera 4-6 */
221 white-space: -o-pre-wrap; /* Opera 7 */
222 white-space: pre-wrap; /* css-3 */
223 word-wrap: break-word; /* Internet Explorer 5.5+ */
224 word-break: break-all;
225 white-space: normal;
226 }
227
228
229 .space_1px {
230 height: 1px;
231 }
232 .space_2px {
233 height: 2px;
234 }
235 .space_3px {
236 height: 3px;
237 }
238 .space_4px {
239 height: 4px;
240 }
241 .space_5px {
242 height: 5px;
243 }
244 .space_6px {
245 height: 6px;
246 }
247 .space_7px {
248 height: 7px;
249 }
250 .space_8px {
251 height: 8px;
252 }
253 .space_9px {
254 height: 9px;
255 }
256 .space_10px {
257 height: 10px;
258 }
259 .layout-table {
260 width: 99%;
261 border-spacing: 0;
262 }
263
264 .layout-table td.layout-table-td {
265 vertical-align: top;
266 padding: 0;
267 }
268 .layout-table td.layout-table-fst-td {
269 min-width: 400px;
270 padding-right: 50px;
271 }
272 .layout-table td.layout-table-snd-td {
273 min-width: 200px;
274 }
275 .layout-table td.layout-table-trd-td {
276 }
277
278 .top-panel {
279 background-color: #444;
280 color: white;
281 min-width: 650px;
282 padding: 8px 10px 0 147px;
283 min-height: 70px;
284 text-shadow: -1px -1px 0 #111;
285 }
286 .top-panel span {
287 color: white;
288 }
289 .top-panel a {
290 color: white;
291 border-bottom: 1px solid white;
292 }
293 #to_main_menu_button a {
294 border-bottom: none;
295 }
296 .page_title {
297 margin-top: -3px;
298 margin-bottom: -3px;
299 color: white;
300 }
301 .page_subtitle {
302 line-height: 100%;
303 white-space: nowrap;
304 }
305 .content {
306 margin-left: 147px;
307 width: 90%;
308 /*padding-top: 20px;*/
309 margin-bottom: 0;
310 /*padding-bottom: 50px;*/
311 /*{# padding-right: 20px;#}*/
312 }
313 .p_after_content {
314 margin-left: 147px;
315 }
316 .links_after_content{
317 font-size: 14px;
318 }
319
320 p {
321 display: block;
322 font-size: 12px;
323 }
324
325 h1 {
326 display: block;
327 font-size: 26px;
328 padding: 0 -3px 0 5px;
329 -webkit-margin-before: 5px;
330 -webkit-margin-after: 0px;
331 -webkit-margin-start: 0px;
332 -webkit-margin-end: 0px;
333 font-weight: bold;
334 }
335
336 #header {
337 display: block;
338 width: 100%;
339 margin-bottom: 10px;
340 }
341
342 .logo_img {
343 height: 40px;
344 margin-bottom: -10px;
345 margin-left: -6px;
346 margin-right: -7px;
347 }
348 </style>
349
350 <style rel="stylesheet">
351 .report-and-plots {
352 margin-top: 15px;
353 }
354
355 /****************/
356 /* REPORT TABLE */
357 .report {
358 margin: 0 100px 50px 0;
359 float: left;
360 font-size: 1em;
361 }
362
363 #main_report {
364 /*min-width: 600px;*/
365 }
366
367 /*#extended_link {*/
368 /*margin-top: 5px;*/
369 /*}*/
370
371 #ref_report {
372 /*min-width: 300px;*/
373 margin-right: 0;
374 margin-bottom: 20px;
375 /*margin-right: 200px;*/
376 }
377
378 .report td {
379 margin: 0;
380 padding: 2px 0.6em 0 14px;
381 /*min-width: 100px;*/
382 max-width: 400px;
383 white-space: nowrap;
384 }
385 .report td.number {
386 text-align: right;
387 }
388
389 .report tr.top_row_tr td,
390 .report tr.group_header td {
391 font-weight: bold;
392 border-bottom: 1px solid #ddd;
393 }
394 .report tr.group_header td {
395 height: 20px;
396 vertical-align: bottom;
397 }
398
399 #ref_report tr.top_row_tr td,
400 #ref_report tr.group_header td {
401 font-weight: normal;
402 }
403
404 .report tr td:first-child {
405 padding-left: 0;
406 }
407 .report tr td:last-child {
408 padding-right: 0;
409 }
410
411 .report tr.row_hidden, tr.group_empty {
412 display: none;
413 }
414
415 .report tr.secondary_hidden {
416 display: none;
417 }
418
419 /*.report td.secondary_td {*/
420 /*padding-left: 10px !important;*/
421 /*}*/
422
423 span.heatmap_legend {
424 font-size: 11px;
425 display: inline-block;
426 }
427
428 #heatmap_header {
429 margin-right: 30px;
430 }
431
432 #combined_reference_length {
433 padding-top: 1px;
434 padding-bottom: 15px;
435 }
436
437 span.metric-name.expandable {
438 margin-left: -13px;
439 }
440
441 span.metric-name.secondary {
442 margin-left: 13px;
443 }
444
445 span.metric-name.expandable.collapsed::before {
446 content: '+ ';
447 color: #CCC;
448 cursor: pointer;
449 }
450
451 span.metric-name.expandable.expanded::before {
452 content: '\2212\a0'; /* &minus&nbsp */
453 color: #CCC;
454 cursor: pointer;
455 }
456
457 .report_legend {
458 padding-left: 15px; /* compensate drag handles */
459 }
460
461 #contigs_are_ordered {
462 z-index: 0;
463 position: relative;
464 }
465
466
467 /*.report .report-table-header {
468 font-weight: bold;
469 }*/
470
471 /*.report thead td {
472 border-bottom: 1px solid #bbb;
473 }*/
474
475
476 /*************/
477 /* Draggable */
478 table.moving_table {
479 box-shadow: -0px 0px 5px 1px #888888;
480 -moz-box-shadow: -0px 0px 5px 1px #888888;
481 -webkit-box-shadow: -0px 0px 5px 1px #888888;
482 /*outline: 1px solid #888888;*/
483 background-color: white;
484 z-index: 3 !important;
485 }
486
487 table.draggable .drag_handle {
488 padding: 2px 1px 0 1px;
489 margin: 0 2px 0 1px;
490
491 cursor: grab;
492 cursor: -moz-grab;
493 cursor: -webkit-grab;
494 }
495
496 table.draggable .drag_handle .drag_image {
497 height: 9px;
498 width: 9px;
499 display: inline-block;
500 background: url("") no-repeat;
501 }
502
503 table.draggable .drag_handle:active,
504 table.draggable td.cell_of_moving_table .drag_handle {
505 cursor: grabbing !important;
506 cursor: -moz-grabbing !important;
507 cursor: -webkit-grabbing !important;
508 }
509
510 /* Override the styles for the first and the last columns of the table.report.
511 The cloned table contains a single column which is both first and last,
512 and we don't need it to inherit those styles. */
513 table.draggable td.cell_of_moving_table {
514 padding-left: 14px !important;
515 padding-right: 0.6em !important;
516 }
517
518 table.draggable td.hovered_column_td {
519 background-color: #cccccc;
520 }
521
522 table.draggable td.second_through_last_col_headers_td {
523 padding-left: 0 !important; /* compensate handle images */
524 }
525
526 table.draggable td.cell_of_empty_space * {
527 visibility: hidden;
528 }
529
530 table.draggable td.cell_of_empty_space {
531 border: none !important;
532 /*border-left: 1px solid #888888;
533 border-right: 1px solid #888888;
534 margin-right: -1px !important;
535 margin-left: -1px !important; */
536 }
537
538 /*table.draggable td.bottom_cell_of_empty_space {
539 border-bottom: 1px solid #888888 !important;
540 }
541
542 table.draggable td.top_cell_of_empty_space {
543 border-top: 1px solid #888888 !important;
544 /*margin-top: -1px;
545 }*/
546
547 table.draggable td.top_cell_of_empty_space {
548 }
549
550 table.draggable td.left_to_cell_of_empty_space {
551 /*outline-left: 1px solid #888888;*/
552 }
553
554 table.draggable td.right_to_cell_of_empty_space {
555 /*outline-right: 1px solid #888888;*/
556 }
557
558 /********/
559 /* META */
560 #main_ref_genome {
561
562 }
563
564 table#refgenome td.last_row {
565 border-top: 1px solid #ddd;
566 }
567
568 /************/
569 /* PLOTTING */
570 .plot-switch {
571 margin-left: 10px;
572 }
573
574 .plot-mis-type-switch {
575 margin-left: 23px;
576 }
577
578 .plot-wrapper {
579 padding-right: 80px;
580 }
581
582 .plot-header {
583 margin-left: 0;
584 font-weight: bold;
585 height: 1.5em;
586 display: block;
587 }
588
589 .plots {
590 margin-left: -30px;
591 margin-right: 70px;
592 margin-top: 2px;
593 margin-bottom: 50px;
594 float: left;
595 }
596 .plots td {
597 vertical-align: top;
598 white-space: nowrap;
599 }
600
601 .plots div#plots-switches, tr#plots-into-tr p {
602 padding-left: 30px;
603 }
604
605 #legend-placeholder {
606 min-width: 80px;
607 margin-top: -2px;
608 margin-left: -5px;
609 position: relative;
610 z-index: 0;
611 }
612
613 .legendColorBox div {
614 display: none;
615 }
616
617 #legend-placeholder td {
618 vertical-align: top;
619 white-space: nowrap;
620 }
621
622 #plot-placeholder {
623 width: 986px;
624 height: 600px;
625
626 /* for auto sizing plots when resizing the page
627 min-width: 500px;
628 min-height: 500px;
629 width: 100%;
630 min-height: 400px;
631 height: 50%; */
632
633 margin-left: -55px;
634 margin-right: 20px;
635 float: left;
636
637 z-index: 2;
638 }
639
640 #change-assembly {
641 white-space: nowrap;
642 width: 0;
643 }
644
645 /*************/
646 /* Plot tips */
647 #plot_tip {
648 position: absolute;
649 opacity: 1;
650 padding: 2px 5px 2px 5px;
651
652 z-index: 1;
653 }
654
655 #plot_tip_vertical_rule, #plot_tip_horizontal_rule {
656 position: absolute;
657 border: 1px solid #BBB;
658 z-index: -2;
659 }
660
661 #plot_tip_vertical_rule {
662 border-left: 1px;
663 }
664
665 #plot_tip_horizontal_rule {
666 border-top: 1px;
667 }
668
669 .white_stroked {
670 color: black;
671 background-color: white;
672 text-shadow:
673 -3px -3px 0 white,
674 3px -3px 0 white,
675 -3px 3px 0 white,
676 3px 3px 0 white;
677 }
678
679 img.icon_plot {
680 width: 14px;
681 height: 12px;
682 display: inline-block;
683 content: '';
684 background: url("");
685 }
686
687 #sortRefsBtn label {
688 display: block;
689 margin-left: 20px;
690 }
691 #sortRefsBtn input {
692 float: left;
693 margin-left: -20px;
694 margin-right: 7px;
695 }
696
697 #mincontig {
698 margin-bottom: 0;
699 }
700 </style>
701
702
703 <script type="text/javascript">
704 /*! jQuery v1.8.2 jquery.com | jquery.org/license */
705 (function(a,b){function G(a){var b=F[a]={};return p.each(a.split(s),function(a,c){b[c]=!0}),b}function J(a,c,d){if(d===b&&a.nodeType===1){var e="data-"+c.replace(I,"-$1").toLowerCase();d=a.getAttribute(e);if(typeof d=="string"){try{d=d==="true"?!0:d==="false"?!1:d==="null"?null:+d+""===d?+d:H.test(d)?p.parseJSON(d):d}catch(f){}p.data(a,c,d)}else d=b}return d}function K(a){var b;for(b in a){if(b==="data"&&p.isEmptyObject(a[b]))continue;if(b!=="toJSON")return!1}return!0}function ba(){return!1}function bb(){return!0}function bh(a){return!a||!a.parentNode||a.parentNode.nodeType===11}function bi(a,b){do a=a[b];while(a&&a.nodeType!==1);return a}function bj(a,b,c){b=b||0;if(p.isFunction(b))return p.grep(a,function(a,d){var e=!!b.call(a,d,a);return e===c});if(b.nodeType)return p.grep(a,function(a,d){return a===b===c});if(typeof b=="string"){var d=p.grep(a,function(a){return a.nodeType===1});if(be.test(b))return p.filter(b,d,!c);b=p.filter(b,d)}return p.grep(a,function(a,d){return p.inArray(a,b)>=0===c})}function bk(a){var b=bl.split("|"),c=a.createDocumentFragment();if(c.createElement)while(b.length)c.createElement(b.pop());return c}function bC(a,b){return a.getElementsByTagName(b)[0]||a.appendChild(a.ownerDocument.createElement(b))}function bD(a,b){if(b.nodeType!==1||!p.hasData(a))return;var c,d,e,f=p._data(a),g=p._data(b,f),h=f.events;if(h){delete g.handle,g.events={};for(c in h)for(d=0,e=h[c].length;d<e;d++)p.event.add(b,c,h[c][d])}g.data&&(g.data=p.extend({},g.data))}function bE(a,b){var c;if(b.nodeType!==1)return;b.clearAttributes&&b.clearAttributes(),b.mergeAttributes&&b.mergeAttributes(a),c=b.nodeName.toLowerCase(),c==="object"?(b.parentNode&&(b.outerHTML=a.outerHTML),p.support.html5Clone&&a.innerHTML&&!p.trim(b.innerHTML)&&(b.innerHTML=a.innerHTML)):c==="input"&&bv.test(a.type)?(b.defaultChecked=b.checked=a.checked,b.value!==a.value&&(b.value=a.value)):c==="option"?b.selected=a.defaultSelected:c==="input"||c==="textarea"?b.defaultValue=a.defaultValue:c==="script"&&b.text!==a.text&&(b.text=a.text),b.removeAttribute(p.expando)}function bF(a){return typeof a.getElementsByTagName!="undefined"?a.getElementsByTagName("*"):typeof a.querySelectorAll!="undefined"?a.querySelectorAll("*"):[]}function bG(a){bv.test(a.type)&&(a.defaultChecked=a.checked)}function bY(a,b){if(b in a)return b;var c=b.charAt(0).toUpperCase()+b.slice(1),d=b,e=bW.length;while(e--){b=bW[e]+c;if(b in a)return b}return d}function bZ(a,b){return a=b||a,p.css(a,"display")==="none"||!p.contains(a.ownerDocument,a)}function b$(a,b){var c,d,e=[],f=0,g=a.length;for(;f<g;f++){c=a[f];if(!c.style)continue;e[f]=p._data(c,"olddisplay"),b?(!e[f]&&c.style.display==="none"&&(c.style.display=""),c.style.display===""&&bZ(c)&&(e[f]=p._data(c,"olddisplay",cc(c.nodeName)))):(d=bH(c,"display"),!e[f]&&d!=="none"&&p._data(c,"olddisplay",d))}for(f=0;f<g;f++){c=a[f];if(!c.style)continue;if(!b||c.style.display==="none"||c.style.display==="")c.style.display=b?e[f]||"":"none"}return a}function b_(a,b,c){var d=bP.exec(b);return d?Math.max(0,d[1]-(c||0))+(d[2]||"px"):b}function ca(a,b,c,d){var e=c===(d?"border":"content")?4:b==="width"?1:0,f=0;for(;e<4;e+=2)c==="margin"&&(f+=p.css(a,c+bV[e],!0)),d?(c==="content"&&(f-=parseFloat(bH(a,"padding"+bV[e]))||0),c!=="margin"&&(f-=parseFloat(bH(a,"border"+bV[e]+"Width"))||0)):(f+=parseFloat(bH(a,"padding"+bV[e]))||0,c!=="padding"&&(f+=parseFloat(bH(a,"border"+bV[e]+"Width"))||0));return f}function cb(a,b,c){var d=b==="width"?a.offsetWidth:a.offsetHeight,e=!0,f=p.support.boxSizing&&p.css(a,"boxSizing")==="border-box";if(d<=0||d==null){d=bH(a,b);if(d<0||d==null)d=a.style[b];if(bQ.test(d))return d;e=f&&(p.support.boxSizingReliable||d===a.style[b]),d=parseFloat(d)||0}return d+ca(a,b,c||(f?"border":"content"),e)+"px"}function cc(a){if(bS[a])return bS[a];var b=p("<"+a+">").appendTo(e.body),c=b.css("display");b.remove();if(c==="none"||c===""){bI=e.body.appendChild(bI||p.extend(e.createElement("iframe"),{frameBorder:0,width:0,height:0}));if(!bJ||!bI.createElement)bJ=(bI.contentWindow||bI.contentDocument).document,bJ.write("<!doctype html><html><body>"),bJ.close();b=bJ.body.appendChild(bJ.createElement(a)),c=bH(b,"display"),e.body.removeChild(bI)}return bS[a]=c,c}function ci(a,b,c,d){var e;if(p.isArray(b))p.each(b,function(b,e){c||ce.test(a)?d(a,e):ci(a+"["+(typeof e=="object"?b:"")+"]",e,c,d)});else if(!c&&p.type(b)==="object")for(e in b)ci(a+"["+e+"]",b[e],c,d);else d(a,b)}function cz(a){return function(b,c){typeof b!="string"&&(c=b,b="*");var d,e,f,g=b.toLowerCase().split(s),h=0,i=g.length;if(p.isFunction(c))for(;h<i;h++)d=g[h],f=/^\+/.test(d),f&&(d=d.substr(1)||"*"),e=a[d]=a[d]||[],e[f?"unshift":"push"](c)}}function cA(a,c,d,e,f,g){f=f||c.dataTypes[0],g=g||{},g[f]=!0;var h,i=a[f],j=0,k=i?i.length:0,l=a===cv;for(;j<k&&(l||!h);j++)h=i[j](c,d,e),typeof h=="string"&&(!l||g[h]?h=b:(c.dataTypes.unshift(h),h=cA(a,c,d,e,h,g)));return(l||!h)&&!g["*"]&&(h=cA(a,c,d,e,"*",g)),h}function cB(a,c){var d,e,f=p.ajaxSettings.flatOptions||{};for(d in c)c[d]!==b&&((f[d]?a:e||(e={}))[d]=c[d]);e&&p.extend(!0,a,e)}function cC(a,c,d){var e,f,g,h,i=a.contents,j=a.dataTypes,k=a.responseFields;for(f in k)f in d&&(c[k[f]]=d[f]);while(j[0]==="*")j.shift(),e===b&&(e=a.mimeType||c.getResponseHeader("content-type"));if(e)for(f in i)if(i[f]&&i[f].test(e)){j.unshift(f);break}if(j[0]in d)g=j[0];else{for(f in d){if(!j[0]||a.converters[f+" "+j[0]]){g=f;break}h||(h=f)}g=g||h}if(g)return g!==j[0]&&j.unshift(g),d[g]}function cD(a,b){var c,d,e,f,g=a.dataTypes.slice(),h=g[0],i={},j=0;a.dataFilter&&(b=a.dataFilter(b,a.dataType));if(g[1])for(c in a.converters)i[c.toLowerCase()]=a.converters[c];for(;e=g[++j];)if(e!=="*"){if(h!=="*"&&h!==e){c=i[h+" "+e]||i["* "+e];if(!c)for(d in i){f=d.split(" ");if(f[1]===e){c=i[h+" "+f[0]]||i["* "+f[0]];if(c){c===!0?c=i[d]:i[d]!==!0&&(e=f[0],g.splice(j--,0,e));break}}}if(c!==!0)if(c&&a["throws"])b=c(b);else try{b=c(b)}catch(k){return{state:"parsererror",error:c?k:"No conversion from "+h+" to "+e}}}h=e}return{state:"success",data:b}}function cL(){try{return new a.XMLHttpRequest}catch(b){}}function cM(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}function cU(){return setTimeout(function(){cN=b},0),cN=p.now()}function cV(a,b){p.each(b,function(b,c){var d=(cT[b]||[]).concat(cT["*"]),e=0,f=d.length;for(;e<f;e++)if(d[e].call(a,b,c))return})}function cW(a,b,c){var d,e=0,f=0,g=cS.length,h=p.Deferred().always(function(){delete i.elem}),i=function(){var b=cN||cU(),c=Math.max(0,j.startTime+j.duration-b),d=1-(c/j.duration||0),e=0,f=j.tweens.length;for(;e<f;e++)j.tweens[e].run(d);return h.notifyWith(a,[j,d,c]),d<1&&f?c:(h.resolveWith(a,[j]),!1)},j=h.promise({elem:a,props:p.extend({},b),opts:p.extend(!0,{specialEasing:{}},c),originalProperties:b,originalOptions:c,startTime:cN||cU(),duration:c.duration,tweens:[],createTween:function(b,c,d){var e=p.Tween(a,j.opts,b,c,j.opts.specialEasing[b]||j.opts.easing);return j.tweens.push(e),e},stop:function(b){var c=0,d=b?j.tweens.length:0;for(;c<d;c++)j.tweens[c].run(1);return b?h.resolveWith(a,[j,b]):h.rejectWith(a,[j,b]),this}}),k=j.props;cX(k,j.opts.specialEasing);for(;e<g;e++){d=cS[e].call(j,a,k,j.opts);if(d)return d}return cV(j,k),p.isFunction(j.opts.start)&&j.opts.start.call(a,j),p.fx.timer(p.extend(i,{anim:j,queue:j.opts.queue,elem:a})),j.progress(j.opts.progress).done(j.opts.done,j.opts.complete).fail(j.opts.fail).always(j.opts.always)}function cX(a,b){var c,d,e,f,g;for(c in a){d=p.camelCase(c),e=b[d],f=a[c],p.isArray(f)&&(e=f[1],f=a[c]=f[0]),c!==d&&(a[d]=f,delete a[c]),g=p.cssHooks[d];if(g&&"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 cY(a,b,c){var d,e,f,g,h,i,j,k,l=this,m=a.style,n={},o=[],q=a.nodeType&&bZ(a);c.queue||(j=p._queueHooks(a,"fx"),j.unqueued==null&&(j.unqueued=0,k=j.empty.fire,j.empty.fire=function(){j.unqueued||k()}),j.unqueued++,l.always(function(){l.always(function(){j.unqueued--,p.queue(a,"fx").length||j.empty.fire()})})),a.nodeType===1&&("height"in b||"width"in b)&&(c.overflow=[m.overflow,m.overflowX,m.overflowY],p.css(a,"display")==="inline"&&p.css(a,"float")==="none"&&(!p.support.inlineBlockNeedsLayout||cc(a.nodeName)==="inline"?m.display="inline-block":m.zoom=1)),c.overflow&&(m.overflow="hidden",p.support.shrinkWrapBlocks||l.done(function(){m.overflow=c.overflow[0],m.overflowX=c.overflow[1],m.overflowY=c.overflow[2]}));for(d in b){f=b[d];if(cP.exec(f)){delete b[d];if(f===(q?"hide":"show"))continue;o.push(d)}}g=o.length;if(g){h=p._data(a,"fxshow")||p._data(a,"fxshow",{}),q?p(a).show():l.done(function(){p(a).hide()}),l.done(function(){var b;p.removeData(a,"fxshow",!0);for(b in n)p.style(a,b,n[b])});for(d=0;d<g;d++)e=o[d],i=l.createTween(e,q?h[e]:0),n[e]=h[e]||p.style(a,e),e in h||(h[e]=i.start,q&&(i.end=i.start,i.start=e==="width"||e==="height"?1:0))}}function cZ(a,b,c,d,e){return new cZ.prototype.init(a,b,c,d,e)}function c$(a,b){var c,d={height:a},e=0;b=b?1:0;for(;e<4;e+=2-b)c=bV[e],d["margin"+c]=d["padding"+c]=a;return b&&(d.opacity=d.width=a),d}function da(a){return p.isWindow(a)?a:a.nodeType===9?a.defaultView||a.parentWindow:!1}var c,d,e=a.document,f=a.location,g=a.navigator,h=a.jQuery,i=a.$,j=Array.prototype.push,k=Array.prototype.slice,l=Array.prototype.indexOf,m=Object.prototype.toString,n=Object.prototype.hasOwnProperty,o=String.prototype.trim,p=function(a,b){return new p.fn.init(a,b,c)},q=/[\-+]?(?:\d*\.|)\d+(?:[eE][\-+]?\d+|)/.source,r=/\S/,s=/\s+/,t=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,u=/^(?:[^#<]*(<[\w\W]+>)[^>]*$|#([\w\-]*)$)/,v=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,w=/^[\],:{}\s]*$/,x=/(?:^|:|,)(?:\s*\[)+/g,y=/\\(?:["\\\/bfnrt]|u[\da-fA-F]{4})/g,z=/"[^"\\\r\n]*"|true|false|null|-?(?:\d\d*\.|)\d+(?:[eE][\-+]?\d+|)/g,A=/^-ms-/,B=/-([\da-z])/gi,C=function(a,b){return(b+"").toUpperCase()},D=function(){e.addEventListener?(e.removeEventListener("DOMContentLoaded",D,!1),p.ready()):e.readyState==="complete"&&(e.detachEvent("onreadystatechange",D),p.ready())},E={};p.fn=p.prototype={constructor:p,init:function(a,c,d){var f,g,h,i;if(!a)return this;if(a.nodeType)return this.context=this[0]=a,this.length=1,this;if(typeof a=="string"){a.charAt(0)==="<"&&a.charAt(a.length-1)===">"&&a.length>=3?f=[null,a,null]:f=u.exec(a);if(f&&(f[1]||!c)){if(f[1])return c=c instanceof p?c[0]:c,i=c&&c.nodeType?c.ownerDocument||c:e,a=p.parseHTML(f[1],i,!0),v.test(f[1])&&p.isPlainObject(c)&&this.attr.call(a,c,!0),p.merge(this,a);g=e.getElementById(f[2]);if(g&&g.parentNode){if(g.id!==f[2])return d.find(a);this.length=1,this[0]=g}return this.context=e,this.selector=a,this}return!c||c.jquery?(c||d).find(a):this.constructor(c).find(a)}return p.isFunction(a)?d.ready(a):(a.selector!==b&&(this.selector=a.selector,this.context=a.context),p.makeArray(a,this))},selector:"",jquery:"1.8.2",length:0,size:function(){return this.length},toArray:function(){return k.call(this)},get:function(a){return a==null?this.toArray():a<0?this[this.length+a]:this[a]},pushStack:function(a,b,c){var d=p.merge(this.constructor(),a);return d.prevObject=this,d.context=this.context,b==="find"?d.selector=this.selector+(this.selector?" ":"")+c:b&&(d.selector=this.selector+"."+b+"("+c+")"),d},each:function(a,b){return p.each(this,a,b)},ready:function(a){return p.ready.promise().done(a),this},eq:function(a){return a=+a,a===-1?this.slice(a):this.slice(a,a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(k.apply(this,arguments),"slice",k.call(arguments).join(","))},map:function(a){return this.pushStack(p.map(this,function(b,c){return a.call(b,c,b)}))},end:function(){return this.prevObject||this.constructor(null)},push:j,sort:[].sort,splice:[].splice},p.fn.init.prototype=p.fn,p.extend=p.fn.extend=function(){var a,c,d,e,f,g,h=arguments[0]||{},i=1,j=arguments.length,k=!1;typeof h=="boolean"&&(k=h,h=arguments[1]||{},i=2),typeof h!="object"&&!p.isFunction(h)&&(h={}),j===i&&(h=this,--i);for(;i<j;i++)if((a=arguments[i])!=null)for(c in a){d=h[c],e=a[c];if(h===e)continue;k&&e&&(p.isPlainObject(e)||(f=p.isArray(e)))?(f?(f=!1,g=d&&p.isArray(d)?d:[]):g=d&&p.isPlainObject(d)?d:{},h[c]=p.extend(k,g,e)):e!==b&&(h[c]=e)}return h},p.extend({noConflict:function(b){return a.$===p&&(a.$=i),b&&a.jQuery===p&&(a.jQuery=h),p},isReady:!1,readyWait:1,holdReady:function(a){a?p.readyWait++:p.ready(!0)},ready:function(a){if(a===!0?--p.readyWait:p.isReady)return;if(!e.body)return setTimeout(p.ready,1);p.isReady=!0;if(a!==!0&&--p.readyWait>0)return;d.resolveWith(e,[p]),p.fn.trigger&&p(e).trigger("ready").off("ready")},isFunction:function(a){return p.type(a)==="function"},isArray:Array.isArray||function(a){return p.type(a)==="array"},isWindow:function(a){return a!=null&&a==a.window},isNumeric:function(a){return!isNaN(parseFloat(a))&&isFinite(a)},type:function(a){return a==null?String(a):E[m.call(a)]||"object"},isPlainObject:function(a){if(!a||p.type(a)!=="object"||a.nodeType||p.isWindow(a))return!1;try{if(a.constructor&&!n.call(a,"constructor")&&!n.call(a.constructor.prototype,"isPrototypeOf"))return!1}catch(c){return!1}var d;for(d in a);return d===b||n.call(a,d)},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},error:function(a){throw new Error(a)},parseHTML:function(a,b,c){var d;return!a||typeof a!="string"?null:(typeof b=="boolean"&&(c=b,b=0),b=b||e,(d=v.exec(a))?[b.createElement(d[1])]:(d=p.buildFragment([a],b,c?null:[]),p.merge([],(d.cacheable?p.clone(d.fragment):d.fragment).childNodes)))},parseJSON:function(b){if(!b||typeof b!="string")return null;b=p.trim(b);if(a.JSON&&a.JSON.parse)return a.JSON.parse(b);if(w.test(b.replace(y,"@").replace(z,"]").replace(x,"")))return(new Function("return "+b))();p.error("Invalid JSON: "+b)},parseXML:function(c){var d,e;if(!c||typeof c!="string")return null;try{a.DOMParser?(e=new DOMParser,d=e.parseFromString(c,"text/xml")):(d=new ActiveXObject("Microsoft.XMLDOM"),d.async="false",d.loadXML(c))}catch(f){d=b}return(!d||!d.documentElement||d.getElementsByTagName("parsererror").length)&&p.error("Invalid XML: "+c),d},noop:function(){},globalEval:function(b){b&&r.test(b)&&(a.execScript||function(b){a.eval.call(a,b)})(b)},camelCase:function(a){return a.replace(A,"ms-").replace(B,C)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,c,d){var e,f=0,g=a.length,h=g===b||p.isFunction(a);if(d){if(h){for(e in a)if(c.apply(a[e],d)===!1)break}else for(;f<g;)if(c.apply(a[f++],d)===!1)break}else if(h){for(e in a)if(c.call(a[e],e,a[e])===!1)break}else for(;f<g;)if(c.call(a[f],f,a[f++])===!1)break;return a},trim:o&&!o.call(" ")?function(a){return a==null?"":o.call(a)}:function(a){return a==null?"":(a+"").replace(t,"")},makeArray:function(a,b){var c,d=b||[];return a!=null&&(c=p.type(a),a.length==null||c==="string"||c==="function"||c==="regexp"||p.isWindow(a)?j.call(d,a):p.merge(d,a)),d},inArray:function(a,b,c){var d;if(b){if(l)return l.call(b,a,c);d=b.length,c=c?c<0?Math.max(0,d+c):c:0;for(;c<d;c++)if(c in b&&b[c]===a)return c}return-1},merge:function(a,c){var d=c.length,e=a.length,f=0;if(typeof d=="number")for(;f<d;f++)a[e++]=c[f];else while(c[f]!==b)a[e++]=c[f++];return a.length=e,a},grep:function(a,b,c){var d,e=[],f=0,g=a.length;c=!!c;for(;f<g;f++)d=!!b(a[f],f),c!==d&&e.push(a[f]);return e},map:function(a,c,d){var e,f,g=[],h=0,i=a.length,j=a instanceof p||i!==b&&typeof i=="number"&&(i>0&&a[0]&&a[i-1]||i===0||p.isArray(a));if(j)for(;h<i;h++)e=c(a[h],h,d),e!=null&&(g[g.length]=e);else for(f in a)e=c(a[f],f,d),e!=null&&(g[g.length]=e);return g.concat.apply([],g)},guid:1,proxy:function(a,c){var d,e,f;return typeof c=="string"&&(d=a[c],c=a,a=d),p.isFunction(a)?(e=k.call(arguments,2),f=function(){return a.apply(c,e.concat(k.call(arguments)))},f.guid=a.guid=a.guid||p.guid++,f):b},access:function(a,c,d,e,f,g,h){var i,j=d==null,k=0,l=a.length;if(d&&typeof d=="object"){for(k in d)p.access(a,c,k,d[k],1,g,e);f=1}else if(e!==b){i=h===b&&p.isFunction(e),j&&(i?(i=c,c=function(a,b,c){return i.call(p(a),c)}):(c.call(a,e),c=null));if(c)for(;k<l;k++)c(a[k],d,i?e.call(a[k],k,c(a[k],d)):e,h);f=1}return f?a:j?c.call(a):l?c(a[0],d):g},now:function(){return(new Date).getTime()}}),p.ready.promise=function(b){if(!d){d=p.Deferred();if(e.readyState==="complete")setTimeout(p.ready,1);else if(e.addEventListener)e.addEventListener("DOMContentLoaded",D,!1),a.addEventListener("load",p.ready,!1);else{e.attachEvent("onreadystatechange",D),a.attachEvent("onload",p.ready);var c=!1;try{c=a.frameElement==null&&e.documentElement}catch(f){}c&&c.doScroll&&function g(){if(!p.isReady){try{c.doScroll("left")}catch(a){return setTimeout(g,50)}p.ready()}}()}}return d.promise(b)},p.each("Boolean Number String Function Array Date RegExp Object".split(" "),function(a,b){E["[object "+b+"]"]=b.toLowerCase()}),c=p(e);var F={};p.Callbacks=function(a){a=typeof a=="string"?F[a]||G(a):p.extend({},a);var c,d,e,f,g,h,i=[],j=!a.once&&[],k=function(b){c=a.memory&&b,d=!0,h=f||0,f=0,g=i.length,e=!0;for(;i&&h<g;h++)if(i[h].apply(b[0],b[1])===!1&&a.stopOnFalse){c=!1;break}e=!1,i&&(j?j.length&&k(j.shift()):c?i=[]:l.disable())},l={add:function(){if(i){var b=i.length;(function d(b){p.each(b,function(b,c){var e=p.type(c);e==="function"&&(!a.unique||!l.has(c))?i.push(c):c&&c.length&&e!=="string"&&d(c)})})(arguments),e?g=i.length:c&&(f=b,k(c))}return this},remove:function(){return i&&p.each(arguments,function(a,b){var c;while((c=p.inArray(b,i,c))>-1)i.splice(c,1),e&&(c<=g&&g--,c<=h&&h--)}),this},has:function(a){return p.inArray(a,i)>-1},empty:function(){return i=[],this},disable:function(){return i=j=c=b,this},disabled:function(){return!i},lock:function(){return j=b,c||l.disable(),this},locked:function(){return!j},fireWith:function(a,b){return b=b||[],b=[a,b.slice?b.slice():b],i&&(!d||j)&&(e?j.push(b):k(b)),this},fire:function(){return l.fireWith(this,arguments),this},fired:function(){return!!d}};return l},p.extend({Deferred:function(a){var b=[["resolve","done",p.Callbacks("once memory"),"resolved"],["reject","fail",p.Callbacks("once memory"),"rejected"],["notify","progress",p.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return p.Deferred(function(c){p.each(b,function(b,d){var f=d[0],g=a[b];e[d[1]](p.isFunction(g)?function(){var a=g.apply(this,arguments);a&&p.isFunction(a.promise)?a.promise().done(c.resolve).fail(c.reject).progress(c.notify):c[f+"With"](this===e?c:this,[a])}:c[f])}),a=null}).promise()},promise:function(a){return a!=null?p.extend(a,d):d}},e={};return d.pipe=d.then,p.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[a^1][2].disable,b[2][2].lock),e[f[0]]=g.fire,e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var b=0,c=k.call(arguments),d=c.length,e=d!==1||a&&p.isFunction(a.promise)?d:0,f=e===1?a:p.Deferred(),g=function(a,b,c){return function(d){b[a]=this,c[a]=arguments.length>1?k.call(arguments):d,c===h?f.notifyWith(b,c):--e||f.resolveWith(b,c)}},h,i,j;if(d>1){h=new Array(d),i=new Array(d),j=new Array(d);for(;b<d;b++)c[b]&&p.isFunction(c[b].promise)?c[b].promise().done(g(b,j,c)).fail(f.reject).progress(g(b,i,h)):--e}return e||f.resolveWith(j,c),f.promise()}}),p.support=function(){var b,c,d,f,g,h,i,j,k,l,m,n=e.createElement("div");n.setAttribute("className","t"),n.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",c=n.getElementsByTagName("*"),d=n.getElementsByTagName("a")[0],d.style.cssText="top:1px;float:left;opacity:.5";if(!c||!c.length)return{};f=e.createElement("select"),g=f.appendChild(e.createElement("option")),h=n.getElementsByTagName("input")[0],b={leadingWhitespace:n.firstChild.nodeType===3,tbody:!n.getElementsByTagName("tbody").length,htmlSerialize:!!n.getElementsByTagName("link").length,style:/top/.test(d.getAttribute("style")),hrefNormalized:d.getAttribute("href")==="/a",opacity:/^0.5/.test(d.style.opacity),cssFloat:!!d.style.cssFloat,checkOn:h.value==="on",optSelected:g.selected,getSetAttribute:n.className!=="t",enctype:!!e.createElement("form").enctype,html5Clone:e.createElement("nav").cloneNode(!0).outerHTML!=="<:nav></:nav>",boxModel:e.compatMode==="CSS1Compat",submitBubbles:!0,changeBubbles:!0,focusinBubbles:!1,deleteExpando:!0,noCloneEvent:!0,inlineBlockNeedsLayout:!1,shrinkWrapBlocks:!1,reliableMarginRight:!0,boxSizingReliable:!0,pixelPosition:!1},h.checked=!0,b.noCloneChecked=h.cloneNode(!0).checked,f.disabled=!0,b.optDisabled=!g.disabled;try{delete n.test}catch(o){b.deleteExpando=!1}!n.addEventListener&&n.attachEvent&&n.fireEvent&&(n.attachEvent("onclick",m=function(){b.noCloneEvent=!1}),n.cloneNode(!0).fireEvent("onclick"),n.detachEvent("onclick",m)),h=e.createElement("input"),h.value="t",h.setAttribute("type","radio"),b.radioValue=h.value==="t",h.setAttribute("checked","checked"),h.setAttribute("name","t"),n.appendChild(h),i=e.createDocumentFragment(),i.appendChild(n.lastChild),b.checkClone=i.cloneNode(!0).cloneNode(!0).lastChild.checked,b.appendChecked=h.checked,i.removeChild(h),i.appendChild(n);if(n.attachEvent)for(k in{submit:!0,change:!0,focusin:!0})j="on"+k,l=j in n,l||(n.setAttribute(j,"return;"),l=typeof n[j]=="function"),b[k+"Bubbles"]=l;return p(function(){var c,d,f,g,h="padding:0;margin:0;border:0;display:block;overflow:hidden;",i=e.getElementsByTagName("body")[0];if(!i)return;c=e.createElement("div"),c.style.cssText="visibility:hidden;border:0;width:0;height:0;position:static;top:0;margin-top:1px",i.insertBefore(c,i.firstChild),d=e.createElement("div"),c.appendChild(d),d.innerHTML="<table><tr><td></td><td>t</td></tr></table>",f=d.getElementsByTagName("td"),f[0].style.cssText="padding:0;margin:0;border:0;display:none",l=f[0].offsetHeight===0,f[0].style.display="",f[1].style.display="none",b.reliableHiddenOffsets=l&&f[0].offsetHeight===0,d.innerHTML="",d.style.cssText="box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%;",b.boxSizing=d.offsetWidth===4,b.doesNotIncludeMarginInBodyOffset=i.offsetTop!==1,a.getComputedStyle&&(b.pixelPosition=(a.getComputedStyle(d,null)||{}).top!=="1%",b.boxSizingReliable=(a.getComputedStyle(d,null)||{width:"4px"}).width==="4px",g=e.createElement("div"),g.style.cssText=d.style.cssText=h,g.style.marginRight=g.style.width="0",d.style.width="1px",d.appendChild(g),b.reliableMarginRight=!parseFloat((a.getComputedStyle(g,null)||{}).marginRight)),typeof d.style.zoom!="undefined"&&(d.innerHTML="",d.style.cssText=h+"width:1px;padding:1px;display:inline;zoom:1",b.inlineBlockNeedsLayout=d.offsetWidth===3,d.style.display="block",d.style.overflow="visible",d.innerHTML="<div></div>",d.firstChild.style.width="5px",b.shrinkWrapBlocks=d.offsetWidth!==3,c.style.zoom=1),i.removeChild(c),c=d=f=g=null}),i.removeChild(n),c=d=f=g=h=i=n=null,b}();var H=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,I=/([A-Z])/g;p.extend({cache:{},deletedIds:[],uuid:0,expando:"jQuery"+(p.fn.jquery+Math.random()).replace(/\D/g,""),noData:{embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:!0},hasData:function(a){return a=a.nodeType?p.cache[a[p.expando]]:a[p.expando],!!a&&!K(a)},data:function(a,c,d,e){if(!p.acceptData(a))return;var f,g,h=p.expando,i=typeof c=="string",j=a.nodeType,k=j?p.cache:a,l=j?a[h]:a[h]&&h;if((!l||!k[l]||!e&&!k[l].data)&&i&&d===b)return;l||(j?a[h]=l=p.deletedIds.pop()||p.guid++:l=h),k[l]||(k[l]={},j||(k[l].toJSON=p.noop));if(typeof c=="object"||typeof c=="function")e?k[l]=p.extend(k[l],c):k[l].data=p.extend(k[l].data,c);return f=k[l],e||(f.data||(f.data={}),f=f.data),d!==b&&(f[p.camelCase(c)]=d),i?(g=f[c],g==null&&(g=f[p.camelCase(c)])):g=f,g},removeData:function(a,b,c){if(!p.acceptData(a))return;var d,e,f,g=a.nodeType,h=g?p.cache:a,i=g?a[p.expando]:p.expando;if(!h[i])return;if(b){d=c?h[i]:h[i].data;if(d){p.isArray(b)||(b in d?b=[b]:(b=p.camelCase(b),b in d?b=[b]:b=b.split(" ")));for(e=0,f=b.length;e<f;e++)delete d[b[e]];if(!(c?K:p.isEmptyObject)(d))return}}if(!c){delete h[i].data;if(!K(h[i]))return}g?p.cleanData([a],!0):p.support.deleteExpando||h!=h.window?delete h[i]:h[i]=null},_data:function(a,b,c){return p.data(a,b,c,!0)},acceptData:function(a){var b=a.nodeName&&p.noData[a.nodeName.toLowerCase()];return!b||b!==!0&&a.getAttribute("classid")===b}}),p.fn.extend({data:function(a,c){var d,e,f,g,h,i=this[0],j=0,k=null;if(a===b){if(this.length){k=p.data(i);if(i.nodeType===1&&!p._data(i,"parsedAttrs")){f=i.attributes;for(h=f.length;j<h;j++)g=f[j].name,g.indexOf("data-")||(g=p.camelCase(g.substring(5)),J(i,g,k[g]));p._data(i,"parsedAttrs",!0)}}return k}return typeof a=="object"?this.each(function(){p.data(this,a)}):(d=a.split(".",2),d[1]=d[1]?"."+d[1]:"",e=d[1]+"!",p.access(this,function(c){if(c===b)return k=this.triggerHandler("getData"+e,[d[0]]),k===b&&i&&(k=p.data(i,a),k=J(i,a,k)),k===b&&d[1]?this.data(d[0]):k;d[1]=c,this.each(function(){var b=p(this);b.triggerHandler("setData"+e,d),p.data(this,a,c),b.triggerHandler("changeData"+e,d)})},null,c,arguments.length>1,null,!1))},removeData:function(a){return this.each(function(){p.removeData(this,a)})}}),p.extend({queue:function(a,b,c){var d;if(a)return b=(b||"fx")+"queue",d=p._data(a,b),c&&(!d||p.isArray(c)?d=p._data(a,b,p.makeArray(c)):d.push(c)),d||[]},dequeue:function(a,b){b=b||"fx";var c=p.queue(a,b),d=c.length,e=c.shift(),f=p._queueHooks(a,b),g=function(){p.dequeue(a,b)};e==="inprogress"&&(e=c.shift(),d--),e&&(b==="fx"&&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 p._data(a,c)||p._data(a,c,{empty:p.Callbacks("once memory").add(function(){p.removeData(a,b+"queue",!0),p.removeData(a,c,!0)})})}}),p.fn.extend({queue:function(a,c){var d=2;return typeof a!="string"&&(c=a,a="fx",d--),arguments.length<d?p.queue(this[0],a):c===b?this:this.each(function(){var b=p.queue(this,a,c);p._queueHooks(this,a),a==="fx"&&b[0]!=="inprogress"&&p.dequeue(this,a)})},dequeue:function(a){return this.each(function(){p.dequeue(this,a)})},delay:function(a,b){return a=p.fx?p.fx.speeds[a]||a:a,b=b||"fx",this.queue(b,function(b,c){var d=setTimeout(b,a);c.stop=function(){clearTimeout(d)}})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,c){var d,e=1,f=p.Deferred(),g=this,h=this.length,i=function(){--e||f.resolveWith(g,[g])};typeof a!="string"&&(c=a,a=b),a=a||"fx";while(h--)d=p._data(g[h],a+"queueHooks"),d&&d.empty&&(e++,d.empty.add(i));return i(),f.promise(c)}});var L,M,N,O=/[\t\r\n]/g,P=/\r/g,Q=/^(?:button|input)$/i,R=/^(?:button|input|object|select|textarea)$/i,S=/^a(?:rea|)$/i,T=/^(?:autofocus|autoplay|async|checked|controls|defer|disabled|hidden|loop|multiple|open|readonly|required|scoped|selected)$/i,U=p.support.getSetAttribute;p.fn.extend({attr:function(a,b){return p.access(this,p.attr,a,b,arguments.length>1)},removeAttr:function(a){return this.each(function(){p.removeAttr(this,a)})},prop:function(a,b){return p.access(this,p.prop,a,b,arguments.length>1)},removeProp:function(a){return a=p.propFix[a]||a,this.each(function(){try{this[a]=b,delete this[a]}catch(c){}})},addClass:function(a){var b,c,d,e,f,g,h;if(p.isFunction(a))return this.each(function(b){p(this).addClass(a.call(this,b,this.className))});if(a&&typeof a=="string"){b=a.split(s);for(c=0,d=this.length;c<d;c++){e=this[c];if(e.nodeType===1)if(!e.className&&b.length===1)e.className=a;else{f=" "+e.className+" ";for(g=0,h=b.length;g<h;g++)f.indexOf(" "+b[g]+" ")<0&&(f+=b[g]+" ");e.className=p.trim(f)}}}return this},removeClass:function(a){var c,d,e,f,g,h,i;if(p.isFunction(a))return this.each(function(b){p(this).removeClass(a.call(this,b,this.className))});if(a&&typeof a=="string"||a===b){c=(a||"").split(s);for(h=0,i=this.length;h<i;h++){e=this[h];if(e.nodeType===1&&e.className){d=(" "+e.className+" ").replace(O," ");for(f=0,g=c.length;f<g;f++)while(d.indexOf(" "+c[f]+" ")>=0)d=d.replace(" "+c[f]+" "," ");e.className=a?p.trim(d):""}}}return this},toggleClass:function(a,b){var c=typeof a,d=typeof b=="boolean";return p.isFunction(a)?this.each(function(c){p(this).toggleClass(a.call(this,c,this.className,b),b)}):this.each(function(){if(c==="string"){var e,f=0,g=p(this),h=b,i=a.split(s);while(e=i[f++])h=d?h:!g.hasClass(e),g[h?"addClass":"removeClass"](e)}else if(c==="undefined"||c==="boolean")this.className&&p._data(this,"__className__",this.className),this.className=this.className||a===!1?"":p._data(this,"__className__")||""})},hasClass:function(a){var b=" "+a+" ",c=0,d=this.length;for(;c<d;c++)if(this[c].nodeType===1&&(" "+this[c].className+" ").replace(O," ").indexOf(b)>=0)return!0;return!1},val:function(a){var c,d,e,f=this[0];if(!arguments.length){if(f)return c=p.valHooks[f.type]||p.valHooks[f.nodeName.toLowerCase()],c&&"get"in c&&(d=c.get(f,"value"))!==b?d:(d=f.value,typeof d=="string"?d.replace(P,""):d==null?"":d);return}return e=p.isFunction(a),this.each(function(d){var f,g=p(this);if(this.nodeType!==1)return;e?f=a.call(this,d,g.val()):f=a,f==null?f="":typeof f=="number"?f+="":p.isArray(f)&&(f=p.map(f,function(a){return a==null?"":a+""})),c=p.valHooks[this.type]||p.valHooks[this.nodeName.toLowerCase()];if(!c||!("set"in c)||c.set(this,f,"value")===b)this.value=f})}}),p.extend({valHooks:{option:{get:function(a){var b=a.attributes.value;return!b||b.specified?a.value:a.text}},select:{get:function(a){var b,c,d,e,f=a.selectedIndex,g=[],h=a.options,i=a.type==="select-one";if(f<0)return null;c=i?f:0,d=i?f+1:h.length;for(;c<d;c++){e=h[c];if(e.selected&&(p.support.optDisabled?!e.disabled:e.getAttribute("disabled")===null)&&(!e.parentNode.disabled||!p.nodeName(e.parentNode,"optgroup"))){b=p(e).val();if(i)return b;g.push(b)}}return i&&!g.length&&h.length?p(h[f]).val():g},set:function(a,b){var c=p.makeArray(b);return p(a).find("option").each(function(){this.selected=p.inArray(p(this).val(),c)>=0}),c.length||(a.selectedIndex=-1),c}}},attrFn:{},attr:function(a,c,d,e){var f,g,h,i=a.nodeType;if(!a||i===3||i===8||i===2)return;if(e&&p.isFunction(p.fn[c]))return p(a)[c](d);if(typeof a.getAttribute=="undefined")return p.prop(a,c,d);h=i!==1||!p.isXMLDoc(a),h&&(c=c.toLowerCase(),g=p.attrHooks[c]||(T.test(c)?M:L));if(d!==b){if(d===null){p.removeAttr(a,c);return}return g&&"set"in g&&h&&(f=g.set(a,d,c))!==b?f:(a.setAttribute(c,d+""),d)}return g&&"get"in g&&h&&(f=g.get(a,c))!==null?f:(f=a.getAttribute(c),f===null?b:f)},removeAttr:function(a,b){var c,d,e,f,g=0;if(b&&a.nodeType===1){d=b.split(s);for(;g<d.length;g++)e=d[g],e&&(c=p.propFix[e]||e,f=T.test(e),f||p.attr(a,e,""),a.removeAttribute(U?e:c),f&&c in a&&(a[c]=!1))}},attrHooks:{type:{set:function(a,b){if(Q.test(a.nodeName)&&a.parentNode)p.error("type property can't be changed");else if(!p.support.radioValue&&b==="radio"&&p.nodeName(a,"input")){var c=a.value;return a.setAttribute("type",b),c&&(a.value=c),b}}},value:{get:function(a,b){return L&&p.nodeName(a,"button")?L.get(a,b):b in a?a.value:null},set:function(a,b,c){if(L&&p.nodeName(a,"button"))return L.set(a,b,c);a.value=b}}},propFix:{tabindex:"tabIndex",readonly:"readOnly","for":"htmlFor","class":"className",maxlength:"maxLength",cellspacing:"cellSpacing",cellpadding:"cellPadding",rowspan:"rowSpan",colspan:"colSpan",usemap:"useMap",frameborder:"frameBorder",contenteditable:"contentEditable"},prop:function(a,c,d){var e,f,g,h=a.nodeType;if(!a||h===3||h===8||h===2)return;return g=h!==1||!p.isXMLDoc(a),g&&(c=p.propFix[c]||c,f=p.propHooks[c]),d!==b?f&&"set"in f&&(e=f.set(a,d,c))!==b?e:a[c]=d:f&&"get"in f&&(e=f.get(a,c))!==null?e:a[c]},propHooks:{tabIndex:{get:function(a){var c=a.getAttributeNode("tabindex");return c&&c.specified?parseInt(c.value,10):R.test(a.nodeName)||S.test(a.nodeName)&&a.href?0:b}}}}),M={get:function(a,c){var d,e=p.prop(a,c);return e===!0||typeof e!="boolean"&&(d=a.getAttributeNode(c))&&d.nodeValue!==!1?c.toLowerCase():b},set:function(a,b,c){var d;return b===!1?p.removeAttr(a,c):(d=p.propFix[c]||c,d in a&&(a[d]=!0),a.setAttribute(c,c.toLowerCase())),c}},U||(N={name:!0,id:!0,coords:!0},L=p.valHooks.button={get:function(a,c){var d;return d=a.getAttributeNode(c),d&&(N[c]?d.value!=="":d.specified)?d.value:b},set:function(a,b,c){var d=a.getAttributeNode(c);return d||(d=e.createAttribute(c),a.setAttributeNode(d)),d.value=b+""}},p.each(["width","height"],function(a,b){p.attrHooks[b]=p.extend(p.attrHooks[b],{set:function(a,c){if(c==="")return a.setAttribute(b,"auto"),c}})}),p.attrHooks.contenteditable={get:L.get,set:function(a,b,c){b===""&&(b="false"),L.set(a,b,c)}}),p.support.hrefNormalized||p.each(["href","src","width","height"],function(a,c){p.attrHooks[c]=p.extend(p.attrHooks[c],{get:function(a){var d=a.getAttribute(c,2);return d===null?b:d}})}),p.support.style||(p.attrHooks.style={get:function(a){return a.style.cssText.toLowerCase()||b},set:function(a,b){return a.style.cssText=b+""}}),p.support.optSelected||(p.propHooks.selected=p.extend(p.propHooks.selected,{get:function(a){var b=a.parentNode;return b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex),null}})),p.support.enctype||(p.propFix.enctype="encoding"),p.support.checkOn||p.each(["radio","checkbox"],function(){p.valHooks[this]={get:function(a){return a.getAttribute("value")===null?"on":a.value}}}),p.each(["radio","checkbox"],function(){p.valHooks[this]=p.extend(p.valHooks[this],{set:function(a,b){if(p.isArray(b))return a.checked=p.inArray(p(a).val(),b)>=0}})});var V=/^(?:textarea|input|select)$/i,W=/^([^\.]*|)(?:\.(.+)|)$/,X=/(?:^|\s)hover(\.\S+|)\b/,Y=/^key/,Z=/^(?:mouse|contextmenu)|click/,$=/^(?:focusinfocus|focusoutblur)$/,_=function(a){return p.event.special.hover?a:a.replace(X,"mouseenter$1 mouseleave$1")};p.event={add:function(a,c,d,e,f){var g,h,i,j,k,l,m,n,o,q,r;if(a.nodeType===3||a.nodeType===8||!c||!d||!(g=p._data(a)))return;d.handler&&(o=d,d=o.handler,f=o.selector),d.guid||(d.guid=p.guid++),i=g.events,i||(g.events=i={}),h=g.handle,h||(g.handle=h=function(a){return typeof p!="undefined"&&(!a||p.event.triggered!==a.type)?p.event.dispatch.apply(h.elem,arguments):b},h.elem=a),c=p.trim(_(c)).split(" ");for(j=0;j<c.length;j++){k=W.exec(c[j])||[],l=k[1],m=(k[2]||"").split(".").sort(),r=p.event.special[l]||{},l=(f?r.delegateType:r.bindType)||l,r=p.event.special[l]||{},n=p.extend({type:l,origType:k[1],data:e,handler:d,guid:d.guid,selector:f,needsContext:f&&p.expr.match.needsContext.test(f),namespace:m.join(".")},o),q=i[l];if(!q){q=i[l]=[],q.delegateCount=0;if(!r.setup||r.setup.call(a,e,m,h)===!1)a.addEventListener?a.addEventListener(l,h,!1):a.attachEvent&&a.attachEvent("on"+l,h)}r.add&&(r.add.call(a,n),n.handler.guid||(n.handler.guid=d.guid)),f?q.splice(q.delegateCount++,0,n):q.push(n),p.event.global[l]=!0}a=null},global:{},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,o,q,r=p.hasData(a)&&p._data(a);if(!r||!(m=r.events))return;b=p.trim(_(b||"")).split(" ");for(f=0;f<b.length;f++){g=W.exec(b[f])||[],h=i=g[1],j=g[2];if(!h){for(h in m)p.event.remove(a,h+b[f],c,d,!0);continue}n=p.event.special[h]||{},h=(d?n.delegateType:n.bindType)||h,o=m[h]||[],k=o.length,j=j?new RegExp("(^|\\.)"+j.split(".").sort().join("\\.(?:.*\\.|)")+"(\\.|$)"):null;for(l=0;l<o.length;l++)q=o[l],(e||i===q.origType)&&(!c||c.guid===q.guid)&&(!j||j.test(q.namespace))&&(!d||d===q.selector||d==="**"&&q.selector)&&(o.splice(l--,1),q.selector&&o.delegateCount--,n.remove&&n.remove.call(a,q));o.length===0&&k!==o.length&&((!n.teardown||n.teardown.call(a,j,r.handle)===!1)&&p.removeEvent(a,h,r.handle),delete m[h])}p.isEmptyObject(m)&&(delete r.handle,p.removeData(a,"events",!0))},customEvent:{getData:!0,setData:!0,changeData:!0},trigger:function(c,d,f,g){if(!f||f.nodeType!==3&&f.nodeType!==8){var h,i,j,k,l,m,n,o,q,r,s=c.type||c,t=[];if($.test(s+p.event.triggered))return;s.indexOf("!")>=0&&(s=s.slice(0,-1),i=!0),s.indexOf(".")>=0&&(t=s.split("."),s=t.shift(),t.sort());if((!f||p.event.customEvent[s])&&!p.event.global[s])return;c=typeof c=="object"?c[p.expando]?c:new p.Event(s,c):new p.Event(s),c.type=s,c.isTrigger=!0,c.exclusive=i,c.namespace=t.join("."),c.namespace_re=c.namespace?new RegExp("(^|\\.)"+t.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,m=s.indexOf(":")<0?"on"+s:"";if(!f){h=p.cache;for(j in h)h[j].events&&h[j].events[s]&&p.event.trigger(c,d,h[j].handle.elem,!0);return}c.result=b,c.target||(c.target=f),d=d!=null?p.makeArray(d):[],d.unshift(c),n=p.event.special[s]||{};if(n.trigger&&n.trigger.apply(f,d)===!1)return;q=[[f,n.bindType||s]];if(!g&&!n.noBubble&&!p.isWindow(f)){r=n.delegateType||s,k=$.test(r+s)?f:f.parentNode;for(l=f;k;k=k.parentNode)q.push([k,r]),l=k;l===(f.ownerDocument||e)&&q.push([l.defaultView||l.parentWindow||a,r])}for(j=0;j<q.length&&!c.isPropagationStopped();j++)k=q[j][0],c.type=q[j][1],o=(p._data(k,"events")||{})[c.type]&&p._data(k,"handle"),o&&o.apply(k,d),o=m&&k[m],o&&p.acceptData(k)&&o.apply&&o.apply(k,d)===!1&&c.preventDefault();return c.type=s,!g&&!c.isDefaultPrevented()&&(!n._default||n._default.apply(f.ownerDocument,d)===!1)&&(s!=="click"||!p.nodeName(f,"a"))&&p.acceptData(f)&&m&&f[s]&&(s!=="focus"&&s!=="blur"||c.target.offsetWidth!==0)&&!p.isWindow(f)&&(l=f[m],l&&(f[m]=null),p.event.triggered=s,f[s](),p.event.triggered=b,l&&(f[m]=l)),c.result}return},dispatch:function(c){c=p.event.fix(c||a.event);var d,e,f,g,h,i,j,l,m,n,o=(p._data(this,"events")||{})[c.type]||[],q=o.delegateCount,r=k.call(arguments),s=!c.exclusive&&!c.namespace,t=p.event.special[c.type]||{},u=[];r[0]=c,c.delegateTarget=this;if(t.preDispatch&&t.preDispatch.call(this,c)===!1)return;if(q&&(!c.button||c.type!=="click"))for(f=c.target;f!=this;f=f.parentNode||this)if(f.disabled!==!0||c.type!=="click"){h={},j=[];for(d=0;d<q;d++)l=o[d],m=l.selector,h[m]===b&&(h[m]=l.needsContext?p(m,this).index(f)>=0:p.find(m,this,null,[f]).length),h[m]&&j.push(l);j.length&&u.push({elem:f,matches:j})}o.length>q&&u.push({elem:this,matches:o.slice(q)});for(d=0;d<u.length&&!c.isPropagationStopped();d++){i=u[d],c.currentTarget=i.elem;for(e=0;e<i.matches.length&&!c.isImmediatePropagationStopped();e++){l=i.matches[e];if(s||!c.namespace&&!l.namespace||c.namespace_re&&c.namespace_re.test(l.namespace))c.data=l.data,c.handleObj=l,g=((p.event.special[l.origType]||{}).handle||l.handler).apply(i.elem,r),g!==b&&(c.result=g,g===!1&&(c.preventDefault(),c.stopPropagation()))}}return t.postDispatch&&t.postDispatch.call(this,c),c.result},props:"attrChange attrName relatedNode srcElement 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 a.which==null&&(a.which=b.charCode!=null?b.charCode:b.keyCode),a}},mouseHooks:{props:"button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(a,c){var d,f,g,h=c.button,i=c.fromElement;return a.pageX==null&&c.clientX!=null&&(d=a.target.ownerDocument||e,f=d.documentElement,g=d.body,a.pageX=c.clientX+(f&&f.scrollLeft||g&&g.scrollLeft||0)-(f&&f.clientLeft||g&&g.clientLeft||0),a.pageY=c.clientY+(f&&f.scrollTop||g&&g.scrollTop||0)-(f&&f.clientTop||g&&g.clientTop||0)),!a.relatedTarget&&i&&(a.relatedTarget=i===a.target?c.toElement:i),!a.which&&h!==b&&(a.which=h&1?1:h&2?3:h&4?2:0),a}},fix:function(a){if(a[p.expando])return a;var b,c,d=a,f=p.event.fixHooks[a.type]||{},g=f.props?this.props.concat(f.props):this.props;a=p.Event(d);for(b=g.length;b;)c=g[--b],a[c]=d[c];return a.target||(a.target=d.srcElement||e),a.target.nodeType===3&&(a.target=a.target.parentNode),a.metaKey=!!a.metaKey,f.filter?f.filter(a,d):a},special:{load:{noBubble:!0},focus:{delegateType:"focusin"},blur:{delegateType:"focusout"},beforeunload:{setup:function(a,b,c){p.isWindow(this)&&(this.onbeforeunload=c)},teardown:function(a,b){this.onbeforeunload===b&&(this.onbeforeunload=null)}}},simulate:function(a,b,c,d){var e=p.extend(new p.Event,c,{type:a,isSimulated:!0,originalEvent:{}});d?p.event.trigger(e,null,b):p.event.dispatch.call(b,e),e.isDefaultPrevented()&&c.preventDefault()}},p.event.handle=p.event.dispatch,p.removeEvent=e.removeEventListener?function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c,!1)}:function(a,b,c){var d="on"+b;a.detachEvent&&(typeof a[d]=="undefined"&&(a[d]=null),a.detachEvent(d,c))},p.Event=function(a,b){if(this instanceof p.Event)a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||a.returnValue===!1||a.getPreventDefault&&a.getPreventDefault()?bb:ba):this.type=a,b&&p.extend(this,b),this.timeStamp=a&&a.timeStamp||p.now(),this[p.expando]=!0;else return new p.Event(a,b)},p.Event.prototype={preventDefault:function(){this.isDefaultPrevented=bb;var a=this.originalEvent;if(!a)return;a.preventDefault?a.preventDefault():a.returnValue=!1},stopPropagation:function(){this.isPropagationStopped=bb;var a=this.originalEvent;if(!a)return;a.stopPropagation&&a.stopPropagation(),a.cancelBubble=!0},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=bb,this.stopPropagation()},isDefaultPrevented:ba,isPropagationStopped:ba,isImmediatePropagationStopped:ba},p.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(a,b){p.event.special[a]={delegateType:b,bindType:b,handle:function(a){var c,d=this,e=a.relatedTarget,f=a.handleObj,g=f.selector;if(!e||e!==d&&!p.contains(d,e))a.type=f.origType,c=f.handler.apply(this,arguments),a.type=b;return c}}}),p.support.submitBubbles||(p.event.special.submit={setup:function(){if(p.nodeName(this,"form"))return!1;p.event.add(this,"click._submit keypress._submit",function(a){var c=a.target,d=p.nodeName(c,"input")||p.nodeName(c,"button")?c.form:b;d&&!p._data(d,"_submit_attached")&&(p.event.add(d,"submit._submit",function(a){a._submit_bubble=!0}),p._data(d,"_submit_attached",!0))})},postDispatch:function(a){a._submit_bubble&&(delete a._submit_bubble,this.parentNode&&!a.isTrigger&&p.event.simulate("submit",this.parentNode,a,!0))},teardown:function(){if(p.nodeName(this,"form"))return!1;p.event.remove(this,"._submit")}}),p.support.changeBubbles||(p.event.special.change={setup:function(){if(V.test(this.nodeName)){if(this.type==="checkbox"||this.type==="radio")p.event.add(this,"propertychange._change",function(a){a.originalEvent.propertyName==="checked"&&(this._just_changed=!0)}),p.event.add(this,"click._change",function(a){this._just_changed&&!a.isTrigger&&(this._just_changed=!1),p.event.simulate("change",this,a,!0)});return!1}p.event.add(this,"beforeactivate._change",function(a){var b=a.target;V.test(b.nodeName)&&!p._data(b,"_change_attached")&&(p.event.add(b,"change._change",function(a){this.parentNode&&!a.isSimulated&&!a.isTrigger&&p.event.simulate("change",this.parentNode,a,!0)}),p._data(b,"_change_attached",!0))})},handle:function(a){var b=a.target;if(this!==b||a.isSimulated||a.isTrigger||b.type!=="radio"&&b.type!=="checkbox")return a.handleObj.handler.apply(this,arguments)},teardown:function(){return p.event.remove(this,"._change"),!V.test(this.nodeName)}}),p.support.focusinBubbles||p.each({focus:"focusin",blur:"focusout"},function(a,b){var c=0,d=function(a){p.event.simulate(b,a.target,p.event.fix(a),!0)};p.event.special[b]={setup:function(){c++===0&&e.addEventListener(a,d,!0)},teardown:function(){--c===0&&e.removeEventListener(a,d,!0)}}}),p.fn.extend({on:function(a,c,d,e,f){var g,h;if(typeof a=="object"){typeof c!="string"&&(d=d||c,c=b);for(h in a)this.on(h,c,d,a[h],f);return this}d==null&&e==null?(e=c,d=c=b):e==null&&(typeof c=="string"?(e=d,d=b):(e=d,d=c,c=b));if(e===!1)e=ba;else if(!e)return this;return f===1&&(g=e,e=function(a){return p().off(a),g.apply(this,arguments)},e.guid=g.guid||(g.guid=p.guid++)),this.each(function(){p.event.add(this,a,e,d,c)})},one:function(a,b,c,d){return this.on(a,b,c,d,1)},off:function(a,c,d){var e,f;if(a&&a.preventDefault&&a.handleObj)return e=a.handleObj,p(a.delegateTarget).off(e.namespace?e.origType+"."+e.namespace:e.origType,e.selector,e.handler),this;if(typeof a=="object"){for(f in a)this.off(f,c,a[f]);return this}if(c===!1||typeof c=="function")d=c,c=b;return d===!1&&(d=ba),this.each(function(){p.event.remove(this,a,d,c)})},bind:function(a,b,c){return this.on(a,null,b,c)},unbind:function(a,b){return this.off(a,null,b)},live:function(a,b,c){return p(this.context).on(a,this.selector,b,c),this},die:function(a,b){return p(this.context).off(a,this.selector||"**",b),this},delegate:function(a,b,c,d){return this.on(b,a,c,d)},undelegate:function(a,b,c){return arguments.length===1?this.off(a,"**"):this.off(b,a||"**",c)},trigger:function(a,b){return this.each(function(){p.event.trigger(a,b,this)})},triggerHandler:function(a,b){if(this[0])return p.event.trigger(a,b,this[0],!0)},toggle:function(a){var b=arguments,c=a.guid||p.guid++,d=0,e=function(c){var e=(p._data(this,"lastToggle"+a.guid)||0)%d;return p._data(this,"lastToggle"+a.guid,e+1),c.preventDefault(),b[e].apply(this,arguments)||!1};e.guid=c;while(d<b.length)b[d++].guid=c;return this.click(e)},hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)}}),p.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){p.fn[b]=function(a,c){return c==null&&(c=a,a=null),arguments.length>0?this.on(b,null,a,c):this.trigger(b)},Y.test(b)&&(p.event.fixHooks[b]=p.event.keyHooks),Z.test(b)&&(p.event.fixHooks[b]=p.event.mouseHooks)}),function(a,b){function bc(a,b,c,d){c=c||[],b=b||r;var e,f,i,j,k=b.nodeType;if(!a||typeof a!="string")return c;if(k!==1&&k!==9)return[];i=g(b);if(!i&&!d)if(e=P.exec(a))if(j=e[1]){if(k===9){f=b.getElementById(j);if(!f||!f.parentNode)return c;if(f.id===j)return c.push(f),c}else if(b.ownerDocument&&(f=b.ownerDocument.getElementById(j))&&h(b,f)&&f.id===j)return c.push(f),c}else{if(e[2])return w.apply(c,x.call(b.getElementsByTagName(a),0)),c;if((j=e[3])&&_&&b.getElementsByClassName)return w.apply(c,x.call(b.getElementsByClassName(j),0)),c}return bp(a.replace(L,"$1"),b,c,d,i)}function bd(a){return function(b){var c=b.nodeName.toLowerCase();return c==="input"&&b.type===a}}function be(a){return function(b){var c=b.nodeName.toLowerCase();return(c==="input"||c==="button")&&b.type===a}}function bf(a){return z(function(b){return b=+b,z(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function bg(a,b,c){if(a===b)return c;var d=a.nextSibling;while(d){if(d===b)return-1;d=d.nextSibling}return 1}function bh(a,b){var c,d,f,g,h,i,j,k=C[o][a];if(k)return b?0:k.slice(0);h=a,i=[],j=e.preFilter;while(h){if(!c||(d=M.exec(h)))d&&(h=h.slice(d[0].length)),i.push(f=[]);c=!1;if(d=N.exec(h))f.push(c=new q(d.shift())),h=h.slice(c.length),c.type=d[0].replace(L," ");for(g in e.filter)(d=W[g].exec(h))&&(!j[g]||(d=j[g](d,r,!0)))&&(f.push(c=new q(d.shift())),h=h.slice(c.length),c.type=g,c.matches=d);if(!c)break}return b?h.length:h?bc.error(a):C(a,i).slice(0)}function bi(a,b,d){var e=b.dir,f=d&&b.dir==="parentNode",g=u++;return b.first?function(b,c,d){while(b=b[e])if(f||b.nodeType===1)return a(b,c,d)}:function(b,d,h){if(!h){var i,j=t+" "+g+" ",k=j+c;while(b=b[e])if(f||b.nodeType===1){if((i=b[o])===k)return b.sizset;if(typeof i=="string"&&i.indexOf(j)===0){if(b.sizset)return b}else{b[o]=k;if(a(b,d,h))return b.sizset=!0,b;b.sizset=!1}}}else while(b=b[e])if(f||b.nodeType===1)if(a(b,d,h))return b}}function bj(a){return a.length>1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function bk(a,b,c,d,e){var f,g=[],h=0,i=a.length,j=b!=null;for(;h<i;h++)if(f=a[h])if(!c||c(f,d,e))g.push(f),j&&b.push(h);return g}function bl(a,b,c,d,e,f){return d&&!d[o]&&(d=bl(d)),e&&!e[o]&&(e=bl(e,f)),z(function(f,g,h,i){if(f&&e)return;var j,k,l,m=[],n=[],o=g.length,p=f||bo(b||"*",h.nodeType?[h]:h,[],f),q=a&&(f||!b)?bk(p,m,a,h,i):p,r=c?e||(f?a:o||d)?[]:g:q;c&&c(q,r,h,i);if(d){l=bk(r,n),d(l,[],h,i),j=l.length;while(j--)if(k=l[j])r[n[j]]=!(q[n[j]]=k)}if(f){j=a&&r.length;while(j--)if(k=r[j])f[m[j]]=!(g[m[j]]=k)}else r=bk(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):w.apply(g,r)})}function bm(a){var b,c,d,f=a.length,g=e.relative[a[0].type],h=g||e.relative[" "],i=g?1:0,j=bi(function(a){return a===b},h,!0),k=bi(function(a){return y.call(b,a)>-1},h,!0),m=[function(a,c,d){return!g&&(d||c!==l)||((b=c).nodeType?j(a,c,d):k(a,c,d))}];for(;i<f;i++)if(c=e.relative[a[i].type])m=[bi(bj(m),c)];else{c=e.filter[a[i].type].apply(null,a[i].matches);if(c[o]){d=++i;for(;d<f;d++)if(e.relative[a[d].type])break;return bl(i>1&&bj(m),i>1&&a.slice(0,i-1).join("").replace(L,"$1"),c,i<d&&bm(a.slice(i,d)),d<f&&bm(a=a.slice(d)),d<f&&a.join(""))}m.push(c)}return bj(m)}function bn(a,b){var d=b.length>0,f=a.length>0,g=function(h,i,j,k,m){var n,o,p,q=[],s=0,u="0",x=h&&[],y=m!=null,z=l,A=h||f&&e.find.TAG("*",m&&i.parentNode||i),B=t+=z==null?1:Math.E;y&&(l=i!==r&&i,c=g.el);for(;(n=A[u])!=null;u++){if(f&&n){for(o=0;p=a[o];o++)if(p(n,i,j)){k.push(n);break}y&&(t=B,c=++g.el)}d&&((n=!p&&n)&&s--,h&&x.push(n))}s+=u;if(d&&u!==s){for(o=0;p=b[o];o++)p(x,q,i,j);if(h){if(s>0)while(u--)!x[u]&&!q[u]&&(q[u]=v.call(k));q=bk(q)}w.apply(k,q),y&&!h&&q.length>0&&s+b.length>1&&bc.uniqueSort(k)}return y&&(t=B,l=z),x};return g.el=0,d?z(g):g}function bo(a,b,c,d){var e=0,f=b.length;for(;e<f;e++)bc(a,b[e],c,d);return c}function bp(a,b,c,d,f){var g,h,j,k,l,m=bh(a),n=m.length;if(!d&&m.length===1){h=m[0]=m[0].slice(0);if(h.length>2&&(j=h[0]).type==="ID"&&b.nodeType===9&&!f&&e.relative[h[1].type]){b=e.find.ID(j.matches[0].replace(V,""),b,f)[0];if(!b)return c;a=a.slice(h.shift().length)}for(g=W.POS.test(a)?-1:h.length-1;g>=0;g--){j=h[g];if(e.relative[k=j.type])break;if(l=e.find[k])if(d=l(j.matches[0].replace(V,""),R.test(h[0].type)&&b.parentNode||b,f)){h.splice(g,1),a=d.length&&h.join("");if(!a)return w.apply(c,x.call(d,0)),c;break}}}return i(a,m)(d,b,f,c,R.test(a)),c}function bq(){}var c,d,e,f,g,h,i,j,k,l,m=!0,n="undefined",o=("sizcache"+Math.random()).replace(".",""),q=String,r=a.document,s=r.documentElement,t=0,u=0,v=[].pop,w=[].push,x=[].slice,y=[].indexOf||function(a){var b=0,c=this.length;for(;b<c;b++)if(this[b]===a)return b;return-1},z=function(a,b){return a[o]=b==null||b,a},A=function(){var a={},b=[];return z(function(c,d){return b.push(c)>e.cacheLength&&delete a[b.shift()],a[c]=d},a)},B=A(),C=A(),D=A(),E="[\\x20\\t\\r\\n\\f]",F="(?:\\\\.|[-\\w]|[^\\x00-\\xa0])+",G=F.replace("w","w#"),H="([*^$|!~]?=)",I="\\["+E+"*("+F+")"+E+"*(?:"+H+E+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+G+")|)|)"+E+"*\\]",J=":("+F+")(?:\\((?:(['\"])((?:\\\\.|[^\\\\])*?)\\2|([^()[\\]]*|(?:(?:"+I+")|[^:]|\\\\.)*|.*))\\)|)",K=":(even|odd|eq|gt|lt|nth|first|last)(?:\\("+E+"*((?:-\\d)?\\d*)"+E+"*\\)|)(?=[^-]|$)",L=new RegExp("^"+E+"+|((?:^|[^\\\\])(?:\\\\.)*)"+E+"+$","g"),M=new RegExp("^"+E+"*,"+E+"*"),N=new RegExp("^"+E+"*([\\x20\\t\\r\\n\\f>+~])"+E+"*"),O=new RegExp(J),P=/^(?:#([\w\-]+)|(\w+)|\.([\w\-]+))$/,Q=/^:not/,R=/[\x20\t\r\n\f]*[+~]/,S=/:not\($/,T=/h\d/i,U=/input|select|textarea|button/i,V=/\\(?!\\)/g,W={ID:new RegExp("^#("+F+")"),CLASS:new RegExp("^\\.("+F+")"),NAME:new RegExp("^\\[name=['\"]?("+F+")['\"]?\\]"),TAG:new RegExp("^("+F.replace("w","w*")+")"),ATTR:new RegExp("^"+I),PSEUDO:new RegExp("^"+J),POS:new RegExp(K,"i"),CHILD:new RegExp("^:(only|nth|first|last)-child(?:\\("+E+"*(even|odd|(([+-]|)(\\d*)n|)"+E+"*(?:([+-]|)"+E+"*(\\d+)|))"+E+"*\\)|)","i"),needsContext:new RegExp("^"+E+"*[>+~]|"+K,"i")},X=function(a){var b=r.createElement("div");try{return a(b)}catch(c){return!1}finally{b=null}},Y=X(function(a){return a.appendChild(r.createComment("")),!a.getElementsByTagName("*").length}),Z=X(function(a){return a.innerHTML="<a href='#'></a>",a.firstChild&&typeof a.firstChild.getAttribute!==n&&a.firstChild.getAttribute("href")==="#"}),$=X(function(a){a.innerHTML="<select></select>";var b=typeof a.lastChild.getAttribute("multiple");return b!=="boolean"&&b!=="string"}),_=X(function(a){return a.innerHTML="<div class='hidden e'></div><div class='hidden'></div>",!a.getElementsByClassName||!a.getElementsByClassName("e").length?!1:(a.lastChild.className="e",a.getElementsByClassName("e").length===2)}),ba=X(function(a){a.id=o+0,a.innerHTML="<a name='"+o+"'></a><div name='"+o+"'></div>",s.insertBefore(a,s.firstChild);var b=r.getElementsByName&&r.getElementsByName(o).length===2+r.getElementsByName(o+0).length;return d=!r.getElementById(o),s.removeChild(a),b});try{x.call(s.childNodes,0)[0].nodeType}catch(bb){x=function(a){var b,c=[];for(;b=this[a];a++)c.push(b);return c}}bc.matches=function(a,b){return bc(a,null,null,b)},bc.matchesSelector=function(a,b){return bc(b,null,null,[a]).length>0},f=bc.getText=function(a){var b,c="",d=0,e=a.nodeType;if(e){if(e===1||e===9||e===11){if(typeof a.textContent=="string")return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=f(a)}else if(e===3||e===4)return a.nodeValue}else for(;b=a[d];d++)c+=f(b);return c},g=bc.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return b?b.nodeName!=="HTML":!1},h=bc.contains=s.contains?function(a,b){var c=a.nodeType===9?a.documentElement:a,d=b&&b.parentNode;return a===d||!!(d&&d.nodeType===1&&c.contains&&c.contains(d))}:s.compareDocumentPosition?function(a,b){return b&&!!(a.compareDocumentPosition(b)&16)}:function(a,b){while(b=b.parentNode)if(b===a)return!0;return!1},bc.attr=function(a,b){var c,d=g(a);return d||(b=b.toLowerCase()),(c=e.attrHandle[b])?c(a):d||$?a.getAttribute(b):(c=a.getAttributeNode(b),c?typeof a[b]=="boolean"?a[b]?b:null:c.specified?c.value:null:null)},e=bc.selectors={cacheLength:50,createPseudo:z,match:W,attrHandle:Z?{}:{href:function(a){return a.getAttribute("href",2)},type:function(a){return a.getAttribute("type")}},find:{ID:d?function(a,b,c){if(typeof b.getElementById!==n&&!c){var d=b.getElementById(a);return d&&d.parentNode?[d]:[]}}:function(a,c,d){if(typeof c.getElementById!==n&&!d){var e=c.getElementById(a);return e?e.id===a||typeof e.getAttributeNode!==n&&e.getAttributeNode("id").value===a?[e]:b:[]}},TAG:Y?function(a,b){if(typeof b.getElementsByTagName!==n)return b.getElementsByTagName(a)}:function(a,b){var c=b.getElementsByTagName(a);if(a==="*"){var d,e=[],f=0;for(;d=c[f];f++)d.nodeType===1&&e.push(d);return e}return c},NAME:ba&&function(a,b){if(typeof b.getElementsByName!==n)return b.getElementsByName(name)},CLASS:_&&function(a,b,c){if(typeof b.getElementsByClassName!==n&&!c)return b.getElementsByClassName(a)}},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(V,""),a[3]=(a[4]||a[5]||"").replace(V,""),a[2]==="~="&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),a[1]==="nth"?(a[2]||bc.error(a[0]),a[3]=+(a[3]?a[4]+(a[5]||1):2*(a[2]==="even"||a[2]==="odd")),a[4]=+(a[6]+a[7]||a[2]==="odd")):a[2]&&bc.error(a[0]),a},PSEUDO:function(a){var b,c;if(W.CHILD.test(a[0]))return null;if(a[3])a[2]=a[3];else if(b=a[4])O.test(b)&&(c=bh(b,!0))&&(c=b.indexOf(")",b.length-c)-b.length)&&(b=b.slice(0,c),a[0]=a[0].slice(0,c)),a[2]=b;return a.slice(0,3)}},filter:{ID:d?function(a){return a=a.replace(V,""),function(b){return b.getAttribute("id")===a}}:function(a){return a=a.replace(V,""),function(b){var c=typeof b.getAttributeNode!==n&&b.getAttributeNode("id");return c&&c.value===a}},TAG:function(a){return a==="*"?function(){return!0}:(a=a.replace(V,"").toLowerCase(),function(b){return b.nodeName&&b.nodeName.toLowerCase()===a})},CLASS:function(a){var b=B[o][a];return b||(b=B(a,new RegExp("(^|"+E+")"+a+"("+E+"|$)"))),function(a){return b.test(a.className||typeof a.getAttribute!==n&&a.getAttribute("class")||"")}},ATTR:function(a,b,c){return function(d,e){var f=bc.attr(d,a);return f==null?b==="!=":b?(f+="",b==="="?f===c:b==="!="?f!==c:b==="^="?c&&f.indexOf(c)===0:b==="*="?c&&f.indexOf(c)>-1:b==="$="?c&&f.substr(f.length-c.length)===c:b==="~="?(" "+f+" ").indexOf(c)>-1:b==="|="?f===c||f.substr(0,c.length+1)===c+"-":!1):!0}},CHILD:function(a,b,c,d){return a==="nth"?function(a){var b,e,f=a.parentNode;if(c===1&&d===0)return!0;if(f){e=0;for(b=f.firstChild;b;b=b.nextSibling)if(b.nodeType===1){e++;if(a===b)break}}return e-=d,e===c||e%c===0&&e/c>=0}:function(b){var c=b;switch(a){case"only":case"first":while(c=c.previousSibling)if(c.nodeType===1)return!1;if(a==="first")return!0;c=b;case"last":while(c=c.nextSibling)if(c.nodeType===1)return!1;return!0}}},PSEUDO:function(a,b){var c,d=e.pseudos[a]||e.setFilters[a.toLowerCase()]||bc.error("unsupported pseudo: "+a);return d[o]?d(b):d.length>1?(c=[a,a,"",b],e.setFilters.hasOwnProperty(a.toLowerCase())?z(function(a,c){var e,f=d(a,b),g=f.length;while(g--)e=y.call(a,f[g]),a[e]=!(c[e]=f[g])}):function(a){return d(a,0,c)}):d}},pseudos:{not:z(function(a){var b=[],c=[],d=i(a.replace(L,"$1"));return d[o]?z(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)if(f=g[h])a[h]=!(b[h]=f)}):function(a,e,f){return b[0]=a,d(b,null,f,c),!c.pop()}}),has:z(function(a){return function(b){return bc(a,b).length>0}}),contains:z(function(a){return function(b){return(b.textContent||b.innerText||f(b)).indexOf(a)>-1}}),enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();return b==="input"&&!!a.checked||b==="option"&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},parent:function(a){return!e.pseudos.empty(a)},empty:function(a){var b;a=a.firstChild;while(a){if(a.nodeName>"@"||(b=a.nodeType)===3||b===4)return!1;a=a.nextSibling}return!0},header:function(a){return T.test(a.nodeName)},text:function(a){var b,c;return a.nodeName.toLowerCase()==="input"&&(b=a.type)==="text"&&((c=a.getAttribute("type"))==null||c.toLowerCase()===b)},radio:bd("radio"),checkbox:bd("checkbox"),file:bd("file"),password:bd("password"),image:bd("image"),submit:be("submit"),reset:be("reset"),button:function(a){var b=a.nodeName.toLowerCase();return b==="input"&&a.type==="button"||b==="button"},input:function(a){return U.test(a.nodeName)},focus:function(a){var b=a.ownerDocument;return a===b.activeElement&&(!b.hasFocus||b.hasFocus())&&(!!a.type||!!a.href)},active:function(a){return a===a.ownerDocument.activeElement},first:bf(function(a,b,c){return[0]}),last:bf(function(a,b,c){return[b-1]}),eq:bf(function(a,b,c){return[c<0?c+b:c]}),even:bf(function(a,b,c){for(var d=0;d<b;d+=2)a.push(d);return a}),odd:bf(function(a,b,c){for(var d=1;d<b;d+=2)a.push(d);return a}),lt:bf(function(a,b,c){for(var d=c<0?c+b:c;--d>=0;)a.push(d);return a}),gt:bf(function(a,b,c){for(var d=c<0?c+b:c;++d<b;)a.push(d);return a})}},j=s.compareDocumentPosition?function(a,b){return a===b?(k=!0,0):(!a.compareDocumentPosition||!b.compareDocumentPosition?a.compareDocumentPosition:a.compareDocumentPosition(b)&4)?-1:1}:function(a,b){if(a===b)return k=!0,0;if(a.sourceIndex&&b.sourceIndex)return a.sourceIndex-b.sourceIndex;var c,d,e=[],f=[],g=a.parentNode,h=b.parentNode,i=g;if(g===h)return bg(a,b);if(!g)return-1;if(!h)return 1;while(i)e.unshift(i),i=i.parentNode;i=h;while(i)f.unshift(i),i=i.parentNode;c=e.length,d=f.length;for(var j=0;j<c&&j<d;j++)if(e[j]!==f[j])return bg(e[j],f[j]);return j===c?bg(a,f[j],-1):bg(e[j],b,1)},[0,0].sort(j),m=!k,bc.uniqueSort=function(a){var b,c=1;k=m,a.sort(j);if(k)for(;b=a[c];c++)b===a[c-1]&&a.splice(c--,1);return a},bc.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},i=bc.compile=function(a,b){var c,d=[],e=[],f=D[o][a];if(!f){b||(b=bh(a)),c=b.length;while(c--)f=bm(b[c]),f[o]?d.push(f):e.push(f);f=D(a,bn(e,d))}return f},r.querySelectorAll&&function(){var a,b=bp,c=/'|\\/g,d=/\=[\x20\t\r\n\f]*([^'"\]]*)[\x20\t\r\n\f]*\]/g,e=[":focus"],f=[":active",":focus"],h=s.matchesSelector||s.mozMatchesSelector||s.webkitMatchesSelector||s.oMatchesSelector||s.msMatchesSelector;X(function(a){a.innerHTML="<select><option selected=''></option></select>",a.querySelectorAll("[selected]").length||e.push("\\["+E+"*(?:checked|disabled|ismap|multiple|readonly|selected|value)"),a.querySelectorAll(":checked").length||e.push(":checked")}),X(function(a){a.innerHTML="<p test=''></p>",a.querySelectorAll("[test^='']").length&&e.push("[*^$]="+E+"*(?:\"\"|'')"),a.innerHTML="<input type='hidden'/>",a.querySelectorAll(":enabled").length||e.push(":enabled",":disabled")}),e=new RegExp(e.join("|")),bp=function(a,d,f,g,h){if(!g&&!h&&(!e||!e.test(a))){var i,j,k=!0,l=o,m=d,n=d.nodeType===9&&a;if(d.nodeType===1&&d.nodeName.toLowerCase()!=="object"){i=bh(a),(k=d.getAttribute("id"))?l=k.replace(c,"\\$&"):d.setAttribute("id",l),l="[id='"+l+"'] ",j=i.length;while(j--)i[j]=l+i[j].join("");m=R.test(a)&&d.parentNode||d,n=i.join(",")}if(n)try{return w.apply(f,x.call(m.querySelectorAll(n),0)),f}catch(p){}finally{k||d.removeAttribute("id")}}return b(a,d,f,g,h)},h&&(X(function(b){a=h.call(b,"div");try{h.call(b,"[test!='']:sizzle"),f.push("!=",J)}catch(c){}}),f=new RegExp(f.join("|")),bc.matchesSelector=function(b,c){c=c.replace(d,"='$1']");if(!g(b)&&!f.test(c)&&(!e||!e.test(c)))try{var i=h.call(b,c);if(i||a||b.document&&b.document.nodeType!==11)return i}catch(j){}return bc(c,null,null,[b]).length>0})}(),e.pseudos.nth=e.pseudos.eq,e.filters=bq.prototype=e.pseudos,e.setFilters=new bq,bc.attr=p.attr,p.find=bc,p.expr=bc.selectors,p.expr[":"]=p.expr.pseudos,p.unique=bc.uniqueSort,p.text=bc.getText,p.isXMLDoc=bc.isXML,p.contains=bc.contains}(a);var bc=/Until$/,bd=/^(?:parents|prev(?:Until|All))/,be=/^.[^:#\[\.,]*$/,bf=p.expr.match.needsContext,bg={children:!0,contents:!0,next:!0,prev:!0};p.fn.extend({find:function(a){var b,c,d,e,f,g,h=this;if(typeof a!="string")return p(a).filter(function(){for(b=0,c=h.length;b<c;b++)if(p.contains(h[b],this))return!0});g=this.pushStack("","find",a);for(b=0,c=this.length;b<c;b++){d=g.length,p.find(a,this[b],g);if(b>0)for(e=d;e<g.length;e++)for(f=0;f<d;f++)if(g[f]===g[e]){g.splice(e--,1);break}}return g},has:function(a){var b,c=p(a,this),d=c.length;return this.filter(function(){for(b=0;b<d;b++)if(p.contains(this,c[b]))return!0})},not:function(a){return this.pushStack(bj(this,a,!1),"not",a)},filter:function(a){return this.pushStack(bj(this,a,!0),"filter",a)},is:function(a){return!!a&&(typeof a=="string"?bf.test(a)?p(a,this.context).index(this[0])>=0:p.filter(a,this).length>0:this.filter(a).length>0)},closest:function(a,b){var c,d=0,e=this.length,f=[],g=bf.test(a)||typeof a!="string"?p(a,b||this.context):0;for(;d<e;d++){c=this[d];while(c&&c.ownerDocument&&c!==b&&c.nodeType!==11){if(g?g.index(c)>-1:p.find.matchesSelector(c,a)){f.push(c);break}c=c.parentNode}}return f=f.length>1?p.unique(f):f,this.pushStack(f,"closest",a)},index:function(a){return a?typeof a=="string"?p.inArray(this[0],p(a)):p.inArray(a.jquery?a[0]:a,this):this[0]&&this[0].parentNode?this.prevAll().length:-1},add:function(a,b){var c=typeof a=="string"?p(a,b):p.makeArray(a&&a.nodeType?[a]:a),d=p.merge(this.get(),c);return this.pushStack(bh(c[0])||bh(d[0])?d:p.unique(d))},addBack:function(a){return this.add(a==null?this.prevObject:this.prevObject.filter(a))}}),p.fn.andSelf=p.fn.addBack,p.each({parent:function(a){var b=a.parentNode;return b&&b.nodeType!==11?b:null},parents:function(a){return p.dir(a,"parentNode")},parentsUntil:function(a,b,c){return p.dir(a,"parentNode",c)},next:function(a){return bi(a,"nextSibling")},prev:function(a){return bi(a,"previousSibling")},nextAll:function(a){return p.dir(a,"nextSibling")},prevAll:function(a){return p.dir(a,"previousSibling")},nextUntil:function(a,b,c){return p.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return p.dir(a,"previousSibling",c)},siblings:function(a){return p.sibling((a.parentNode||{}).firstChild,a)},children:function(a){return p.sibling(a.firstChild)},contents:function(a){return p.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:p.merge([],a.childNodes)}},function(a,b){p.fn[a]=function(c,d){var e=p.map(this,b,c);return bc.test(a)||(d=c),d&&typeof d=="string"&&(e=p.filter(d,e)),e=this.length>1&&!bg[a]?p.unique(e):e,this.length>1&&bd.test(a)&&(e=e.reverse()),this.pushStack(e,a,k.call(arguments).join(","))}}),p.extend({filter:function(a,b,c){return c&&(a=":not("+a+")"),b.length===1?p.find.matchesSelector(b[0],a)?[b[0]]:[]:p.find.matches(a,b)},dir:function(a,c,d){var e=[],f=a[c];while(f&&f.nodeType!==9&&(d===b||f.nodeType!==1||!p(f).is(d)))f.nodeType===1&&e.push(f),f=f[c];return e},sibling:function(a,b){var c=[];for(;a;a=a.nextSibling)a.nodeType===1&&a!==b&&c.push(a);return c}});var bl="abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",bm=/ jQuery\d+="(?:null|\d+)"/g,bn=/^\s+/,bo=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,bp=/<([\w:]+)/,bq=/<tbody/i,br=/<|&#?\w+;/,bs=/<(?:script|style|link)/i,bt=/<(?:script|object|embed|option|style)/i,bu=new RegExp("<(?:"+bl+")[\\s/>]","i"),bv=/^(?:checkbox|radio)$/,bw=/checked\s*(?:[^=]|=\s*.checked.)/i,bx=/\/(java|ecma)script/i,by=/^\s*<!(?:\[CDATA\[|\-\-)|[\]\-]{2}>\s*$/g,bz={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],area:[1,"<map>","</map>"],_default:[0,"",""]},bA=bk(e),bB=bA.appendChild(e.createElement("div"));bz.optgroup=bz.option,bz.tbody=bz.tfoot=bz.colgroup=bz.caption=bz.thead,bz.th=bz.td,p.support.htmlSerialize||(bz._default=[1,"X<div>","</div>"]),p.fn.extend({text:function(a){return p.access(this,function(a){return a===b?p.text(this):this.empty().append((this[0]&&this[0].ownerDocument||e).createTextNode(a))},null,a,arguments.length)},wrapAll:function(a){if(p.isFunction(a))return this.each(function(b){p(this).wrapAll(a.call(this,b))});if(this[0]){var b=p(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&a.firstChild.nodeType===1)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){return p.isFunction(a)?this.each(function(b){p(this).wrapInner(a.call(this,b))}):this.each(function(){var b=p(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=p.isFunction(a);return this.each(function(c){p(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(){return this.parent().each(function(){p.nodeName(this,"body")||p(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,!0,function(a){(this.nodeType===1||this.nodeType===11)&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,!0,function(a){(this.nodeType===1||this.nodeType===11)&&this.insertBefore(a,this.firstChild)})},before:function(){if(!bh(this[0]))return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this)});if(arguments.length){var a=p.clean(arguments);return this.pushStack(p.merge(a,this),"before",this.selector)}},after:function(){if(!bh(this[0]))return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this.nextSibling)});if(arguments.length){var a=p.clean(arguments);return this.pushStack(p.merge(this,a),"after",this.selector)}},remove:function(a,b){var c,d=0;for(;(c=this[d])!=null;d++)if(!a||p.filter(a,[c]).length)!b&&c.nodeType===1&&(p.cleanData(c.getElementsByTagName("*")),p.cleanData([c])),c.parentNode&&c.parentNode.removeChild(c);return this},empty:function(){var a,b=0;for(;(a=this[b])!=null;b++){a.nodeType===1&&p.cleanData(a.getElementsByTagName("*"));while(a.firstChild)a.removeChild(a.firstChild)}return this},clone:function(a,b){return a=a==null?!1:a,b=b==null?a:b,this.map(function(){return p.clone(this,a,b)})},html:function(a){return p.access(this,function(a){var c=this[0]||{},d=0,e=this.length;if(a===b)return c.nodeType===1?c.innerHTML.replace(bm,""):b;if(typeof a=="string"&&!bs.test(a)&&(p.support.htmlSerialize||!bu.test(a))&&(p.support.leadingWhitespace||!bn.test(a))&&!bz[(bp.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(bo,"<$1></$2>");try{for(;d<e;d++)c=this[d]||{},c.nodeType===1&&(p.cleanData(c.getElementsByTagName("*")),c.innerHTML=a);c=0}catch(f){}}c&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(a){return bh(this[0])?this.length?this.pushStack(p(p.isFunction(a)?a():a),"replaceWith",a):this:p.isFunction(a)?this.each(function(b){var c=p(this),d=c.html();c.replaceWith(a.call(this,b,d))}):(typeof a!="string"&&(a=p(a).detach()),this.each(function(){var b=this.nextSibling,c=this.parentNode;p(this).remove(),b?p(b).before(a):p(c).append(a)}))},detach:function(a){return this.remove(a,!0)},domManip:function(a,c,d){a=[].concat.apply([],a);var e,f,g,h,i=0,j=a[0],k=[],l=this.length;if(!p.support.checkClone&&l>1&&typeof j=="string"&&bw.test(j))return this.each(function(){p(this).domManip(a,c,d)});if(p.isFunction(j))return this.each(function(e){var f=p(this);a[0]=j.call(this,e,c?f.html():b),f.domManip(a,c,d)});if(this[0]){e=p.buildFragment(a,this,k),g=e.fragment,f=g.firstChild,g.childNodes.length===1&&(g=f);if(f){c=c&&p.nodeName(f,"tr");for(h=e.cacheable||l-1;i<l;i++)d.call(c&&p.nodeName(this[i],"table")?bC(this[i],"tbody"):this[i],i===h?g:p.clone(g,!0,!0))}g=f=null,k.length&&p.each(k,function(a,b){b.src?p.ajax?p.ajax({url:b.src,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0}):p.error("no ajax"):p.globalEval((b.text||b.textContent||b.innerHTML||"").replace(by,"")),b.parentNode&&b.parentNode.removeChild(b)})}return this}}),p.buildFragment=function(a,c,d){var f,g,h,i=a[0];return c=c||e,c=!c.nodeType&&c[0]||c,c=c.ownerDocument||c,a.length===1&&typeof i=="string"&&i.length<512&&c===e&&i.charAt(0)==="<"&&!bt.test(i)&&(p.support.checkClone||!bw.test(i))&&(p.support.html5Clone||!bu.test(i))&&(g=!0,f=p.fragments[i],h=f!==b),f||(f=c.createDocumentFragment(),p.clean(a,c,f,d),g&&(p.fragments[i]=h&&f)),{fragment:f,cacheable:g}},p.fragments={},p.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){p.fn[a]=function(c){var d,e=0,f=[],g=p(c),h=g.length,i=this.length===1&&this[0].parentNode;if((i==null||i&&i.nodeType===11&&i.childNodes.length===1)&&h===1)return g[b](this[0]),this;for(;e<h;e++)d=(e>0?this.clone(!0):this).get(),p(g[e])[b](d),f=f.concat(d);return this.pushStack(f,a,g.selector)}}),p.extend({clone:function(a,b,c){var d,e,f,g;p.support.html5Clone||p.isXMLDoc(a)||!bu.test("<"+a.nodeName+">")?g=a.cloneNode(!0):(bB.innerHTML=a.outerHTML,bB.removeChild(g=bB.firstChild));if((!p.support.noCloneEvent||!p.support.noCloneChecked)&&(a.nodeType===1||a.nodeType===11)&&!p.isXMLDoc(a)){bE(a,g),d=bF(a),e=bF(g);for(f=0;d[f];++f)e[f]&&bE(d[f],e[f])}if(b){bD(a,g);if(c){d=bF(a),e=bF(g);for(f=0;d[f];++f)bD(d[f],e[f])}}return d=e=null,g},clean:function(a,b,c,d){var f,g,h,i,j,k,l,m,n,o,q,r,s=b===e&&bA,t=[];if(!b||typeof b.createDocumentFragment=="undefined")b=e;for(f=0;(h=a[f])!=null;f++){typeof h=="number"&&(h+="");if(!h)continue;if(typeof h=="string")if(!br.test(h))h=b.createTextNode(h);else{s=s||bk(b),l=b.createElement("div"),s.appendChild(l),h=h.replace(bo,"<$1></$2>"),i=(bp.exec(h)||["",""])[1].toLowerCase(),j=bz[i]||bz._default,k=j[0],l.innerHTML=j[1]+h+j[2];while(k--)l=l.lastChild;if(!p.support.tbody){m=bq.test(h),n=i==="table"&&!m?l.firstChild&&l.firstChild.childNodes:j[1]==="<table>"&&!m?l.childNodes:[];for(g=n.length-1;g>=0;--g)p.nodeName(n[g],"tbody")&&!n[g].childNodes.length&&n[g].parentNode.removeChild(n[g])}!p.support.leadingWhitespace&&bn.test(h)&&l.insertBefore(b.createTextNode(bn.exec(h)[0]),l.firstChild),h=l.childNodes,l.parentNode.removeChild(l)}h.nodeType?t.push(h):p.merge(t,h)}l&&(h=l=s=null);if(!p.support.appendChecked)for(f=0;(h=t[f])!=null;f++)p.nodeName(h,"input")?bG(h):typeof h.getElementsByTagName!="undefined"&&p.grep(h.getElementsByTagName("input"),bG);if(c){q=function(a){if(!a.type||bx.test(a.type))return d?d.push(a.parentNode?a.parentNode.removeChild(a):a):c.appendChild(a)};for(f=0;(h=t[f])!=null;f++)if(!p.nodeName(h,"script")||!q(h))c.appendChild(h),typeof h.getElementsByTagName!="undefined"&&(r=p.grep(p.merge([],h.getElementsByTagName("script")),q),t.splice.apply(t,[f+1,0].concat(r)),f+=r.length)}return t},cleanData:function(a,b){var c,d,e,f,g=0,h=p.expando,i=p.cache,j=p.support.deleteExpando,k=p.event.special;for(;(e=a[g])!=null;g++)if(b||p.acceptData(e)){d=e[h],c=d&&i[d];if(c){if(c.events)for(f in c.events)k[f]?p.event.remove(e,f):p.removeEvent(e,f,c.handle);i[d]&&(delete i[d],j?delete e[h]:e.removeAttribute?e.removeAttribute(h):e[h]=null,p.deletedIds.push(d))}}}}),function(){var a,b;p.uaMatch=function(a){a=a.toLowerCase();var b=/(chrome)[ \/]([\w.]+)/.exec(a)||/(webkit)[ \/]([\w.]+)/.exec(a)||/(opera)(?:.*version|)[ \/]([\w.]+)/.exec(a)||/(msie) ([\w.]+)/.exec(a)||a.indexOf("compatible")<0&&/(mozilla)(?:.*? rv:([\w.]+)|)/.exec(a)||[];return{browser:b[1]||"",version:b[2]||"0"}},a=p.uaMatch(g.userAgent),b={},a.browser&&(b[a.browser]=!0,b.version=a.version),b.chrome?b.webkit=!0:b.webkit&&(b.safari=!0),p.browser=b,p.sub=function(){function a(b,c){return new a.fn.init(b,c)}p.extend(!0,a,this),a.superclass=this,a.fn=a.prototype=this(),a.fn.constructor=a,a.sub=this.sub,a.fn.init=function c(c,d){return d&&d instanceof p&&!(d instanceof a)&&(d=a(d)),p.fn.init.call(this,c,d,b)},a.fn.init.prototype=a.fn;var b=a(e);return a}}();var bH,bI,bJ,bK=/alpha\([^)]*\)/i,bL=/opacity=([^)]*)/,bM=/^(top|right|bottom|left)$/,bN=/^(none|table(?!-c[ea]).+)/,bO=/^margin/,bP=new RegExp("^("+q+")(.*)$","i"),bQ=new RegExp("^("+q+")(?!px)[a-z%]+$","i"),bR=new RegExp("^([-+])=("+q+")","i"),bS={},bT={position:"absolute",visibility:"hidden",display:"block"},bU={letterSpacing:0,fontWeight:400},bV=["Top","Right","Bottom","Left"],bW=["Webkit","O","Moz","ms"],bX=p.fn.toggle;p.fn.extend({css:function(a,c){return p.access(this,function(a,c,d){return d!==b?p.style(a,c,d):p.css(a,c)},a,c,arguments.length>1)},show:function(){return b$(this,!0)},hide:function(){return b$(this)},toggle:function(a,b){var c=typeof a=="boolean";return p.isFunction(a)&&p.isFunction(b)?bX.apply(this,arguments):this.each(function(){(c?a:bZ(this))?p(this).show():p(this).hide()})}}),p.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=bH(a,"opacity");return c===""?"1":c}}}},cssNumber:{fillOpacity:!0,fontWeight:!0,lineHeight:!0,opacity:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":p.support.cssFloat?"cssFloat":"styleFloat"},style:function(a,c,d,e){if(!a||a.nodeType===3||a.nodeType===8||!a.style)return;var f,g,h,i=p.camelCase(c),j=a.style;c=p.cssProps[i]||(p.cssProps[i]=bY(j,i)),h=p.cssHooks[c]||p.cssHooks[i];if(d===b)return h&&"get"in h&&(f=h.get(a,!1,e))!==b?f:j[c];g=typeof d,g==="string"&&(f=bR.exec(d))&&(d=(f[1]+1)*f[2]+parseFloat(p.css(a,c)),g="number");if(d==null||g==="number"&&isNaN(d))return;g==="number"&&!p.cssNumber[i]&&(d+="px");if(!h||!("set"in h)||(d=h.set(a,d,e))!==b)try{j[c]=d}catch(k){}},css:function(a,c,d,e){var f,g,h,i=p.camelCase(c);return c=p.cssProps[i]||(p.cssProps[i]=bY(a.style,i)),h=p.cssHooks[c]||p.cssHooks[i],h&&"get"in h&&(f=h.get(a,!0,e)),f===b&&(f=bH(a,c)),f==="normal"&&c in bU&&(f=bU[c]),d||e!==b?(g=parseFloat(f),d||p.isNumeric(g)?g||0:f):f},swap:function(a,b,c){var d,e,f={};for(e in b)f[e]=a.style[e],a.style[e]=b[e];d=c.call(a);for(e in b)a.style[e]=f[e];return d}}),a.getComputedStyle?bH=function(b,c){var d,e,f,g,h=a.getComputedStyle(b,null),i=b.style;return h&&(d=h[c],d===""&&!p.contains(b.ownerDocument,b)&&(d=p.style(b,c)),bQ.test(d)&&bO.test(c)&&(e=i.width,f=i.minWidth,g=i.maxWidth,i.minWidth=i.maxWidth=i.width=d,d=h.width,i.width=e,i.minWidth=f,i.maxWidth=g)),d}:e.documentElement.currentStyle&&(bH=function(a,b){var c,d,e=a.currentStyle&&a.currentStyle[b],f=a.style;return e==null&&f&&f[b]&&(e=f[b]),bQ.test(e)&&!bM.test(b)&&(c=f.left,d=a.runtimeStyle&&a.runtimeStyle.left,d&&(a.runtimeStyle.left=a.currentStyle.left),f.left=b==="fontSize"?"1em":e,e=f.pixelLeft+"px",f.left=c,d&&(a.runtimeStyle.left=d)),e===""?"auto":e}),p.each(["height","width"],function(a,b){p.cssHooks[b]={get:function(a,c,d){if(c)return a.offsetWidth===0&&bN.test(bH(a,"display"))?p.swap(a,bT,function(){return cb(a,b,d)}):cb(a,b,d)},set:function(a,c,d){return b_(a,c,d?ca(a,b,d,p.support.boxSizing&&p.css(a,"boxSizing")==="border-box"):0)}}}),p.support.opacity||(p.cssHooks.opacity={get:function(a,b){return bL.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?.01*parseFloat(RegExp.$1)+"":b?"1":""},set:function(a,b){var c=a.style,d=a.currentStyle,e=p.isNumeric(b)?"alpha(opacity="+b*100+")":"",f=d&&d.filter||c.filter||"";c.zoom=1;if(b>=1&&p.trim(f.replace(bK,""))===""&&c.removeAttribute){c.removeAttribute("filter");if(d&&!d.filter)return}c.filter=bK.test(f)?f.replace(bK,e):f+" "+e}}),p(function(){p.support.reliableMarginRight||(p.cssHooks.marginRight={get:function(a,b){return p.swap(a,{display:"inline-block"},function(){if(b)return bH(a,"marginRight")})}}),!p.support.pixelPosition&&p.fn.position&&p.each(["top","left"],function(a,b){p.cssHooks[b]={get:function(a,c){if(c){var d=bH(a,b);return bQ.test(d)?p(a).position()[b]+"px":d}}}})}),p.expr&&p.expr.filters&&(p.expr.filters.hidden=function(a){return a.offsetWidth===0&&a.offsetHeight===0||!p.support.reliableHiddenOffsets&&(a.style&&a.style.display||bH(a,"display"))==="none"},p.expr.filters.visible=function(a){return!p.expr.filters.hidden(a)}),p.each({margin:"",padding:"",border:"Width"},function(a,b){p.cssHooks[a+b]={expand:function(c){var d,e=typeof c=="string"?c.split(" "):[c],f={};for(d=0;d<4;d++)f[a+bV[d]+b]=e[d]||e[d-2]||e[0];return f}},bO.test(a)||(p.cssHooks[a+b].set=b_)});var cd=/%20/g,ce=/\[\]$/,cf=/\r?\n/g,cg=/^(?:color|date|datetime|datetime-local|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i,ch=/^(?:select|textarea)/i;p.fn.extend({serialize:function(){return p.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?p.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||ch.test(this.nodeName)||cg.test(this.type))}).map(function(a,b){var c=p(this).val();return c==null?null:p.isArray(c)?p.map(c,function(a,c){return{name:b.name,value:a.replace(cf,"\r\n")}}):{name:b.name,value:c.replace(cf,"\r\n")}}).get()}}),p.param=function(a,c){var d,e=[],f=function(a,b){b=p.isFunction(b)?b():b==null?"":b,e[e.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};c===b&&(c=p.ajaxSettings&&p.ajaxSettings.traditional);if(p.isArray(a)||a.jquery&&!p.isPlainObject(a))p.each(a,function(){f(this.name,this.value)});else for(d in a)ci(d,a[d],c,f);return e.join("&").replace(cd,"+")};var cj,ck,cl=/#.*$/,cm=/^(.*?):[ \t]*([^\r\n]*)\r?$/mg,cn=/^(?:about|app|app\-storage|.+\-extension|file|res|widget):$/,co=/^(?:GET|HEAD)$/,cp=/^\/\//,cq=/\?/,cr=/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,cs=/([?&])_=[^&]*/,ct=/^([\w\+\.\-]+:)(?:\/\/([^\/?#:]*)(?::(\d+)|)|)/,cu=p.fn.load,cv={},cw={},cx=["*/"]+["*"];try{ck=f.href}catch(cy){ck=e.createElement("a"),ck.href="",ck=ck.href}cj=ct.exec(ck.toLowerCase())||[],p.fn.load=function(a,c,d){if(typeof a!="string"&&cu)return cu.apply(this,arguments);if(!this.length)return this;var e,f,g,h=this,i=a.indexOf(" ");return i>=0&&(e=a.slice(i,a.length),a=a.slice(0,i)),p.isFunction(c)?(d=c,c=b):c&&typeof c=="object"&&(f="POST"),p.ajax({url:a,type:f,dataType:"html",data:c,complete:function(a,b){d&&h.each(d,g||[a.responseText,b,a])}}).done(function(a){g=arguments,h.html(e?p("<div>").append(a.replace(cr,"")).find(e):a)}),this},p.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),function(a,b){p.fn[b]=function(a){return this.on(b,a)}}),p.each(["get","post"],function(a,c){p[c]=function(a,d,e,f){return p.isFunction(d)&&(f=f||e,e=d,d=b),p.ajax({type:c,url:a,data:d,success:e,dataType:f})}}),p.extend({getScript:function(a,c){return p.get(a,b,c,"script")},getJSON:function(a,b,c){return p.get(a,b,c,"json")},ajaxSetup:function(a,b){return b?cB(a,p.ajaxSettings):(b=a,a=p.ajaxSettings),cB(a,b),a},ajaxSettings:{url:ck,isLocal:cn.test(cj[1]),global:!0,type:"GET",contentType:"application/x-www-form-urlencoded; charset=UTF-8",processData:!0,async:!0,accepts:{xml:"application/xml, text/xml",html:"text/html",text:"text/plain",json:"application/json, text/javascript","*":cx},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText"},converters:{"* text":a.String,"text html":!0,"text json":p.parseJSON,"text xml":p.parseXML},flatOptions:{context:!0,url:!0}},ajaxPrefilter:cz(cv),ajaxTransport:cz(cw),ajax:function(a,c){function y(a,c,f,i){var k,s,t,u,w,y=c;if(v===2)return;v=2,h&&clearTimeout(h),g=b,e=i||"",x.readyState=a>0?4:0,f&&(u=cC(l,x,f));if(a>=200&&a<300||a===304)l.ifModified&&(w=x.getResponseHeader("Last-Modified"),w&&(p.lastModified[d]=w),w=x.getResponseHeader("Etag"),w&&(p.etag[d]=w)),a===304?(y="notmodified",k=!0):(k=cD(l,u),y=k.state,s=k.data,t=k.error,k=!t);else{t=y;if(!y||a)y="error",a<0&&(a=0)}x.status=a,x.statusText=(c||y)+"",k?o.resolveWith(m,[s,y,x]):o.rejectWith(m,[x,y,t]),x.statusCode(r),r=b,j&&n.trigger("ajax"+(k?"Success":"Error"),[x,l,k?s:t]),q.fireWith(m,[x,y]),j&&(n.trigger("ajaxComplete",[x,l]),--p.active||p.event.trigger("ajaxStop"))}typeof a=="object"&&(c=a,a=b),c=c||{};var d,e,f,g,h,i,j,k,l=p.ajaxSetup({},c),m=l.context||l,n=m!==l&&(m.nodeType||m instanceof p)?p(m):p.event,o=p.Deferred(),q=p.Callbacks("once memory"),r=l.statusCode||{},t={},u={},v=0,w="canceled",x={readyState:0,setRequestHeader:function(a,b){if(!v){var c=a.toLowerCase();a=u[c]=u[c]||a,t[a]=b}return this},getAllResponseHeaders:function(){return v===2?e:null},getResponseHeader:function(a){var c;if(v===2){if(!f){f={};while(c=cm.exec(e))f[c[1].toLowerCase()]=c[2]}c=f[a.toLowerCase()]}return c===b?null:c},overrideMimeType:function(a){return v||(l.mimeType=a),this},abort:function(a){return a=a||w,g&&g.abort(a),y(0,a),this}};o.promise(x),x.success=x.done,x.error=x.fail,x.complete=q.add,x.statusCode=function(a){if(a){var b;if(v<2)for(b in a)r[b]=[r[b],a[b]];else b=a[x.status],x.always(b)}return this},l.url=((a||l.url)+"").replace(cl,"").replace(cp,cj[1]+"//"),l.dataTypes=p.trim(l.dataType||"*").toLowerCase().split(s),l.crossDomain==null&&(i=ct.exec(l.url.toLowerCase())||!1,l.crossDomain=i&&i.join(":")+(i[3]?"":i[1]==="http:"?80:443)!==cj.join(":")+(cj[3]?"":cj[1]==="http:"?80:443)),l.data&&l.processData&&typeof l.data!="string"&&(l.data=p.param(l.data,l.traditional)),cA(cv,l,c,x);if(v===2)return x;j=l.global,l.type=l.type.toUpperCase(),l.hasContent=!co.test(l.type),j&&p.active++===0&&p.event.trigger("ajaxStart");if(!l.hasContent){l.data&&(l.url+=(cq.test(l.url)?"&":"?")+l.data,delete l.data),d=l.url;if(l.cache===!1){var z=p.now(),A=l.url.replace(cs,"$1_="+z);l.url=A+(A===l.url?(cq.test(l.url)?"&":"?")+"_="+z:"")}}(l.data&&l.hasContent&&l.contentType!==!1||c.contentType)&&x.setRequestHeader("Content-Type",l.contentType),l.ifModified&&(d=d||l.url,p.lastModified[d]&&x.setRequestHeader("If-Modified-Since",p.lastModified[d]),p.etag[d]&&x.setRequestHeader("If-None-Match",p.etag[d])),x.setRequestHeader("Accept",l.dataTypes[0]&&l.accepts[l.dataTypes[0]]?l.accepts[l.dataTypes[0]]+(l.dataTypes[0]!=="*"?", "+cx+"; q=0.01":""):l.accepts["*"]);for(k in l.headers)x.setRequestHeader(k,l.headers[k]);if(!l.beforeSend||l.beforeSend.call(m,x,l)!==!1&&v!==2){w="abort";for(k in{success:1,error:1,complete:1})x[k](l[k]);g=cA(cw,l,c,x);if(!g)y(-1,"No Transport");else{x.readyState=1,j&&n.trigger("ajaxSend",[x,l]),l.async&&l.timeout>0&&(h=setTimeout(function(){x.abort("timeout")},l.timeout));try{v=1,g.send(t,y)}catch(B){if(v<2)y(-1,B);else throw B}}return x}return x.abort()},active:0,lastModified:{},etag:{}});var cE=[],cF=/\?/,cG=/(=)\?(?=&|$)|\?\?/,cH=p.now();p.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var a=cE.pop()||p.expando+"_"+cH++;return this[a]=!0,a}}),p.ajaxPrefilter("json jsonp",function(c,d,e){var f,g,h,i=c.data,j=c.url,k=c.jsonp!==!1,l=k&&cG.test(j),m=k&&!l&&typeof i=="string"&&!(c.contentType||"").indexOf("application/x-www-form-urlencoded")&&cG.test(i);if(c.dataTypes[0]==="jsonp"||l||m)return f=c.jsonpCallback=p.isFunction(c.jsonpCallback)?c.jsonpCallback():c.jsonpCallback,g=a[f],l?c.url=j.replace(cG,"$1"+f):m?c.data=i.replace(cG,"$1"+f):k&&(c.url+=(cF.test(j)?"&":"?")+c.jsonp+"="+f),c.converters["script json"]=function(){return h||p.error(f+" was not called"),h[0]},c.dataTypes[0]="json",a[f]=function(){h=arguments},e.always(function(){a[f]=g,c[f]&&(c.jsonpCallback=d.jsonpCallback,cE.push(f)),h&&p.isFunction(g)&&g(h[0]),h=g=b}),"script"}),p.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/javascript|ecmascript/},converters:{"text script":function(a){return p.globalEval(a),a}}}),p.ajaxPrefilter("script",function(a){a.cache===b&&(a.cache=!1),a.crossDomain&&(a.type="GET",a.global=!1)}),p.ajaxTransport("script",function(a){if(a.crossDomain){var c,d=e.head||e.getElementsByTagName("head")[0]||e.documentElement;return{send:function(f,g){c=e.createElement("script"),c.async="async",a.scriptCharset&&(c.charset=a.scriptCharset),c.src=a.url,c.onload=c.onreadystatechange=function(a,e){if(e||!c.readyState||/loaded|complete/.test(c.readyState))c.onload=c.onreadystatechange=null,d&&c.parentNode&&d.removeChild(c),c=b,e||g(200,"success")},d.insertBefore(c,d.firstChild)},abort:function(){c&&c.onload(0,1)}}}});var cI,cJ=a.ActiveXObject?function(){for(var a in cI)cI[a](0,1)}:!1,cK=0;p.ajaxSettings.xhr=a.ActiveXObject?function(){return!this.isLocal&&cL()||cM()}:cL,function(a){p.extend(p.support,{ajax:!!a,cors:!!a&&"withCredentials"in a})}(p.ajaxSettings.xhr()),p.support.ajax&&p.ajaxTransport(function(c){if(!c.crossDomain||p.support.cors){var d;return{send:function(e,f){var g,h,i=c.xhr();c.username?i.open(c.type,c.url,c.async,c.username,c.password):i.open(c.type,c.url,c.async);if(c.xhrFields)for(h in c.xhrFields)i[h]=c.xhrFields[h];c.mimeType&&i.overrideMimeType&&i.overrideMimeType(c.mimeType),!c.crossDomain&&!e["X-Requested-With"]&&(e["X-Requested-With"]="XMLHttpRequest");try{for(h in e)i.setRequestHeader(h,e[h])}catch(j){}i.send(c.hasContent&&c.data||null),d=function(a,e){var h,j,k,l,m;try{if(d&&(e||i.readyState===4)){d=b,g&&(i.onreadystatechange=p.noop,cJ&&delete cI[g]);if(e)i.readyState!==4&&i.abort();else{h=i.status,k=i.getAllResponseHeaders(),l={},m=i.responseXML,m&&m.documentElement&&(l.xml=m);try{l.text=i.responseText}catch(a){}try{j=i.statusText}catch(n){j=""}!h&&c.isLocal&&!c.crossDomain?h=l.text?200:404:h===1223&&(h=204)}}}catch(o){e||f(-1,o)}l&&f(h,j,l,k)},c.async?i.readyState===4?setTimeout(d,0):(g=++cK,cJ&&(cI||(cI={},p(a).unload(cJ)),cI[g]=d),i.onreadystatechange=d):d()},abort:function(){d&&d(0,1)}}}});var cN,cO,cP=/^(?:toggle|show|hide)$/,cQ=new RegExp("^(?:([-+])=|)("+q+")([a-z%]*)$","i"),cR=/queueHooks$/,cS=[cY],cT={"*":[function(a,b){var c,d,e=this.createTween(a,b),f=cQ.exec(b),g=e.cur(),h=+g||0,i=1,j=20;if(f){c=+f[2],d=f[3]||(p.cssNumber[a]?"":"px");if(d!=="px"&&h){h=p.css(e.elem,a,!0)||c||1;do i=i||".5",h=h/i,p.style(e.elem,a,h+d);while(i!==(i=e.cur()/g)&&i!==1&&--j)}e.unit=d,e.start=h,e.end=f[1]?h+(f[1]+1)*c:c}return e}]};p.Animation=p.extend(cW,{tweener:function(a,b){p.isFunction(a)?(b=a,a=["*"]):a=a.split(" ");var c,d=0,e=a.length;for(;d<e;d++)c=a[d],cT[c]=cT[c]||[],cT[c].unshift(b)},prefilter:function(a,b){b?cS.unshift(a):cS.push(a)}}),p.Tween=cZ,cZ.prototype={constructor:cZ,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||(p.cssNumber[c]?"":"px")},cur:function(){var a=cZ.propHooks[this.prop];return a&&a.get?a.get(this):cZ.propHooks._default.get(this)},run:function(a){var b,c=cZ.propHooks[this.prop];return this.options.duration?this.pos=b=p.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):this.pos=b=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):cZ.propHooks._default.set(this),this}},cZ.prototype.init.prototype=cZ.prototype,cZ.propHooks={_default:{get:function(a){var b;return a.elem[a.prop]==null||!!a.elem.style&&a.elem.style[a.prop]!=null?(b=p.css(a.elem,a.prop,!1,""),!b||b==="auto"?0:b):a.elem[a.prop]},set:function(a){p.fx.step[a.prop]?p.fx.step[a.prop](a):a.elem.style&&(a.elem.style[p.cssProps[a.prop]]!=null||p.cssHooks[a.prop])?p.style(a.elem,a.prop,a.now+a.unit):a.elem[a.prop]=a.now}}},cZ.propHooks.scrollTop=cZ.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},p.each(["toggle","show","hide"],function(a,b){var c=p.fn[b];p.fn[b]=function(d,e,f){return d==null||typeof d=="boolean"||!a&&p.isFunction(d)&&p.isFunction(e)?c.apply(this,arguments):this.animate(c$(b,!0),d,e,f)}}),p.fn.extend({fadeTo:function(a,b,c,d){return this.filter(bZ).css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=p.isEmptyObject(a),f=p.speed(b,c,d),g=function(){var b=cW(this,p.extend({},a),f);e&&b.stop(!0)};return e||f.queue===!1?this.each(g):this.queue(f.queue,g)},stop:function(a,c,d){var e=function(a){var b=a.stop;delete a.stop,b(d)};return typeof a!="string"&&(d=c,c=a,a=b),c&&a!==!1&&this.queue(a||"fx",[]),this.each(function(){var b=!0,c=a!=null&&a+"queueHooks",f=p.timers,g=p._data(this);if(c)g[c]&&g[c].stop&&e(g[c]);else for(c in g)g[c]&&g[c].stop&&cR.test(c)&&e(g[c]);for(c=f.length;c--;)f[c].elem===this&&(a==null||f[c].queue===a)&&(f[c].anim.stop(d),b=!1,f.splice(c,1));(b||!d)&&p.dequeue(this,a)})}}),p.each({slideDown:c$("show"),slideUp:c$("hide"),slideToggle:c$("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){p.fn[a]=function(a,c,d){return this.animate(b,a,c,d)}}),p.speed=function(a,b,c){var d=a&&typeof a=="object"?p.extend({},a):{complete:c||!c&&b||p.isFunction(a)&&a,duration:a,easing:c&&b||b&&!p.isFunction(b)&&b};d.duration=p.fx.off?0:typeof d.duration=="number"?d.duration:d.duration in p.fx.speeds?p.fx.speeds[d.duration]:p.fx.speeds._default;if(d.queue==null||d.queue===!0)d.queue="fx";return d.old=d.complete,d.complete=function(){p.isFunction(d.old)&&d.old.call(this),d.queue&&p.dequeue(this,d.queue)},d},p.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2}},p.timers=[],p.fx=cZ.prototype.init,p.fx.tick=function(){var a,b=p.timers,c=0;for(;c<b.length;c++)a=b[c],!a()&&b[c]===a&&b.splice(c--,1);b.length||p.fx.stop()},p.fx.timer=function(a){a()&&p.timers.push(a)&&!cO&&(cO=setInterval(p.fx.tick,p.fx.interval))},p.fx.interval=13,p.fx.stop=function(){clearInterval(cO),cO=null},p.fx.speeds={slow:600,fast:200,_default:400},p.fx.step={},p.expr&&p.expr.filters&&(p.expr.filters.animated=function(a){return p.grep(p.timers,function(b){return a===b.elem}).length});var c_=/^(?:body|html)$/i;p.fn.offset=function(a){if(arguments.length)return a===b?this:this.each(function(b){p.offset.setOffset(this,a,b)});var c,d,e,f,g,h,i,j={top:0,left:0},k=this[0],l=k&&k.ownerDocument;if(!l)return;return(d=l.body)===k?p.offset.bodyOffset(k):(c=l.documentElement,p.contains(c,k)?(typeof k.getBoundingClientRect!="undefined"&&(j=k.getBoundingClientRect()),e=da(l),f=c.clientTop||d.clientTop||0,g=c.clientLeft||d.clientLeft||0,h=e.pageYOffset||c.scrollTop,i=e.pageXOffset||c.scrollLeft,{top:j.top+h-f,left:j.left+i-g}):j)},p.offset={bodyOffset:function(a){var b=a.offsetTop,c=a.offsetLeft;return p.support.doesNotIncludeMarginInBodyOffset&&(b+=parseFloat(p.css(a,"marginTop"))||0,c+=parseFloat(p.css(a,"marginLeft"))||0),{top:b,left:c}},setOffset:function(a,b,c){var d=p.css(a,"position");d==="static"&&(a.style.position="relative");var e=p(a),f=e.offset(),g=p.css(a,"top"),h=p.css(a,"left"),i=(d==="absolute"||d==="fixed")&&p.inArray("auto",[g,h])>-1,j={},k={},l,m;i?(k=e.position(),l=k.top,m=k.left):(l=parseFloat(g)||0,m=parseFloat(h)||0),p.isFunction(b)&&(b=b.call(a,c,f)),b.top!=null&&(j.top=b.top-f.top+l),b.left!=null&&(j.left=b.left-f.left+m),"using"in b?b.using.call(a,j):e.css(j)}},p.fn.extend({position:function(){if(!this[0])return;var a=this[0],b=this.offsetParent(),c=this.offset(),d=c_.test(b[0].nodeName)?{top:0,left:0}:b.offset();return c.top-=parseFloat(p.css(a,"marginTop"))||0,c.left-=parseFloat(p.css(a,"marginLeft"))||0,d.top+=parseFloat(p.css(b[0],"borderTopWidth"))||0,d.left+=parseFloat(p.css(b[0],"borderLeftWidth"))||0,{top:c.top-d.top,left:c.left-d.left}},offsetParent:function(){return this.map(function(){var a=this.offsetParent||e.body;while(a&&!c_.test(a.nodeName)&&p.css(a,"position")==="static")a=a.offsetParent;return a||e.body})}}),p.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(a,c){var d=/Y/.test(c);p.fn[a]=function(e){return p.access(this,function(a,e,f){var g=da(a);if(f===b)return g?c in g?g[c]:g.document.documentElement[e]:a[e];g?g.scrollTo(d?p(g).scrollLeft():f,d?f:p(g).scrollTop()):a[e]=f},a,e,arguments.length,null)}}),p.each({Height:"height",Width:"width"},function(a,c){p.each({padding:"inner"+a,content:c,"":"outer"+a},function(d,e){p.fn[e]=function(e,f){var g=arguments.length&&(d||typeof e!="boolean"),h=d||(e===!0||f===!0?"margin":"border");return p.access(this,function(c,d,e){var f;return p.isWindow(c)?c.document.documentElement["client"+a]:c.nodeType===9?(f=c.documentElement,Math.max(c.body["scroll"+a],f["scroll"+a],c.body["offset"+a],f["offset"+a],f["client"+a])):e===b?p.css(c,d,e,h):p.style(c,d,e,h)},c,g?e:b,g,null)}})}),a.jQuery=a.$=p,typeof define=="function"&&define.amd&&define.amd.jQuery&&define("jquery",[],function(){return p})})(window);
706 </script>
707
708 <script type="text/javascript">
709 (function(b){b.color={};b.color.make=function(d,e,g,f){var c={};c.r=d||0;c.g=e||0;c.b=g||0;c.a=f!=null?f:1;c.add=function(h,j){for(var k=0;k<h.length;++k){c[h.charAt(k)]+=j}return c.normalize()};c.scale=function(h,j){for(var k=0;k<h.length;++k){c[h.charAt(k)]*=j}return c.normalize()};c.toString=function(){if(c.a>=1){return"rgb("+[c.r,c.g,c.b].join(",")+")"}else{return"rgba("+[c.r,c.g,c.b,c.a].join(",")+")"}};c.normalize=function(){function h(k,j,l){return j<k?k:(j>l?l:j)}c.r=h(0,parseInt(c.r),255);c.g=h(0,parseInt(c.g),255);c.b=h(0,parseInt(c.b),255);c.a=h(0,c.a,1);return c};c.clone=function(){return b.color.make(c.r,c.b,c.g,c.a)};return c.normalize()};b.color.extract=function(d,e){var c;do{c=d.css(e).toLowerCase();if(c!=""&&c!="transparent"){break}d=d.parent()}while(!b.nodeName(d.get(0),"body"));if(c=="rgba(0, 0, 0, 0)"){c="transparent"}return b.color.parse(c)};b.color.parse=function(c){var d,f=b.color.make;if(d=/rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(c)){return f(parseInt(d[1],10),parseInt(d[2],10),parseInt(d[3],10))}if(d=/rgba\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]+(?:\.[0-9]+)?)\s*\)/.exec(c)){return f(parseInt(d[1],10),parseInt(d[2],10),parseInt(d[3],10),parseFloat(d[4]))}if(d=/rgb\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*\)/.exec(c)){return f(parseFloat(d[1])*2.55,parseFloat(d[2])*2.55,parseFloat(d[3])*2.55)}if(d=/rgba\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\s*\)/.exec(c)){return f(parseFloat(d[1])*2.55,parseFloat(d[2])*2.55,parseFloat(d[3])*2.55,parseFloat(d[4]))}if(d=/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(c)){return f(parseInt(d[1],16),parseInt(d[2],16),parseInt(d[3],16))}if(d=/#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(c)){return f(parseInt(d[1]+d[1],16),parseInt(d[2]+d[2],16),parseInt(d[3]+d[3],16))}var e=b.trim(c).toLowerCase();if(e=="transparent"){return f(255,255,255,0)}else{d=a[e]||[0,0,0];return f(d[0],d[1],d[2])}};var a={aqua:[0,255,255],azure:[240,255,255],beige:[245,245,220],black:[0,0,0],blue:[0,0,255],brown:[165,42,42],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgrey:[169,169,169],darkgreen:[0,100,0],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkviolet:[148,0,211],fuchsia:[255,0,255],gold:[255,215,0],green:[0,128,0],indigo:[75,0,130],khaki:[240,230,140],lightblue:[173,216,230],lightcyan:[224,255,255],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightyellow:[255,255,224],lime:[0,255,0],magenta:[255,0,255],maroon:[128,0,0],navy:[0,0,128],olive:[128,128,0],orange:[255,165,0],pink:[255,192,203],purple:[128,0,128],violet:[128,0,128],red:[255,0,0],silver:[192,192,192],white:[255,255,255],yellow:[255,255,0]}})(jQuery);(function(c){function b(av,ai,J,af){var Q=[],O={colors:["#edc240","#afd8f8","#cb4b4b","#4da74d","#9440ed"],legend:{show:true,noColumns:1,labelFormatter:null,labelBoxBorderColor:"#ccc",container:null,position:"ne",margin:5,backgroundColor:null,backgroundOpacity:0.85},xaxis:{show:null,position:"bottom",mode:null,color:null,tickColor:null,transform:null,inverseTransform:null,min:null,max:null,autoscaleMargin:null,ticks:null,tickFormatter:null,labelWidth:null,labelHeight:null,reserveSpace:null,tickLength:null,alignTicksWithAxis:null,tickDecimals:null,tickSize:null,minTickSize:null,monthNames:null,timeformat:null,twelveHourClock:false},yaxis:{autoscaleMargin:0.02,position:"left"},xaxes:[],yaxes:[],series:{points:{show:false,radius:3,lineWidth:2,fill:true,fillColor:"#ffffff",symbol:"circle"},lines:{lineWidth:2,fill:false,fillColor:null,steps:false},bars:{show:false,lineWidth:2,barWidth:1,fill:true,fillColor:null,align:"left",horizontal:false},shadowSize:3},grid:{show:true,aboveData:false,color:"#545454",backgroundColor:null,borderColor:null,tickColor:null,labelMargin:5,axisMargin:8,borderWidth:2,minBorderMargin:null,markings:null,markingsColor:"#f4f4f4",markingsLineWidth:2,clickable:false,hoverable:false,autoHighlight:true,mouseActiveRadius:10},hooks:{}},az=null,ad=null,y=null,H=null,A=null,p=[],aw=[],q={left:0,right:0,top:0,bottom:0},G=0,I=0,h=0,w=0,ak={processOptions:[],processRawData:[],processDatapoints:[],drawSeries:[],draw:[],bindEvents:[],drawOverlay:[],shutdown:[]},aq=this;aq.setData=aj;aq.setupGrid=t;aq.draw=W;aq.getPlaceholder=function(){return av};aq.getCanvas=function(){return az};aq.getPlotOffset=function(){return q};aq.width=function(){return h};aq.height=function(){return w};aq.offset=function(){var aB=y.offset();aB.left+=q.left;aB.top+=q.top;return aB};aq.getData=function(){return Q};aq.getAxes=function(){var aC={},aB;c.each(p.concat(aw),function(aD,aE){if(aE){aC[aE.direction+(aE.n!=1?aE.n:"")+"axis"]=aE}});return aC};aq.getXAxes=function(){return p};aq.getYAxes=function(){return aw};aq.c2p=C;aq.p2c=ar;aq.getOptions=function(){return O};aq.highlight=x;aq.unhighlight=T;aq.triggerRedrawOverlay=f;aq.pointOffset=function(aB){return{left:parseInt(p[aA(aB,"x")-1].p2c(+aB.x)+q.left),top:parseInt(aw[aA(aB,"y")-1].p2c(+aB.y)+q.top)}};aq.shutdown=ag;aq.resize=function(){B();g(az);g(ad)};aq.hooks=ak;F(aq);Z(J);X();aj(ai);t();W();ah();function an(aD,aB){aB=[aq].concat(aB);for(var aC=0;aC<aD.length;++aC){aD[aC].apply(this,aB)}}function F(){for(var aB=0;aB<af.length;++aB){var aC=af[aB];aC.init(aq);if(aC.options){c.extend(true,O,aC.options)}}}function Z(aC){var aB;c.extend(true,O,aC);if(O.xaxis.color==null){O.xaxis.color=O.grid.color}if(O.yaxis.color==null){O.yaxis.color=O.grid.color}if(O.xaxis.tickColor==null){O.xaxis.tickColor=O.grid.tickColor}if(O.yaxis.tickColor==null){O.yaxis.tickColor=O.grid.tickColor}if(O.grid.borderColor==null){O.grid.borderColor=O.grid.color}if(O.grid.tickColor==null){O.grid.tickColor=c.color.parse(O.grid.color).scale("a",0.22).toString()}for(aB=0;aB<Math.max(1,O.xaxes.length);++aB){O.xaxes[aB]=c.extend(true,{},O.xaxis,O.xaxes[aB])}for(aB=0;aB<Math.max(1,O.yaxes.length);++aB){O.yaxes[aB]=c.extend(true,{},O.yaxis,O.yaxes[aB])}if(O.xaxis.noTicks&&O.xaxis.ticks==null){O.xaxis.ticks=O.xaxis.noTicks}if(O.yaxis.noTicks&&O.yaxis.ticks==null){O.yaxis.ticks=O.yaxis.noTicks}if(O.x2axis){O.xaxes[1]=c.extend(true,{},O.xaxis,O.x2axis);O.xaxes[1].position="top"}if(O.y2axis){O.yaxes[1]=c.extend(true,{},O.yaxis,O.y2axis);O.yaxes[1].position="right"}if(O.grid.coloredAreas){O.grid.markings=O.grid.coloredAreas}if(O.grid.coloredAreasColor){O.grid.markingsColor=O.grid.coloredAreasColor}if(O.lines){c.extend(true,O.series.lines,O.lines)}if(O.points){c.extend(true,O.series.points,O.points)}if(O.bars){c.extend(true,O.series.bars,O.bars)}if(O.shadowSize!=null){O.series.shadowSize=O.shadowSize}for(aB=0;aB<O.xaxes.length;++aB){V(p,aB+1).options=O.xaxes[aB]}for(aB=0;aB<O.yaxes.length;++aB){V(aw,aB+1).options=O.yaxes[aB]}for(var aD in ak){if(O.hooks[aD]&&O.hooks[aD].length){ak[aD]=ak[aD].concat(O.hooks[aD])}}an(ak.processOptions,[O])}function aj(aB){Q=Y(aB);ax();z()}function Y(aE){var aC=[];for(var aB=0;aB<aE.length;++aB){var aD=c.extend(true,{},O.series);if(aE[aB].data!=null){aD.data=aE[aB].data;delete aE[aB].data;c.extend(true,aD,aE[aB]);aE[aB].data=aD.data}else{aD.data=aE[aB]}aC.push(aD)}return aC}function aA(aC,aD){var aB=aC[aD+"axis"];if(typeof aB=="object"){aB=aB.n}if(typeof aB!="number"){aB=1}return aB}function m(){return c.grep(p.concat(aw),function(aB){return aB})}function C(aE){var aC={},aB,aD;for(aB=0;aB<p.length;++aB){aD=p[aB];if(aD&&aD.used){aC["x"+aD.n]=aD.c2p(aE.left)}}for(aB=0;aB<aw.length;++aB){aD=aw[aB];if(aD&&aD.used){aC["y"+aD.n]=aD.c2p(aE.top)}}if(aC.x1!==undefined){aC.x=aC.x1}if(aC.y1!==undefined){aC.y=aC.y1}return aC}function ar(aF){var aD={},aC,aE,aB;for(aC=0;aC<p.length;++aC){aE=p[aC];if(aE&&aE.used){aB="x"+aE.n;if(aF[aB]==null&&aE.n==1){aB="x"}if(aF[aB]!=null){aD.left=aE.p2c(aF[aB]);break}}}for(aC=0;aC<aw.length;++aC){aE=aw[aC];if(aE&&aE.used){aB="y"+aE.n;if(aF[aB]==null&&aE.n==1){aB="y"}if(aF[aB]!=null){aD.top=aE.p2c(aF[aB]);break}}}return aD}function V(aC,aB){if(!aC[aB-1]){aC[aB-1]={n:aB,direction:aC==p?"x":"y",options:c.extend(true,{},aC==p?O.xaxis:O.yaxis)}}return aC[aB-1]}function ax(){var aG;var aM=Q.length,aB=[],aE=[];for(aG=0;aG<Q.length;++aG){var aJ=Q[aG].color;if(aJ!=null){--aM;if(typeof aJ=="number"){aE.push(aJ)}else{aB.push(c.color.parse(Q[aG].color))}}}for(aG=0;aG<aE.length;++aG){aM=Math.max(aM,aE[aG]+1)}var aC=[],aF=0;aG=0;while(aC.length<aM){var aI;if(O.colors.length==aG){aI=c.color.make(100,100,100)}else{aI=c.color.parse(O.colors[aG])}var aD=aF%2==1?-1:1;aI.scale("rgb",1+aD*Math.ceil(aF/2)*0.2);aC.push(aI);++aG;if(aG>=O.colors.length){aG=0;++aF}}var aH=0,aN;for(aG=0;aG<Q.length;++aG){aN=Q[aG];if(aN.color==null){aN.color=aC[aH].toString();++aH}else{if(typeof aN.color=="number"){aN.color=aC[aN.color].toString()}}if(aN.lines.show==null){var aL,aK=true;for(aL in aN){if(aN[aL]&&aN[aL].show){aK=false;break}}if(aK){aN.lines.show=true}}aN.xaxis=V(p,aA(aN,"x"));aN.yaxis=V(aw,aA(aN,"y"))}}function z(){var aO=Number.POSITIVE_INFINITY,aI=Number.NEGATIVE_INFINITY,aB=Number.MAX_VALUE,aU,aS,aR,aN,aD,aJ,aT,aP,aH,aG,aC,a0,aX,aL;function aF(a3,a2,a1){if(a2<a3.datamin&&a2!=-aB){a3.datamin=a2}if(a1>a3.datamax&&a1!=aB){a3.datamax=a1}}c.each(m(),function(a1,a2){a2.datamin=aO;a2.datamax=aI;a2.used=false});for(aU=0;aU<Q.length;++aU){aJ=Q[aU];aJ.datapoints={points:[]};an(ak.processRawData,[aJ,aJ.data,aJ.datapoints])}for(aU=0;aU<Q.length;++aU){aJ=Q[aU];var aZ=aJ.data,aW=aJ.datapoints.format;if(!aW){aW=[];aW.push({x:true,number:true,required:true});aW.push({y:true,number:true,required:true});if(aJ.bars.show||(aJ.lines.show&&aJ.lines.fill)){aW.push({y:true,number:true,required:false,defaultValue:0});if(aJ.bars.horizontal){delete aW[aW.length-1].y;aW[aW.length-1].x=true}}aJ.datapoints.format=aW}if(aJ.datapoints.pointsize!=null){continue}aJ.datapoints.pointsize=aW.length;aP=aJ.datapoints.pointsize;aT=aJ.datapoints.points;insertSteps=aJ.lines.show&&aJ.lines.steps;aJ.xaxis.used=aJ.yaxis.used=true;for(aS=aR=0;aS<aZ.length;++aS,aR+=aP){aL=aZ[aS];var aE=aL==null;if(!aE){for(aN=0;aN<aP;++aN){a0=aL[aN];aX=aW[aN];if(aX){if(aX.number&&a0!=null){a0=+a0;if(isNaN(a0)){a0=null}else{if(a0==Infinity){a0=aB}else{if(a0==-Infinity){a0=-aB}}}}if(a0==null){if(aX.required){aE=true}if(aX.defaultValue!=null){a0=aX.defaultValue}}}aT[aR+aN]=a0}}if(aE){for(aN=0;aN<aP;++aN){a0=aT[aR+aN];if(a0!=null){aX=aW[aN];if(aX.x){aF(aJ.xaxis,a0,a0)}if(aX.y){aF(aJ.yaxis,a0,a0)}}aT[aR+aN]=null}}else{if(insertSteps&&aR>0&&aT[aR-aP]!=null&&aT[aR-aP]!=aT[aR]&&aT[aR-aP+1]!=aT[aR+1]){for(aN=0;aN<aP;++aN){aT[aR+aP+aN]=aT[aR+aN]}aT[aR+1]=aT[aR-aP+1];aR+=aP}}}}for(aU=0;aU<Q.length;++aU){aJ=Q[aU];an(ak.processDatapoints,[aJ,aJ.datapoints])}for(aU=0;aU<Q.length;++aU){aJ=Q[aU];aT=aJ.datapoints.points,aP=aJ.datapoints.pointsize;var aK=aO,aQ=aO,aM=aI,aV=aI;for(aS=0;aS<aT.length;aS+=aP){if(aT[aS]==null){continue}for(aN=0;aN<aP;++aN){a0=aT[aS+aN];aX=aW[aN];if(!aX||a0==aB||a0==-aB){continue}if(aX.x){if(a0<aK){aK=a0}if(a0>aM){aM=a0}}if(aX.y){if(a0<aQ){aQ=a0}if(a0>aV){aV=a0}}}}if(aJ.bars.show){var aY=aJ.bars.align=="left"?0:-aJ.bars.barWidth/2;if(aJ.bars.horizontal){aQ+=aY;aV+=aY+aJ.bars.barWidth}else{aK+=aY;aM+=aY+aJ.bars.barWidth}}aF(aJ.xaxis,aK,aM);aF(aJ.yaxis,aQ,aV)}c.each(m(),function(a1,a2){if(a2.datamin==aO){a2.datamin=null}if(a2.datamax==aI){a2.datamax=null}})}function j(aB,aC){var aD=document.createElement("canvas");aD.className=aC;aD.width=G;aD.height=I;if(!aB){c(aD).css({position:"absolute",left:0,top:0})}c(aD).appendTo(av);if(!aD.getContext){aD=window.G_vmlCanvasManager.initElement(aD)}aD.getContext("2d").save();return aD}function B(){G=av.width();I=av.height();if(G<=0||I<=0){throw"Invalid dimensions for plot, width = "+G+", height = "+I}}function g(aC){if(aC.width!=G){aC.width=G}if(aC.height!=I){aC.height=I}var aB=aC.getContext("2d");aB.restore();aB.save()}function X(){var aC,aB=av.children("canvas.base"),aD=av.children("canvas.overlay");if(aB.length==0||aD==0){av.html("");av.css({padding:0});if(av.css("position")=="static"){av.css("position","relative")}B();az=j(true,"base");ad=j(false,"overlay");aC=false}else{az=aB.get(0);ad=aD.get(0);aC=true}H=az.getContext("2d");A=ad.getContext("2d");y=c([ad,az]);if(aC){av.data("plot").shutdown();aq.resize();A.clearRect(0,0,G,I);y.unbind();av.children().not([az,ad]).remove()}av.data("plot",aq)}function ah(){if(O.grid.hoverable){y.mousemove(aa);y.mouseleave(l)}if(O.grid.clickable){y.click(R)}an(ak.bindEvents,[y])}function ag(){if(M){clearTimeout(M)}y.unbind("mousemove",aa);y.unbind("mouseleave",l);y.unbind("click",R);an(ak.shutdown,[y])}function r(aG){function aC(aH){return aH}var aF,aB,aD=aG.options.transform||aC,aE=aG.options.inverseTransform;if(aG.direction=="x"){aF=aG.scale=h/Math.abs(aD(aG.max)-aD(aG.min));aB=Math.min(aD(aG.max),aD(aG.min))}else{aF=aG.scale=w/Math.abs(aD(aG.max)-aD(aG.min));aF=-aF;aB=Math.max(aD(aG.max),aD(aG.min))}if(aD==aC){aG.p2c=function(aH){return(aH-aB)*aF}}else{aG.p2c=function(aH){return(aD(aH)-aB)*aF}}if(!aE){aG.c2p=function(aH){return aB+aH/aF}}else{aG.c2p=function(aH){return aE(aB+aH/aF)}}}function L(aD){var aB=aD.options,aF,aJ=aD.ticks||[],aI=[],aE,aK=aB.labelWidth,aG=aB.labelHeight,aC;function aH(aM,aL){return c('<div style="position:absolute;top:-10000px;'+aL+'font-size:smaller"><div class="'+aD.direction+"Axis "+aD.direction+aD.n+'Axis">'+aM.join("")+"</div></div>").appendTo(av)}if(aD.direction=="x"){if(aK==null){aK=Math.floor(G/(aJ.length>0?aJ.length:1))}if(aG==null){aI=[];for(aF=0;aF<aJ.length;++aF){aE=aJ[aF].label;if(aE){aI.push('<div class="tickLabel" style="float:left;width:'+aK+'px">'+aE+"</div>")}}if(aI.length>0){aI.push('<div style="clear:left"></div>');aC=aH(aI,"width:10000px;");aG=aC.height();aC.remove()}}}else{if(aK==null||aG==null){for(aF=0;aF<aJ.length;++aF){aE=aJ[aF].label;if(aE){aI.push('<div class="tickLabel">'+aE+"</div>")}}if(aI.length>0){aC=aH(aI,"");if(aK==null){aK=aC.children().width()}if(aG==null){aG=aC.find("div.tickLabel").height()}aC.remove()}}}if(aK==null){aK=0}if(aG==null){aG=0}aD.labelWidth=aK;aD.labelHeight=aG}function au(aD){var aC=aD.labelWidth,aL=aD.labelHeight,aH=aD.options.position,aF=aD.options.tickLength,aG=O.grid.axisMargin,aJ=O.grid.labelMargin,aK=aD.direction=="x"?p:aw,aE;var aB=c.grep(aK,function(aN){return aN&&aN.options.position==aH&&aN.reserveSpace});if(c.inArray(aD,aB)==aB.length-1){aG=0}if(aF==null){aF="full"}var aI=c.grep(aK,function(aN){return aN&&aN.reserveSpace});var aM=c.inArray(aD,aI)==0;if(!aM&&aF=="full"){aF=5}if(!isNaN(+aF)){aJ+=+aF}if(aD.direction=="x"){aL+=aJ;if(aH=="bottom"){q.bottom+=aL+aG;aD.box={top:I-q.bottom,height:aL}}else{aD.box={top:q.top+aG,height:aL};q.top+=aL+aG}}else{aC+=aJ;if(aH=="left"){aD.box={left:q.left+aG,width:aC};q.left+=aC+aG}else{q.right+=aC+aG;aD.box={left:G-q.right,width:aC}}}aD.position=aH;aD.tickLength=aF;aD.box.padding=aJ;aD.innermost=aM}function U(aB){if(aB.direction=="x"){aB.box.left=q.left;aB.box.width=h}else{aB.box.top=q.top;aB.box.height=w}}function t(){var aC,aE=m();c.each(aE,function(aF,aG){aG.show=aG.options.show;if(aG.show==null){aG.show=aG.used}aG.reserveSpace=aG.show||aG.options.reserveSpace;n(aG)});allocatedAxes=c.grep(aE,function(aF){return aF.reserveSpace});q.left=q.right=q.top=q.bottom=0;if(O.grid.show){c.each(allocatedAxes,function(aF,aG){S(aG);P(aG);ap(aG,aG.ticks);L(aG)});for(aC=allocatedAxes.length-1;aC>=0;--aC){au(allocatedAxes[aC])}var aD=O.grid.minBorderMargin;if(aD==null){aD=0;for(aC=0;aC<Q.length;++aC){aD=Math.max(aD,Q[aC].points.radius+Q[aC].points.lineWidth/2)}}for(var aB in q){q[aB]+=O.grid.borderWidth;q[aB]=Math.max(aD,q[aB])}}h=G-q.left-q.right;w=I-q.bottom-q.top;c.each(aE,function(aF,aG){r(aG)});if(O.grid.show){c.each(allocatedAxes,function(aF,aG){U(aG)});k()}o()}function n(aE){var aF=aE.options,aD=+(aF.min!=null?aF.min:aE.datamin),aB=+(aF.max!=null?aF.max:aE.datamax),aH=aB-aD;if(aH==0){var aC=aB==0?1:0.01;if(aF.min==null){aD-=aC}if(aF.max==null||aF.min!=null){aB+=aC}}else{var aG=aF.autoscaleMargin;if(aG!=null){if(aF.min==null){aD-=aH*aG;if(aD<0&&aE.datamin!=null&&aE.datamin>=0){aD=0}}if(aF.max==null){aB+=aH*aG;if(aB>0&&aE.datamax!=null&&aE.datamax<=0){aB=0}}}}aE.min=aD;aE.max=aB}function S(aG){var aM=aG.options;var aH;if(typeof aM.ticks=="number"&&aM.ticks>0){aH=aM.ticks}else{aH=0.3*Math.sqrt(aG.direction=="x"?G:I)}var aT=(aG.max-aG.min)/aH,aO,aB,aN,aR,aS,aQ,aI;if(aM.mode=="time"){var aJ={second:1000,minute:60*1000,hour:60*60*1000,day:24*60*60*1000,month:30*24*60*60*1000,year:365.2425*24*60*60*1000};var aK=[[1,"second"],[2,"second"],[5,"second"],[10,"second"],[30,"second"],[1,"minute"],[2,"minute"],[5,"minute"],[10,"minute"],[30,"minute"],[1,"hour"],[2,"hour"],[4,"hour"],[8,"hour"],[12,"hour"],[1,"day"],[2,"day"],[3,"day"],[0.25,"month"],[0.5,"month"],[1,"month"],[2,"month"],[3,"month"],[6,"month"],[1,"year"]];var aC=0;if(aM.minTickSize!=null){if(typeof aM.tickSize=="number"){aC=aM.tickSize}else{aC=aM.minTickSize[0]*aJ[aM.minTickSize[1]]}}for(var aS=0;aS<aK.length-1;++aS){if(aT<(aK[aS][0]*aJ[aK[aS][1]]+aK[aS+1][0]*aJ[aK[aS+1][1]])/2&&aK[aS][0]*aJ[aK[aS][1]]>=aC){break}}aO=aK[aS][0];aN=aK[aS][1];if(aN=="year"){aQ=Math.pow(10,Math.floor(Math.log(aT/aJ.year)/Math.LN10));aI=(aT/aJ.year)/aQ;if(aI<1.5){aO=1}else{if(aI<3){aO=2}else{if(aI<7.5){aO=5}else{aO=10}}}aO*=aQ}aG.tickSize=aM.tickSize||[aO,aN];aB=function(aX){var a2=[],a0=aX.tickSize[0],a3=aX.tickSize[1],a1=new Date(aX.min);var aW=a0*aJ[a3];if(a3=="second"){a1.setUTCSeconds(a(a1.getUTCSeconds(),a0))}if(a3=="minute"){a1.setUTCMinutes(a(a1.getUTCMinutes(),a0))}if(a3=="hour"){a1.setUTCHours(a(a1.getUTCHours(),a0))}if(a3=="month"){a1.setUTCMonth(a(a1.getUTCMonth(),a0))}if(a3=="year"){a1.setUTCFullYear(a(a1.getUTCFullYear(),a0))}a1.setUTCMilliseconds(0);if(aW>=aJ.minute){a1.setUTCSeconds(0)}if(aW>=aJ.hour){a1.setUTCMinutes(0)}if(aW>=aJ.day){a1.setUTCHours(0)}if(aW>=aJ.day*4){a1.setUTCDate(1)}if(aW>=aJ.year){a1.setUTCMonth(0)}var a5=0,a4=Number.NaN,aY;do{aY=a4;a4=a1.getTime();a2.push(a4);if(a3=="month"){if(a0<1){a1.setUTCDate(1);var aV=a1.getTime();a1.setUTCMonth(a1.getUTCMonth()+1);var aZ=a1.getTime();a1.setTime(a4+a5*aJ.hour+(aZ-aV)*a0);a5=a1.getUTCHours();a1.setUTCHours(0)}else{a1.setUTCMonth(a1.getUTCMonth()+a0)}}else{if(a3=="year"){a1.setUTCFullYear(a1.getUTCFullYear()+a0)}else{a1.setTime(a4+aW)}}}while(a4<aX.max&&a4!=aY);return a2};aR=function(aV,aY){var a0=new Date(aV);if(aM.timeformat!=null){return c.plot.formatDate(a0,aM.timeformat,aM.monthNames)}var aW=aY.tickSize[0]*aJ[aY.tickSize[1]];var aX=aY.max-aY.min;var aZ=(aM.twelveHourClock)?" %p":"";if(aW<aJ.minute){fmt="%h:%M:%S"+aZ}else{if(aW<aJ.day){if(aX<2*aJ.day){fmt="%h:%M"+aZ}else{fmt="%b %d %h:%M"+aZ}}else{if(aW<aJ.month){fmt="%b %d"}else{if(aW<aJ.year){if(aX<aJ.year){fmt="%b"}else{fmt="%b %y"}}else{fmt="%y"}}}}return c.plot.formatDate(a0,fmt,aM.monthNames)}}else{var aU=aM.tickDecimals;var aP=-Math.floor(Math.log(aT)/Math.LN10);if(aU!=null&&aP>aU){aP=aU}aQ=Math.pow(10,-aP);aI=aT/aQ;if(aI<1.5){aO=1}else{if(aI<3){aO=2;if(aI>2.25&&(aU==null||aP+1<=aU)){aO=2.5;++aP}}else{if(aI<7.5){aO=5}else{aO=10}}}aO*=aQ;if(aM.minTickSize!=null&&aO<aM.minTickSize){aO=aM.minTickSize}aG.tickDecimals=Math.max(0,aU!=null?aU:aP);aG.tickSize=aM.tickSize||aO;aB=function(aX){var aZ=[];var a0=a(aX.min,aX.tickSize),aW=0,aV=Number.NaN,aY;do{aY=aV;aV=a0+aW*aX.tickSize;aZ.push(aV);++aW}while(aV<aX.max&&aV!=aY);return aZ};aR=function(aV,aW){return aV.toFixed(aW.tickDecimals)}}if(aM.alignTicksWithAxis!=null){var aF=(aG.direction=="x"?p:aw)[aM.alignTicksWithAxis-1];if(aF&&aF.used&&aF!=aG){var aL=aB(aG);if(aL.length>0){if(aM.min==null){aG.min=Math.min(aG.min,aL[0])}if(aM.max==null&&aL.length>1){aG.max=Math.max(aG.max,aL[aL.length-1])}}aB=function(aX){var aY=[],aV,aW;for(aW=0;aW<aF.ticks.length;++aW){aV=(aF.ticks[aW].v-aF.min)/(aF.max-aF.min);aV=aX.min+aV*(aX.max-aX.min);aY.push(aV)}return aY};if(aG.mode!="time"&&aM.tickDecimals==null){var aE=Math.max(0,-Math.floor(Math.log(aT)/Math.LN10)+1),aD=aB(aG);if(!(aD.length>1&&/\..*0$/.test((aD[1]-aD[0]).toFixed(aE)))){aG.tickDecimals=aE}}}}aG.tickGenerator=aB;if(c.isFunction(aM.tickFormatter)){aG.tickFormatter=function(aV,aW){return""+aM.tickFormatter(aV,aW)}}else{aG.tickFormatter=aR}}function P(aF){var aH=aF.options.ticks,aG=[];if(aH==null||(typeof aH=="number"&&aH>0)){aG=aF.tickGenerator(aF)}else{if(aH){if(c.isFunction(aH)){aG=aH({min:aF.min,max:aF.max})}else{aG=aH}}}var aE,aB;aF.ticks=[];for(aE=0;aE<aG.length;++aE){var aC=null;var aD=aG[aE];if(typeof aD=="object"){aB=+aD[0];if(aD.length>1){aC=aD[1]}}else{aB=+aD}if(aC==null){aC=aF.tickFormatter(aB,aF)}if(!isNaN(aB)){aF.ticks.push({v:aB,label:aC})}}}function ap(aB,aC){if(aB.options.autoscaleMargin&&aC.length>0){if(aB.options.min==null){aB.min=Math.min(aB.min,aC[0].v)}if(aB.options.max==null&&aC.length>1){aB.max=Math.max(aB.max,aC[aC.length-1].v)}}}function W(){H.clearRect(0,0,G,I);var aC=O.grid;if(aC.show&&aC.backgroundColor){N()}if(aC.show&&!aC.aboveData){ac()}for(var aB=0;aB<Q.length;++aB){an(ak.drawSeries,[H,Q[aB]]);d(Q[aB])}an(ak.draw,[H]);if(aC.show&&aC.aboveData){ac()}}function D(aB,aI){var aE,aH,aG,aD,aF=m();for(i=0;i<aF.length;++i){aE=aF[i];if(aE.direction==aI){aD=aI+aE.n+"axis";if(!aB[aD]&&aE.n==1){aD=aI+"axis"}if(aB[aD]){aH=aB[aD].from;aG=aB[aD].to;break}}}if(!aB[aD]){aE=aI=="x"?p[0]:aw[0];aH=aB[aI+"1"];aG=aB[aI+"2"]}if(aH!=null&&aG!=null&&aH>aG){var aC=aH;aH=aG;aG=aC}return{from:aH,to:aG,axis:aE}}function N(){H.save();H.translate(q.left,q.top);H.fillStyle=am(O.grid.backgroundColor,w,0,"rgba(255, 255, 255, 0)");H.fillRect(0,0,h,w);H.restore()}function ac(){var aF;H.save();H.translate(q.left,q.top);var aH=O.grid.markings;if(aH){if(c.isFunction(aH)){var aK=aq.getAxes();aK.xmin=aK.xaxis.min;aK.xmax=aK.xaxis.max;aK.ymin=aK.yaxis.min;aK.ymax=aK.yaxis.max;aH=aH(aK)}for(aF=0;aF<aH.length;++aF){var aD=aH[aF],aC=D(aD,"x"),aI=D(aD,"y");if(aC.from==null){aC.from=aC.axis.min}if(aC.to==null){aC.to=aC.axis.max}if(aI.from==null){aI.from=aI.axis.min}if(aI.to==null){aI.to=aI.axis.max}if(aC.to<aC.axis.min||aC.from>aC.axis.max||aI.to<aI.axis.min||aI.from>aI.axis.max){continue}aC.from=Math.max(aC.from,aC.axis.min);aC.to=Math.min(aC.to,aC.axis.max);aI.from=Math.max(aI.from,aI.axis.min);aI.to=Math.min(aI.to,aI.axis.max);if(aC.from==aC.to&&aI.from==aI.to){continue}aC.from=aC.axis.p2c(aC.from);aC.to=aC.axis.p2c(aC.to);aI.from=aI.axis.p2c(aI.from);aI.to=aI.axis.p2c(aI.to);if(aC.from==aC.to||aI.from==aI.to){H.beginPath();H.strokeStyle=aD.color||O.grid.markingsColor;H.lineWidth=aD.lineWidth||O.grid.markingsLineWidth;H.moveTo(aC.from,aI.from);H.lineTo(aC.to,aI.to);H.stroke()}else{H.fillStyle=aD.color||O.grid.markingsColor;H.fillRect(aC.from,aI.to,aC.to-aC.from,aI.from-aI.to)}}}var aK=m(),aM=O.grid.borderWidth;for(var aE=0;aE<aK.length;++aE){var aB=aK[aE],aG=aB.box,aQ=aB.tickLength,aN,aL,aP,aJ;if(!aB.show||aB.ticks.length==0){continue}H.strokeStyle=aB.options.tickColor||c.color.parse(aB.options.color).scale("a",0.22).toString();H.lineWidth=aB.options.lineWidth;if(aB.direction=="x"){aN=0;if(aQ=="full"){aL=(aB.position=="top"?0:w)}else{aL=aG.top-q.top+(aB.position=="top"?aG.height:0)}}else{aL=0;if(aQ=="full"){aN=(aB.position=="left"?0:h)}else{aN=aG.left-q.left+(aB.position=="left"?aG.width:0)}}if(!aB.innermost){H.beginPath();aP=aJ=0;if(aB.direction=="x"){aP=h}else{aJ=w}if(H.lineWidth==1){aN=Math.floor(aN)+0.5;aL=Math.floor(aL)+0.5}H.moveTo(aN,aL);H.lineTo(aN+aP,aL+aJ);H.stroke()}H.beginPath();for(aF=0;aF<aB.ticks.length;++aF){var aO=aB.ticks[aF].v;aP=aJ=0;if(aO<aB.min||aO>aB.max||(aQ=="full"&&aM>0&&(aO==aB.min||aO==aB.max))){continue}if(aB.direction=="x"){aN=aB.p2c(aO);aJ=aQ=="full"?-w:aQ;if(aB.position=="top"){aJ=-aJ}}else{aL=aB.p2c(aO);aP=aQ=="full"?-h:aQ;if(aB.position=="left"){aP=-aP}}if(H.lineWidth==1){if(aB.direction=="x"){aN=Math.floor(aN)+0.5}else{aL=Math.floor(aL)+0.5}}H.moveTo(aN,aL);H.lineTo(aN+aP,aL+aJ)}H.stroke()}if(aM){H.lineWidth=aM;H.strokeStyle=O.grid.borderColor;H.strokeRect(-aM/2,-aM/2,h+aM,w+aM)}H.restore()}function k(){av.find(".tickLabels").remove();var aG=['<div class="tickLabels" style="font-size:smaller">'];var aJ=m();for(var aD=0;aD<aJ.length;++aD){var aC=aJ[aD],aF=aC.box;if(!aC.show){continue}aG.push('<div class="'+aC.direction+"Axis "+aC.direction+aC.n+'Axis" style="color:'+aC.options.color+'">');for(var aE=0;aE<aC.ticks.length;++aE){var aH=aC.ticks[aE];if(!aH.label||aH.v<aC.min||aH.v>aC.max){continue}var aK={},aI;if(aC.direction=="x"){aI="center";aK.left=Math.round(q.left+aC.p2c(aH.v)-aC.labelWidth/2);if(aC.position=="bottom"){aK.top=aF.top+aF.padding}else{aK.bottom=I-(aF.top+aF.height-aF.padding)}}else{aK.top=Math.round(q.top+aC.p2c(aH.v)-aC.labelHeight/2);if(aC.position=="left"){aK.right=G-(aF.left+aF.width-aF.padding);aI="right"}else{aK.left=aF.left+aF.padding;aI="left"}}aK.width=aC.labelWidth;var aB=["position:absolute","text-align:"+aI];for(var aL in aK){aB.push(aL+":"+aK[aL]+"px")}aG.push('<div class="tickLabel" style="'+aB.join(";")+'">'+aH.label+"</div>")}aG.push("</div>")}aG.push("</div>");av.append(aG.join(""))}function d(aB){if(aB.lines.show){at(aB)}if(aB.bars.show){e(aB)}if(aB.points.show){ao(aB)}}function at(aE){function aD(aP,aQ,aI,aU,aT){var aV=aP.points,aJ=aP.pointsize,aN=null,aM=null;H.beginPath();for(var aO=aJ;aO<aV.length;aO+=aJ){var aL=aV[aO-aJ],aS=aV[aO-aJ+1],aK=aV[aO],aR=aV[aO+1];if(aL==null||aK==null){continue}if(aS<=aR&&aS<aT.min){if(aR<aT.min){continue}aL=(aT.min-aS)/(aR-aS)*(aK-aL)+aL;aS=aT.min}else{if(aR<=aS&&aR<aT.min){if(aS<aT.min){continue}aK=(aT.min-aS)/(aR-aS)*(aK-aL)+aL;aR=aT.min}}if(aS>=aR&&aS>aT.max){if(aR>aT.max){continue}aL=(aT.max-aS)/(aR-aS)*(aK-aL)+aL;aS=aT.max}else{if(aR>=aS&&aR>aT.max){if(aS>aT.max){continue}aK=(aT.max-aS)/(aR-aS)*(aK-aL)+aL;aR=aT.max}}if(aL<=aK&&aL<aU.min){if(aK<aU.min){continue}aS=(aU.min-aL)/(aK-aL)*(aR-aS)+aS;aL=aU.min}else{if(aK<=aL&&aK<aU.min){if(aL<aU.min){continue}aR=(aU.min-aL)/(aK-aL)*(aR-aS)+aS;aK=aU.min}}if(aL>=aK&&aL>aU.max){if(aK>aU.max){continue}aS=(aU.max-aL)/(aK-aL)*(aR-aS)+aS;aL=aU.max}else{if(aK>=aL&&aK>aU.max){if(aL>aU.max){continue}aR=(aU.max-aL)/(aK-aL)*(aR-aS)+aS;aK=aU.max}}if(aL!=aN||aS!=aM){H.moveTo(aU.p2c(aL)+aQ,aT.p2c(aS)+aI)}aN=aK;aM=aR;H.lineTo(aU.p2c(aK)+aQ,aT.p2c(aR)+aI)}H.stroke()}function aF(aI,aQ,aP){var aW=aI.points,aV=aI.pointsize,aN=Math.min(Math.max(0,aP.min),aP.max),aX=0,aU,aT=false,aM=1,aL=0,aR=0;while(true){if(aV>0&&aX>aW.length+aV){break}aX+=aV;var aZ=aW[aX-aV],aK=aW[aX-aV+aM],aY=aW[aX],aJ=aW[aX+aM];if(aT){if(aV>0&&aZ!=null&&aY==null){aR=aX;aV=-aV;aM=2;continue}if(aV<0&&aX==aL+aV){H.fill();aT=false;aV=-aV;aM=1;aX=aL=aR+aV;continue}}if(aZ==null||aY==null){continue}if(aZ<=aY&&aZ<aQ.min){if(aY<aQ.min){continue}aK=(aQ.min-aZ)/(aY-aZ)*(aJ-aK)+aK;aZ=aQ.min}else{if(aY<=aZ&&aY<aQ.min){if(aZ<aQ.min){continue}aJ=(aQ.min-aZ)/(aY-aZ)*(aJ-aK)+aK;aY=aQ.min}}if(aZ>=aY&&aZ>aQ.max){if(aY>aQ.max){continue}aK=(aQ.max-aZ)/(aY-aZ)*(aJ-aK)+aK;aZ=aQ.max}else{if(aY>=aZ&&aY>aQ.max){if(aZ>aQ.max){continue}aJ=(aQ.max-aZ)/(aY-aZ)*(aJ-aK)+aK;aY=aQ.max}}if(!aT){H.beginPath();H.moveTo(aQ.p2c(aZ),aP.p2c(aN));aT=true}if(aK>=aP.max&&aJ>=aP.max){H.lineTo(aQ.p2c(aZ),aP.p2c(aP.max));H.lineTo(aQ.p2c(aY),aP.p2c(aP.max));continue}else{if(aK<=aP.min&&aJ<=aP.min){H.lineTo(aQ.p2c(aZ),aP.p2c(aP.min));H.lineTo(aQ.p2c(aY),aP.p2c(aP.min));continue}}var aO=aZ,aS=aY;if(aK<=aJ&&aK<aP.min&&aJ>=aP.min){aZ=(aP.min-aK)/(aJ-aK)*(aY-aZ)+aZ;aK=aP.min}else{if(aJ<=aK&&aJ<aP.min&&aK>=aP.min){aY=(aP.min-aK)/(aJ-aK)*(aY-aZ)+aZ;aJ=aP.min}}if(aK>=aJ&&aK>aP.max&&aJ<=aP.max){aZ=(aP.max-aK)/(aJ-aK)*(aY-aZ)+aZ;aK=aP.max}else{if(aJ>=aK&&aJ>aP.max&&aK<=aP.max){aY=(aP.max-aK)/(aJ-aK)*(aY-aZ)+aZ;aJ=aP.max}}if(aZ!=aO){H.lineTo(aQ.p2c(aO),aP.p2c(aK))}H.lineTo(aQ.p2c(aZ),aP.p2c(aK));H.lineTo(aQ.p2c(aY),aP.p2c(aJ));if(aY!=aS){H.lineTo(aQ.p2c(aY),aP.p2c(aJ));H.lineTo(aQ.p2c(aS),aP.p2c(aJ))}}}H.save();H.translate(q.left,q.top);H.lineJoin="round";var aG=aE.lines.lineWidth,aB=aE.shadowSize;if(aG>0&&aB>0){H.lineWidth=aB;H.strokeStyle="rgba(0,0,0,0.1)";var aH=Math.PI/18;aD(aE.datapoints,Math.sin(aH)*(aG/2+aB/2),Math.cos(aH)*(aG/2+aB/2),aE.xaxis,aE.yaxis);H.lineWidth=aB/2;aD(aE.datapoints,Math.sin(aH)*(aG/2+aB/4),Math.cos(aH)*(aG/2+aB/4),aE.xaxis,aE.yaxis)}H.lineWidth=aG;H.strokeStyle=aE.color;var aC=ae(aE.lines,aE.color,0,w);if(aC){H.fillStyle=aC;aF(aE.datapoints,aE.xaxis,aE.yaxis)}if(aG>0){aD(aE.datapoints,0,0,aE.xaxis,aE.yaxis)}H.restore()}function ao(aE){function aH(aN,aM,aU,aK,aS,aT,aQ,aJ){var aR=aN.points,aI=aN.pointsize;for(var aL=0;aL<aR.length;aL+=aI){var aP=aR[aL],aO=aR[aL+1];if(aP==null||aP<aT.min||aP>aT.max||aO<aQ.min||aO>aQ.max){continue}H.beginPath();aP=aT.p2c(aP);aO=aQ.p2c(aO)+aK;if(aJ=="circle"){H.arc(aP,aO,aM,0,aS?Math.PI:Math.PI*2,false)}else{aJ(H,aP,aO,aM,aS)}H.closePath();if(aU){H.fillStyle=aU;H.fill()}/*H.stroke()*/}}H.save();H.translate(q.left,q.top);var aG=aE.points.lineWidth,aC=aE.shadowSize,aB=aE.points.radius,aF=aE.points.symbol;if(aG>0&&aC>0){var aD=aC/2;H.lineWidth=aD;H.strokeStyle="rgba(0,0,0,0.1)";aH(aE.datapoints,aB,null,aD+aD/2,true,aE.xaxis,aE.yaxis,aF);H.strokeStyle="rgba(0,0,0,0.2)";aH(aE.datapoints,aB,null,aD/2,true,aE.xaxis,aE.yaxis,aF)}H.lineWidth=aG;H.strokeStyle=aE.color;aH(aE.datapoints,aB,ae(aE.points,aE.color),0,false,aE.xaxis,aE.yaxis,aF);H.restore()}function E(aN,aM,aV,aI,aQ,aF,aD,aL,aK,aU,aR,aC){var aE,aT,aJ,aP,aG,aB,aO,aH,aS;if(aR){aH=aB=aO=true;aG=false;aE=aV;aT=aN;aP=aM+aI;aJ=aM+aQ;if(aT<aE){aS=aT;aT=aE;aE=aS;aG=true;aB=false}}else{aG=aB=aO=true;aH=false;aE=aN+aI;aT=aN+aQ;aJ=aV;aP=aM;if(aP<aJ){aS=aP;aP=aJ;aJ=aS;aH=true;aO=false}}if(aT<aL.min||aE>aL.max||aP<aK.min||aJ>aK.max){return}if(aE<aL.min){aE=aL.min;aG=false}if(aT>aL.max){aT=aL.max;aB=false}if(aJ<aK.min){aJ=aK.min;aH=false}if(aP>aK.max){aP=aK.max;aO=false}aE=aL.p2c(aE);aJ=aK.p2c(aJ);aT=aL.p2c(aT);aP=aK.p2c(aP);if(aD){aU.beginPath();aU.moveTo(aE,aJ);aU.lineTo(aE,aP);aU.lineTo(aT,aP);aU.lineTo(aT,aJ);aU.fillStyle=aD(aJ,aP);aU.fill()}if(aC>0&&(aG||aB||aO||aH)){aU.beginPath();aU.moveTo(aE,aJ+aF);if(aG){aU.lineTo(aE,aP+aF)}else{aU.moveTo(aE,aP+aF)}if(aO){aU.lineTo(aT,aP+aF)}else{aU.moveTo(aT,aP+aF)}if(aB){aU.lineTo(aT,aJ+aF)}else{aU.moveTo(aT,aJ+aF)}if(aH){aU.lineTo(aE,aJ+aF)}else{aU.moveTo(aE,aJ+aF)}aU.stroke()}}function e(aD){function aC(aJ,aI,aL,aG,aK,aN,aM){var aO=aJ.points,aF=aJ.pointsize;for(var aH=0;aH<aO.length;aH+=aF){if(aO[aH]==null){continue}E(aO[aH],aO[aH+1],aO[aH+2],aI,aL,aG,aK,aN,aM,H,aD.bars.horizontal,aD.bars.lineWidth)}}H.save();H.translate(q.left,q.top);H.lineWidth=aD.bars.lineWidth;H.strokeStyle=aD.color;var aB=aD.bars.align=="left"?0:-aD.bars.barWidth/2;var aE=aD.bars.fill?function(aF,aG){return ae(aD.bars,aD.color,aF,aG)}:null;aC(aD.datapoints,aB,aB+aD.bars.barWidth,0,aE,aD.xaxis,aD.yaxis);H.restore()}function ae(aD,aB,aC,aF){var aE=aD.fill;if(!aE){return null}if(aD.fillColor){return am(aD.fillColor,aC,aF,aB)}var aG=c.color.parse(aB);aG.a=typeof aE=="number"?aE:0.4;aG.normalize();return aG.toString()}function o(){av.find(".legend").remove();if(!O.legend.show){return}var aH=[],aF=false,aN=O.legend.labelFormatter,aM,aJ;for(var aE=0;aE<Q.length;++aE){aM=Q[aE];aJ=aM.label;if(!aJ){continue}if(aE%O.legend.noColumns==0){if(aF){aH.push("</tr>")}aH.push("<tr>");aF=true}if(aN){aJ=aN(aJ,aM)}aH.push('<td class="legendColorBox"><div style="border:1px solid '+O.legend.labelBoxBorderColor+';padding:1px"><div style="width:4px;height:0;border:5px solid '+aM.color+';overflow:hidden"></div></div></td><td class="legendLabel">'+aJ+"</td>")}if(aF){aH.push("</tr>")}if(aH.length==0){return}var aL='<table style="font-size:smaller;color:'+O.grid.color+'">'+aH.join("")+"</table>";if(O.legend.container!=null){c(O.legend.container).html(aL)}else{var aI="",aC=O.legend.position,aD=O.legend.margin;if(aD[0]==null){aD=[aD,aD]}if(aC.charAt(0)=="n"){aI+="top:"+(aD[1]+q.top)+"px;"}else{if(aC.charAt(0)=="s"){aI+="bottom:"+(aD[1]+q.bottom)+"px;"}}if(aC.charAt(1)=="e"){aI+="right:"+(aD[0]+q.right)+"px;"}else{if(aC.charAt(1)=="w"){aI+="left:"+(aD[0]+q.left)+"px;"}}var aK=c('<div class="legend">'+aL.replace('style="','style="position:absolute;'+aI+";")+"</div>").appendTo(av);if(O.legend.backgroundOpacity!=0){var aG=O.legend.backgroundColor;if(aG==null){aG=O.grid.backgroundColor;if(aG&&typeof aG=="string"){aG=c.color.parse(aG)}else{aG=c.color.extract(aK,"background-color")}aG.a=1;aG=aG.toString()}var aB=aK.children();c('<div style="position:absolute;width:'+aB.width()+"px;height:"+aB.height()+"px;"+aI+"background-color:"+aG+';"> </div>').prependTo(aK).css("opacity",O.legend.backgroundOpacity)}}}var ab=[],M=null;function K(aI,aG,aD){var aO=O.grid.mouseActiveRadius,a0=aO*aO+1,aY=null,aR=false,aW,aU;for(aW=Q.length-1;aW>=0;--aW){if(!aD(Q[aW])){continue}var aP=Q[aW],aH=aP.xaxis,aF=aP.yaxis,aV=aP.datapoints.points,aT=aP.datapoints.pointsize,aQ=aH.c2p(aI),aN=aF.c2p(aG),aC=aO/aH.scale,aB=aO/aF.scale;if(aH.options.inverseTransform){aC=Number.MAX_VALUE}if(aF.options.inverseTransform){aB=Number.MAX_VALUE}if(aP.lines.show||aP.points.show||aP.dashes.show){for(aU=0;aU<aV.length;aU+=aT){var aK=aV[aU],aJ=aV[aU+1];if(aK==null){continue}if(aK-aQ>aC||aK-aQ<-aC||aJ-aN>aB||aJ-aN<-aB){continue}var aM=Math.abs(aH.p2c(aK)-aI),aL=Math.abs(aF.p2c(aJ)-aG),aS=aM*aM+aL*aL;if(aS<a0){a0=aS;aY=[aW,aU/aT]}}}if(aP.bars.show&&!aY){var aE=aP.bars.align=="left"?0:-aP.bars.barWidth/2,aX=aE+aP.bars.barWidth;for(aU=0;aU<aV.length;aU+=aT){var aK=aV[aU],aJ=aV[aU+1],aZ=aV[aU+2];if(aK==null){continue}if(Q[aW].bars.horizontal?(aQ<=Math.max(aZ,aK)&&aQ>=Math.min(aZ,aK)&&aN>=aJ+aE&&aN<=aJ+aX):(aQ>=aK+aE&&aQ<=aK+aX&&aN>=Math.min(aZ,aJ)&&aN<=Math.max(aZ,aJ))){aY=[aW,aU/aT]}}}}if(aY){aW=aY[0];aU=aY[1];aT=Q[aW].datapoints.pointsize;return{datapoint:Q[aW].datapoints.points.slice(aU*aT,(aU+1)*aT),dataIndex:aU,series:Q[aW],seriesIndex:aW}}return null}function aa(aB){if(O.grid.hoverable){u("plothover",aB,function(aC){return aC.hoverable!=false})}}function l(aB){if(O.grid.hoverable){u("plothover",aB,function(aC){return false})}}function R(aB){u("plotclick",aB,function(aC){return aC.clickable!=false})}function u(aC,aB,aD){var aE=y.offset(),aH=aB.pageX-aE.left-q.left,aF=aB.pageY-aE.top-q.top,aJ=C({left:aH,top:aF});aJ.pageX=aB.pageX;aJ.pageY=aB.pageY;var aK=K(aH,aF,aD);if(aK){aK.pageX=parseInt(aK.series.xaxis.p2c(aK.datapoint[0])+aE.left+q.left);aK.pageY=parseInt(aK.series.yaxis.p2c(aK.datapoint[1])+aE.top+q.top)}if(O.grid.autoHighlight){for(var aG=0;aG<ab.length;++aG){var aI=ab[aG];if(aI.auto==aC&&!(aK&&aI.series==aK.series&&aI.point[0]==aK.datapoint[0]&&aI.point[1]==aK.datapoint[1])){T(aI.series,aI.point)}}if(aK){x(aK.series,aK.datapoint,aC)}}av.trigger(aC,[aJ,aK])}function f(){if(!M){M=setTimeout(s,30)}}function s(){M=null;A.save();A.clearRect(0,0,G,I);A.translate(q.left,q.top);var aC,aB;for(aC=0;aC<ab.length;++aC){aB=ab[aC];if(aB.series.bars.show){v(aB.series,aB.point)}else{ay(aB.series,aB.point)}}A.restore();an(ak.drawOverlay,[A])}function x(aD,aB,aF){if(typeof aD=="number"){aD=Q[aD]}if(typeof aB=="number"){var aE=aD.datapoints.pointsize;aB=aD.datapoints.points.slice(aE*aB,aE*(aB+1))}var aC=al(aD,aB);if(aC==-1){ab.push({series:aD,point:aB,auto:aF});f()}else{if(!aF){ab[aC].auto=false}}}function T(aD,aB){if(aD==null&&aB==null){ab=[];f()}if(typeof aD=="number"){aD=Q[aD]}if(typeof aB=="number"){aB=aD.data[aB]}var aC=al(aD,aB);if(aC!=-1){ab.splice(aC,1);f()}}function al(aD,aE){for(var aB=0;aB<ab.length;++aB){var aC=ab[aB];if(aC.series==aD&&aC.point[0]==aE[0]&&aC.point[1]==aE[1]){return aB}}return -1}function ay(aE,aD){var aC=aD[0],aI=aD[1],aH=aE.xaxis,aG=aE.yaxis;if(aC<aH.min||aC>aH.max||aI<aG.min||aI>aG.max){return}var aF=aE.points.radius+aE.points.lineWidth/2;A.lineWidth=aF;A.strokeStyle=c.color.parse(aE.color).scale("a",0.5).toString();var aB=1.5*aF,aC=aH.p2c(aC),aI=aG.p2c(aI);A.beginPath();if(aE.points.symbol=="circle"){A.arc(aC,aI,aB,0,2*Math.PI,false)}else{aE.points.symbol(A,aC,aI,aB,false)}A.closePath();A.stroke()}function v(aE,aB){A.lineWidth=aE.bars.lineWidth;A.strokeStyle=c.color.parse(aE.color).scale("a",0.5).toString();var aD=c.color.parse(aE.color).scale("a",0.5).toString();var aC=aE.bars.align=="left"?0:-aE.bars.barWidth/2;E(aB[0],aB[1],aB[2]||0,aC,aC+aE.bars.barWidth,0,function(){return aD},aE.xaxis,aE.yaxis,A,aE.bars.horizontal,aE.bars.lineWidth)}function am(aJ,aB,aH,aC){if(typeof aJ=="string"){return aJ}else{var aI=H.createLinearGradient(0,aH,0,aB);for(var aE=0,aD=aJ.colors.length;aE<aD;++aE){var aF=aJ.colors[aE];if(typeof aF!="string"){var aG=c.color.parse(aC);if(aF.brightness!=null){aG=aG.scale("rgb",aF.brightness)}if(aF.opacity!=null){aG.a*=aF.opacity}aF=aG.toString()}aI.addColorStop(aE/(aD-1),aF)}return aI}}}c.plot=function(g,e,d){var f=new b(c(g),e,d,c.plot.plugins);return f};c.plot.version="0.7";c.plot.plugins=[];c.plot.formatDate=function(l,f,h){var o=function(d){d=""+d;return d.length==1?"0"+d:d};var e=[];var p=false,j=false;var n=l.getUTCHours();var k=n<12;if(h==null){h=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]}if(f.search(/%p|%P/)!=-1){if(n>12){n=n-12}else{if(n==0){n=12}}}for(var g=0;g<f.length;++g){var m=f.charAt(g);if(p){switch(m){case"h":m=""+n;break;case"H":m=o(n);break;case"M":m=o(l.getUTCMinutes());break;case"S":m=o(l.getUTCSeconds());break;case"d":m=""+l.getUTCDate();break;case"m":m=""+(l.getUTCMonth()+1);break;case"y":m=""+l.getUTCFullYear();break;case"b":m=""+h[l.getUTCMonth()];break;case"p":m=(k)?("am"):("pm");break;case"P":m=(k)?("AM"):("PM");break;case"0":m="";j=true;break}if(m&&j){m=o(m);j=false}e.push(m);if(!j){p=false}}else{if(m=="%"){p=true}else{e.push(m)}}}return e.join("")};function a(e,d){return d*Math.floor(e/d)}})(jQuery);
710 </script>
711
712 <script type="text/javascript">
713 if(!document.createElement("canvas").getContext){(function(){var z=Math;var K=z.round;var J=z.sin;var U=z.cos;var b=z.abs;var k=z.sqrt;var D=10;var F=D/2;function T(){return this.context_||(this.context_=new W(this))}var O=Array.prototype.slice;function G(i,j,m){var Z=O.call(arguments,2);return function(){return i.apply(j,Z.concat(O.call(arguments)))}}function AD(Z){return String(Z).replace(/&/g,"&amp;").replace(/"/g,"&quot;")}function r(i){if(!i.namespaces.g_vml_){i.namespaces.add("g_vml_","urn:schemas-microsoft-com:vml","#default#VML")}if(!i.namespaces.g_o_){i.namespaces.add("g_o_","urn:schemas-microsoft-com:office:office","#default#VML")}if(!i.styleSheets.ex_canvas_){var Z=i.createStyleSheet();Z.owningElement.id="ex_canvas_";Z.cssText="canvas{display:inline-block;overflow:hidden;text-align:left;width:300px;height:150px}"}}r(document);var E={init:function(Z){if(/MSIE/.test(navigator.userAgent)&&!window.opera){var i=Z||document;i.createElement("canvas");i.attachEvent("onreadystatechange",G(this.init_,this,i))}},init_:function(m){var j=m.getElementsByTagName("canvas");for(var Z=0;Z<j.length;Z++){this.initElement(j[Z])}},initElement:function(i){if(!i.getContext){i.getContext=T;r(i.ownerDocument);i.innerHTML="";i.attachEvent("onpropertychange",S);i.attachEvent("onresize",w);var Z=i.attributes;if(Z.width&&Z.width.specified){i.style.width=Z.width.nodeValue+"px"}else{i.width=i.clientWidth}if(Z.height&&Z.height.specified){i.style.height=Z.height.nodeValue+"px"}else{i.height=i.clientHeight}}return i}};function S(i){var Z=i.srcElement;switch(i.propertyName){case"width":Z.getContext().clearRect();Z.style.width=Z.attributes.width.nodeValue+"px";Z.firstChild.style.width=Z.clientWidth+"px";break;case"height":Z.getContext().clearRect();Z.style.height=Z.attributes.height.nodeValue+"px";Z.firstChild.style.height=Z.clientHeight+"px";break}}function w(i){var Z=i.srcElement;if(Z.firstChild){Z.firstChild.style.width=Z.clientWidth+"px";Z.firstChild.style.height=Z.clientHeight+"px"}}E.init();var I=[];for(var AC=0;AC<16;AC++){for(var AB=0;AB<16;AB++){I[AC*16+AB]=AC.toString(16)+AB.toString(16)}}function V(){return[[1,0,0],[0,1,0],[0,0,1]]}function d(m,j){var i=V();for(var Z=0;Z<3;Z++){for(var AF=0;AF<3;AF++){var p=0;for(var AE=0;AE<3;AE++){p+=m[Z][AE]*j[AE][AF]}i[Z][AF]=p}}return i}function Q(i,Z){Z.fillStyle=i.fillStyle;Z.lineCap=i.lineCap;Z.lineJoin=i.lineJoin;Z.lineWidth=i.lineWidth;Z.miterLimit=i.miterLimit;Z.shadowBlur=i.shadowBlur;Z.shadowColor=i.shadowColor;Z.shadowOffsetX=i.shadowOffsetX;Z.shadowOffsetY=i.shadowOffsetY;Z.strokeStyle=i.strokeStyle;Z.globalAlpha=i.globalAlpha;Z.font=i.font;Z.textAlign=i.textAlign;Z.textBaseline=i.textBaseline;Z.arcScaleX_=i.arcScaleX_;Z.arcScaleY_=i.arcScaleY_;Z.lineScale_=i.lineScale_}var B={aliceblue:"#F0F8FF",antiquewhite:"#FAEBD7",aquamarine:"#7FFFD4",azure:"#F0FFFF",beige:"#F5F5DC",bisque:"#FFE4C4",black:"#000000",blanchedalmond:"#FFEBCD",blueviolet:"#8A2BE2",brown:"#A52A2A",burlywood:"#DEB887",cadetblue:"#5F9EA0",chartreuse:"#7FFF00",chocolate:"#D2691E",coral:"#FF7F50",cornflowerblue:"#6495ED",cornsilk:"#FFF8DC",crimson:"#DC143C",cyan:"#00FFFF",darkblue:"#00008B",darkcyan:"#008B8B",darkgoldenrod:"#B8860B",darkgray:"#A9A9A9",darkgreen:"#006400",darkgrey:"#A9A9A9",darkkhaki:"#BDB76B",darkmagenta:"#8B008B",darkolivegreen:"#556B2F",darkorange:"#FF8C00",darkorchid:"#9932CC",darkred:"#8B0000",darksalmon:"#E9967A",darkseagreen:"#8FBC8F",darkslateblue:"#483D8B",darkslategray:"#2F4F4F",darkslategrey:"#2F4F4F",darkturquoise:"#00CED1",darkviolet:"#9400D3",deeppink:"#FF1493",deepskyblue:"#00BFFF",dimgray:"#696969",dimgrey:"#696969",dodgerblue:"#1E90FF",firebrick:"#B22222",floralwhite:"#FFFAF0",forestgreen:"#228B22",gainsboro:"#DCDCDC",ghostwhite:"#F8F8FF",gold:"#FFD700",goldenrod:"#DAA520",grey:"#808080",greenyellow:"#ADFF2F",honeydew:"#F0FFF0",hotpink:"#FF69B4",indianred:"#CD5C5C",indigo:"#4B0082",ivory:"#FFFFF0",khaki:"#F0E68C",lavender:"#E6E6FA",lavenderblush:"#FFF0F5",lawngreen:"#7CFC00",lemonchiffon:"#FFFACD",lightblue:"#ADD8E6",lightcoral:"#F08080",lightcyan:"#E0FFFF",lightgoldenrodyellow:"#FAFAD2",lightgreen:"#90EE90",lightgrey:"#D3D3D3",lightpink:"#FFB6C1",lightsalmon:"#FFA07A",lightseagreen:"#20B2AA",lightskyblue:"#87CEFA",lightslategray:"#778899",lightslategrey:"#778899",lightsteelblue:"#B0C4DE",lightyellow:"#FFFFE0",limegreen:"#32CD32",linen:"#FAF0E6",magenta:"#FF00FF",mediumaquamarine:"#66CDAA",mediumblue:"#0000CD",mediumorchid:"#BA55D3",mediumpurple:"#9370DB",mediumseagreen:"#3CB371",mediumslateblue:"#7B68EE",mediumspringgreen:"#00FA9A",mediumturquoise:"#48D1CC",mediumvioletred:"#C71585",midnightblue:"#191970",mintcream:"#F5FFFA",mistyrose:"#FFE4E1",moccasin:"#FFE4B5",navajowhite:"#FFDEAD",oldlace:"#FDF5E6",olivedrab:"#6B8E23",orange:"#FFA500",orangered:"#FF4500",orchid:"#DA70D6",palegoldenrod:"#EEE8AA",palegreen:"#98FB98",paleturquoise:"#AFEEEE",palevioletred:"#DB7093",papayawhip:"#FFEFD5",peachpuff:"#FFDAB9",peru:"#CD853F",pink:"#FFC0CB",plum:"#DDA0DD",powderblue:"#B0E0E6",rosybrown:"#BC8F8F",royalblue:"#4169E1",saddlebrown:"#8B4513",salmon:"#FA8072",sandybrown:"#F4A460",seagreen:"#2E8B57",seashell:"#FFF5EE",sienna:"#A0522D",skyblue:"#87CEEB",slateblue:"#6A5ACD",slategray:"#708090",slategrey:"#708090",snow:"#FFFAFA",springgreen:"#00FF7F",steelblue:"#4682B4",tan:"#D2B48C",thistle:"#D8BFD8",tomato:"#FF6347",turquoise:"#40E0D0",violet:"#EE82EE",wheat:"#F5DEB3",whitesmoke:"#F5F5F5",yellowgreen:"#9ACD32"};function g(i){var m=i.indexOf("(",3);var Z=i.indexOf(")",m+1);var j=i.substring(m+1,Z).split(",");if(j.length==4&&i.substr(3,1)=="a"){alpha=Number(j[3])}else{j[3]=1}return j}function C(Z){return parseFloat(Z)/100}function N(i,j,Z){return Math.min(Z,Math.max(j,i))}function c(AF){var j,i,Z;h=parseFloat(AF[0])/360%360;if(h<0){h++}s=N(C(AF[1]),0,1);l=N(C(AF[2]),0,1);if(s==0){j=i=Z=l}else{var m=l<0.5?l*(1+s):l+s-l*s;var AE=2*l-m;j=A(AE,m,h+1/3);i=A(AE,m,h);Z=A(AE,m,h-1/3)}return"#"+I[Math.floor(j*255)]+I[Math.floor(i*255)]+I[Math.floor(Z*255)]}function A(i,Z,j){if(j<0){j++}if(j>1){j--}if(6*j<1){return i+(Z-i)*6*j}else{if(2*j<1){return Z}else{if(3*j<2){return i+(Z-i)*(2/3-j)*6}else{return i}}}}function Y(Z){var AE,p=1;Z=String(Z);if(Z.charAt(0)=="#"){AE=Z}else{if(/^rgb/.test(Z)){var m=g(Z);var AE="#",AF;for(var j=0;j<3;j++){if(m[j].indexOf("%")!=-1){AF=Math.floor(C(m[j])*255)}else{AF=Number(m[j])}AE+=I[N(AF,0,255)]}p=m[3]}else{if(/^hsl/.test(Z)){var m=g(Z);AE=c(m);p=m[3]}else{AE=B[Z]||Z}}}return{color:AE,alpha:p}}var L={style:"normal",variant:"normal",weight:"normal",size:10,family:"sans-serif"};var f={};function X(Z){if(f[Z]){return f[Z]}var m=document.createElement("div");var j=m.style;try{j.font=Z}catch(i){}return f[Z]={style:j.fontStyle||L.style,variant:j.fontVariant||L.variant,weight:j.fontWeight||L.weight,size:j.fontSize||L.size,family:j.fontFamily||L.family}}function P(j,i){var Z={};for(var AF in j){Z[AF]=j[AF]}var AE=parseFloat(i.currentStyle.fontSize),m=parseFloat(j.size);if(typeof j.size=="number"){Z.size=j.size}else{if(j.size.indexOf("px")!=-1){Z.size=m}else{if(j.size.indexOf("em")!=-1){Z.size=AE*m}else{if(j.size.indexOf("%")!=-1){Z.size=(AE/100)*m}else{if(j.size.indexOf("pt")!=-1){Z.size=m/0.75}else{Z.size=AE}}}}}Z.size*=0.981;return Z}function AA(Z){return Z.style+" "+Z.variant+" "+Z.weight+" "+Z.size+"px "+Z.family}function t(Z){switch(Z){case"butt":return"flat";case"round":return"round";case"square":default:return"square"}}function W(i){this.m_=V();this.mStack_=[];this.aStack_=[];this.currentPath_=[];this.strokeStyle="#000";this.fillStyle="#000";this.lineWidth=1;this.lineJoin="miter";this.lineCap="butt";this.miterLimit=D*1;this.globalAlpha=1;this.font="10px sans-serif";this.textAlign="left";this.textBaseline="alphabetic";this.canvas=i;var Z=i.ownerDocument.createElement("div");Z.style.width=i.clientWidth+"px";Z.style.height=i.clientHeight+"px";Z.style.overflow="hidden";Z.style.position="absolute";i.appendChild(Z);this.element_=Z;this.arcScaleX_=1;this.arcScaleY_=1;this.lineScale_=1}var M=W.prototype;M.clearRect=function(){if(this.textMeasureEl_){this.textMeasureEl_.removeNode(true);this.textMeasureEl_=null}this.element_.innerHTML=""};M.beginPath=function(){this.currentPath_=[]};M.moveTo=function(i,Z){var j=this.getCoords_(i,Z);this.currentPath_.push({type:"moveTo",x:j.x,y:j.y});this.currentX_=j.x;this.currentY_=j.y};M.lineTo=function(i,Z){var j=this.getCoords_(i,Z);this.currentPath_.push({type:"lineTo",x:j.x,y:j.y});this.currentX_=j.x;this.currentY_=j.y};M.bezierCurveTo=function(j,i,AI,AH,AG,AE){var Z=this.getCoords_(AG,AE);var AF=this.getCoords_(j,i);var m=this.getCoords_(AI,AH);e(this,AF,m,Z)};function e(Z,m,j,i){Z.currentPath_.push({type:"bezierCurveTo",cp1x:m.x,cp1y:m.y,cp2x:j.x,cp2y:j.y,x:i.x,y:i.y});Z.currentX_=i.x;Z.currentY_=i.y}M.quadraticCurveTo=function(AG,j,i,Z){var AF=this.getCoords_(AG,j);var AE=this.getCoords_(i,Z);var AH={x:this.currentX_+2/3*(AF.x-this.currentX_),y:this.currentY_+2/3*(AF.y-this.currentY_)};var m={x:AH.x+(AE.x-this.currentX_)/3,y:AH.y+(AE.y-this.currentY_)/3};e(this,AH,m,AE)};M.arc=function(AJ,AH,AI,AE,i,j){AI*=D;var AN=j?"at":"wa";var AK=AJ+U(AE)*AI-F;var AM=AH+J(AE)*AI-F;var Z=AJ+U(i)*AI-F;var AL=AH+J(i)*AI-F;if(AK==Z&&!j){AK+=0.125}var m=this.getCoords_(AJ,AH);var AG=this.getCoords_(AK,AM);var AF=this.getCoords_(Z,AL);this.currentPath_.push({type:AN,x:m.x,y:m.y,radius:AI,xStart:AG.x,yStart:AG.y,xEnd:AF.x,yEnd:AF.y})};M.rect=function(j,i,Z,m){this.moveTo(j,i);this.lineTo(j+Z,i);this.lineTo(j+Z,i+m);this.lineTo(j,i+m);this.closePath()};M.strokeRect=function(j,i,Z,m){var p=this.currentPath_;this.beginPath();this.moveTo(j,i);this.lineTo(j+Z,i);this.lineTo(j+Z,i+m);this.lineTo(j,i+m);this.closePath();this.stroke();this.currentPath_=p};M.fillRect=function(j,i,Z,m){var p=this.currentPath_;this.beginPath();this.moveTo(j,i);this.lineTo(j+Z,i);this.lineTo(j+Z,i+m);this.lineTo(j,i+m);this.closePath();this.fill();this.currentPath_=p};M.createLinearGradient=function(i,m,Z,j){var p=new v("gradient");p.x0_=i;p.y0_=m;p.x1_=Z;p.y1_=j;return p};M.createRadialGradient=function(m,AE,j,i,p,Z){var AF=new v("gradientradial");AF.x0_=m;AF.y0_=AE;AF.r0_=j;AF.x1_=i;AF.y1_=p;AF.r1_=Z;return AF};M.drawImage=function(AO,j){var AH,AF,AJ,AV,AM,AK,AQ,AX;var AI=AO.runtimeStyle.width;var AN=AO.runtimeStyle.height;AO.runtimeStyle.width="auto";AO.runtimeStyle.height="auto";var AG=AO.width;var AT=AO.height;AO.runtimeStyle.width=AI;AO.runtimeStyle.height=AN;if(arguments.length==3){AH=arguments[1];AF=arguments[2];AM=AK=0;AQ=AJ=AG;AX=AV=AT}else{if(arguments.length==5){AH=arguments[1];AF=arguments[2];AJ=arguments[3];AV=arguments[4];AM=AK=0;AQ=AG;AX=AT}else{if(arguments.length==9){AM=arguments[1];AK=arguments[2];AQ=arguments[3];AX=arguments[4];AH=arguments[5];AF=arguments[6];AJ=arguments[7];AV=arguments[8]}else{throw Error("Invalid number of arguments")}}}var AW=this.getCoords_(AH,AF);var m=AQ/2;var i=AX/2;var AU=[];var Z=10;var AE=10;AU.push(" <g_vml_:group",' coordsize="',D*Z,",",D*AE,'"',' coordorigin="0,0"',' style="width:',Z,"px;height:",AE,"px;position:absolute;");if(this.m_[0][0]!=1||this.m_[0][1]||this.m_[1][1]!=1||this.m_[1][0]){var p=[];p.push("M11=",this.m_[0][0],",","M12=",this.m_[1][0],",","M21=",this.m_[0][1],",","M22=",this.m_[1][1],",","Dx=",K(AW.x/D),",","Dy=",K(AW.y/D),"");var AS=AW;var AR=this.getCoords_(AH+AJ,AF);var AP=this.getCoords_(AH,AF+AV);var AL=this.getCoords_(AH+AJ,AF+AV);AS.x=z.max(AS.x,AR.x,AP.x,AL.x);AS.y=z.max(AS.y,AR.y,AP.y,AL.y);AU.push("padding:0 ",K(AS.x/D),"px ",K(AS.y/D),"px 0;filter:progid:DXImageTransform.Microsoft.Matrix(",p.join(""),", sizingmethod='clip');")}else{AU.push("top:",K(AW.y/D),"px;left:",K(AW.x/D),"px;")}AU.push(' ">','<g_vml_:image src="',AO.src,'"',' style="width:',D*AJ,"px;"," height:",D*AV,'px"',' cropleft="',AM/AG,'"',' croptop="',AK/AT,'"',' cropright="',(AG-AM-AQ)/AG,'"',' cropbottom="',(AT-AK-AX)/AT,'"'," />","</g_vml_:group>");this.element_.insertAdjacentHTML("BeforeEnd",AU.join(""))};M.stroke=function(AM){var m=10;var AN=10;var AE=5000;var AG={x:null,y:null};var AL={x:null,y:null};for(var AH=0;AH<this.currentPath_.length;AH+=AE){var AK=[];var AF=false;AK.push("<g_vml_:shape",' filled="',!!AM,'"',' style="position:absolute;width:',m,"px;height:",AN,'px;"',' coordorigin="0,0"',' coordsize="',D*m,",",D*AN,'"',' stroked="',!AM,'"',' path="');var AO=false;for(var AI=AH;AI<Math.min(AH+AE,this.currentPath_.length);AI++){if(AI%AE==0&&AI>0){AK.push(" m ",K(this.currentPath_[AI-1].x),",",K(this.currentPath_[AI-1].y))}var Z=this.currentPath_[AI];var AJ;switch(Z.type){case"moveTo":AJ=Z;AK.push(" m ",K(Z.x),",",K(Z.y));break;case"lineTo":AK.push(" l ",K(Z.x),",",K(Z.y));break;case"close":AK.push(" x ");Z=null;break;case"bezierCurveTo":AK.push(" c ",K(Z.cp1x),",",K(Z.cp1y),",",K(Z.cp2x),",",K(Z.cp2y),",",K(Z.x),",",K(Z.y));break;case"at":case"wa":AK.push(" ",Z.type," ",K(Z.x-this.arcScaleX_*Z.radius),",",K(Z.y-this.arcScaleY_*Z.radius)," ",K(Z.x+this.arcScaleX_*Z.radius),",",K(Z.y+this.arcScaleY_*Z.radius)," ",K(Z.xStart),",",K(Z.yStart)," ",K(Z.xEnd),",",K(Z.yEnd));break}if(Z){if(AG.x==null||Z.x<AG.x){AG.x=Z.x}if(AL.x==null||Z.x>AL.x){AL.x=Z.x}if(AG.y==null||Z.y<AG.y){AG.y=Z.y}if(AL.y==null||Z.y>AL.y){AL.y=Z.y}}}AK.push(' ">');if(!AM){R(this,AK)}else{a(this,AK,AG,AL)}AK.push("</g_vml_:shape>");this.element_.insertAdjacentHTML("beforeEnd",AK.join(""))}};function R(j,AE){var i=Y(j.strokeStyle);var m=i.color;var p=i.alpha*j.globalAlpha;var Z=j.lineScale_*j.lineWidth;if(Z<1){p*=Z}AE.push("<g_vml_:stroke",' opacity="',p,'"',' joinstyle="',j.lineJoin,'"',' miterlimit="',j.miterLimit,'"',' endcap="',t(j.lineCap),'"',' weight="',Z,'px"',' color="',m,'" />')}function a(AO,AG,Ah,AP){var AH=AO.fillStyle;var AY=AO.arcScaleX_;var AX=AO.arcScaleY_;var Z=AP.x-Ah.x;var m=AP.y-Ah.y;if(AH instanceof v){var AL=0;var Ac={x:0,y:0};var AU=0;var AK=1;if(AH.type_=="gradient"){var AJ=AH.x0_/AY;var j=AH.y0_/AX;var AI=AH.x1_/AY;var Aj=AH.y1_/AX;var Ag=AO.getCoords_(AJ,j);var Af=AO.getCoords_(AI,Aj);var AE=Af.x-Ag.x;var p=Af.y-Ag.y;AL=Math.atan2(AE,p)*180/Math.PI;if(AL<0){AL+=360}if(AL<0.000001){AL=0}}else{var Ag=AO.getCoords_(AH.x0_,AH.y0_);Ac={x:(Ag.x-Ah.x)/Z,y:(Ag.y-Ah.y)/m};Z/=AY*D;m/=AX*D;var Aa=z.max(Z,m);AU=2*AH.r0_/Aa;AK=2*AH.r1_/Aa-AU}var AS=AH.colors_;AS.sort(function(Ak,i){return Ak.offset-i.offset});var AN=AS.length;var AR=AS[0].color;var AQ=AS[AN-1].color;var AW=AS[0].alpha*AO.globalAlpha;var AV=AS[AN-1].alpha*AO.globalAlpha;var Ab=[];for(var Ae=0;Ae<AN;Ae++){var AM=AS[Ae];Ab.push(AM.offset*AK+AU+" "+AM.color)}AG.push('<g_vml_:fill type="',AH.type_,'"',' method="none" focus="100%"',' color="',AR,'"',' color2="',AQ,'"',' colors="',Ab.join(","),'"',' opacity="',AV,'"',' g_o_:opacity2="',AW,'"',' angle="',AL,'"',' focusposition="',Ac.x,",",Ac.y,'" />')}else{if(AH instanceof u){if(Z&&m){var AF=-Ah.x;var AZ=-Ah.y;AG.push("<g_vml_:fill",' position="',AF/Z*AY*AY,",",AZ/m*AX*AX,'"',' type="tile"',' src="',AH.src_,'" />')}}else{var Ai=Y(AO.fillStyle);var AT=Ai.color;var Ad=Ai.alpha*AO.globalAlpha;AG.push('<g_vml_:fill color="',AT,'" opacity="',Ad,'" />')}}}M.fill=function(){this.stroke(true)};M.closePath=function(){this.currentPath_.push({type:"close"})};M.getCoords_=function(j,i){var Z=this.m_;return{x:D*(j*Z[0][0]+i*Z[1][0]+Z[2][0])-F,y:D*(j*Z[0][1]+i*Z[1][1]+Z[2][1])-F}};M.save=function(){var Z={};Q(this,Z);this.aStack_.push(Z);this.mStack_.push(this.m_);this.m_=d(V(),this.m_)};M.restore=function(){if(this.aStack_.length){Q(this.aStack_.pop(),this);this.m_=this.mStack_.pop()}};function H(Z){return isFinite(Z[0][0])&&isFinite(Z[0][1])&&isFinite(Z[1][0])&&isFinite(Z[1][1])&&isFinite(Z[2][0])&&isFinite(Z[2][1])}function y(i,Z,j){if(!H(Z)){return }i.m_=Z;if(j){var p=Z[0][0]*Z[1][1]-Z[0][1]*Z[1][0];i.lineScale_=k(b(p))}}M.translate=function(j,i){var Z=[[1,0,0],[0,1,0],[j,i,1]];y(this,d(Z,this.m_),false)};M.rotate=function(i){var m=U(i);var j=J(i);var Z=[[m,j,0],[-j,m,0],[0,0,1]];y(this,d(Z,this.m_),false)};M.scale=function(j,i){this.arcScaleX_*=j;this.arcScaleY_*=i;var Z=[[j,0,0],[0,i,0],[0,0,1]];y(this,d(Z,this.m_),true)};M.transform=function(p,m,AF,AE,i,Z){var j=[[p,m,0],[AF,AE,0],[i,Z,1]];y(this,d(j,this.m_),true)};M.setTransform=function(AE,p,AG,AF,j,i){var Z=[[AE,p,0],[AG,AF,0],[j,i,1]];y(this,Z,true)};M.drawText_=function(AK,AI,AH,AN,AG){var AM=this.m_,AQ=1000,i=0,AP=AQ,AF={x:0,y:0},AE=[];var Z=P(X(this.font),this.element_);var j=AA(Z);var AR=this.element_.currentStyle;var p=this.textAlign.toLowerCase();switch(p){case"left":case"center":case"right":break;case"end":p=AR.direction=="ltr"?"right":"left";break;case"start":p=AR.direction=="rtl"?"right":"left";break;default:p="left"}switch(this.textBaseline){case"hanging":case"top":AF.y=Z.size/1.75;break;case"middle":break;default:case null:case"alphabetic":case"ideographic":case"bottom":AF.y=-Z.size/2.25;break}switch(p){case"right":i=AQ;AP=0.05;break;case"center":i=AP=AQ/2;break}var AO=this.getCoords_(AI+AF.x,AH+AF.y);AE.push('<g_vml_:line from="',-i,' 0" to="',AP,' 0.05" ',' coordsize="100 100" coordorigin="0 0"',' filled="',!AG,'" stroked="',!!AG,'" style="position:absolute;width:1px;height:1px;">');if(AG){R(this,AE)}else{a(this,AE,{x:-i,y:0},{x:AP,y:Z.size})}var AL=AM[0][0].toFixed(3)+","+AM[1][0].toFixed(3)+","+AM[0][1].toFixed(3)+","+AM[1][1].toFixed(3)+",0,0";var AJ=K(AO.x/D)+","+K(AO.y/D);AE.push('<g_vml_:skew on="t" matrix="',AL,'" ',' offset="',AJ,'" origin="',i,' 0" />','<g_vml_:path textpathok="true" />','<g_vml_:textpath on="true" string="',AD(AK),'" style="v-text-align:',p,";font:",AD(j),'" /></g_vml_:line>');this.element_.insertAdjacentHTML("beforeEnd",AE.join(""))};M.fillText=function(j,Z,m,i){this.drawText_(j,Z,m,i,false)};M.strokeText=function(j,Z,m,i){this.drawText_(j,Z,m,i,true)};M.measureText=function(j){if(!this.textMeasureEl_){var Z='<span style="position:absolute;top:-20000px;left:0;padding:0;margin:0;border:none;white-space:pre;"></span>';this.element_.insertAdjacentHTML("beforeEnd",Z);this.textMeasureEl_=this.element_.lastChild}var i=this.element_.ownerDocument;this.textMeasureEl_.innerHTML="";this.textMeasureEl_.style.font=this.font;this.textMeasureEl_.appendChild(i.createTextNode(j));return{width:this.textMeasureEl_.offsetWidth}};M.clip=function(){};M.arcTo=function(){};M.createPattern=function(i,Z){return new u(i,Z)};function v(Z){this.type_=Z;this.x0_=0;this.y0_=0;this.r0_=0;this.x1_=0;this.y1_=0;this.r1_=0;this.colors_=[]}v.prototype.addColorStop=function(i,Z){Z=Y(Z);this.colors_.push({offset:i,color:Z.color,alpha:Z.alpha})};function u(i,Z){q(i);switch(Z){case"repeat":case null:case"":this.repetition_="repeat";break;case"repeat-x":case"repeat-y":case"no-repeat":this.repetition_=Z;break;default:n("SYNTAX_ERR")}this.src_=i.src;this.width_=i.width;this.height_=i.height}function n(Z){throw new o(Z)}function q(Z){if(!Z||Z.nodeType!=1||Z.tagName!="IMG"){n("TYPE_MISMATCH_ERR")}if(Z.readyState!="complete"){n("INVALID_STATE_ERR")}}function o(Z){this.code=this[Z];this.message=Z+": DOM Exception "+this.code}var x=o.prototype=new Error;x.INDEX_SIZE_ERR=1;x.DOMSTRING_SIZE_ERR=2;x.HIERARCHY_REQUEST_ERR=3;x.WRONG_DOCUMENT_ERR=4;x.INVALID_CHARACTER_ERR=5;x.NO_DATA_ALLOWED_ERR=6;x.NO_MODIFICATION_ALLOWED_ERR=7;x.NOT_FOUND_ERR=8;x.NOT_SUPPORTED_ERR=9;x.INUSE_ATTRIBUTE_ERR=10;x.INVALID_STATE_ERR=11;x.SYNTAX_ERR=12;x.INVALID_MODIFICATION_ERR=13;x.NAMESPACE_ERR=14;x.INVALID_ACCESS_ERR=15;x.VALIDATION_ERR=16;x.TYPE_MISMATCH_ERR=17;G_vmlCanvasManager=E;CanvasRenderingContext2D=W;CanvasGradient=v;CanvasPattern=u;DOMException=o})()};
714 </script>
715
716 <script type="text/javascript">
717 /*
718 * jQuery.flot.dashes
719 *
720 * options = {
721 * series: {
722 * dashes: {
723 *
724 * // show
725 * // default: false
726 * // Whether to show dashes for the series.
727 * show: <boolean>,
728 *
729 * // lineWidth
730 * // default: 2
731 * // The width of the dashed line in pixels.
732 * lineWidth: <number>,
733 *
734 * // dashLength
735 * // default: 10
736 * // Controls the length of the individual dashes and the amount of
737 * // space between them.
738 * // If this is a number, the dashes and spaces will have that length.
739 * // If this is an array, it is read as [ dashLength, spaceLength ]
740 * dashLength: <number> or <array[2]>
741 * }
742 * }
743 * }
744 */
745 (function($){
746
747 function init(plot) {
748
749 plot.hooks.processDatapoints.push(function(plot, series, datapoints) {
750
751 if (!series.dashes.show) return;
752
753 plot.hooks.draw.push(function(plot, ctx) {
754
755 var plotOffset = plot.getPlotOffset(),
756 axisx = series.xaxis,
757 axisy = series.yaxis;
758
759 function plotDashes(xoffset, yoffset) {
760
761 var points = datapoints.points,
762 ps = datapoints.pointsize,
763 prevx = null,
764 prevy = null,
765 dashRemainder = 0,
766 dashOn = true,
767 dashOnLength,
768 dashOffLength;
769
770 if (series.dashes.dashLength[0]) {
771 dashOnLength = series.dashes.dashLength[0];
772 if (series.dashes.dashLength[1]) {
773 dashOffLength = series.dashes.dashLength[1];
774 } else {
775 dashOffLength = dashOnLength;
776 }
777 } else {
778 dashOffLength = dashOnLength = series.dashes.dashLength;
779 }
780
781 ctx.beginPath();
782
783 for (var i = ps; i < points.length; i += ps) {
784
785 var x1 = points[i - ps],
786 y1 = points[i - ps + 1],
787 x2 = points[i],
788 y2 = points[i + 1];
789
790 if (x1 == null || x2 == null) continue;
791
792 // clip with ymin
793 if (y1 <= y2 && y1 < axisy.min) {
794 if (y2 < axisy.min) continue; // line segment is outside
795 // compute new intersection point
796 x1 = (axisy.min - y1) / (y2 - y1) * (x2 - x1) + x1;
797 y1 = axisy.min;
798 } else if (y2 <= y1 && y2 < axisy.min) {
799 if (y1 < axisy.min) continue;
800 x2 = (axisy.min - y1) / (y2 - y1) * (x2 - x1) + x1;
801 y2 = axisy.min;
802 }
803
804 // clip with ymax
805 if (y1 >= y2 && y1 > axisy.max) {
806 if (y2 > axisy.max) continue;
807 x1 = (axisy.max - y1) / (y2 - y1) * (x2 - x1) + x1;
808 y1 = axisy.max;
809 } else if (y2 >= y1 && y2 > axisy.max) {
810 if (y1 > axisy.max) continue;
811 x2 = (axisy.max - y1) / (y2 - y1) * (x2 - x1) + x1;
812 y2 = axisy.max;
813 }
814
815 // clip with xmin
816 if (x1 <= x2 && x1 < axisx.min) {
817 if (x2 < axisx.min) continue;
818 y1 = (axisx.min - x1) / (x2 - x1) * (y2 - y1) + y1;
819 x1 = axisx.min;
820 } else if (x2 <= x1 && x2 < axisx.min) {
821 if (x1 < axisx.min) continue;
822 y2 = (axisx.min - x1) / (x2 - x1) * (y2 - y1) + y1;
823 x2 = axisx.min;
824 }
825
826 // clip with xmax
827 if (x1 >= x2 && x1 > axisx.max) {
828 if (x2 > axisx.max) continue;
829 y1 = (axisx.max - x1) / (x2 - x1) * (y2 - y1) + y1;
830 x1 = axisx.max;
831 } else if (x2 >= x1 && x2 > axisx.max) {
832 if (x1 > axisx.max) continue;
833 y2 = (axisx.max - x1) / (x2 - x1) * (y2 - y1) + y1;
834 x2 = axisx.max;
835 }
836
837 if (x1 != prevx || y1 != prevy) {
838 ctx.moveTo(axisx.p2c(x1) + xoffset, axisy.p2c(y1) + yoffset);
839 }
840
841 var ax1 = axisx.p2c(x1) + xoffset,
842 ay1 = axisy.p2c(y1) + yoffset,
843 ax2 = axisx.p2c(x2) + xoffset,
844 ay2 = axisy.p2c(y2) + yoffset,
845 dashOffset;
846
847 function lineSegmentOffset(segmentLength) {
848
849 var c = Math.sqrt(Math.pow(ax2 - ax1, 2) + Math.pow(ay2 - ay1, 2));
850
851 if (c <= segmentLength) {
852 return {
853 deltaX: ax2 - ax1,
854 deltaY: ay2 - ay1,
855 distance: c,
856 remainder: segmentLength - c
857 }
858 } else {
859 var xsign = ax2 > ax1 ? 1 : -1,
860 ysign = ay2 > ay1 ? 1 : -1;
861 return {
862 deltaX: xsign * Math.sqrt(Math.pow(segmentLength, 2) / (1 + Math.pow((ay2 - ay1)/(ax2 - ax1), 2))),
863 deltaY: ysign * Math.sqrt(Math.pow(segmentLength, 2) - Math.pow(segmentLength, 2) / (1 + Math.pow((ay2 - ay1)/(ax2 - ax1), 2))),
864 distance: segmentLength,
865 remainder: 0
866 };
867 }
868 }
869 //-end lineSegmentOffset
870
871 do {
872
873 dashOffset = lineSegmentOffset(
874 dashRemainder > 0 ? dashRemainder :
875 dashOn ? dashOnLength : dashOffLength);
876
877 if (dashOffset.deltaX != 0 || dashOffset.deltaY != 0) {
878 if (dashOn) {
879 ctx.lineTo(ax1 + dashOffset.deltaX, ay1 + dashOffset.deltaY);
880 } else {
881 ctx.moveTo(ax1 + dashOffset.deltaX, ay1 + dashOffset.deltaY);
882 }
883 }
884
885 dashOn = !dashOn;
886 dashRemainder = dashOffset.remainder;
887 ax1 += dashOffset.deltaX;
888 ay1 += dashOffset.deltaY;
889
890 } while (dashOffset.distance > 0);
891
892 prevx = x2;
893 prevy = y2;
894 }
895
896 ctx.stroke();
897 }
898 //-end plotDashes
899
900 ctx.save();
901 ctx.translate(plotOffset.left, plotOffset.top);
902 ctx.lineJoin = 'round';
903
904 var lw = series.dashes.lineWidth,
905 sw = series.shadowSize;
906
907 // FIXME: consider another form of shadow when filling is turned on
908 if (lw > 0 && sw > 0) {
909 // draw shadow as a thick and thin line with transparency
910 ctx.lineWidth = sw;
911 ctx.strokeStyle = "rgba(0,0,0,0.1)";
912 // position shadow at angle from the mid of line
913 var angle = Math.PI/18;
914 plotDashes(Math.sin(angle) * (lw/2 + sw/2), Math.cos(angle) * (lw/2 + sw/2));
915 ctx.lineWidth = sw/2;
916 plotDashes(Math.sin(angle) * (lw/2 + sw/4), Math.cos(angle) * (lw/2 + sw/4));
917 }
918
919 ctx.lineWidth = lw;
920 ctx.strokeStyle = series.color;
921
922 if (lw > 0) {
923 plotDashes(0, 0);
924 }
925
926 ctx.restore();
927
928 });
929 //-end draw hook
930
931 });
932 //-end processDatapoints hook
933
934 }
935 //-end init
936
937 $.plot.plugins.push({
938 init: init,
939 options: {
940 series: {
941 dashes: {
942 show: false,
943 lineWidth: 2,
944 dashLength: 10
945 }
946 }
947 },
948 name: 'dashes',
949 version: '0.1'
950 });
951
952 })(jQuery)
953
954
955 </script>
956
957 <script type="text/javascript">
958
959 var cumulative = {
960 isInitialized: false,
961
962 maxX: 0,
963 maxY: 0,
964 maxYTick: 0,
965 series: null,
966 showWithData: null,
967 colors: [],
968
969 draw: function(name, title, colors, filenames, listsOfLengths, refLengths, tickX,
970 placeholder, legendPlaceholder, glossary, order, scalePlaceholder) {
971
972 $(scalePlaceholder).empty();
973
974 if (!this.isInitialized) {
975 // div.html(
976 // "<span class='plot-header'>" + addTooltipIfDefinitionExists(glossary, title) + "</span>" +
977 // "<div class='plot-placeholder' id='cumulative-plot-placeholder'></div>"
978 // );
979 cumulative.series = [];
980 var plotsN = filenames.length;
981 var refLength = 0;
982 if (refLengths) {
983 for (var i = 0, size = refLengths.length; i < size; i++)
984 refLength += refLengths[i];
985 }
986 if (refLength) {
987 cumulative.maxY = refLength;
988 }
989
990 cumulative.colors = colors;
991
992 function addCumulativeLenData(label, index, color, lengths, isRef) {
993 if (!(lengths instanceof Array))
994 lengths = [lengths];
995 var size = lengths.length;
996 var points = {
997 data: new Array(size + 1),
998 label: label,
999 number: index,
1000 color: color
1001 };
1002
1003 points.data[0] = [0, 0];
1004
1005 var y = 0;
1006 for (var j = 0; j < size; j++) {
1007 y += lengths[j];
1008 points.data[j+1] = [j+1, y];
1009 if (y > cumulative.maxY) {
1010 cumulative.maxY = y;
1011 }
1012 }
1013
1014 if (size > cumulative.maxX) {
1015 cumulative.maxX = size;
1016 }
1017 if (isRef){
1018 points.isReference = true;
1019 points.dashes = {show: true, lineWidth: 1};
1020 if (size < cumulative.maxX) {
1021 points.data[size + 1] = [cumulative.maxX, y];
1022 }
1023 }
1024 return points;
1025 }
1026
1027 for (var i = 0; i < plotsN; i++) {
1028 var lengths = listsOfLengths[order[i]];
1029 var asm_name = filenames[order[i]];
1030 var color = colors[order[i]];
1031 cumulative.series[i] = addCumulativeLenData(asm_name, i, color, lengths);
1032 }
1033
1034 // var lineColors = [];
1035 //
1036 // for (i = 0; i < colors.length; i++) {
1037 // lineColors.push(changeColor(colors[i], 0.9, false));
1038 // }
1039
1040 for (i = 0; i < plotsN; i++) {
1041 if (typeof broken_scaffolds_labels !== undefined && $.inArray(filenames[order[i]], broken_scaffolds_labels) != -1) {
1042 cumulative.series[i].dashes = {
1043 show: true,
1044 lineWidth: 1
1045 };
1046 }
1047 else {
1048 cumulative.series[i].lines = {
1049 show: true,
1050 lineWidth: 1
1051 };
1052 }
1053 }
1054
1055 for (i = 0; i < plotsN; i++) {
1056 cumulative.colors.push(cumulative.series[i].color);
1057 }
1058
1059 //cumulative.maxYTick = getMaxDecimalTick(cumulative.maxY);
1060
1061 if (refLengths) {
1062 size = refLengths.length;
1063 var ref_label = 'reference,&nbsp;' + toPrettyString(refLength, 'bp');
1064 cumulative.series.push(addCumulativeLenData(ref_label, i, '#000000', refLengths, true));
1065 cumulative.colors.push('#000000');
1066 }
1067
1068
1069 // if (referenceLength) {
1070 // yaxes.push({
1071 // ticks: [referenceLength],
1072 // min: 0,
1073 // max: maxYTick,
1074 // position: 'right',
1075 //// labelWidth: 50,
1076 // reserveSpace: true,
1077 // tickFormatter: function (val, axis) {
1078 // return '<div style="">' + toPrettyStringWithDimension(referenceLength, 'bp') +
1079 // ' <span style="margin-left: -0.2em;">(reference)</span></div>';
1080 // },
1081 // minTickSize: 1,
1082 // });
1083 // }
1084 var yaxis = {
1085 min: 0,
1086 //max: cumulative.maxYTick,
1087 labelWidth: 120,
1088 reserveSpace: true,
1089 lineWidth: 0.5,
1090 color: '#000000',
1091 tickFormatter: getBpTickFormatter(cumulative.maxY),
1092 minTickSize: 1
1093 };
1094 var yaxes = [yaxis];
1095
1096 cumulative.showWithData = function(series, colors) {
1097 var plot = $.plot(placeholder, series, {
1098 shadowSize: 0,
1099 colors: cumulative.colors,
1100 legend: {
1101 container: $('useless-invisible-element-that-does-not-even-exist'),
1102 },
1103 // legend: {
1104 // container: legendPlaceholder,
1105 // position: 'se',
1106 // labelBoxBorderColor: '#FFF',
1107 // labelFormatter: labelFormatter,
1108 // },
1109 grid: {
1110 borderWidth: 1,
1111 hoverable: true,
1112 autoHighlight: false,
1113 mouseActiveRadius: 1000
1114 },
1115 yaxes: yaxes,
1116 xaxis: {
1117 min: 0,
1118 max: cumulative.maxX,
1119 lineWidth: 0.5,
1120 color: '#000',
1121 tickFormatter: getContigNumberTickFormatter(cumulative.maxX, tickX),
1122 minTickSize: tickX
1123 }
1124 });
1125
1126 bindTip(placeholder, series, plot, ordinalNumberToPrettyString, tickX, 'contig', 'bottom right');
1127 };
1128
1129 cumulative.isInitialized = true;
1130 }
1131
1132 addLegendClickEvents(cumulative, filenames.length, showPlotWithInfo, refLengths);
1133
1134 showPlotWithInfo(cumulative);
1135
1136 $('#contigs_are_ordered').show();
1137 },
1138 };
1139
1140 </script>
1141
1142 <script type="text/javascript">
1143
1144 var nx = {
1145 nx: {
1146 isInitialized: false,
1147 maxY: 0,
1148 maxYTick: 0,
1149 series: null,
1150 showWithData: null
1151 },
1152
1153 nax: {
1154 isInitialized: false,
1155 maxY: 0,
1156 maxYTick: 0,
1157 series: null,
1158 showWithData: null
1159 },
1160
1161 ngx: {
1162 isInitialized: false,
1163 maxY: 0,
1164 maxYTick: 0,
1165 series: null,
1166 showWithData: null
1167 },
1168
1169 ngax: {
1170 isInitialized: false,
1171 maxY: 0,
1172 maxYTick: 0,
1173 series: null,
1174 showWithData: null
1175 },
1176
1177 draw: function (name, title, colors, filenames, data, refPlotValue, tickX,
1178 placeholder, legendPlaceholder, glossary, order, scalePlaceholder) {
1179
1180 $(scalePlaceholder).empty();
1181
1182 var coordX = data.coord_x;
1183 var coordY = data.coord_y;
1184
1185 var cur_filenames = data.filenames;
1186 var info = nx[name];
1187
1188 if (!info.isInitialized) {
1189 var plotsN = cur_filenames.length;
1190 info.series = new Array(plotsN);
1191
1192 for (var i = 0; i < plotsN; i++) {
1193 var index = $.inArray(cur_filenames[order[i]], filenames);
1194 var plot_coordX = coordX[order[i]];
1195 var plot_coordY = coordY[order[i]];
1196 var size = plot_coordX.length;
1197
1198 info.series[i] = {
1199 data: [],
1200 label: filenames[index],
1201 number: index,
1202 color: colors[index]
1203 };
1204 info.series[i].data.push([0.0, plot_coordY[0]]);
1205 var currentLen = 0;
1206 var x = 0.0;
1207
1208 for (var k = 0; k < size; k++) {
1209 info.series[i].data.push([plot_coordX[k], plot_coordY[k]]);
1210 }
1211
1212 if (info.series[i].data[0][1] > info.maxY) {
1213 info.maxY = info.series[i].data[0][1];
1214 }
1215
1216 var lastPt = info.series[i].data[info.series[i].data.length-1];
1217 info.series[i].data.push([lastPt[0], 0]);
1218 }
1219
1220 for (i = 0; i < plotsN; i++) {
1221 if (typeof broken_scaffolds_labels !== undefined && $.inArray(filenames[order[i]], broken_scaffolds_labels) != -1) {
1222 info.series[i].dashes = {
1223 show: true,
1224 lineWidth: 1
1225 };
1226 }
1227 else {
1228 info.series[i].lines = {
1229 show: true,
1230 lineWidth: 1
1231 };
1232 }
1233 }
1234
1235 // for (i = 0; i < plotsN; i++) {
1236 // plotsData[i].points = {
1237 // show: true,
1238 // radius: 1,
1239 // fill: 1,
1240 // fillColor: false,
1241 // }
1242 // }
1243
1244 info.showWithData = function(series, colors) {
1245 var plot = $.plot(placeholder, series, {
1246 shadowSize: 0,
1247 colors: colors,
1248 legend: {
1249 container: $('useless-invisible-element-that-does-not-even-exist'),
1250 },
1251 grid: {
1252 borderWidth: 1,
1253 hoverable: true,
1254 autoHighlight: false,
1255 mouseActiveRadius: 1000
1256 },
1257 yaxis: {
1258 min: 0,
1259 // max: info.maxY,
1260 labelWidth: 120,
1261 reserveSpace: true,
1262 lineWidth: 0.5,
1263 color: '#000',
1264 tickFormatter: getBpTickFormatter(info.maxY),
1265 minTickSize: 1
1266 },
1267 xaxis: {
1268 min: 0,
1269 max: 100,
1270 lineWidth: 0.5,
1271 color: '#000',
1272 tickFormatter: function (val, axis) {
1273 if (val == 100) {
1274 return '&nbsp;x<span class="rhs">&nbsp;</span>=<span class="rhs">&nbsp;</span>100%'
1275 } else {
1276 return val;
1277 }
1278 }
1279 },
1280 minTickSize: tickX
1281 }
1282 );
1283
1284 var firstLabel = $('.yAxis .tickLabel').last();
1285 firstLabel.prepend(title + '<span class="rhs">&nbsp;</span>=<span class="rhs">&nbsp;</span>');
1286
1287 bindTip(placeholder, series, plot, toPrettyString, 1, '%', 'top right');
1288
1289 };
1290
1291 info.isInitialized = true;
1292 }
1293
1294 addLegendClickEvents(info, filenames.length, showPlotWithInfo);
1295 showPlotWithInfo(info);
1296 }
1297 };
1298
1299
1300
1301 </script>
1302
1303 <script type="text/javascript">
1304
1305 var normal_scale_span =
1306 "<span class='selected-switch'>" +
1307 'Normal' +
1308 "</span>";
1309 var normal_scale_a =
1310 "<a class='dotted-link' onClick='setNormalScale()'>" +
1311 'Normal' +
1312 "</a>";
1313 var log_scale_span =
1314 "<span class='selected-switch'>" +
1315 'logarithmic' +
1316 "</span>";
1317 var log_scale_a =
1318 "<a class='dotted-link' onClick='setLogScale()'>" +
1319 'logarithmic' +
1320 "</a>";
1321
1322 var show_all_span =
1323 "<span class='selected-switch gc'>" +
1324 'Back to overview' +
1325 "</span>";
1326 var show_all_a =
1327 "&nbsp;&nbsp;&nbsp;<a class='dotted-link' onClick='showAll()'>" +
1328 'Back to overview' +
1329 "</a>";
1330
1331 var gc = {
1332 isInitialized: false,
1333
1334 maxY: 0,
1335 plot: null,
1336 series: null,
1337 showWithData: null,
1338 minPow: 0,
1339 ticks: null,
1340 placeholder: null,
1341 legendPlaceholder: null,
1342 colors: null,
1343 yAxisLabeled: false,
1344
1345 show_all_el: show_all_span,
1346 reference: false,
1347
1348 normal_scale_el: null,
1349 log_scale_el: null,
1350
1351 draw: function(name, title, colors, filenames, gcInfos, reflen, tickX,
1352 placeholder, legendPlaceholder, glossary, order, scalePlaceholder) {
1353 gc.normal_scale_el = normal_scale_span;
1354 gc.log_scale_el = log_scale_a;
1355 $(scalePlaceholder).html(
1356 "<div id='change-scale' style='margin-right: 3px; visibility: hidden;'>" +
1357 "<span id='normal_scale_label'>" +
1358 gc.normal_scale_el +
1359 "</span>&nbsp;/&nbsp;" +
1360 "<span id='log_scale_label'>" +
1361 gc.log_scale_el +
1362 "</span> scale" +
1363 "</div>"
1364 );
1365
1366 var refIndex = gcInfos.reference_index;
1367 if (!gc.isInitialized) {
1368 gc.legendPlaceholder = legendPlaceholder;
1369 gc.placeholder = placeholder;
1370 gc.colors = colors;
1371 gc.filenames = filenames;
1372
1373 var bin_size = 1.0;
1374 var plotsN = filenames.length;
1375 gc.series = new Array(plotsN + 1);
1376 gc.series[0] = new Array(plotsN);
1377
1378 gc.maxY = 0;
1379 var minY = Number.MAX_VALUE;
1380
1381 function updateMinY(y) {
1382 if (y < minY && y != 0) {
1383 minY = y;
1384 }
1385 }
1386 function updateMaxY(y) {
1387 if (y > gc.maxY) {
1388 gc.maxY = y;
1389 }
1390 }
1391
1392 for (var i = 0; i < plotsN; i++) {
1393 gc.series[0][i] = {
1394 data: [],
1395 label: filenames[order[i]],
1396 number: order[i],
1397 color: colors[order[i]]
1398 };
1399 }
1400
1401 function makeSeriesFromDistributions(distributionsXandY, series_i, plot_i) {
1402 var distributionsX = distributionsXandY[0];
1403 var distributionsY = distributionsXandY[1];
1404
1405 for (var j = 0; j < distributionsX.length; j++) {
1406 var x = distributionsX[j];
1407 var y = distributionsY[j];
1408 gc.series[series_i][plot_i].data.push([x, y]);
1409 updateMinY(y);
1410 updateMaxY(y);
1411 }
1412 }
1413
1414 function makeSeries(listsOfGCInfo, listOfGcDistributions, seriesIdx) {
1415 for (var i = 0; i < plotsN; i++) {
1416 if (listsOfGCInfo) {
1417 makeSeriesFromInfo(listsOfGCInfo[order[i]], seriesIdx, i);
1418 } else {
1419 makeSeriesFromDistributions(listOfGcDistributions[order[i]], seriesIdx, i);
1420 }
1421 }
1422 }
1423
1424 var listsOfGCInfo = gcInfos.lists_of_gc_info;
1425 var listOfGcDistributions = gcInfos.list_of_GC_distributions;
1426 makeSeries(listsOfGCInfo, listOfGcDistributions, 0);
1427
1428 function makeSeriesFromInfo(GC_info, series_i, i) {
1429 var cur_bin = 0.0;
1430
1431 var x = cur_bin;
1432 var y = filterAndSumGcInfo(GC_info, function(GC_percent) {
1433 return GC_percent == cur_bin;
1434 });
1435 gc.series[series_i][i].data.push([x, y]);
1436
1437 updateMinY(y);
1438 updateMaxY(y);
1439
1440 while (cur_bin < 100.0 - bin_size) {
1441 cur_bin += bin_size;
1442
1443 x = cur_bin;
1444 y = filterAndSumGcInfo(GC_info, function(GC_percent) {
1445 return GC_percent > (cur_bin - bin_size) && GC_percent <= cur_bin;
1446 });
1447 gc.series[series_i][i].data.push([x, y]);
1448
1449 updateMinY(y);
1450 updateMaxY(y);
1451 }
1452
1453 x = 100.0;
1454 y = filterAndSumGcInfo(GC_info, function(GC_percent) {
1455 return GC_percent > cur_bin && GC_percent <= 100.0;
1456 });
1457
1458 gc.series[series_i][i].data.push([x, y]);
1459
1460 updateMinY(y);
1461 updateMaxY(y);
1462 }
1463
1464 for (i = 0; i < plotsN; i++) {
1465 if (typeof broken_scaffolds_labels !== undefined && $.inArray(filenames[order[i]], broken_scaffolds_labels) != -1) {
1466 gc.series[0][i].dashes = {
1467 show: true,
1468 lineWidth: 1
1469 };
1470 }
1471 else {
1472 gc.series[0][i].lines = {
1473 show: true,
1474 lineWidth: 1
1475 };
1476 }
1477 }
1478
1479 if (refIndex) {
1480 gc.reference = true;
1481 gc.series[0].push({
1482 data: [],
1483 label: 'reference',
1484 isReference: true,
1485 number: filenames.length,
1486 lines: {},
1487 dashes: {
1488 show: true,
1489 lineWidth: 1
1490 },
1491 color: '#000000'
1492 });
1493 if (listsOfGCInfo) {
1494 makeSeriesFromInfo(listsOfGCInfo[refIndex], 0, refIndex);
1495 } else {
1496 makeSeriesFromDistributions(listOfGcDistributions[refIndex], 0, refIndex);
1497 }
1498 gc.colors.push('#000000')
1499 }
1500
1501 if (gcInfos.list_of_GC_contigs_distributions) {
1502 listOfGcDistributions = gcInfos.list_of_GC_contigs_distributions;
1503 var maxY = 0;
1504 for (var file_n = 0; file_n < filenames.length; file_n++) {
1505 gc.series[file_n + 1] = new Array(1);
1506 gc.series[file_n + 1][0] = {
1507 data: [],
1508 label: filenames[order[file_n]],
1509 number: order[file_n],
1510 color: colors[order[file_n]],
1511 bars: {
1512 show: true,
1513 lineWidth: 0.6,
1514 fill: 0.6,
1515 barWidth: 5
1516 }
1517 };
1518
1519 var distributionsX = listOfGcDistributions[file_n][0];
1520 var distributionsY = listOfGcDistributions[file_n][1];
1521
1522 for (var j = 0; j < distributionsX.length; j++) {
1523 var x = distributionsX[j];
1524 var y = distributionsY[j];
1525 gc.series[file_n + 1][0].data.push([x, y]);
1526 maxY = Math.max(maxY, y);
1527 }
1528 }
1529 for (var file_n = 0; file_n < filenames.length; file_n++) {
1530 gc.series[file_n + 1][0].maxY = maxY;
1531 }
1532 }
1533 // Calculate the minimum possible non-zero Y to clip useless bottoms
1534 // of logarithmic plots.
1535 var maxYTick = getMaxDecimalTick(gc.maxY);
1536 gc.minPow = Math.round(Math.log(minY) / Math.log(10));
1537 gc.ticks = [];
1538 for (var pow = gc.minPow; Math.pow(10, pow) < maxYTick; pow++) {
1539 gc.ticks.push(Math.pow(10, pow));
1540 }
1541 gc.ticks.push(Math.pow(10, pow));
1542
1543 gc.isInitialized = true;
1544 }
1545
1546 gc.showWithData = showInNormalScaleWithData;
1547 if (gcInfos.list_of_GC_contigs_distributions) {
1548 createLegend(gc.filenames, gc.colors, 0, gc.reference);
1549 }
1550 addLegendClickEvents(gc, filenames.length, showPlotWithInfo, false, 0);
1551
1552 showPlotWithInfo(gc, 0);
1553
1554 $('#change-scale').css('visibility', 'visible');
1555 $('#gc_info').show();
1556 }
1557 };
1558
1559 function showAll() {
1560 $('#change-scale').show();
1561 $('#gc_info').show();
1562 $('#gc_contigs_info').hide();
1563 createLegend(gc.filenames, gc.colors, 0, gc.reference);
1564
1565 gc.show_all_el = show_all_span;
1566 gc.showWithData = gc.log_scale_el == log_scale_a ? showInNormalScaleWithData : showInLogarithmicScaleWithData;
1567
1568 $('#show_all_label').html(gc.show_all_el);
1569 showPlotWithInfo(gc, 0);
1570 }
1571
1572 function showPlot(index) {
1573 $('#change-scale').hide();
1574 $('#gc_info').hide();
1575 $('#gc_contigs_info').show();
1576 createLegend([gc.filenames[index - 1]], [gc.colors[index - 1]], index);
1577
1578 gc.show_all_el = show_all_a;
1579 gc.showWithData = showOneAssembly;
1580
1581 $('#show_all_label').html(gc.show_all_el);
1582 showPlotWithInfo(gc, index);
1583 }
1584
1585 function showOneAssembly(series, colors) {
1586 if (series == null) {
1587 return;
1588 }
1589
1590 gc.plot = $.plot(gc.placeholder, series, {
1591 shadowSize: 0,
1592 colors: colors,
1593 legend: {
1594 container: $('useless-invisible-element-that-does-not-even-exist')
1595 },
1596 grid: {
1597 hoverable: true,
1598 borderWidth: 1,
1599 autoHighlight: false,
1600 mouseActiveRadius: 1000
1601 },
1602 yaxis: {
1603 min: 0,
1604 max: series[0].maxY * 1.1,
1605 labelWidth: 120,
1606 reserveSpace: true,
1607 lineWidth: 0.5,
1608 color: '#000',
1609 tickFormatter: getJustNumberTickFormatter(gc.maxY),
1610 minTickSize: 1
1611 },
1612 xaxis: {
1613 min: 0,
1614 max: 100,
1615 lineWidth: 0.5,
1616 color: '#000',
1617 tickFormatter: function (val, axis) {
1618 if (val == 100) {
1619 return '&nbsp;100% GC'
1620 } else {
1621 return val;
1622 }
1623 }
1624 },
1625 minTickSize: 1
1626 }
1627 );
1628
1629 var firstLabel = $('.yAxis .tickLabel').last();
1630 firstLabel.append(' contigs');
1631 unBindTips(gc.placeholder);
1632 bindTip(gc.placeholder, series, gc.plot, getIntervalToPrettyString(5), 1, '%<span class="rhs">&nbsp;</span>GC', 'top right');
1633 }
1634
1635 function showInNormalScaleWithData(series, colors) {
1636 if (series == null || gc.maxY == null)
1637 return;
1638
1639 gc.yAxisLabeled = false;
1640
1641 gc.plot = $.plot(gc.placeholder, series, {
1642 shadowSize: 0,
1643 colors: colors,
1644 legend: {
1645 container: $('useless-invisible-element-that-does-not-even-exist'),
1646 },
1647 grid: {
1648 borderWidth: 1,
1649 hoverable: true,
1650 autoHighlight: false,
1651 mouseActiveRadius: 1000,
1652 },
1653 yaxis: {
1654 min: 0,
1655 // max: gc.maxY + 0.1 * gc.maxY,
1656 labelWidth: 120,
1657 reserveSpace: true,
1658 lineWidth: 0.5,
1659 color: '#000',
1660 tickFormatter: windowsTickFormatter,
1661 minTickSize: 1
1662 },
1663 xaxis: {
1664 min: 0,
1665 max: 100,
1666 lineWidth: 0.5,
1667 color: '#000',
1668 tickFormatter: function (val, axis) {
1669 if (val == 100) {
1670 return '&nbsp;100% GC'
1671 } else {
1672 return val;
1673 }
1674 }
1675 },
1676 minTickSize: 1
1677 }
1678 );
1679
1680 var firstLabel = $('.yAxis .tickLabel').last();
1681 firstLabel.append(' windows');
1682 bindTip(gc.placeholder, series, gc.plot, toPrettyString, 1, '%<span class="rhs">&nbsp;</span>GC', 'top right');
1683 }
1684
1685
1686 function showInLogarithmicScaleWithData(series, colors) {
1687 if (series == null || gc.maxY == null || gc.minPow == null) {
1688 return;
1689 }
1690
1691 gc.yAxisLabeled = false;
1692
1693 gc.plot = $.plot(gc.placeholder, series, {
1694 shadowSize: 0,
1695 colors: colors,
1696 legend: {
1697 container: $('useless-invisible-element-that-does-not-even-exist'),
1698 },
1699 grid: {
1700 hoverable: true,
1701 borderWidth: 1,
1702 autoHighlight: false,
1703 mouseActiveRadius: 1000
1704 },
1705 yaxis: {
1706 min: Math.pow(10, gc.minPow),
1707 // max: gc.maxY,
1708 labelWidth: 120,
1709 reserveSpace: true,
1710 lineWidth: 0.5,
1711 color: '#000',
1712 tickFormatter: windowsTickFormatter,
1713 minTickSize: 1,
1714 ticks: gc.ticks,
1715
1716 transform: function(v) {
1717 return Math.log(v + 0.0001)/*move away from zero*/ / Math.log(10);
1718 },
1719 inverseTransform: function(v) {
1720 return Math.pow(v, 10);
1721 },
1722 tickDecimals: 3
1723 },
1724 xaxis: {
1725 min: 0,
1726 max: 100,
1727 lineWidth: 0.5,
1728 color: '#000',
1729 tickFormatter: function (val, axis) {
1730 if (val == 100) {
1731 return '&nbsp;100%<span class="rhs">&nbsp;</span>GC'
1732 } else {
1733 return val;
1734 }
1735 }
1736 },
1737 minTickSize: 1
1738 }
1739 );
1740
1741 var firstLabel = $('.yAxis .tickLabel').last();
1742 firstLabel.append(' windows');
1743 bindTip(gc.placeholder, series, gc.plot, toPrettyString, 1, '% GC', 'top right');
1744 }
1745
1746
1747 function setLogScale() {
1748 gc.normal_scale_el = normal_scale_a;
1749 gc.log_scale_el = log_scale_span;
1750 gc.showWithData = showInLogarithmicScaleWithData;
1751
1752 $('#normal_scale_label').html(gc.normal_scale_el);
1753 $('#log_scale_label').html(gc.log_scale_el);
1754 showPlotWithInfo(gc, 0);
1755 }
1756
1757
1758 function setNormalScale() {
1759 gc.normal_scale_el = normal_scale_span;
1760 gc.log_scale_el = log_scale_a;
1761 gc.showWithData = showInNormalScaleWithData;
1762
1763 $('#normal_scale_label').html(gc.normal_scale_el);
1764 $('#log_scale_label').html(gc.log_scale_el);
1765 showPlotWithInfo(gc, 0);
1766 }
1767
1768
1769
1770 function filterAndSumGcInfo(GC_info, condition) {
1771 var contigs_lengths_cur_bin = [];
1772 for (var j = 0; j < GC_info.length; j++) {
1773 var GC = GC_info[j];
1774 var contig_length = GC[0];
1775 var GC_percent = GC[1];
1776
1777 if (condition(GC_percent) == true) {
1778 contigs_lengths_cur_bin.push(contig_length);
1779 }
1780 }
1781 var val_bp = 0;
1782 for (var j = 0; j < contigs_lengths_cur_bin.length; j++) {
1783 val_bp += contigs_lengths_cur_bin[j];
1784 }
1785 return val_bp;
1786 }
1787
1788 function createLegend(labels, colors, index, reference) {
1789 var selectedAssemblies = getSelectedAssemblies(labels);
1790 $('#legend-placeholder').empty();
1791 var selectors = "";
1792
1793 labels.forEach(function(label, i) {
1794 var link = index ? '' : '<span id="' + labels[i] + '-switch"' + "class='plot-gc-type-switch dotted-link'>by contigs<br></span><br>";
1795 var assemblyIdx = gc.filenames.indexOf(label);
1796 addLabelToLegend(assemblyIdx, label, selectedAssemblies, colors, link);
1797 });
1798 if (reference) {
1799 isChecked = (selectedAssemblies.length > 0 && selectedAssemblies.indexOf(gc.filenames.length.toString())) != -1 ? 'checked="checked"' : "";
1800 $('#legend-placeholder').append(
1801 '<div id="reference-label">' +
1802 '<label for="reference" style="color: #000000;">' +
1803 '<input type="checkbox" name="' + gc.filenames.length +
1804 '" checked="' + isChecked + '" id="reference">&nbsp;' + 'reference' +
1805 '</label>' +
1806 '</div>'
1807 );
1808 }
1809 if (index > 0) {
1810 for (var filenames_n = 0; filenames_n < gc.filenames.length; filenames_n++){
1811 selectors += '<br><span id="' + gc.filenames[filenames_n] + '-switch" ' +
1812 "class='plot-switch dotted-link'>" +
1813 gc.filenames[filenames_n] + "</span>";
1814 }
1815 $('#legend-placeholder').append(
1816 "<br><br><div id='change-assembly' style='margin-right: 3px;'>" +
1817 "<span id='show_all_label'>" +
1818 gc.show_all_el +
1819 "</span><br>" + selectors +
1820 "</div>"
1821 );
1822 }
1823 addLinksToSwitches(index - 1);
1824 addLegendClickEvents(gc, gc.series.length, showPlotWithInfo, false, index);
1825 }
1826
1827 function addLinksToSwitches(index) {
1828 var filenames = gc.filenames;
1829 for (filenames_n = 0; filenames_n < filenames.length; filenames_n++){
1830 var switchSpan = document.getElementById(filenames[filenames_n] + "-switch");
1831 $(switchSpan).click(getToggleSwitchFunction(filenames_n + 1));
1832 if (filenames_n == index) {
1833 switchSpan.className = 'plot-switch selected-switch gc';
1834 }
1835 }
1836 }
1837
1838 function getToggleSwitchFunction(index) {
1839 return function() {
1840 if (index > 0) {
1841 showPlot(index);
1842 }
1843 else {
1844 showAll();
1845 }
1846 };
1847 }
1848 </script>
1849
1850 <script type="text/javascript">
1851
1852 var frc = {
1853 genes: {
1854 isInitialized: false,
1855
1856 maxY: 0,
1857 maxYTick: 0,
1858 series: null,
1859 showWithData: null,
1860
1861 yAxisLabeled: false
1862 },
1863
1864 operons: {
1865 isInitialized: false,
1866
1867 maxY: 0,
1868 maxYTick: 0,
1869 series: null,
1870 showWithData: null,
1871
1872 yAxisLabeled: false
1873 },
1874
1875 misassemblies: {
1876 isInitialized: false,
1877
1878 maxY: 0,
1879 maxYTick: 0,
1880 series: null,
1881 showWithData: null,
1882
1883 yAxisLabeled: false
1884 },
1885
1886 draw: function (name, title, colors, filenames, data, refGenesNumber, tickX,
1887 placeholder, legendPlaceholder, glossary, order, scalePlaceholder) {
1888 // div.html(
1889 // "<span class='plot-header'>" + kind[0].toUpperCase() + kind.slice(1) + "s covered</span>" +
1890 // "<div class='plot-placeholder' id='" + kind + "s-plot-placeholder'></div>"
1891 // );
1892 $(scalePlaceholder).empty();
1893
1894 var info = frc[name];
1895 var coordX = data.coord_x;
1896 var coordY = data.coord_y;
1897
1898 info.yAxisLabeled = false;
1899 var cur_filenames = data.filenames;
1900 if (!info.isInitialized) {
1901 var plotsN = cur_filenames.length;
1902 info.series = new Array(plotsN);
1903
1904 info.maxY = 0;
1905 info.maxX = 0;
1906
1907 for (var i = 0; i < plotsN; i++) {
1908 var index = $.inArray(cur_filenames[order[i]], filenames);
1909 var plot_coordX = coordX[order[i]];
1910 var plot_coordY = coordY[order[i]];
1911 var featureSpace = plot_coordX[plot_coordX.length - 1];
1912 var maxY = plot_coordY[plot_coordY.length - 1];
1913
1914 info.series[i] = {
1915 data: [],
1916 label: filenames[index],
1917 number: index,
1918 color: colors[index]
1919 };
1920
1921 info.series[i].data.push([0.0, plot_coordY[0]]);
1922
1923 if (featureSpace > info.maxX) {
1924 info.maxX = featureSpace;
1925 }
1926 for (var k = 0; k < plot_coordX.length; k++) {
1927 info.series[i].data.push([plot_coordX[k], plot_coordY[k]]);
1928 }
1929
1930 if (maxY > info.maxY) {
1931 info.maxY = maxY;
1932 }
1933 }
1934
1935 for (i = 0; i < plotsN; i++) {
1936 if (typeof broken_scaffolds_labels !== undefined && $.inArray(filenames[order[i]], broken_scaffolds_labels) != -1) {
1937 info.series[i].dashes = {
1938 show: true,
1939 lineWidth: 1
1940 };
1941 }
1942 else {
1943 info.series[i].lines = {
1944 show: true,
1945 lineWidth: 1
1946 };
1947 }
1948 }
1949
1950 info.showWithData = function(series, colors) {
1951 var plot = $.plot(placeholder, series, {
1952 shadowSize: 0,
1953 colors: colors,
1954 legend: {
1955 container: $('useless-invisible-element-that-does-not-even-exist')
1956 },
1957 grid: {
1958 borderWidth: 1,
1959 hoverable: true,
1960 autoHighlight: false,
1961 mouseActiveRadius: 1000,
1962 },
1963 yaxis: {
1964 min: 0,
1965 max: Math.max(100, info.maxY),
1966 labelWidth: 145,
1967 reserveSpace: true,
1968 lineWidth: 0.5,
1969 color: '#000',
1970 tickFormatter: getPercentTickFormatter(Math.max(100, info.maxY)),
1971 minTickSize: 1
1972 },
1973 xaxis: {
1974 min: 0,
1975 max: info.maxX,
1976 lineWidth: 0.5,
1977 color: '#000',
1978 tickFormatter: getJustNumberTickFormatter(info.maxX, ' ' + name),
1979 minTickSize: tickX
1980 }
1981 });
1982
1983 var firstLabel = $('.yAxis .tickLabel').last();
1984 firstLabel.prepend('Genome coverage<span class="rhs">&nbsp;</span>=<span class="rhs">&nbsp;</span>');
1985
1986 bindTip(placeholder, series, plot, frcNumberToPrettyString, tickX, name, 'bottom right', false, '%');
1987 };
1988
1989 info.isInitialized = true;
1990 }
1991
1992 addLegendClickEvents(info, filenames.length, showPlotWithInfo, refGenesNumber);
1993 showPlotWithInfo(info);
1994 $('#frc_info').show();
1995 $('.frc_plot_name').html(name);
1996 }
1997 };
1998
1999
2000
2001 </script>
2002
2003 <script type="text/javascript">
2004
2005 /**********/
2006 /* COLORS */
2007
2008 // var colors = ["#FF5900", "#008FFF", "#168A16", "#7C00FF", "#00B7FF", "#FF0080", "#7AE01B", "#782400", "#E01B6A"];
2009 var standard_colors = [
2010 '#FF0000', //red
2011 '#0000FF', //blue
2012 '#008000', //green
2013 '#FFA500', //orange
2014 '#FF00FF', //fushua
2015 '#CCCC00', //yellow
2016 '#800000', //maroon
2017 '#00CCCC', //aqua
2018 '#808080', //gray
2019 '#800080', //purple
2020 '#808000', //olive
2021 '#000080', //navy
2022 '#008080', //team
2023 '#00FF00', //lime
2024 ];
2025
2026 function distinctColors(count) {
2027 var colors = [];
2028 for(var hue = 0; hue < 360; hue += 360 / count) {
2029 var color = hsvToRgb(hue, 100, 100);
2030 var colorStr = '#' + color[0].toString(16) + color[1].toString(16) + color[2].toString(16);
2031 colors.push();
2032 }
2033 return colors;
2034 }
2035
2036 /**************/
2037 /* FORMATTING */
2038 function isIntegral(num) {
2039 return num % 1 === 0;
2040 }
2041
2042 function isFractional(num) {
2043 return !isIntegral(num);
2044 }
2045
2046 function getIntervalToPrettyString(interval) {
2047 return function(num, unit) {
2048 return intervalToPrettyString(interval, num, unit);
2049 }
2050 }
2051
2052 function intervalToPrettyString(interval, num, unit) {
2053 if (typeof num === 'number') {
2054 var str = toPrettyString(num);
2055 str += '-' + toPrettyString(num + interval);
2056 str += (unit ? '<span class="rhs">&nbsp;</span>' + unit : '');
2057 return str;
2058 } else {
2059 return num;
2060 }
2061 }
2062
2063 function toPrettyString(num, unit) {
2064 if (typeof num === 'number') {
2065 var str;
2066 if (num <= 9999) {
2067 if (isFractional(num)) {
2068 if (isIntegral(num * 10)) {
2069 str = num.toFixed(1);
2070 } else if (isIntegral(num * 100) || num >= 100) {
2071 str = num.toFixed(2);
2072 } else {
2073 str = num.toFixed(3);
2074 if (str.slice(-1) == '0')
2075 str = str.slice(0, -1);
2076 }
2077 } else {
2078 str = num.toFixed(0);
2079 }
2080 } else {
2081 str = num.toFixed(0).replace(/(\d)(?=(\d\d\d)+(?!\d))/g,'$1<span class="hs"></span>');
2082 }
2083 str += (unit ? '<span class="rhs">&nbsp;</span>' + unit : '');
2084 return str;
2085 } else {
2086 return num;
2087 }
2088 }
2089
2090 //elif isinstance(value, float):
2091 // if value == 0.0:
2092 // return '0'
2093 // if human_readable:
2094 // if unit == '%':
2095 // value *= 100
2096 // precision = 2
2097 // for i in range(10, 1, -1):
2098 // if abs(value) < 1./(10**i):
2099 // precision = i + 1
2100 // break
2101 // return '{value:.{precision}f}{unit_str}'.format(**locals())
2102 // else:
2103 // return str(value)
2104
2105
2106 function refToPrettyString(num, refs) {
2107 return refs[Math.round(num)-1];
2108 }
2109
2110 function ordinalNumberToPrettyString(num, unit, tickX) {
2111 num = num * tickX;
2112 var numStr = num.toString();
2113 var lastDigit = numStr[numStr.length-1];
2114 var beforeLastDigit = numStr[numStr.length-2];
2115
2116 var res = toPrettyString(num);
2117
2118 if (lastDigit == '1' && beforeLastDigit != '1') {
2119 res += "st";
2120 } else if (lastDigit == '2' && beforeLastDigit != '1') {
2121 res += "nd";
2122 } else if (lastDigit == '3' && beforeLastDigit != '1') {
2123 res += "rd";
2124 } else {
2125 res += 'th';
2126 }
2127
2128 res += (unit ? '<span class="rhs">&nbsp;</span>' + unit : '');
2129
2130 return res;
2131 }
2132
2133 function frcNumberToPrettyString(num, unit, tickX, index) {
2134 if (index % 2 == 0 && num > 0) num--;
2135 return toPrettyString(num) + ' ' + unit;
2136 }
2137
2138 function getMaxDecimalTick(maxY) {
2139 var maxYTick = maxY;
2140 if (maxY <= 100000000000) {
2141 maxYTick = Math.ceil((maxY+1)/10000000000)*10000000000;
2142 } if (maxY <= 10000000000) {
2143 maxYTick = Math.ceil((maxY+1)/1000000000)*1000000000;
2144 } if (maxY <= 1000000000) {
2145 maxYTick = Math.ceil((maxY+1)/100000000)*100000000;
2146 } if (maxY <= 100000000) {
2147 maxYTick = Math.ceil((maxY+1)/10000000)*10000000;
2148 } if (maxY <= 10000000) {
2149 maxYTick = Math.ceil((maxY+1)/1000000)*1000000;
2150 } if (maxY <= 1000000) {
2151 maxYTick = Math.ceil((maxY+1)/100000)*100000;
2152 } if (maxY <= 100000) {
2153 maxYTick = Math.ceil((maxY+1)/10000)*10000;
2154 } if (maxY <= 10000) {
2155 maxYTick = Math.ceil((maxY+1)/1000)*1000;
2156 } if (maxY <= 1000) {
2157 maxYTick = Math.ceil((maxY+1)/100)*100.
2158 } if (maxY <= 100) {
2159 maxYTick = Math.ceil((maxY+1)/10)*10.
2160 }
2161 return maxYTick;
2162 }
2163
2164 function getBpTickFormatter(maxY, additionalText) {
2165 additionalText = additionalText || '';
2166
2167 return function(val, axis) {
2168 var res;
2169 if (val == 0) {
2170 res = 0;
2171
2172 } else if (axis.max >= 1000000) {
2173 res = val / 1000000;
2174
2175 if (val > axis.max - 1 || val + axis.tickSize >= 1000000000) {
2176 res = additionalText + toPrettyString(res, 'Mbp');
2177 } else {
2178 res = toPrettyString(res);
2179 }
2180 } else if (axis.max >= 1000) {
2181 res = val / 1000;
2182
2183 if (val > axis.max - 1 || val + axis.tickSize >= 1000000) {
2184 res = additionalText + toPrettyString(res, 'kbp');
2185 } else {
2186 res = toPrettyString(res);
2187 }
2188 } else if (axis.max >= 1) {
2189 res = val;
2190
2191 if (val > axis.max - 1 || val + axis.tickSize >= 1000) {
2192 res = additionalText + toPrettyString(res, 'bp');
2193 } else {
2194 res = toPrettyString(res);
2195 }
2196 }
2197 return res;
2198 }
2199 }
2200
2201 function windowsTickFormatter(v, axis) {
2202 return toPrettyString(v);
2203 // var val = v.toFixed(0);
2204 // if (!gc.yAxisLabeled && val > gc.maxY) {
2205 // gc.yAxisLabeled = true;
2206 // var res = val + ' window';
2207 // if (val > 1) {
2208 // res += 's'
2209 // }
2210 // return res;
2211 // } else {
2212 // return val;
2213 // }
2214 }
2215
2216 function getBpLogTickFormatter(maxY) {
2217 return getBpTickFormatter(maxY);
2218 }
2219
2220 function getContigNumberTickFormatter(maxX, tickX) {
2221 return function (val, axis) {
2222 if (typeof axis.tickSize == 'number' && val > maxX - axis.tickSize) {
2223 return "&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;" + ordinalNumberToPrettyString(val, 'contig', tickX);
2224 } else {
2225 return val * tickX;
2226 }
2227 }
2228 }
2229
2230 function getJustNumberTickFormatter(maxY, additionalText) {
2231 return function (val, axis) {
2232 additionalText = additionalText || '';
2233 if (val > axis.max - axis.tickSize) {
2234 res = toPrettyString(val) + additionalText;
2235 } else {
2236 res = toPrettyString(val);
2237 }
2238 return res;
2239 }
2240 }
2241
2242 function getPercentTickFormatter(maxY, additionalText) {
2243 return function (val, axis) {
2244 additionalText = additionalText || '';
2245 if (val > maxY + 1 || val == 100) {
2246 res = additionalText + toPrettyString(val, '%');
2247 } else {
2248 res = toPrettyString(val);
2249 }
2250 return res;
2251 }
2252 }
2253
2254 function trim(str) {
2255 return str.replace(/^\s+/g, '');
2256 }
2257
2258 function initial_spaces_to_nbsp(str, metricName) {
2259 if (metricName.length > 0 && metricName[0] == ' ') {
2260 str = '&nbsp;&nbsp;&nbsp;' + str;
2261 }
2262 return str;
2263 }
2264
2265 function containsObject(obj, list) {
2266 var i;
2267 for (i = 0; i < list.length; i++) {
2268 if (list[i] === obj) {
2269 return true;
2270 }
2271 }
2272
2273 return false;
2274 }
2275
2276 function addLegendClickEvents(info, numLegendItems, showPlotWithInfo, showReference, index) {
2277 if (showReference) numLegendItems++;
2278 for (var i = 0; i < numLegendItems; i++) {
2279 $('#legend-placeholder input[name=' + i + ']').click(function() {
2280 showPlotWithInfo(info, index);
2281 });
2282 }
2283 }
2284
2285 /*********************/
2286 /* GLOSSARY TOOLTIPS */
2287 function addTooltipIfDefinitionExists(glossary, metricName) {
2288 metricName = trim(metricName);
2289
2290 if (containsObject(metricName, Object.keys(glossary))) {
2291 return '<a class="tooltip-link" rel="tooltip" title="' +
2292 metricName + ' ' + glossary[metricName] + '">' + metricName + '</a>';
2293 } else {
2294 return metricName;
2295 }
2296 }
2297
2298 /*************/
2299 /* PLOT TIPS */
2300 function bindTip(placeholder, series, plot, xToPrettyStringFunction, tickX, xUnit, position, summaryPlots, unitY) {
2301 var prevPoint = null;
2302 var prevIndex = null;
2303
2304 $(placeholder).bind("plothover", function(event, pos, item) {
2305 if (dragTable && dragTable.isDragging)
2306 return;
2307
2308 if (item) {
2309 if (prevPoint != item.dataIndex || (summaryPlots && item.seriesIndex != prevIndex)) {
2310 prevPoint = item.dataIndex;
2311 prevIndex = item.seriesIndex;
2312 var x = item.datapoint[0];
2313
2314 showTip(item.pageX, item.pageY, plot.offset(),
2315 plot.width(), plot.height(),
2316 series, item.seriesIndex, x, item.dataIndex,
2317 xToPrettyStringFunction(x, xUnit, tickX, item.dataIndex) + ':',
2318 position, summaryPlots, unitY);
2319 }
2320 } else {
2321 $('#plot_tip').hide();
2322 $('#plot_tip_vertical_rule').hide();
2323 $('#plot_tip_horizontal_rule').hide();
2324 prevPoint = null;
2325 }
2326 });
2327 }
2328
2329 function unBindTips(placeholder) {
2330 $(placeholder).unbind("plothover");
2331 }
2332
2333 var tipElementExists = false;
2334 function showTip(pageX, pageY, offset, plotWidth, plotHeight,
2335 series, centralSeriesIndex, xPos, xIndex, xStr, position, summaryPlots, unitY) {
2336 const LINE_HEIGHT = 16; // pixels
2337
2338 position = ((position != null) ? position : 'bottom right');
2339 // pageY -= LINE_HEIGHT * (centralSeriesIndex + 1.5);
2340
2341 var directions = position.split(' ');
2342
2343 if (!tipElementExists) {
2344 $('<div id="plot_tip" class="white_stroked"></div>').appendTo('body');
2345
2346 $('<div id="plot_tip_vertical_rule"></div>').css({
2347 height: plotHeight,
2348 }).appendTo('body');
2349
2350 $('<div id="plot_tip_horizontal_rule"></div>').css({
2351 width: plotWidth,
2352 }).appendTo('body');
2353
2354 tipElementExists = true;
2355 }
2356
2357 $('#plot_tip').html('').css({
2358 top: pageY + 5 - ((directions[0] == 'top') ? LINE_HEIGHT * (series.length + 2) : 0),
2359 left: pageX + 10,
2360 }).show();
2361
2362 $('#plot_tip_vertical_rule').html('').css({
2363 top: offset.top,
2364 left: pageX,
2365 }).show();
2366
2367 $('#plot_tip_horizontal_rule').html('').css({
2368 top: pageY,
2369 left: offset.left,
2370 }).show();
2371
2372 $('<div>' + xStr + '</div>').css({
2373 height: LINE_HEIGHT,
2374 }).appendTo('#plot_tip');
2375
2376 var sortedYsAndColors = [];
2377 for (var i = 0; i < series.length; i++) {
2378 if (!summaryPlots || (summaryPlots && series[i].data[xIndex] != undefined && series[i].data[xIndex][1] != null)) {
2379 sortedYsAndColors.push({
2380 y: summaryPlots ? series[i].data[xIndex][1] : (i == centralSeriesIndex ? (series[i].data[xIndex] || series[i].data[series[i].data.length - 1])[1] :
2381 findNearestPoint(series[i].data, xPos)),
2382 color: series[i].color,
2383 label: (series[i].isReference ? 'Reference' : series[i].label),
2384 isCurrent: i == centralSeriesIndex,
2385 });
2386 }
2387 }
2388 sortedYsAndColors.sort(function(a, b) { return a.y < b.y;});
2389
2390 for (i = 0; i < sortedYsAndColors.length; i++) {
2391 var item = sortedYsAndColors[i];
2392
2393 $('<div id="tip_line' + i + '">' + toPrettyString(item.y) + (unitY ? unitY : '') +
2394 ', <span style="color: ' + item.color + ';">' + item.label + '</span></div>').css({
2395 height: LINE_HEIGHT,
2396 "font-weight": item.isCurrent ? "bold" : "normal",
2397 }).appendTo('#plot_tip');
2398 }
2399 }
2400
2401 function findNearestPoint(points, x) {
2402 for (var i = 0; i < points.length; i++) {
2403 if (points[i][0] >= x) return points[i][1];
2404 }
2405 return points[points.length-1][1]
2406 }
2407
2408 function addLabelToLegend(idx, label, selectedLabels, colors, link) {
2409 var isChecked = (selectedLabels.length > 0 && selectedLabels.indexOf(idx.toString())) != -1 ? 'checked="checked"' : "";
2410 $('#legend-placeholder').append('<div>' +
2411 '<label for="' + label + '" style="color: ' + colors[idx] + '">' +
2412 '<input type="checkbox" name="' + idx + '"' + isChecked + ' id="' + label + '">&nbsp;' + label + '</label>' +
2413 (link ? '<br>' + link : '') + '</div>');
2414 }
2415
2416 function getSelectedAssemblies(labels) {
2417 var selectedAssemblies = [];
2418 var labelsMatch = false;
2419 var legendLabels = [];
2420 $('#legend-placeholder input[type="checkbox"]').each(function() {
2421 legendLabels.push($(this).attr('id'));
2422 });
2423 if (labels.every(function(label, i) { return ($.inArray(label, legendLabels) != -1 || label == 'reference')}) ) {
2424 labelsMatch = true;
2425 }
2426 if (labelsMatch) {
2427 $('#legend-placeholder input:checked[type="checkbox"]').each(function() {
2428 selectedAssemblies.push($(this).attr('name'));
2429 });
2430 }
2431 else {
2432 selectedAssemblies = Array.apply(null, {length: labels}).map(Number.call, Number);
2433 }
2434 return selectedAssemblies;
2435 }
2436
2437 // Cookie functions based on http://www.quirksmode.org/js/cookies.html
2438 // Cookies won't work for local files.
2439
2440 var createCookie = function(name, value, days) {
2441 var expires = '';
2442 if (days) {
2443 var date = new Date();
2444 date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000));
2445 expires = '; expires=' + date.toGMTString();
2446 }
2447 var path = document.location.pathname;
2448 document.cookie = name + '=' + value + expires + '; path=' + path;
2449 };
2450
2451 var readCookie = function(name) {
2452 var nameEQ = name + '=';
2453 var ca = document.cookie.split(';');
2454 for(var i = 0; i < ca.length; i++) {
2455 var c = ca[i];
2456 while (c.charAt(0) == ' ') {
2457 c = c.substring(1, c.length);
2458 }
2459 if (c.indexOf(nameEQ) == 0) {
2460 return c.substring(nameEQ.length, c.length);
2461 }
2462 }
2463 return null;
2464 };
2465
2466 var eraseCookie = function(name) {
2467 createCookie(name, '', -1);
2468 };
2469
2470
2471 // Dean's forEach: http://dean.edwards.name/base/forEach.js
2472 /*forEach, version 1.0
2473 Copyright 2006, Dean Edwards
2474 License: http://www.opensource.org/licenses/mit-license.php */
2475
2476 // array-like enumeration
2477 if (!Array.forEach) { // mozilla already supports this
2478 Array.forEach = function(array, block, context) {
2479 for (var i = 0; i < array.length; i++) {
2480 block.call(context, array[i], i, array);
2481 }
2482 };
2483 }
2484
2485 // generic enumeration
2486 Function.prototype.forEach = function(object, block, context) {
2487 for (var key in object) {
2488 if (typeof this.prototype[key] == "undefined") {
2489 block.call(context, object[key], key, object);
2490 }
2491 }
2492 };
2493
2494 // character enumeration
2495 String.forEach = function(string, block, context) {
2496 Array.forEach(string.split(""), function(chr, index) {
2497 block.call(context, chr, index, string);
2498 });
2499 };
2500
2501 // globally resolve forEach enumeration
2502 var forEach = function(object, block, context) {
2503 if (object) {
2504 if (object instanceof Function) { // functions have a "length" property
2505 Function.forEach(object, block, context);
2506
2507 } else if (object.each instanceof Function) { // jQuery
2508 object.each(function(i, elt) {
2509 block(elt);
2510 }, context);
2511
2512 } else if (object.forEach instanceof Function) { // the object implements a custom forEach method
2513 object.forEach(block, context);
2514
2515 } else if (typeof object == "string") { // a string
2516 String.forEach(object, block, context);
2517
2518 } else if (typeof object.length == "number") { // array-like object
2519 Array.forEach(object, block, context);
2520
2521 } else {
2522 Object.forEach(object, block, context);
2523 }
2524 }
2525 };
2526
2527
2528 jQuery.fn.exists = function(){
2529 return jQuery(this).length > 0;
2530 };
2531
2532
2533 function Range(from, to) {
2534 var r = [];
2535 for (var i = from; i < to; i++) {
2536 r.push(i);
2537 }
2538 return r;
2539 }
2540
2541
2542
2543 </script>
2544
2545 <script type="text/javascript">
2546 /**
2547 * HSV to RGB color conversion
2548 *
2549 * H runs from 0 to 360 degrees
2550 * S and V run from 0 to 100
2551 *
2552 * Ported from the excellent java algorithm by Eugene Vishnevsky at:
2553 * http://www.cs.rit.edu/~ncs/color/t_convert.html
2554 */
2555 function hsvToRgb(h, s, v) {
2556 var r, g, b;
2557 var i;
2558 var f, p, q, t;
2559
2560 // Make sure our arguments stay in-range
2561 h = Math.max(0, Math.min(360, h));
2562 s = Math.max(0, Math.min(100, s));
2563 v = Math.max(0, Math.min(100, v));
2564
2565 // We accept saturation and value arguments from 0 to 100 because that's
2566 // how Photoshop represents those values. Internally, however, the
2567 // saturation and value are calculated from a range of 0 to 1. We make
2568 // That conversion here.
2569 s /= 100;
2570 v /= 100;
2571
2572 if(s == 0) {
2573 // Achromatic (grey)
2574 r = g = b = v;
2575 return [Math.round(r * 255), Math.round(g * 255), Math.round(b * 255)];
2576 }
2577
2578 h /= 60; // sector 0 to 5
2579 i = Math.floor(h);
2580 f = h - i; // factorial part of h
2581 p = v * (1 - s);
2582 q = v * (1 - s * f);
2583 t = v * (1 - s * (1 - f));
2584
2585 switch(i) {
2586 case 0:
2587 r = v;
2588 g = t;
2589 b = p;
2590 break;
2591
2592 case 1:
2593 r = q;
2594 g = v;
2595 b = p;
2596 break;
2597
2598 case 2:
2599 r = p;
2600 g = v;
2601 b = t;
2602 break;
2603
2604 case 3:
2605 r = p;
2606 g = q;
2607 b = v;
2608 break;
2609
2610 case 4:
2611 r = t;
2612 g = p;
2613 b = v;
2614 break;
2615
2616 default: // case 5:
2617 r = v;
2618 g = p;
2619 b = q;
2620 }
2621
2622 return [Math.round(r * 255), Math.round(g * 255), Math.round(b * 255)];
2623 }
2624
2625 function hslToRgb(h, s, l){
2626 var r, g, b;
2627
2628 if(s == 0) {
2629 r = g = b = l; // achromatic
2630 } else {
2631 function hue2rgb(p, q, t){
2632 if(t < 0) t += 1;
2633 if(t > 1) t -= 1;
2634 if(t < 1/6) return p + (q - p) * 6 * t;
2635 if(t < 1/2) return q;
2636 if(t < 2/3) return p + (q - p) * (2/3 - t) * 6;
2637 return p;
2638 }
2639
2640 var q = l < 0.5 ? l * (1 + s) : l + s - l * s;
2641 var p = 2 * l - q;
2642 r = hue2rgb(p, q, h + 1/3);
2643 g = hue2rgb(p, q, h);
2644 b = hue2rgb(p, q, h - 1/3);
2645 }
2646
2647 return [Math.round(r * 255), Math.round(g * 255), Math.round(b * 255)];
2648 }
2649 </script>
2650
2651 <script type="text/javascript">
2652
2653 var gns = {
2654 features: {
2655 isInitialized: false,
2656
2657 maxY: 0,
2658 maxYTick: 0,
2659 series: null,
2660 showWithData: null,
2661
2662 yAxisLabeled: false
2663 },
2664
2665 operons: {
2666 isInitialized: false,
2667
2668 maxY: 0,
2669 maxYTick: 0,
2670 series: null,
2671 showWithData: null,
2672
2673 yAxisLabeled: false
2674 },
2675
2676 draw: function (name, title, colors, filenames, data, refFeaturesNumber, tickX,
2677 placeholder, legendPlaceholder, glossary, order, scalePlaceholder) {
2678 // div.html(
2679 // "<span class='plot-header'>" + kind[0].toUpperCase() + kind.slice(1) + "s covered</span>" +
2680 // "<div class='plot-placeholder' id='" + kind + "s-plot-placeholder'></div>"
2681 // );
2682 $(scalePlaceholder).empty();
2683
2684 var info = gns[name];
2685
2686 info.yAxisLabeled = false;
2687 var cur_filenames = data.filenames;
2688 if (!info.isInitialized) {
2689 var filesFeatureInContigs = data.filesFeatureInContigs;
2690 var kind = data.kind;
2691
2692 var plotsN = cur_filenames.length;
2693 info.series = new Array(plotsN);
2694
2695 info.maxY = 0;
2696 info.maxX = 0;
2697
2698 if (refFeaturesNumber) {
2699 info.maxY = refFeaturesNumber;
2700 }
2701
2702 for (var fi = 0; fi < plotsN; fi++) {
2703 var index = $.inArray(cur_filenames[order[fi]], filenames);
2704 var filename = filenames[index];
2705 var featureInContigs = filesFeatureInContigs[filename];
2706
2707 info.series[fi] = {
2708 data: [[0, 0]],
2709 label: filenames[index],
2710 number: index,
2711 color: colors[index]
2712 };
2713
2714 var contigNo = 0;
2715 var totalFull = 0;
2716
2717 for (var k = 0; k < featureInContigs.length; k++) {
2718 contigNo += 1;
2719 totalFull += featureInContigs[k];
2720
2721 info.series[fi].data.push([contigNo, totalFull]);
2722
2723 if (info.series[fi].data[k][1] > info.maxY) {
2724 info.maxY = info.series[fi].data[k][1];
2725 }
2726 }
2727
2728 if (featureInContigs.length > info.maxX) {
2729 info.maxX = featureInContigs.length;
2730 }
2731 }
2732
2733 for (i = 0; i < plotsN; i++) {
2734 if (typeof broken_scaffolds_labels !== undefined && $.inArray(filenames[order[i]], broken_scaffolds_labels) != -1) {
2735 info.series[i].dashes = {
2736 show: true,
2737 lineWidth: 1
2738 };
2739 }
2740 else {
2741 info.series[i].lines = {
2742 show: true,
2743 lineWidth: 1
2744 };
2745 }
2746 }
2747
2748 // for (i = 0; i < plotsN; i++) {
2749 // plotsData[i].points = {
2750 // show: true,
2751 // radius: 1,
2752 // fill: 1,
2753 // fillColor: false,
2754 // }
2755 // }
2756
2757 if (refFeaturesNumber) {
2758 info.series.push({
2759 data: [[0, refFeaturesNumber], [info.maxX, refFeaturesNumber]],
2760 label: 'reference,&nbsp;' + toPrettyString(refFeaturesNumber, 'features'),
2761 isReference: true,
2762 dashes: {
2763 show: true,
2764 lineWidth: 1
2765 },
2766 yaxis: 1,
2767 number: filenames.length,
2768 color: '#000000'
2769 });
2770
2771 colors.push('#000000');
2772 }
2773
2774 info.showWithData = function(series, colors) {
2775 var plot = $.plot(placeholder, series, {
2776 shadowSize: 0,
2777 colors: colors,
2778 legend: {
2779 container: $('useless-invisible-element-that-does-not-even-exist'),
2780 },
2781 grid: {
2782 borderWidth: 1,
2783 hoverable: true,
2784 autoHighlight: false,
2785 mouseActiveRadius: 1000,
2786 },
2787 yaxis: {
2788 min: 0,
2789 // max: info.maxY,
2790 labelWidth: 120,
2791 reserveSpace: true,
2792 lineWidth: 0.5,
2793 color: '#000',
2794 tickFormatter: function (val, axis) {
2795 // if (!info.yAxisLabeled && val > info.maxY) {
2796 // info.yAxisLabeled = true;
2797 // var res = val + ' ' + kind;
2798 // if (val > 1) {
2799 // res += 's'
2800 // }
2801 // return res;
2802 // } else {
2803 return val;
2804 // }
2805 },
2806 minTickSize: 1
2807 },
2808 xaxis: {
2809 min: 0,
2810 max: info.maxX,
2811 lineWidth: 0.5,
2812 color: '#000',
2813 tickFormatter: getContigNumberTickFormatter(info.maxX, tickX),
2814 minTickSize: tickX
2815 },
2816 });
2817
2818 var firstLabel = $('.yAxis .tickLabel').last();
2819 firstLabel.append(' ' + name);
2820
2821 bindTip(placeholder, series, plot, ordinalNumberToPrettyString, tickX, 'contig', 'bottom right');
2822 };
2823
2824 info.isInitialized = true;
2825 }
2826
2827 addLegendClickEvents(info, filenames.length, showPlotWithInfo, refFeaturesNumber);
2828
2829 showPlotWithInfo(info);
2830
2831 $('#contigs_are_ordered').show();
2832 }
2833 };
2834
2835
2836
2837 </script>
2838
2839 <script type="text/javascript">
2840 /*
2841 DT v1.0
2842 June 26, 2008
2843 Dan Vanderkam, http://danvk.org/DT/
2844 http://code.google.com/p/DT/
2845
2846 This is code was based on:
2847 - Stuart Langridge's SortTable (kryogenix.org/code/browser/sorttable)
2848 - Mike Hall's draggable class (http://www.brainjar.com/dhtml/drag/)
2849 - A discussion of permuting table columns on comp.lang.javascript
2850
2851 Licensed under the MIT license.
2852 */
2853
2854 // Here's the notice from Mike Hall's draggable script:
2855 //*****************************************************************************
2856 // Do not remove this notice.
2857 //
2858 // Copyright 2001 by Mike Hall.
2859 // See http://www.brainjar.com for terms of use.
2860 //*****************************************************************************
2861
2862 var classes = {
2863 cell_of_emptySpace: 'cell_of_empty_space',
2864 cell_of_movingTable: 'cell_of_moving_table',
2865 newTable: 'moving_table',
2866 handle: 'drag_handle',
2867 hoveredCell: 'hovered_column_td',
2868 assemblyName: 'assembly_name',
2869
2870 bottomCell_of_emptySpace: 'bottom_cell_of_empty_space',
2871 topCell_of_emptySpace: 'top_cell_of_empty_space',
2872 leftToCell_of_emptySpace: 'left_to_cell_of_empty_space',
2873 rightToCell_of_emptySpace: 'right_to_cell_of_empty_space',
2874
2875 mainReportTable_id: 'main_report_table',
2876 totalReportJson_id: 'total-report-json',
2877 };
2878
2879 var dragTable = {
2880 isDragging: false,
2881
2882 // How far should the mouse move before it's considered a drag, not a click?
2883 dragRadius2: 0, // 100,
2884 setMinDragDistance: function(x) {
2885 DT.dragRadius2 = x * x;
2886 },
2887
2888 // How long should cookies persist? (in days)
2889 cookieDays: 365,
2890 setCookieDays: function(x) {
2891 DT.cookieDays = x;
2892 },
2893
2894 // Determine browser and version.
2895 // TODO: eliminate browser sniffing except where it's really necessary.
2896 Browser: function() {
2897 var ua, s, i;
2898
2899 this.isIE = false;
2900 this.isNS = false;
2901 this.version = null;
2902 ua = navigator.userAgent;
2903
2904 s = "MSIE";
2905 if ((i = ua.indexOf(s)) >= 0) {
2906 this.isIE = true;
2907 this.version = parseFloat(ua.substr(i + s.length));
2908 return;
2909 }
2910
2911 s = "Netscape6/";
2912 if ((i = ua.indexOf(s)) >= 0) {
2913 this.isNS = true;
2914 this.version = parseFloat(ua.substr(i + s.length));
2915 return;
2916 }
2917
2918 // Treat any other "Gecko" browser as NS 6.1.
2919 s = "Gecko";
2920 if ((i = ua.indexOf(s)) >= 0) {
2921 this.isNS = true;
2922 this.version = 6.1;
2923 return;
2924 }
2925 },
2926 browser: null,
2927
2928 // Detect all draggable tables and attach handlers to their headers.
2929 init: function() {
2930 // Don't initialize twice
2931 if (arguments.callee.done)
2932 return;
2933 else
2934 arguments.callee.done = true;
2935
2936 // if (_dgtimer)
2937 // clearInterval(_dgtimer);
2938
2939 if (!document.createElement || !document.getElementsByTagName)
2940 return;
2941
2942 DT.dragObj.zIndex = 0;
2943 DT.browser = new DT.Browser();
2944 forEach(document.getElementsByTagName('table'), function(table) {
2945 if ($(table).hasClass('draggable')) {
2946 DT.makeDraggable(table);
2947 }
2948 });
2949 },
2950
2951 // The thead business is taken straight from sorttable.
2952 makeDraggable: function(table) {
2953 DT.dragObj.table = table;
2954
2955 if (table.getElementsByTagName('thead').length == 0) {
2956 thead = document.createElement('thead');
2957 thead.appendChild(table.rows[0]);
2958 table.insertBefore(thead, table.firstChild);
2959 }
2960
2961 // Safari doesn't support table.tHead, sigh
2962 if (table.tHead == null) {
2963 table.tHead = table.getElementsByTagName('thead')[0];
2964 }
2965
2966 var handles = $('.' + classes.handle) || table.tHead.rows[0].cells;
2967
2968 forEach(handles, function(handle) {
2969 handle.onmousedown = DT.dragStart;
2970 });
2971 },
2972
2973 // Global object to hold drag information.
2974 dragObj: {},
2975
2976 getEventPosition: function(event) {
2977 var x, y;
2978 if (DT.browser.isIE) {
2979 x = window.event.clientX + document.documentElement.scrollLeft
2980 + document.body.scrollLeft;
2981 y = window.event.clientY + document.documentElement.scrollTop
2982 + document.body.scrollTop;
2983 return {x: x, y: y};
2984 }
2985 return {x: event.pageX, y: event.pageY};
2986 },
2987
2988 // Determine the position of this element on the page. Many thanks to Magnus
2989 // Kristiansen for help making this work with "position: fixed" elements.
2990 getPositionOnThePage: function(elt, stopAtRelative) {
2991 var ex = 0, ey = 0;
2992 do {
2993 var curStyle = DT.browser.isIE ? elt.currentStyle
2994 : window.getComputedStyle(elt, '');
2995 var supportFixed = !(DT.browser.isIE &&
2996 DT.browser.version < 7);
2997 if (stopAtRelative && curStyle.position == 'relative') {
2998 break;
2999 } else if (supportFixed && curStyle.position == 'fixed') {
3000 // Get the fixed el's offset
3001 ex += parseInt(curStyle.left, 10);
3002 ey += parseInt(curStyle.top, 10);
3003 // Compensate for scrolling
3004 ex += document.body.scrollLeft;
3005 ey += document.body.scrollTop;
3006 // End the loop
3007 break;
3008 } else {
3009 ex += elt.offsetLeft;
3010 ey += elt.offsetTop;
3011 }
3012 } while (elt = elt.offsetParent);
3013 return {x: ex, y: ey};
3014 },
3015
3016 // MouseDown handler -- sets up the appropriate mousemove/mouseup handlers
3017 // and fills in the global DT.dragObj object.
3018 dragStart: function(event, id) {
3019 DT.isDragging = true;
3020
3021 var drag_obj = DT.dragObj;
3022
3023 var browser = DT.browser;
3024 var clicked_node = browser.isIE ? window.event.srcElement : event.target;
3025 var pos = DT.getEventPosition(event);
3026
3027 var table = $(clicked_node).closest('table')[0];
3028 var top_cell = $(clicked_node).closest('td, th')[0];
3029 drag_obj.topCell = top_cell;
3030 drag_obj.table = table;
3031
3032 var col_index = top_cell.cellIndex;
3033 drag_obj.movingColIndex = drag_obj.startIndex = col_index;
3034 drag_obj.movingColWidth = $(top_cell).width();
3035
3036 // Since a column header can't be dragged directly, duplicate its contents
3037 // in a div and drag that instead.
3038 var new_table = DT.fullCopy(table, false);
3039
3040 // Copy the entire column
3041 var forEachSection = function(table, func) {
3042 if (table.tHead) {
3043 func(table.tHead);
3044 }
3045 forEach(table.tBodies, function(tbody) {
3046 func(tbody);
3047 });
3048 if (table.tFoot) {
3049 func(table.tFoot);
3050 }
3051 };
3052
3053 forEachSection(table, function(sec) {
3054 var new_sec = DT.fullCopy(sec, false);
3055
3056 forEach(sec.rows, function(row) {
3057 var cell = row.cells[col_index];
3058 var new_tr = DT.fullCopy(row, false);
3059 if (row.offsetHeight) new_tr.style.height = row.offsetHeight + "px";
3060 var new_td = DT.fullCopy(cell, true);
3061 if (cell.offsetWidth) new_td.style.width = cell.offsetWidth + "px !important";
3062 new_tr.appendChild(new_td);
3063 new_sec.appendChild(new_tr);
3064 });
3065
3066 new_table.appendChild(new_sec);
3067 });
3068
3069 var obj_pos = DT.getPositionOnThePage(top_cell, true);
3070 new_table.style.position = "absolute";
3071 new_table.style.left = obj_pos.x + "px";
3072 new_table.style.top = obj_pos.y + "px";
3073 // new_table.style.width = dragObj.origNode.offsetWidth + "px";
3074 // new_table.style.height = dragObj.origNode.offsetHeight + "px";
3075
3076 // Hold off adding the element until this is clearly a drag.
3077 drag_obj.addedNode = false;
3078
3079 drag_obj.tableContainer = drag_obj.table.parentNode || document.body;
3080 drag_obj.newTable = new_table;
3081
3082 // Save starting positions of cursor and element.
3083 drag_obj.startPos = pos;
3084 drag_obj.prevPos = pos;
3085 drag_obj.elStartLeft = parseInt(drag_obj.newTable.style.left, 10);
3086 drag_obj.elStartTop = parseInt(drag_obj.newTable.style.top, 10);
3087
3088 if (isNaN(drag_obj.elStartLeft)) drag_obj.elStartLeft = 0;
3089 if (isNaN(drag_obj.elStartTop)) drag_obj.elStartTop = 0;
3090
3091 // Update element's z-index.
3092 drag_obj.newTable.style.zIndex = ++drag_obj.zIndex;
3093
3094 // Capture mousemove and mouseup events on the page.
3095 if (browser.isIE) {
3096 document.attachEvent("onmousemove", DT.dragMove);
3097 document.attachEvent("onmouseup", DT.dragEnd);
3098 window.event.cancelBubble = true;
3099 window.event.returnValue = false;
3100 } else {
3101 document.addEventListener("mousemove", DT.dragMove, true);
3102 document.addEventListener("mouseup", DT.dragEnd, true);
3103 event.preventDefault();
3104 }
3105 },
3106
3107 // Move the floating column header with the mouse
3108 // TODO: Reorder columns as the mouse moves for a more interactive feel.
3109 dragMove: function(event) {
3110 var x, y;
3111 var drag_obj = DT.dragObj;
3112 var col_index = drag_obj.movingColIndex;
3113
3114 // Get cursor position with respect to the page.
3115 var pos = DT.getEventPosition(event);
3116
3117 var full_dx = drag_obj.startPos.x - pos.x;
3118 var full_dy = drag_obj.startPos.y - pos.y;
3119
3120 if (!drag_obj.addedNode && full_dx * full_dx + full_dy * full_dy > DT.dragRadius2) {
3121 // Real dragging has began, the following block performs once
3122
3123 // Attach a moving table
3124 drag_obj.tableContainer.insertBefore(drag_obj.newTable, drag_obj.table);
3125 drag_obj.addedNode = true;
3126
3127 // Add classes for the dragged column (original and the clone)
3128 $(drag_obj.newTable).addClass(classes.newTable);
3129 $(DT.getColumn(drag_obj.newTable)).addClass(classes.cell_of_movingTable);
3130
3131 $(DT.getColumn(drag_obj.table, col_index)).addClass(classes.cell_of_emptySpace);
3132 $(DT.getColumn(drag_obj.table, col_index)[0]).addClass(classes.topCell_of_emptySpace);
3133 var visibleCells = $(DT.getColumn(drag_obj.table, col_index)).filter(':visible');
3134 $(visibleCells[visibleCells.length - 1]).addClass(classes.bottomCell_of_emptySpace);
3135
3136 DT.addStylesForAdjacentColumns(col_index);
3137 }
3138
3139 // Move drag element by the same amount the cursor has moved.
3140 var style = drag_obj.newTable.style;
3141 style.left = (drag_obj.elStartLeft + pos.x - drag_obj.startPos.x) + "px";
3142 style.top = (drag_obj.elStartTop + pos.y - drag_obj.startPos.y) + "px";
3143
3144 if (DT.browser.isIE) {
3145 window.event.cancelBubble = true;
3146 window.event.returnValue = false;
3147 } else {
3148 event.preventDefault();
3149 }
3150
3151 // If moving over an adjacent column, do swapping, swapping with the adjacent column
3152 var column_pos_x = DT.getPositionOnThePage(DT.getColumn(drag_obj.newTable)[0]).x;
3153 var column_center_x = column_pos_x + drag_obj.movingColWidth / 2;
3154 var hovered_col_index = DT.getColumnAtPosition(drag_obj.table, column_center_x);
3155
3156 var dx = drag_obj.prevPos.x - pos.x;
3157
3158 if (DT.isSuitableColumnToSwap(hovered_col_index, col_index)) {
3159 if (dx < 0 && hovered_col_index > col_index || // moving right
3160 dx > 0 && hovered_col_index < col_index) { // moving left
3161 DT.removeStylesForAdjacentColumns(col_index);
3162 DT.moveColumn(drag_obj.table, col_index, hovered_col_index);
3163 DT.addStylesForAdjacentColumns(hovered_col_index);
3164 drag_obj.movingColIndex = hovered_col_index;
3165 }
3166 }
3167 drag_obj.prevPos = pos;
3168 },
3169
3170 removeStylesForAdjacentColumns: function(oldIndex) {
3171 var table = DT.dragObj.table;
3172 var rows = table.rows;
3173 var oldColumn = DT.getColumn(table, oldIndex);
3174 $(DT.getColumn(table, oldIndex - 1)).removeClass(classes.leftToCell_of_emptySpace);
3175 $(DT.getColumn(table, oldIndex + 1)).removeClass(classes.rightToCell_of_emptySpace);
3176 },
3177
3178 addStylesForAdjacentColumns: function(index) {
3179 var table = DT.dragObj.table;
3180 var rows = table.rows;
3181 var column = DT.getColumn(table, index);
3182 $(DT.getColumn(table, index - 1)).addClass(classes.leftToCell_of_emptySpace);
3183 $(DT.getColumn(table, index + 1)).addClass(classes.rightToCell_of_emptySpace);
3184 },
3185
3186 // Stop capturing mousemove and mouseup events.
3187 // Determine which (if any) column we're over and shuffle the table.
3188 dragEnd: function(event) {
3189 if (DT.browser.isIE) {
3190 document.detachEvent("onmousemove", DT.dragMove);
3191 document.detachEvent("onmouseup", DT.dragEnd);
3192 } else {
3193 document.removeEventListener("mousemove", DT.dragMove, true);
3194 document.removeEventListener("mouseup", DT.dragEnd, true);
3195 }
3196
3197 var drag_obj = DT.dragObj;
3198 var col_index = drag_obj.movingColIndex;
3199
3200 // If the floating header wasn't added, the mouse didn't move far enough.
3201 if (drag_obj.addedNode) {
3202 // TODO: Move with animation
3203 var final_pos = DT.getPositionOnThePage(DT.getColumn(drag_obj.table, col_index)[0]);
3204
3205 $(drag_obj.newTable).animate({
3206 left: final_pos.x,
3207 top: final_pos.y,
3208 }, 'fast', function() {
3209 $(drag_obj.newTable).remove();
3210 $(DT.getColumn(drag_obj.table, col_index)).removeClass(classes.cell_of_emptySpace);
3211 $(DT.getColumn(drag_obj.table, col_index)[0]).removeClass(classes.topCell_of_emptySpace);
3212 var visibleCells = $(DT.getColumn(drag_obj.table, col_index)).filter(':visible');
3213 $(visibleCells[visibleCells.length - 1]).removeClass(classes.bottomCell_of_emptySpace);
3214
3215 DT.removeStylesForAdjacentColumns(col_index);
3216 });
3217
3218 DT.storeDrag(drag_obj.table);
3219 }
3220 DT.isDragging = false;
3221 },
3222
3223 moveColumn: function(table, index, nextIndex) {
3224 forEach(table.rows, function(row) {
3225 var startCell = $(row.cells[index]);
3226 var finishCell = $(row.cells[nextIndex]);
3227
3228 // startCell.animate({
3229 // left: finishCell.offset().left,
3230 // }, 'slow', function() {
3231 if (nextIndex > index) {
3232 startCell.before(finishCell);
3233 } else {
3234 startCell.after(finishCell);
3235 }
3236 // });
3237 });
3238 },
3239
3240 // clone an element, copying its style and class.
3241 fullCopy: function(elt, deep) {
3242 if (!elt) {
3243 return null;
3244 }
3245 var new_elt = elt.cloneNode(deep);
3246 new_elt.className = elt.className;
3247 $(new_elt).addClass('clone');
3248 forEach(elt.style, function(value, key, object) {
3249 if (value == null) return;
3250 if (typeof(value) == "string" && value.length == 0) return;
3251
3252 new_elt.style[key] = elt.style[key];
3253 });
3254 return new_elt;
3255 },
3256
3257 getColumn: function(table, index) {
3258 index = typeof index !== 'undefined' ? index : 0;
3259
3260 if (index < 0 || index >= table.rows[0].cells.length) {
3261 return [];
3262
3263 } else {
3264 var column = [];
3265 forEach(table.rows, function(row) {
3266 column.push(row.cells[index]);
3267 });
3268 return column;
3269 }
3270 },
3271
3272 isSuitableColumnToSwap: function(targetIndex, movingColIndex) {
3273 if (targetIndex != -1) {
3274 if (typeof movingColIndex === 'undefined' || targetIndex != movingColIndex) { // check if equals the moving one
3275 var top_cell = $(DT.getColumn(DT.dragObj.table, targetIndex)[0]);
3276 if (top_cell.find('.' + classes.handle).addBack('.' + classes.handle).exists()) {
3277 return true;
3278 }
3279 }
3280 }
3281 return false;
3282 },
3283
3284 // Which column does the x value fall inside of? x should include scrollLeft.
3285 getColumnAtPosition: function(table, x) {
3286 var header = table.tHead.rows[0].cells;
3287 for (var i = 0; i < header.length; i++) {
3288 //var left = header[i].offsetLeft;
3289 var pos = DT.getPositionOnThePage(header[i]);
3290 //if (left <= x && x <= left + header[i].offsetWidth) {
3291 var px = pos.x;
3292 var ow = header[i].offsetWidth;
3293 var xpow = pos.x + header[i].offsetWidth;
3294 if (pos.x <= x && x <= pos.x + header[i].offsetWidth) {
3295 return i;
3296 }
3297 }
3298 return -1;
3299 },
3300
3301 // Store a column swap in a cookie for posterity.
3302 storeDrag: function(table) {
3303 var order = [];
3304 forEach(table.rows[0].cells, function(cell) {
3305 var pos = cell.getAttribute('position');
3306 if (pos)
3307 order.push(pos);
3308 });
3309
3310 var order_string = order[0];
3311 for (var i = 1; i < order.length; i++)
3312 order_string += ' ' + order[i];
3313
3314 DT.storeInCookies(order_string);
3315 DT.sendOrderToServer(order_string);
3316 },
3317
3318 storeInCookies: function(string) {
3319 if (navigator.cookieEnabled) {
3320 var cookieName = 'order';
3321 createCookie(cookieName, string, DT.cookieDays);
3322 }
3323 },
3324
3325 sendOrderToServer: function(string) {
3326 if (document.reportId) {
3327 $.ajax({
3328 type: 'GET',
3329 url: '/reorder-report-columns',
3330 dataType: 'json',
3331 data: {
3332 reportId: document.reportId,
3333 order: string,
3334 },
3335 });
3336 }
3337 },
3338 };
3339
3340 var DT = dragTable;
3341
3342 /* ******************************************************************
3343 Supporting functions: bundled here to avoid depending on a library
3344 ****************************************************************** */
3345
3346
3347 //// Dean Edwards/Matthias Miller/John Resig
3348 //// has a hook for DT.init already been added? (see below)
3349 //var dgListenOnLoad = false;
3350 //
3351 ///* for Mozilla/Opera9 */
3352 //if (document.addEventListener) {
3353 // dgListenOnLoad = true;
3354 // document.addEventListener("DOMContentLoaded", DT.init, false);
3355 //}
3356 //
3357 ///* for Internet Explorer */
3358 ///*@cc_on @*/
3359 ///*@if (@_win32)
3360 // dgListenOnLoad = true;
3361 // document.write("<script id=__dt_onload defer src=//0)><\/script>");
3362 // var script = document.getElementById("__dt_onload");
3363 // script.onreadystatechange = function() {
3364 // if (this.readyState == "complete") {
3365 // DT.init(); // call the onload handler
3366 // }
3367 // };
3368 ///*@end @*/
3369 //
3370 ///* for Safari */
3371 //if (/WebKit/i.test(navigator.userAgent)) { // sniff
3372 // dgListenOnLoad = true;
3373 // var _dgtimer = setInterval(function() {
3374 // if (/loaded|complete/.test(document.readyState)) {
3375 // DT.init(); // call the onload handler
3376 // }
3377 // }, 10);
3378 //}
3379 //
3380 ///* for other browsers */
3381 ///* Avoid this unless it's absolutely necessary (it breaks sorttable) */
3382 //if (!dgListenOnLoad) {
3383 // window.onload = DT.init;
3384 //}
3385
3386 </script>
3387
3388 <script type="text/javascript">
3389 /*! HTML5 Shiv vpre3.6 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed
3390 Uncompressed source: https://github.com/aFarkas/html5shiv */
3391 (function(a,b){function h(a,b){var c=a.createElement("p"),d=a.getElementsByTagName("head")[0]||a.documentElement;return c.innerHTML="x<style>"+b+"</style>",d.insertBefore(c.lastChild,d.firstChild)}function i(){var a=l.elements;return typeof a=="string"?a.split(" "):a}function j(a){var b={},c=a.createElement,f=a.createDocumentFragment,g=f();a.createElement=function(a){if(!l.shivMethods)return c(a);var f;return b[a]?f=b[a].cloneNode():e.test(a)?f=(b[a]=c(a)).cloneNode():f=c(a),f.canHaveChildren&&!d.test(a)?g.appendChild(f):f},a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+i().join().replace(/\w+/g,function(a){return c(a),g.createElement(a),'c("'+a+'")'})+");return n}")(l,g)}function k(a){var b;return a.documentShived?a:(l.shivCSS&&!f&&(b=!!h(a,"article,aside,details,figcaption,figure,footer,header,hgroup,nav,section{display:block}audio{display:none}canvas,video{display:inline-block;*display:inline;*zoom:1}[hidden]{display:none}audio[controls]{display:inline-block;*display:inline;*zoom:1}mark{background:#FF0;color:#000}")),g||(b=!j(a)),b&&(a.documentShived=b),a)}var c=a.html5||{},d=/^<|^(?:button|form|map|select|textarea|object|iframe|option|optgroup)$/i,e=/^<|^(?:a|b|button|code|div|fieldset|form|h1|h2|h3|h4|h5|h6|i|iframe|img|input|label|li|link|ol|option|p|param|q|script|select|span|strong|style|table|tbody|td|textarea|tfoot|th|thead|tr|ul)$/i,f,g;(function(){var c=b.createElement("a");c.innerHTML="<xyz></xyz>",f="hidden"in c,f&&typeof injectElementWithStyles=="function"&&injectElementWithStyles("#modernizr{}",function(b){b.hidden=!0,f=(a.getComputedStyle?getComputedStyle(b,null):b.currentStyle).display=="none"}),g=c.childNodes.length==1||function(){try{b.createElement("a")}catch(a){return!0}var c=b.createDocumentFragment();return typeof c.cloneNode=="undefined"||typeof c.createDocumentFragment=="undefined"||typeof c.createElement=="undefined"}()})();var l={elements:c.elements||"abbr article aside audio bdi canvas data datalist details figcaption figure footer header hgroup mark meter nav output progress section summary time video",shivCSS:c.shivCSS!==!1,shivMethods:c.shivMethods!==!1,type:"default",shivDocument:k};a.html5=l,k(b)})(this,document)
3392 </script>
3393
3394 <script type="text/javascript">
3395 /**
3396 * Bootstrap.js by @fat & @mdo
3397 * plugins: bootstrap-tooltip.js
3398 * Copyright 2012 Twitter, Inc.
3399 * http://www.apache.org/licenses/LICENSE-2.0.txt
3400 */
3401 !function(a){var b=function(a,b){this.init("tooltip",a,b)};b.prototype={constructor:b,init:function(b,c,d){var e,f;this.type=b,this.$element=a(c),this.options=this.getOptions(d),this.enabled=!0,this.options.trigger!="manual"&&(e=this.options.trigger=="hover"?"mouseenter":"focus",f=this.options.trigger=="hover"?"mouseleave":"blur",this.$element.on(e,this.options.selector,a.proxy(this.enter,this)),this.$element.on(f,this.options.selector,a.proxy(this.leave,this))),this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},getOptions:function(b){return b=a.extend({},a.fn[this.type].defaults,b,this.$element.data()),b.delay&&typeof b.delay=="number"&&(b.delay={show:b.delay,hide:b.delay}),b},enter:function(b){var c=a(b.currentTarget)[this.type](this._options).data(this.type);if(!c.options.delay||!c.options.delay.show)return c.show();clearTimeout(this.timeout),c.hoverState="in",this.timeout=setTimeout(function(){c.hoverState=="in"&&c.show()},c.options.delay.show)},leave:function(b){var c=a(b.currentTarget)[this.type](this._options).data(this.type);this.timeout&&clearTimeout(this.timeout);if(!c.options.delay||!c.options.delay.hide)return c.hide();c.hoverState="out",this.timeout=setTimeout(function(){c.hoverState=="out"&&c.hide()},c.options.delay.hide)},show:function(){var a,b,c,d,e,f,g;if(this.hasContent()&&this.enabled){a=this.tip(),this.setContent(),this.options.animation&&a.addClass("fade"),f=typeof this.options.placement=="function"?this.options.placement.call(this,a[0],this.$element[0]):this.options.placement,b=/in/.test(f),a.remove().css({top:0,left:0,display:"block"}).appendTo(b?this.$element:document.body),c=this.getPosition(b),d=a[0].offsetWidth,e=a[0].offsetHeight;switch(b?f.split(" ")[1]:f){case"bottom":g={top:c.top+c.height,left:c.left+c.width/2-d/2};break;case"top":g={top:c.top-e+4,left:c.left+c.width/2-d/2};break;case"left":g={top:c.top+c.height/2-e/2,left:c.left-d};break;case"right":g={top:c.top+c.height/2-e/2,left:c.left+c.width}}a.css(g).addClass(f).addClass("in")}},isHTML:function(a){return typeof a!="string"||a.charAt(0)==="<"&&a.charAt(a.length-1)===">"&&a.length>=3||/^(?:[^<]*<[\w\W]+>[^>]*$)/.exec(a)},setContent:function(){var a=this.tip(),b=this.getTitle();a.find(".tooltip-inner")[this.isHTML(b)?"html":"text"](b),a.removeClass("fade in top bottom left right")},hide:function(){function d(){var b=setTimeout(function(){c.off(a.support.transition.end).remove()},500);c.one(a.support.transition.end,function(){clearTimeout(b),c.remove()})}var b=this,c=this.tip();c.removeClass("in"),a.support.transition&&this.$tip.hasClass("fade")?d():c.remove()},fixTitle:function(){var a=this.$element;(a.attr("title")||typeof a.attr("data-original-title")!="string")&&a.attr("data-original-title",a.attr("title")||"").removeAttr("title")},hasContent:function(){return this.getTitle()},getPosition:function(b){return a.extend({},b?{top:0,left:0}:this.$element.offset(),{width:this.$element[0].offsetWidth,height:this.$element[0].offsetHeight})},getTitle:function(){var a,b=this.$element,c=this.options;return a=b.attr("data-original-title")||(typeof c.title=="function"?c.title.call(b[0]):c.title),a},tip:function(){return this.$tip=this.$tip||a(this.options.template)},validate:function(){this.$element[0].parentNode||(this.hide(),this.$element=null,this.options=null)},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},toggleEnabled:function(){this.enabled=!this.enabled},toggle:function(){this[this.tip().hasClass("in")?"hide":"show"]()}},a.fn.tooltip=function(c){return this.each(function(){var d=a(this),e=d.data("tooltip"),f=typeof c=="object"&&c;e||d.data("tooltip",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.tooltip.Constructor=b,a.fn.tooltip.defaults={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover",title:"",delay:0}}(window.jQuery)
3402 </script>
3403
3404 <script type="text/javascript">
3405 /*!
3406 * Bootstrap.js by @fat & @mdo
3407 * Copyright 2012 Twitter, Inc.
3408 * http://www.apache.org/licenses/LICENSE-2.0.txt
3409 */
3410 !function(a){a(function(){"use strict",a.support.transition=function(){var a=function(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd",msTransition:"MSTransitionEnd",transition:"transitionend"},c;for(c in b)if(a.style[c]!==undefined)return b[c]}();return a&&{end:a}}()})}(window.jQuery),!function(a){"use strict";var b='[data-dismiss="alert"]',c=function(c){a(c).on("click",b,this.close)};c.prototype.close=function(b){function f(){e.trigger("closed").remove()}var c=a(this),d=c.attr("data-target"),e;d||(d=c.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,"")),e=a(d),b&&b.preventDefault(),e.length||(e=c.hasClass("alert")?c:c.parent()),e.trigger(b=a.Event("close"));if(b.isDefaultPrevented())return;e.removeClass("in"),a.support.transition&&e.hasClass("fade")?e.on(a.support.transition.end,f):f()},a.fn.alert=function(b){return this.each(function(){var d=a(this),e=d.data("alert");e||d.data("alert",e=new c(this)),typeof b=="string"&&e[b].call(d)})},a.fn.alert.Constructor=c,a(function(){a("body").on("click.alert.data-api",b,c.prototype.close)})}(window.jQuery),!function(a){"use strict";var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.button.defaults,c)};b.prototype.setState=function(a){var b="disabled",c=this.$element,d=c.data(),e=c.is("input")?"val":"html";a+="Text",d.resetText||c.data("resetText",c[e]()),c[e](d[a]||this.options[a]),setTimeout(function(){a=="loadingText"?c.addClass(b).attr(b,b):c.removeClass(b).removeAttr(b)},0)},b.prototype.toggle=function(){var a=this.$element.parent('[data-toggle="buttons-radio"]');a&&a.find(".active").removeClass("active"),this.$element.toggleClass("active")},a.fn.button=function(c){return this.each(function(){var d=a(this),e=d.data("button"),f=typeof c=="object"&&c;e||d.data("button",e=new b(this,f)),c=="toggle"?e.toggle():c&&e.setState(c)})},a.fn.button.defaults={loadingText:"loading..."},a.fn.button.Constructor=b,a(function(){a("body").on("click.button.data-api","[data-toggle^=button]",function(b){var c=a(b.target);c.hasClass("btn")||(c=c.closest(".btn")),c.button("toggle")})})}(window.jQuery),!function(a){"use strict";var b=function(b,c){this.$element=a(b),this.options=c,this.options.slide&&this.slide(this.options.slide),this.options.pause=="hover"&&this.$element.on("mouseenter",a.proxy(this.pause,this)).on("mouseleave",a.proxy(this.cycle,this))};b.prototype={cycle:function(b){return b||(this.paused=!1),this.options.interval&&!this.paused&&(this.interval=setInterval(a.proxy(this.next,this),this.options.interval)),this},to:function(b){var c=this.$element.find(".active"),d=c.parent().children(),e=d.index(c),f=this;if(b>d.length-1||b<0)return;return this.sliding?this.$element.one("slid",function(){f.to(b)}):e==b?this.pause().cycle():this.slide(b>e?"next":"prev",a(d[b]))},pause:function(a){return a||(this.paused=!0),clearInterval(this.interval),this.interval=null,this},next:function(){if(this.sliding)return;return this.slide("next")},prev:function(){if(this.sliding)return;return this.slide("prev")},slide:function(b,c){var d=this.$element.find(".active"),e=c||d[b](),f=this.interval,g=b=="next"?"left":"right",h=b=="next"?"first":"last",i=this,j=a.Event("slide");this.sliding=!0,f&&this.pause(),e=e.length?e:this.$element.find(".item")[h]();if(e.hasClass("active"))return;if(a.support.transition&&this.$element.hasClass("slide")){this.$element.trigger(j);if(j.isDefaultPrevented())return;e.addClass(b),e[0].offsetWidth,d.addClass(g),e.addClass(g),this.$element.one(a.support.transition.end,function(){e.removeClass([b,g].join(" ")).addClass("active"),d.removeClass(["active",g].join(" ")),i.sliding=!1,setTimeout(function(){i.$element.trigger("slid")},0)})}else{this.$element.trigger(j);if(j.isDefaultPrevented())return;d.removeClass("active"),e.addClass("active"),this.sliding=!1,this.$element.trigger("slid")}return f&&this.cycle(),this}},a.fn.carousel=function(c){return this.each(function(){var d=a(this),e=d.data("carousel"),f=a.extend({},a.fn.carousel.defaults,typeof c=="object"&&c);e||d.data("carousel",e=new b(this,f)),typeof c=="number"?e.to(c):typeof c=="string"||(c=f.slide)?e[c]():f.interval&&e.cycle()})},a.fn.carousel.defaults={interval:5e3,pause:"hover"},a.fn.carousel.Constructor=b,a(function(){a("body").on("click.carousel.data-api","[data-slide]",function(b){var c=a(this),d,e=a(c.attr("data-target")||(d=c.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,"")),f=!e.data("modal")&&a.extend({},e.data(),c.data());e.carousel(f),b.preventDefault()})})}(window.jQuery),!function(a){"use strict";var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.collapse.defaults,c),this.options.parent&&(this.$parent=a(this.options.parent)),this.options.toggle&&this.toggle()};b.prototype={constructor:b,dimension:function(){var a=this.$element.hasClass("width");return a?"width":"height"},show:function(){var b,c,d,e;if(this.transitioning)return;b=this.dimension(),c=a.camelCase(["scroll",b].join("-")),d=this.$parent&&this.$parent.find("> .accordion-group > .in");if(d&&d.length){e=d.data("collapse");if(e&&e.transitioning)return;d.collapse("hide"),e||d.data("collapse",null)}this.$element[b](0),this.transition("addClass",a.Event("show"),"shown"),this.$element[b](this.$element[0][c])},hide:function(){var b;if(this.transitioning)return;b=this.dimension(),this.reset(this.$element[b]()),this.transition("removeClass",a.Event("hide"),"hidden"),this.$element[b](0)},reset:function(a){var b=this.dimension();return this.$element.removeClass("collapse")[b](a||"auto")[0].offsetWidth,this.$element[a!==null?"addClass":"removeClass"]("collapse"),this},transition:function(b,c,d){var e=this,f=function(){c.type=="show"&&e.reset(),e.transitioning=0,e.$element.trigger(d)};this.$element.trigger(c);if(c.isDefaultPrevented())return;this.transitioning=1,this.$element[b]("in"),a.support.transition&&this.$element.hasClass("collapse")?this.$element.one(a.support.transition.end,f):f()},toggle:function(){this[this.$element.hasClass("in")?"hide":"show"]()}},a.fn.collapse=function(c){return this.each(function(){var d=a(this),e=d.data("collapse"),f=typeof c=="object"&&c;e||d.data("collapse",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.collapse.defaults={toggle:!0},a.fn.collapse.Constructor=b,a(function(){a("body").on("click.collapse.data-api","[data-toggle=collapse]",function(b){var c=a(this),d,e=c.attr("data-target")||b.preventDefault()||(d=c.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,""),f=a(e).data("collapse")?"toggle":c.data();a(e).collapse(f)})})}(window.jQuery),!function(a){function d(){a(b).parent().removeClass("open")}"use strict";var b='[data-toggle="dropdown"]',c=function(b){var c=a(b).on("click.dropdown.data-api",this.toggle);a("html").on("click.dropdown.data-api",function(){c.parent().removeClass("open")})};c.prototype={constructor:c,toggle:function(b){var c=a(this),e,f,g;if(c.is(".disabled, :disabled"))return;return f=c.attr("data-target"),f||(f=c.attr("href"),f=f&&f.replace(/.*(?=#[^\s]*$)/,"")),e=a(f),e.length||(e=c.parent()),g=e.hasClass("open"),d(),g||e.toggleClass("open"),!1}},a.fn.dropdown=function(b){return this.each(function(){var d=a(this),e=d.data("dropdown");e||d.data("dropdown",e=new c(this)),typeof b=="string"&&e[b].call(d)})},a.fn.dropdown.Constructor=c,a(function(){a("html").on("click.dropdown.data-api",d),a("body").on("click.dropdown",".dropdown form",function(a){a.stopPropagation()}).on("click.dropdown.data-api",b,c.prototype.toggle)})}(window.jQuery),!function(a){function c(){var b=this,c=setTimeout(function(){b.$element.off(a.support.transition.end),d.call(b)},500);this.$element.one(a.support.transition.end,function(){clearTimeout(c),d.call(b)})}function d(a){this.$element.hide().trigger("hidden"),e.call(this)}function e(b){var c=this,d=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var e=a.support.transition&&d;this.$backdrop=a('<div class="modal-backdrop '+d+'" />').appendTo(document.body),this.options.backdrop!="static"&&this.$backdrop.click(a.proxy(this.hide,this)),e&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in"),e?this.$backdrop.one(a.support.transition.end,b):b()}else!this.isShown&&this.$backdrop?(this.$backdrop.removeClass("in"),a.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one(a.support.transition.end,a.proxy(f,this)):f.call(this)):b&&b()}function f(){this.$backdrop.remove(),this.$backdrop=null}function g(){var b=this;this.isShown&&this.options.keyboard?a(document).on("keyup.dismiss.modal",function(a){a.which==27&&b.hide()}):this.isShown||a(document).off("keyup.dismiss.modal")}"use strict";var b=function(b,c){this.options=c,this.$element=a(b).delegate('[data-dismiss="modal"]',"click.dismiss.modal",a.proxy(this.hide,this))};b.prototype={constructor:b,toggle:function(){return this[this.isShown?"hide":"show"]()},show:function(){var b=this,c=a.Event("show");this.$element.trigger(c);if(this.isShown||c.isDefaultPrevented())return;a("body").addClass("modal-open"),this.isShown=!0,g.call(this),e.call(this,function(){var c=a.support.transition&&b.$element.hasClass("fade");b.$element.parent().length||b.$element.appendTo(document.body),b.$element.show(),c&&b.$element[0].offsetWidth,b.$element.addClass("in"),c?b.$element.one(a.support.transition.end,function(){b.$element.trigger("shown")}):b.$element.trigger("shown")})},hide:function(b){b&&b.preventDefault();var e=this;b=a.Event("hide"),this.$element.trigger(b);if(!this.isShown||b.isDefaultPrevented())return;this.isShown=!1,a("body").removeClass("modal-open"),g.call(this),this.$element.removeClass("in"),a.support.transition&&this.$element.hasClass("fade")?c.call(this):d.call(this)}},a.fn.modal=function(c){return this.each(function(){var d=a(this),e=d.data("modal"),f=a.extend({},a.fn.modal.defaults,d.data(),typeof c=="object"&&c);e||d.data("modal",e=new b(this,f)),typeof c=="string"?e[c]():f.show&&e.show()})},a.fn.modal.defaults={backdrop:!0,keyboard:!0,show:!0},a.fn.modal.Constructor=b,a(function(){a("body").on("click.modal.data-api",'[data-toggle="modal"]',function(b){var c=a(this),d,e=a(c.attr("data-target")||(d=c.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,"")),f=e.data("modal")?"toggle":a.extend({},e.data(),c.data());b.preventDefault(),e.modal(f)})})}(window.jQuery),!function(a){"use strict";var b=function(a,b){this.init("tooltip",a,b)};b.prototype={constructor:b,init:function(b,c,d){var e,f;this.type=b,this.$element=a(c),this.options=this.getOptions(d),this.enabled=!0,this.options.trigger!="manual"&&(e=this.options.trigger=="hover"?"mouseenter":"focus",f=this.options.trigger=="hover"?"mouseleave":"blur",this.$element.on(e,this.options.selector,a.proxy(this.enter,this)),this.$element.on(f,this.options.selector,a.proxy(this.leave,this))),this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},getOptions:function(b){return b=a.extend({},a.fn[this.type].defaults,b,this.$element.data()),b.delay&&typeof b.delay=="number"&&(b.delay={show:b.delay,hide:b.delay}),b},enter:function(b){var c=a(b.currentTarget)[this.type](this._options).data(this.type);if(!c.options.delay||!c.options.delay.show)return c.show();clearTimeout(this.timeout),c.hoverState="in",this.timeout=setTimeout(function(){c.hoverState=="in"&&c.show()},c.options.delay.show)},leave:function(b){var c=a(b.currentTarget)[this.type](this._options).data(this.type);this.timeout&&clearTimeout(this.timeout);if(!c.options.delay||!c.options.delay.hide)return c.hide();c.hoverState="out",this.timeout=setTimeout(function(){c.hoverState=="out"&&c.hide()},c.options.delay.hide)},show:function(){var a,b,c,d,e,f,g;if(this.hasContent()&&this.enabled){a=this.tip(),this.setContent(),this.options.animation&&a.addClass("fade"),f=typeof this.options.placement=="function"?this.options.placement.call(this,a[0],this.$element[0]):this.options.placement,b=/in/.test(f),a.remove().css({top:0,left:0,display:"block"}).appendTo(b?this.$element:document.body),c=this.getPosition(b),d=a[0].offsetWidth,e=a[0].offsetHeight;switch(b?f.split(" ")[1]:f){case"bottom":g={top:c.top+c.height,left:c.left+c.width/2-d/2};break;case"top":g={top:c.top-e,left:c.left+c.width/2-d/2};break;case"left":g={top:c.top+c.height/2-e/2,left:c.left-d};break;case"right":g={top:c.top+c.height/2-e/2,left:c.left+c.width}}a.css(g).addClass(f).addClass("in")}},isHTML:function(a){return typeof a!="string"||a.charAt(0)==="<"&&a.charAt(a.length-1)===">"&&a.length>=3||/^(?:[^<]*<[\w\W]+>[^>]*$)/.exec(a)},setContent:function(){var a=this.tip(),b=this.getTitle();a.find(".tooltip-inner")[this.isHTML(b)?"html":"text"](b),a.removeClass("fade in top bottom left right")},hide:function(){function d(){var b=setTimeout(function(){c.off(a.support.transition.end).remove()},500);c.one(a.support.transition.end,function(){clearTimeout(b),c.remove()})}var b=this,c=this.tip();c.removeClass("in"),a.support.transition&&this.$tip.hasClass("fade")?d():c.remove()},fixTitle:function(){var a=this.$element;(a.attr("title")||typeof a.attr("data-original-title")!="string")&&a.attr("data-original-title",a.attr("title")||"").removeAttr("title")},hasContent:function(){return this.getTitle()},getPosition:function(b){return a.extend({},b?{top:0,left:0}:this.$element.offset(),{width:this.$element[0].offsetWidth,height:this.$element[0].offsetHeight})},getTitle:function(){var a,b=this.$element,c=this.options;return a=b.attr("data-original-title")||(typeof c.title=="function"?c.title.call(b[0]):c.title),a},tip:function(){return this.$tip=this.$tip||a(this.options.template)},validate:function(){this.$element[0].parentNode||(this.hide(),this.$element=null,this.options=null)},enable:function(){this.enabled=!0},disable:function(){this.enabled=!1},toggleEnabled:function(){this.enabled=!this.enabled},toggle:function(){this[this.tip().hasClass("in")?"hide":"show"]()}},a.fn.tooltip=function(c){return this.each(function(){var d=a(this),e=d.data("tooltip"),f=typeof c=="object"&&c;e||d.data("tooltip",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.tooltip.Constructor=b,a.fn.tooltip.defaults={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover",title:"",delay:0}}(window.jQuery),!function(a){"use strict";var b=function(a,b){this.init("popover",a,b)};b.prototype=a.extend({},a.fn.tooltip.Constructor.prototype,{constructor:b,setContent:function(){var a=this.tip(),b=this.getTitle(),c=this.getContent();a.find(".popover-title")[this.isHTML(b)?"html":"text"](b),a.find(".popover-content > *")[this.isHTML(c)?"html":"text"](c),a.removeClass("fade top bottom left right in")},hasContent:function(){return this.getTitle()||this.getContent()},getContent:function(){var a,b=this.$element,c=this.options;return a=b.attr("data-content")||(typeof c.content=="function"?c.content.call(b[0]):c.content),a},tip:function(){return this.$tip||(this.$tip=a(this.options.template)),this.$tip}}),a.fn.popover=function(c){return this.each(function(){var d=a(this),e=d.data("popover"),f=typeof c=="object"&&c;e||d.data("popover",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.popover.Constructor=b,a.fn.popover.defaults=a.extend({},a.fn.tooltip.defaults,{placement:"right",content:"",template:'<div class="popover"><div class="arrow"></div><div class="popover-inner"><h3 class="popover-title"></h3><div class="popover-content"><p></p></div></div></div>'})}(window.jQuery),!function(a){function b(b,c){var d=a.proxy(this.process,this),e=a(b).is("body")?a(window):a(b),f;this.options=a.extend({},a.fn.scrollspy.defaults,c),this.$scrollElement=e.on("scroll.scroll.data-api",d),this.selector=(this.options.target||(f=a(b).attr("href"))&&f.replace(/.*(?=#[^\s]+$)/,"")||"")+" .nav li > a",this.$body=a("body"),this.refresh(),this.process()}"use strict",b.prototype={constructor:b,refresh:function(){var b=this,c;this.offsets=a([]),this.targets=a([]),c=this.$body.find(this.selector).map(function(){var b=a(this),c=b.data("target")||b.attr("href"),d=/^#\w/.test(c)&&a(c);return d&&c.length&&[[d.position().top,c]]||null}).sort(function(a,b){return a[0]-b[0]}).each(function(){b.offsets.push(this[0]),b.targets.push(this[1])})},process:function(){var a=this.$scrollElement.scrollTop()+this.options.offset,b=this.$scrollElement[0].scrollHeight||this.$body[0].scrollHeight,c=b-this.$scrollElement.height(),d=this.offsets,e=this.targets,f=this.activeTarget,g;if(a>=c)return f!=(g=e.last()[0])&&this.activate(g);for(g=d.length;g--;)f!=e[g]&&a>=d[g]&&(!d[g+1]||a<=d[g+1])&&this.activate(e[g])},activate:function(b){var c,d;this.activeTarget=b,a(this.selector).parent(".active").removeClass("active"),d=this.selector+'[data-target="'+b+'"],'+this.selector+'[href="'+b+'"]',c=a(d).parent("li").addClass("active"),c.parent(".dropdown-menu")&&(c=c.closest("li.dropdown").addClass("active")),c.trigger("activate")}},a.fn.scrollspy=function(c){return this.each(function(){var d=a(this),e=d.data("scrollspy"),f=typeof c=="object"&&c;e||d.data("scrollspy",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.scrollspy.Constructor=b,a.fn.scrollspy.defaults={offset:10},a(function(){a('[data-spy="scroll"]').each(function(){var b=a(this);b.scrollspy(b.data())})})}(window.jQuery),!function(a){"use strict";var b=function(b){this.element=a(b)};b.prototype={constructor:b,show:function(){var b=this.element,c=b.closest("ul:not(.dropdown-menu)"),d=b.attr("data-target"),e,f,g;d||(d=b.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,""));if(b.parent("li").hasClass("active"))return;e=c.find(".active a").last()[0],g=a.Event("show",{relatedTarget:e}),b.trigger(g);if(g.isDefaultPrevented())return;f=a(d),this.activate(b.parent("li"),c),this.activate(f,f.parent(),function(){b.trigger({type:"shown",relatedTarget:e})})},activate:function(b,c,d){function g(){e.removeClass("active").find("> .dropdown-menu > .active").removeClass("active"),b.addClass("active"),f?(b[0].offsetWidth,b.addClass("in")):b.removeClass("fade"),b.parent(".dropdown-menu")&&b.closest("li.dropdown").addClass("active"),d&&d()}var e=c.find("> .active"),f=d&&a.support.transition&&e.hasClass("fade");f?e.one(a.support.transition.end,g):g(),e.removeClass("in")}},a.fn.tab=function(c){return this.each(function(){var d=a(this),e=d.data("tab");e||d.data("tab",e=new b(this)),typeof c=="string"&&e[c]()})},a.fn.tab.Constructor=b,a(function(){a("body").on("click.tab.data-api",'[data-toggle="tab"], [data-toggle="pill"]',function(b){b.preventDefault(),a(this).tab("show")})})}(window.jQuery),!function(a){"use strict";var b=function(b,c){this.$element=a(b),this.options=a.extend({},a.fn.typeahead.defaults,c),this.matcher=this.options.matcher||this.matcher,this.sorter=this.options.sorter||this.sorter,this.highlighter=this.options.highlighter||this.highlighter,this.updater=this.options.updater||this.updater,this.$menu=a(this.options.menu).appendTo("body"),this.source=this.options.source,this.shown=!1,this.listen()};b.prototype={constructor:b,select:function(){var a=this.$menu.find(".active").attr("data-value");return this.$element.val(this.updater(a)).change(),this.hide()},updater:function(a){return a},show:function(){var b=a.extend({},this.$element.offset(),{height:this.$element[0].offsetHeight});return this.$menu.css({top:b.top+b.height,left:b.left}),this.$menu.show(),this.shown=!0,this},hide:function(){return this.$menu.hide(),this.shown=!1,this},lookup:function(b){var c=this,d,e;return this.query=this.$element.val(),this.query?(d=a.grep(this.source,function(a){return c.matcher(a)}),d=this.sorter(d),d.length?this.render(d.slice(0,this.options.items)).show():this.shown?this.hide():this):this.shown?this.hide():this},matcher:function(a){return~a.toLowerCase().indexOf(this.query.toLowerCase())},sorter:function(a){var b=[],c=[],d=[],e;while(e=a.shift())e.toLowerCase().indexOf(this.query.toLowerCase())?~e.indexOf(this.query)?c.push(e):d.push(e):b.push(e);return b.concat(c,d)},highlighter:function(a){var b=this.query.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g,"\\$&");return a.replace(new RegExp("("+b+")","ig"),function(a,b){return"<strong>"+b+"</strong>"})},render:function(b){var c=this;return b=a(b).map(function(b,d){return b=a(c.options.item).attr("data-value",d),b.find("a").html(c.highlighter(d)),b[0]}),b.first().addClass("active"),this.$menu.html(b),this},next:function(b){var c=this.$menu.find(".active").removeClass("active"),d=c.next();d.length||(d=a(this.$menu.find("li")[0])),d.addClass("active")},prev:function(a){var b=this.$menu.find(".active").removeClass("active"),c=b.prev();c.length||(c=this.$menu.find("li").last()),c.addClass("active")},listen:function(){this.$element.on("blur",a.proxy(this.blur,this)).on("keypress",a.proxy(this.keypress,this)).on("keyup",a.proxy(this.keyup,this)),(a.browser.webkit||a.browser.msie)&&this.$element.on("keydown",a.proxy(this.keypress,this)),this.$menu.on("click",a.proxy(this.click,this)).on("mouseenter","li",a.proxy(this.mouseenter,this))},keyup:function(a){switch(a.keyCode){case 40:case 38:break;case 9:case 13:if(!this.shown)return;this.select();break;case 27:if(!this.shown)return;this.hide();break;default:this.lookup()}a.stopPropagation(),a.preventDefault()},keypress:function(a){if(!this.shown)return;switch(a.keyCode){case 9:case 13:case 27:a.preventDefault();break;case 38:if(a.type!="keydown")break;a.preventDefault(),this.prev();break;case 40:if(a.type!="keydown")break;a.preventDefault(),this.next()}a.stopPropagation()},blur:function(a){var b=this;setTimeout(function(){b.hide()},150)},click:function(a){a.stopPropagation(),a.preventDefault(),this.select()},mouseenter:function(b){this.$menu.find(".active").removeClass("active"),a(b.currentTarget).addClass("active")}},a.fn.typeahead=function(c){return this.each(function(){var d=a(this),e=d.data("typeahead"),f=typeof c=="object"&&c;e||d.data("typeahead",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.typeahead.defaults={source:[],items:8,menu:'<ul class="typeahead dropdown-menu"></ul>',item:'<li><a href="#"></a></li>'},a.fn.typeahead.Constructor=b,a(function(){a("body").on("focus.typeahead.data-api",'[data-provide="typeahead"]',function(b){var c=a(this);if(c.data("typeahead"))return;b.preventDefault(),c.typeahead(c.data())})})}(window.jQuery);
3411 </script>
3412
3413 <script type="text/javascript">
3414 /* ===========================================================
3415 * bootstrap-tooltip.js v2.0.4
3416 * http://twitter.github.com/bootstrap/javascript.html#tooltips
3417 * Inspired by the original jQuery.tipsy by Jason Frame
3418 * ===========================================================
3419 * Copyright 2012 Twitter, Inc.
3420 *
3421 * Licensed under the Apache License, Version 2.0 (the "License");
3422 * you may not use this file except in compliance with the License.
3423 * You may obtain a copy of the License at
3424 *
3425 * http://www.apache.org/licenses/LICENSE-2.0
3426 *
3427 * Unless required by applicable law or agreed to in writing, software
3428 * distributed under the License is distributed on an "AS IS" BASIS,
3429 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
3430 * See the License for the specific language governing permissions and
3431 * limitations under the License.
3432 * ========================================================== */
3433
3434
3435 !function ($) {
3436
3437 "use strict"; // jshint ;_;
3438
3439
3440 /* TOOLTIP PUBLIC CLASS DEFINITION
3441 * =============================== */
3442
3443 var Tooltip = function (element, options) {
3444 this.init('tooltip', element, options)
3445 };
3446
3447 Tooltip.prototype = {
3448
3449 constructor: Tooltip
3450
3451 , init: function (type, element, options) {
3452 var eventIn
3453 , eventOut;
3454
3455 this.type = type;
3456 this.$element = $(element);
3457 this.options = this.getOptions(options);
3458 this.enabled = true;
3459
3460 if (this.options.trigger != 'manual') {
3461 eventIn = this.options.trigger == 'hover' ? 'mouseenter' : 'focus';
3462 eventOut = this.options.trigger == 'hover' ? 'mouseleave' : 'blur';
3463 this.$element.on(eventIn, this.options.selector, $.proxy(this.enter, this));
3464 this.$element.on(eventOut, this.options.selector, $.proxy(this.leave, this));
3465 }
3466
3467 this.options.selector ?
3468 (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
3469 this.fixTitle();
3470 }
3471
3472 , getOptions: function (options) {
3473 options = $.extend({}, $.fn[this.type].defaults, options, this.$element.data())
3474
3475 if (options.delay && typeof options.delay == 'number') {
3476 options.delay = {
3477 show: options.delay
3478 , hide: options.delay
3479 };
3480 }
3481
3482 return options;
3483 }
3484
3485 , enter: function (e) {
3486 if (dragTable && dragTable.isDragging)
3487 return;
3488
3489 var self = $(e.currentTarget)[this.type](this._options).data(this.type);
3490
3491 if (!self.options.delay || !self.options.delay.show) self.show();
3492
3493 clearTimeout(this.timeout);
3494 self.hoverState = 'in';
3495 this.timeout = setTimeout(
3496 function() { if (self.hoverState == 'in') self.show(); },
3497 self.options.delay.show
3498 );
3499 }
3500
3501 , leave: function (e) {
3502 var self = $(e.currentTarget)[this.type](this._options).data(this.type);
3503
3504 if (this.timeout) clearTimeout(this.timeout);
3505 if (!self.options.delay || !self.options.delay.hide) self.hide();
3506
3507 self.hoverState = 'out';
3508 this.timeout = setTimeout(
3509 function() { if (self.hoverState == 'out') self.hide() },
3510 self.options.delay.hide
3511 );
3512 }
3513
3514 , show: function () {
3515 var $tip
3516 , inside
3517 , pos
3518 , actualWidth
3519 , actualHeight
3520 , placement
3521 , tp;
3522
3523 if (this.hasContent() && this.enabled) {
3524 $tip = this.tip();
3525 this.setContent();
3526
3527 if (this.options.animation) {
3528 $tip.addClass('fade');
3529 }
3530
3531 placement = typeof this.options.placement == 'function' ?
3532 this.options.placement.call(this, $tip[0], this.$element[0]) :
3533 this.options.placement;
3534
3535 inside = /in/.test(placement);
3536
3537 $tip
3538 .remove()
3539 .css({ top: 0, left: 0, display: 'block' })
3540 .appendTo(inside ? this.$element : document.body);
3541
3542 pos = this.getPosition(inside);
3543
3544 actualWidth = $tip[0].offsetWidth;
3545 actualHeight = $tip[0].offsetHeight;
3546
3547 switch (inside ? placement.split(' ')[1] : placement) {
3548 case 'bottom':
3549 tp = {top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2};
3550 break;
3551 case 'top': // modificated by Vlad Saveliev: +4px to top position
3552 tp = {top: pos.top - actualHeight + 4, left: pos.left + pos.width / 2 - actualWidth / 2};
3553 break;
3554 case 'left':
3555 tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth};
3556 break;
3557 case 'right':
3558 tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width};
3559 break;
3560 }
3561
3562 $tip
3563 .css(tp)
3564 .addClass(placement)
3565 .addClass('in');
3566 }
3567 }
3568
3569 , isHTML: function(text) {
3570 // html string detection logic adapted from jQuery
3571 return typeof text != 'string'
3572 || ( text.charAt(0) === "<"
3573 && text.charAt( text.length - 1 ) === ">"
3574 && text.length >= 3
3575 ) || /^(?:[^<]*<[\w\W]+>[^>]*$)/.exec(text);
3576 }
3577
3578 , setContent: function () {
3579 var $tip = this.tip()
3580 , title = this.getTitle();
3581
3582 $tip.find('.tooltip-inner')[this.isHTML(title) ? 'html' : 'text'](title);
3583 $tip.removeClass('fade in top bottom left right');
3584 }
3585
3586 , hide: function () {
3587 var that = this
3588 , $tip = this.tip();
3589
3590 $tip.removeClass('in');
3591
3592 function removeWithAnimation() {
3593 var timeout = setTimeout(function () {
3594 $tip.off($.support.transition.end).remove()
3595 }, 500);
3596
3597 $tip.one($.support.transition.end, function () {
3598 clearTimeout(timeout);
3599 $tip.remove();
3600 })
3601 }
3602
3603 $.support.transition && this.$tip.hasClass('fade') ?
3604 removeWithAnimation() :
3605 $tip.remove()
3606 }
3607
3608 , fixTitle: function () {
3609 var $e = this.$element;
3610 if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
3611 $e.attr('data-original-title', $e.attr('title') || '').removeAttr('title');
3612 }
3613 }
3614
3615 , hasContent: function () {
3616 return this.getTitle();
3617 }
3618
3619 , getPosition: function (inside) {
3620 return $.extend({}, (inside ? {top: 0, left: 0} : this.$element.offset()), {
3621 width: this.$element[0].offsetWidth
3622 , height: this.$element[0].offsetHeight
3623 })
3624 }
3625
3626 , getTitle: function () {
3627 var title
3628 , $e = this.$element
3629 , o = this.options;
3630
3631 title = $e.attr('data-original-title')
3632 || (typeof o.title == 'function' ? o.title.call($e[0]) : o.title);
3633
3634 return title;
3635 }
3636
3637 , tip: function () {
3638 return this.$tip = this.$tip || $(this.options.template);
3639 }
3640
3641 , validate: function () {
3642 if (!this.$element[0].parentNode) {
3643 this.hide();
3644 this.$element = null;
3645 this.options = null;
3646 }
3647 }
3648
3649 , enable: function () {
3650 this.enabled = true;
3651 }
3652
3653 , disable: function () {
3654 this.enabled = false;
3655 }
3656
3657 , toggleEnabled: function () {
3658 this.enabled = !this.enabled;
3659 }
3660
3661 , toggle: function () {
3662 this[this.tip().hasClass('in') ? 'hide' : 'show']();
3663 }
3664
3665 };
3666
3667
3668 /* TOOLTIP PLUGIN DEFINITION
3669 * ========================= */
3670
3671 $.fn.tooltip = function ( option ) {
3672 return this.each(function () {
3673 var $this = $(this)
3674 , data = $this.data('tooltip')
3675 , options = typeof option == 'object' && option;
3676 if (!data) $this.data('tooltip', (data = new Tooltip(this, options)));
3677 if (typeof option == 'string') data[option]();
3678 })
3679 };
3680
3681 $.fn.tooltip.Constructor = Tooltip;
3682
3683 $.fn.tooltip.defaults = {
3684 animation: true
3685 , placement: 'top'
3686 , selector: false
3687 , template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
3688 , trigger: 'hover'
3689 , title: ''
3690 , delay: 0
3691 };
3692
3693 }(window.jQuery);
3694
3695 </script>
3696
3697 <script type="text/javascript">
3698 function showPlotWithInfo(info, index) {
3699 var newSeries = [];
3700 var newColors = [];
3701 var oldSeries = info.series;
3702 var usingSeries;
3703 var sortOrder;
3704 if ($("input[name=sortRefs]")[0])
3705 sortOrder = getSortOrder();
3706 if (index != undefined) {
3707 oldSeries = info.series[index];
3708 }
3709 if (sortOrder == 'alphabet') {
3710 usingSeries = [];
3711 sortedRefs = info.references.slice(0).sort();
3712 for(var i = 0; i < oldSeries.length; i++) {
3713 usingSeries.push($.extend(true, {}, oldSeries[i]));
3714 for(var j = 0; j < info.references.length; j++) {
3715 usingSeries[i].data[j][1] = oldSeries[i].data[info.references.indexOf(sortedRefs[j])][1];
3716 }
3717 }
3718 }
3719 else usingSeries = oldSeries;
3720 $('#legend-placeholder').find('input[type="checkbox"]:checked').each(function() {
3721 var number = $(this).attr('name');
3722 if (number && usingSeries && usingSeries.length > 0) {
3723 var i = 0;
3724 do {
3725 var series = usingSeries[i];
3726 i++;
3727 } while (i <= usingSeries.length && (series == null || series.number != number));
3728 //
3729 if (i <= usingSeries.length) {
3730 newSeries.push(series);
3731 newColors.push(series.color);
3732 } else {
3733 console.log('no series with number ' + number);
3734 }
3735 }
3736 });
3737 if (sortOrder) sortReferences(sortOrder, info);
3738
3739 if (newSeries.length === 0) {
3740 newSeries.push({
3741 data: []
3742 });
3743 newColors.push('#FFF');
3744 }
3745
3746 info.showWithData(newSeries, newColors);
3747 }
3748
3749 function recoverOrderFromCookies() {
3750 if (!navigator.cookieEnabled)
3751 return null;
3752
3753 var order_string = readCookie("order");
3754 if (!order_string)
3755 return null;
3756
3757 var order = [];
3758 var fail = false;
3759 forEach(order_string.split(' '), function(val) {
3760 val = parseInt(val);
3761 if (isNaN(val))
3762 fail = true;
3763 else
3764 order.push(val);
3765 });
3766
3767 if (fail)
3768 return null;
3769
3770 return order;
3771 }
3772
3773
3774 function readJson(what) {
3775 var result;
3776 try {
3777 result = JSON.parse($('#' + what + '-json').html());
3778 } catch (e) {
3779 result = null;
3780 }
3781 return result;
3782 }
3783
3784
3785 function getToggleFunction(assembliesNames, order, name, title, drawPlot, data, refPlotValue, tickX) {
3786 return function() {
3787 this.parentNode.getElementsByClassName('selected-switch')[0].className = 'plot-switch dotted-link';
3788 this.className = 'plot-switch selected-switch';
3789 togglePlots(assembliesNames, order, name, title, drawPlot, data, refPlotValue, tickX)
3790 };
3791 }
3792
3793 function togglePlots(assembliesNames, order, name, title, drawPlot, data, refPlotValue, tickX) {
3794 var plotPlaceholder = document.getElementById('plot-placeholder');
3795 var legendPlaceholder = document.getElementById('legend-placeholder');
3796 var scalePlaceholder = document.getElementById('scale-placeholder');
3797
3798 var glossary = JSON.parse($('#glossary-json').html());
3799
3800 if (name === 'cumulative') {
3801 $(plotPlaceholder).addClass('cumulative-plot-placeholder');
3802 } else {
3803 $(plotPlaceholder).removeClass('cumulative-plot-placeholder');
3804 }
3805
3806 $('#contigs_are_ordered').hide();
3807 $('#gc_info').hide();
3808 $('#gc_contigs_info').hide();
3809 $('#frc_info').hide();
3810
3811 var selectedAssemblies = getSelectedAssemblies(assembliesNames);
3812 var sortBtnClass;
3813 if ($("input[name=sortRefs]")[0]) {
3814 sortBtnClass = getSortRefsRule();
3815 }
3816 $('#legend-placeholder').empty();
3817 assembliesNames.forEach(function(filename, i) {
3818 addLabelToLegend(i, filename, selectedAssemblies, colors);
3819 });
3820 if (refPlotValue) {
3821 $('#legend-placeholder').append(
3822 '<div id="reference-label">' +
3823 '<label for="reference" style="color: #000000;">' +
3824 '<input type="checkbox" name="' + assembliesNames.length +
3825 '" checked="checked" id="reference">&nbsp;' + 'reference' +
3826 '</label>' +
3827 '</div>'
3828 );
3829 }
3830 if (sortBtnClass) {
3831 addSortRefsBtn(sortBtnClass);
3832 }
3833
3834 drawPlot(name, title, colors, assembliesNames, data, refPlotValue, tickX,
3835 plotPlaceholder, legendPlaceholder, glossary, order, scalePlaceholder);
3836 }
3837
3838 function makePlot(firstPlot, assembliesNames, order, name, title, drawPlot, data, refPlotValue, tickX) {
3839 var switchSpan = document.createElement('span');
3840 switchSpan.id = name + '-switch';
3841 switchSpan.innerHTML = title;
3842 var plotsSwitchesDiv = document.getElementById('plots-switches');
3843 plotsSwitchesDiv.appendChild(switchSpan);
3844
3845 if (firstPlot) {
3846 switchSpan.className = 'plot-switch selected-switch';
3847 togglePlots(assembliesNames, order, name, title, drawPlot, data, refPlotValue, tickX);
3848 } else {
3849 switchSpan.className = 'plot-switch dotted-link';
3850 }
3851
3852 $(switchSpan).click(getToggleFunction(assembliesNames, order, name, title, drawPlot, data, refPlotValue, tickX));
3853 }
3854 </script>
3855
3856 <script type="text/javascript">
3857 String.prototype.trunc =
3858 function(n){
3859 return this.substr(0, n-1) + (this.length > n ? '&hellip;' : '');
3860 };
3861
3862
3863 function getColor (hue, lightness) {
3864 lightness = lightness ? lightness : 92;
3865 var rgb = hslToRgb(hue / 360, 0.8, lightness / 100);
3866 return '#' + rgb[0].toString(16) + rgb[1].toString(16) + rgb[2].toString(16);
3867 }
3868
3869 function getMedian (x) {
3870 if (x.length == 0) return null;
3871 if (x.length % 2 == 1) return x[(x.length - 1) / 2];
3872 else return (x[(x.length / 2) - 1] + x[(x.length / 2)]) / 2;
3873 }
3874
3875 function toggleSecondary(event, caller) {
3876 event = event || window.event;
3877 if(event.target.nodeName == "IMG") return;
3878 if (!caller.hasClass('primary') || caller.hasClass('not_extend')) {
3879 return;
3880 }
3881 var nextRow = caller.next('.content-row');
3882 $(caller).find('.metric-name').toggleClass('collapsed').toggleClass('expanded');
3883
3884 while (!nextRow.hasClass('primary') && (nextRow.length > 0)) {
3885 nextRow.toggleClass('secondary_hidden');
3886 nextRow.find('.left_column_td').css('background-color', '#E8E8E8');
3887 nextRow = nextRow.next('.content-row');
3888 }
3889 }
3890
3891 function setUpHeatMap(table) {
3892
3893 (function () {
3894 $(function () {
3895 $('tr.group_empty').removeClass('row_hidden');
3896 });
3897 })();
3898
3899 $('#main_report').append(table);
3900 var rows = $('#main_report_table').find('.content-row');
3901 var showHeatmap = false;
3902 for (var rows_n = 0; rows_n < rows.length; rows_n++) {
3903 if ($(rows[rows_n]).find('td[number]').length > 1) {
3904 showHeatmap = true;
3905 break
3906 }
3907 }
3908
3909 if (showHeatmap) {
3910 var canvas = document.getElementById('gradientHeatmap');
3911 var context = canvas.getContext('2d');
3912 context.rect(0, 0, canvas.width, canvas.height);
3913
3914 var gradient = context.createLinearGradient(0, 0, canvas.width, canvas.height);
3915 gradient.addColorStop(0, getColor(0, 65));
3916 gradient.addColorStop(0.5, 'white');
3917 gradient.addColorStop(1, getColor(240, 65));
3918 canvas.style.border = "0px solid rgba(0, 0, 0, .1)";
3919 context.fillStyle = gradient;
3920 context.fill();
3921 $('#heatmaps_chbox').change(function(){
3922 if($(this).is(':checked')) toggleHeatMap('on');
3923 else toggleHeatMap('off');
3924 });
3925 toggleHeatMap('on');
3926 $('#heatmap_header').show();
3927 }
3928 }
3929
3930 function toggleHeatMap(state){
3931 var rows = $('#main_report_table').find('.content-row');
3932 for (var rows_n = 0; rows_n < rows.length; rows_n++) {
3933 var cells = $(rows[rows_n]).find('td[number]');
3934 if (state == 'on') {
3935 var quality = $(rows[rows_n]).attr('quality');
3936 heatMapOneRow(cells, quality);
3937 }
3938 else cells.each(function (i) {
3939 $(this).css('background', 'white');
3940 $(this).css('color', 'black');
3941 });
3942 }
3943 }
3944
3945 function heatMapOneRow (cells, quality) {
3946 if (quality == 'Equal')
3947 return;
3948 var BLUE_HUE = 240;
3949 var BLUE_OUTER_BRT = 55;
3950 var BLUE_INNER_BRT = 65;
3951
3952 var RED_HUE = 0;
3953 var RED_OUTER_BRT = 50;
3954 var RED_INNER_BRT = 60;
3955
3956 var MIN_NORMAL_BRT = 80;
3957 var MEDIAN_BRT = 100;
3958
3959 var numbers = $.map(cells, function (cell) {
3960 return parseFloat($(cell).attr('number'));
3961 });
3962
3963 var min = Math.min.apply(null, numbers);
3964 var max = Math.max.apply(null, numbers);
3965
3966 var topHue = BLUE_HUE;
3967 var lowHue = RED_HUE;
3968
3969 var innerTopBrt = BLUE_INNER_BRT;
3970 var outerTopBrt = BLUE_OUTER_BRT;
3971 var innerLowBrt = RED_INNER_BRT;
3972 var outerLowBrt = RED_OUTER_BRT;
3973
3974 if (quality == 'Less is better') {
3975 topHue = RED_HUE;
3976 lowHue = BLUE_HUE;
3977
3978 innerTopBrt = RED_INNER_BRT;
3979 outerTopBrt = RED_OUTER_BRT;
3980 innerLowBrt = BLUE_INNER_BRT;
3981 outerLowBrt = BLUE_OUTER_BRT;
3982 }
3983
3984 var twoCols = cells.length == 2;
3985
3986 if (max == min) {
3987 $(cells).css('color', MEDIAN_BRT);
3988 } else {
3989 var sortedValues = numbers.slice().sort(function(a, b) {
3990 return a - b;
3991 });
3992 var median = getMedian(sortedValues);
3993 var l = numbers.length;
3994 var q1 = sortedValues[Math.floor((l - 1) / 4)];
3995 var q3 = sortedValues[Math.floor((l - 1) * 3 / 4)];
3996
3997 var d = q3 - q1;
3998 var low_outer_fence = q1 - 3 * d;
3999 var low_inner_fence = q1 - 1.5 * d;
4000 var top_inner_fence = q3 + 1.5 * d;
4001 var top_outer_fence = q3 + 3 * d;
4002 cells.each(function (i) {
4003 var number = numbers[i];
4004 if (number < low_outer_fence) {
4005 $(this).css('background', getColor(lowHue, twoCols ? null : outerLowBrt));
4006 if (twoCols != true) $(this).css('color', 'white');
4007 }
4008 else if (number < low_inner_fence) {
4009 $(this).css('background', getColor(lowHue, twoCols ? null : innerLowBrt));
4010 }
4011 else if (number < median) {
4012 var k = (MEDIAN_BRT - MIN_NORMAL_BRT) / (median - low_inner_fence);
4013 var brt = Math.round(MEDIAN_BRT - (median - number) * k);
4014 $(this).css('background', getColor(lowHue, twoCols ? null : brt));
4015 }
4016 else if (number > top_inner_fence) {
4017 $(this).css('background', getColor(topHue, twoCols ? null : innerTopBrt));
4018 }
4019 else if (number > top_outer_fence) {
4020 $(this).css('background', getColor(topHue, twoCols ? null : outerTopBrt));
4021 if (twoCols != true) $(this).css('color', 'white');
4022 }
4023 else if (number > median) {
4024 var k = (MEDIAN_BRT - MIN_NORMAL_BRT) / (top_inner_fence - median);
4025 var brt = Math.round(MEDIAN_BRT - (number - median) * k);
4026 $(this).css('background', getColor(topHue, twoCols ? null : brt));
4027 }
4028 });
4029 }
4030 }
4031 function extendedClick() {
4032 $('.row_to_hide').toggleClass('row_hidden');
4033
4034 var link = $('#extended_report_link');
4035 if (link.html() == 'Extended report') {
4036 link.html('Short report');
4037 } else {
4038 link.html('Extended report');
4039 }
4040 }
4041
4042 function buildExtendedLinkClick() {
4043 return '<p id="extended_link"><a class="dotted-link" id="extended_report_link" onclick="extendedClick($(this))">Extended report</a></p>';
4044 }
4045
4046 function appendIcarusLinks() {
4047 if (icarusLinks = readJson('icarus')) {
4048 if (icarusLinks.links != undefined) {
4049 var links = '';
4050 for (var link_n = 0; link_n < icarusLinks.links.length; link_n++) {
4051 //links += '<a href="' + icarusLinks.links[link_n] + '">' + icarusLinks.links_names[link_n] + '</a><br>'
4052 links += '<a class="btn btn-default btn-xs" role="button" href="' + icarusLinks.links[link_n] + '">' + icarusLinks.links_names[link_n] + '</a><br>'
4053 }
4054 $('#icarus').html(links);
4055 }
4056 }
4057 }
4058
4059 </script>
4060
4061
4062 <script type="text/javascript">
4063 var colors = ["#FF0000","#0000FF"];
4064 var broken_scaffolds_labels = [];
4065 </script>
4066 <script type="text/javascript">
4067 function addRow(metric, mainMetrics, rowName, group_n, order, glossary, isExpandable, isPrimary) {
4068 (function(group_n) {
4069 var id_group = '#group_' + group_n;
4070 $(function() {
4071 $(id_group).removeClass('group_empty');
4072 });
4073 })(group_n);
4074
4075 var table = '';
4076 metricName = metric.metricName;
4077 var quality = metric.quality;
4078 var values = metric.values;
4079
4080 var trClass = 'content-row';
4081 if (metric.isMain || $.inArray(metricName, mainMetrics) > -1) {
4082 (function(group_n) {
4083 var id_group = '#group_' + group_n;
4084 $(function() {
4085 $(id_group).removeClass('row_hidden');
4086 $(id_group).removeClass('row_to_hide');
4087 });
4088 })(group_n);
4089 } else {
4090 trClass = 'content-row row_hidden row_to_hide';
4091 }
4092 var tdClass = '';
4093 if (!isPrimary) {
4094 trClass += ' secondary_hidden';
4095 tdClass = 'secondary_td';
4096 }
4097 else {
4098 trClass += ' primary';
4099 }
4100 if (isExpandable) {
4101 table +=
4102 '<tr class="' + trClass + '" quality="' + quality + '" onclick="toggleSecondary(event, $(this))">' +
4103 '<td class="left_column_td ' + tdClass + '">' +
4104 '<span class="metric-name expandable collapsed">' +
4105 initial_spaces_to_nbsp(addTooltipIfDefinitionExists(glossary, rowName.trunc(55)), metricName) +
4106 '</span></td>';
4107 }
4108 else {
4109 table +=
4110 '<tr class="' + trClass + '" quality="' + quality + '">' +
4111 '<td class="left_column_td"><span class="metric-name">' +
4112 initial_spaces_to_nbsp(addTooltipIfDefinitionExists(glossary, rowName.trunc(55)), metricName) +
4113 '</span>' +
4114 '</td>';
4115 }
4116 for (var val_n = 0; val_n < values.length; val_n++) {
4117 value = values[order[val_n]];
4118
4119 if (value === null || value === '') {
4120 table += '<td><span>-</span></td>';
4121 } else {
4122 if (typeof value === 'number') {
4123 table +=
4124 '<td number="' + value + '"><span>'
4125 + toPrettyString(value) + '</span></td>';
4126 } else {
4127 var result = /([0-9\.]+)(.*)/.exec(value);
4128 var num = parseFloat(result[1]);
4129 var rest = result[2];
4130 // alert('value = ' + value + ' result = ' + result);
4131
4132 // var num = parseFloat(value);
4133
4134 if (num !== null) {
4135 table += '<td number="' + num + '"><span>' + toPrettyString(num) + rest + '</span></td>';
4136 } else {
4137 table += '<td><span>' + value + '</span></td>';
4138 }
4139 }
4140 }
4141 }
4142 return table;
4143 }
4144
4145 function getSubRows(subReports, groupName, metricName) {
4146 rows = [];
4147 if (subReports) {
4148 for (var report_n = 0; report_n < subReports.length; report_n++) {
4149 subReport = subReports[report_n];
4150 for (var group_n = 0; group_n < subReport.length; group_n++) {
4151 if (subReport[group_n][0] != groupName)
4152 continue;
4153 metrics = subReport[group_n][1];
4154 for (var metric_n = 0; metric_n < metrics.length; metric_n++) {
4155 if (metrics[metric_n].metricName == metricName)
4156 rows.push(metrics[metric_n])
4157 }
4158 }
4159 }
4160 }
4161 return rows;
4162 }
4163
4164 function buildTotalReport(assembliesNames, totalReport, order, glossary, qualities, mainMetrics) {
4165 var report = totalReport.report,
4166 date = totalReport.date,
4167 minContig = totalReport.minContig,
4168 referenceName = totalReport.referenceName,
4169 subReports = totalReport.subreports,
4170 subReferences = totalReport.subreferences;
4171 $('#report_date').html('<p>' + date + '</p>');
4172 var extraInfo = '<p>All statistics are based on contigs of size >= ' + minContig +
4173 '<span class="rhs">&nbsp;</span>bp, unless otherwise noted (e.g., "# contigs (>= 0 bp)" and "Total length (>= 0 bp)" include all contigs).</p>';
4174 $('#extrainfo').html(extraInfo);
4175 $('#plot-caption').show();
4176
4177 var table = '';
4178 table += '<table cellspacing="0" class="report_table draggable" id="main_report_table">';
4179
4180 if (referenceName) {
4181 $('#reference_name').show().find('.val').html(referenceName);
4182 }
4183
4184 if (report[0][0] == 'Genome statistics') { // if first section is empty (no reference), swap it and w/o reference statistics
4185 var genomeMetrics = report[0][1];
4186 var isSectionEmpty = true;
4187 for (var index = 0; index < genomeMetrics.length; index++) {
4188 if (genomeMetrics[index].isMain || $.inArray(genomeMetrics[index].metric_name, mainMetrics) > -1)
4189 isSectionEmpty = false;
4190 }
4191 if (isSectionEmpty) {
4192 for (var group_n = 0; group_n < report.length; group_n++) {
4193 if (report[group_n][0] == 'Statistics without reference') {
4194 report[0] = report.splice(group_n, 1, report[0])[0];
4195 }
4196 }
4197 }
4198 }
4199
4200 for (var group_n = 0; group_n < report.length; group_n++) {
4201 var group = report[group_n];
4202 var groupName = group[0];
4203 var metrics = group[1];
4204 var width = assembliesNames.length + 1;
4205
4206 if (groupName == 'Reference statistics') {
4207 var referenceValues = {};
4208 for (var metric_n = 0; metric_n < metrics.length; metric_n++) {
4209 var metric = metrics[metric_n];
4210 var metricName = metric.metricName;
4211 var value = metric.values[0];
4212 referenceValues[metricName] = value;
4213 }
4214 var refLen = referenceValues['Reference length'];
4215 var refFragments = referenceValues['Reference fragments'];
4216 var refGC = referenceValues['Reference GC (%)'];
4217 var refFeatures = referenceValues['Reference genomic features'];
4218 var refOperons = referenceValues['Reference operons'];
4219 var refChr = referenceValues['Reference chromosomes'];
4220 var totalReads = referenceValues['# total reads'];
4221 var refMappedReads = referenceValues['Reference mapped (%)'];
4222 var refPairedReads = referenceValues['Reference properly paired (%)'];
4223 var estRefLen = referenceValues['Estimated reference length'];
4224
4225 if (refLen)
4226 $('#reference_length').show().find('.val').html(toPrettyString(refLen));
4227 else if (estRefLen)
4228 $('#est_reference_length').show().find('.val').html(toPrettyString(estRefLen));
4229 if (refFragments) {
4230 $('#reference_fragments').show().find('.val').html(refFragments);
4231 if (refFragments > 1)
4232 $('#reference_fragments').find('.plural_ending').show();
4233 }
4234 if (refGC)
4235 $('#reference_gc').show().find('.val').html(toPrettyString(refGC));
4236 if (refFeatures)
4237 $('#reference_features').show().find('.val').html(toPrettyString(refFeatures));
4238 if (refOperons)
4239 $('#reference_operons').show().find('.val').html(toPrettyString(refOperons));
4240 if (refChr) {
4241 $('#reference_chr').show().find('.val').html(refChr);
4242 if (refChr > 1)
4243 $('#reference_chr').find('.plural_ending').show();
4244 }
4245 if (totalReads)
4246 $('#total_reads').show().find('.val').html(toPrettyString(totalReads));
4247 if (refMappedReads !== undefined)
4248 $('#reference_mapped_reads').show().find('.val').html(toPrettyString(refMappedReads));
4249 if (refPairedReads !== undefined)
4250 $('#reference_paired_reads').show().find('.val').html(toPrettyString(refPairedReads));
4251 continue;
4252 }
4253
4254 if (group_n == 0) {
4255 table += '<tr class="top_row_tr"><td id="top_left_td" class="left_column_td"><span>' + groupName + '</span></td>';
4256
4257 for (var assembly_n = 0; assembly_n < assembliesNames.length; assembly_n++) {
4258 var assemblyName = assembliesNames[order[assembly_n]];
4259 if (assemblyName.length > 30) {
4260 assemblyName =
4261 '<span class="tooltip-link" rel="tooltip" title="' + assemblyName + '">' +
4262 assemblyName.trunc(30) +
4263 '</span>'
4264 }
4265
4266 table += '<td class="second_through_last_col_headers_td" position="' + order[assembly_n] + '">' +
4267 '<span class="drag_handle"><span class="drag_image"></span></span>' +
4268 '<span class="assembly_name">' + assemblyName + '</span>' +
4269 '</td>';
4270 }
4271
4272 } else {
4273 table +=
4274 '<tr class="group_header row_to_hide row_hidden group_empty" id="group_' + group_n + '">' +
4275 '<td class="left_column_td"><span>' + groupName + '</span></td>'; //colspan="' + width + '"
4276 for (var i = 1; i < width; i++) {
4277 table += '<td></td>';
4278 }
4279 table += '</tr>';
4280 }
4281
4282 for (metric_n = 0; metric_n < metrics.length; metric_n++) {
4283 isExpandable = false;
4284 isPrimary = true;
4285 metricName = metrics[metric_n].metricName;
4286 subRows = getSubRows(subReports, groupName, metricName);
4287 if (subRows && subRows.length > 0) {
4288 isExpandable = true;
4289 table += addRow(metrics[metric_n], mainMetrics, metricName, group_n, order, glossary, isExpandable, isPrimary);
4290 for (var rows_n = 0; rows_n < subRows.length; rows_n++) {
4291 isExpandable = false;
4292 isPrimary = false;
4293 table += addRow(subRows[rows_n], mainMetrics, subReferences[rows_n], group_n, order, glossary, isExpandable, isPrimary);
4294 }
4295 }
4296 else table += addRow(metrics[metric_n], mainMetrics, metricName, group_n, order, glossary, isExpandable, isPrimary);
4297 }
4298 table += '</tr>';
4299 }
4300 table += '</table>';
4301
4302 table += buildExtendedLinkClick();
4303
4304 setUpHeatMap(table);
4305 }
4306
4307 </script>
4308
4309
4310 <script type="text/javascript">
4311
4312 function buildReport() {
4313 var assembliesNames;
4314 var order;
4315
4316 var totalReport = null;
4317 var qualities = null;
4318 var mainMetrics = null;
4319 var contigsLens = null;
4320 var coordNx = null;
4321 var contigsLensNx = null;
4322 var alignedContigsLens = null;
4323 var refLengths = null;
4324 var contigs = null;
4325 var featuresInContigs = null;
4326 var operonsInContigs = null;
4327 var gcInfos = null;
4328
4329 var glossary = JSON.parse($('#glossary-json').html());
4330
4331 var plotsSwitchesDiv = document.getElementById('plots-switches');
4332 var toRemoveRefLabel = true;
4333 var firstPlot = true;
4334
4335 /****************/
4336 /* Total report */
4337
4338 if (!(totalReport = readJson('total-report'))) {
4339 console.log("Error: cannot read #total-report-json");
4340 return 1;
4341 }
4342
4343 assembliesNames = totalReport.assembliesNames;
4344
4345 order = recoverOrderFromCookies() || totalReport.order || Range(0, assembliesNames.length);
4346
4347 buildTotalReport(assembliesNames, totalReport, order, glossary, qualities, mainMetrics);
4348
4349 if (refLengths = readJson('reference-length'))
4350 refLengths = refLengths.reflen;
4351
4352 /****************/
4353 /* Plots */
4354
4355 while (assembliesNames.length > colors.length) { // colors is defined in utils.js
4356 colors = colors.concat(colors);
4357 }
4358
4359 $(plotsSwitchesDiv).html('<b>Plots:</b>');
4360
4361 var selectedAssemblies = Array.apply(null, {length: assembliesNames}).map(Number.call, Number);
4362 assembliesNames.forEach(function(filename, i) {
4363 addLabelToLegend(i, filename, selectedAssemblies, colors)
4364 });
4365
4366 var tickX = 1;
4367 if (tickX = readJson('tick-x'))
4368 tickX = tickX.tickX;
4369
4370 if (contigsLens = readJson('contigs-lengths')) {
4371 makePlot(firstPlot, assembliesNames, order, 'cumulative', 'Cumulative length', cumulative.draw, contigsLens.lists_of_lengths, refLengths, tickX);
4372 firstPlot = false;
4373 }
4374
4375 if (coordNx = readJson('coord-nx')) {
4376 makePlot(firstPlot, assembliesNames, order, 'nx', 'Nx', nx.draw, {
4377 coord_x: coordNx.coord_x,
4378 coord_y: coordNx.coord_y,
4379 filenames: coordNx.filenames
4380 },
4381 null, null
4382 );
4383 firstPlot = false;
4384 }
4385
4386 if (coordNx = readJson('coord-nax')) {
4387 makePlot(firstPlot, assembliesNames, order, 'nax', 'NAx', nx.draw, {
4388 coord_x: coordNx.coord_x,
4389 coord_y: coordNx.coord_y,
4390 filenames: coordNx.filenames
4391 },
4392 null, null
4393 );
4394 firstPlot = false;
4395 }
4396
4397 if (coordNx = readJson('coord-ngx')) {
4398 makePlot(firstPlot, assembliesNames, order, 'ngx', 'NGx', nx.draw, {
4399 coord_x: coordNx.coord_x,
4400 coord_y: coordNx.coord_y,
4401 filenames: coordNx.filenames
4402 },
4403 null, null
4404 );
4405 firstPlot = false;
4406 }
4407
4408 if (coordNx = readJson('coord-ngax')) {
4409 makePlot(firstPlot, assembliesNames, order, 'ngax', 'NGAx', nx.draw, {
4410 coord_x: coordNx.coord_x,
4411 coord_y: coordNx.coord_y,
4412 filenames: coordNx.filenames
4413 },
4414 null, null
4415 );
4416 firstPlot = false;
4417 }
4418
4419 if (coordMisassemblies = readJson('coord-misassemblies')) {
4420 makePlot(firstPlot, assembliesNames, order, 'misassemblies', 'Misassemblies', frc.draw, {
4421 coord_x: coordMisassemblies.coord_x,
4422 coord_y: coordMisassemblies.coord_y,
4423 filenames: coordMisassemblies.filenames
4424 },
4425 null, 1
4426 );
4427 firstPlot = false;
4428 }
4429
4430 featuresInContigs = readJson('features-in-contigs');
4431 operonsInContigs = readJson('operons-in-contigs');
4432 // if (genesInContigs || operonsInContigs)
4433 // contigs = readJson('contigs');
4434
4435 if (featuresInContigs) {
4436 makePlot(firstPlot, assembliesNames, order, 'features', 'Genomic features', gns.draw, {
4437 filesFeatureInContigs: featuresInContigs.features_in_contigs,
4438 kind: 'gene',
4439 filenames: featuresInContigs.filenames
4440 },
4441 featuresInContigs.ref_features_number, tickX
4442 );
4443 firstPlot = false;
4444 }
4445 if (operonsInContigs) {
4446 makePlot(firstPlot, assembliesNames, order, 'operons', 'Operons', gns.draw, {
4447 filesFeatureInContigs: operonsInContigs.operons_in_contigs,
4448 kind: 'operon',
4449 filenames: operonsInContigs.filenames
4450 },
4451 operonsInContigs.ref_operons_number, tickX
4452 );
4453 firstPlot = false;
4454 }
4455 gcInfos = readJson('gc');
4456 if (gcInfos && (gcInfos.lists_of_gc_info || gcInfos.list_of_GC_distributions)) {
4457 makePlot(firstPlot, assembliesNames, order, 'gc', 'GC content', gc.draw, gcInfos, gcInfos.reference_index);
4458 }
4459
4460 var noReference = true;
4461 var report = totalReport.report;
4462 for (var group_n = 0; group_n < report.length; group_n++) {
4463 var group = report[group_n];
4464 var groupName = group[0];
4465 if (groupName == 'Reference statistics' && group[1].length > 0) {
4466 noReference = false;
4467 }
4468 }
4469 if (noReference) extendAll();
4470 appendIcarusLinks();
4471 return 0;
4472 }
4473
4474 function extendAll() {
4475 $('.row_to_hide').toggleClass('row_hidden');
4476
4477 var link = $('#extended_report_link');
4478 link.hide();
4479 }
4480 </script>
4481
4482
4483 <script type="text/javascript">
4484 $(function() {
4485
4486 buildReport();
4487
4488 dragTable.init();
4489
4490 $("[rel=tooltip]").tooltip({ animation: false, });
4491 });
4492 </script>
4493 </head>
4494
4495 <body>
4496 <div class="top-panel">
4497 <table class="layout-table">
4498 <tr>
4499 <td class='layout-table-td'>
4500 <div class="page_title">
4501 <h1>
4502 QUAST
4503 </h1>
4504 <p class="page_subtitle">
4505 <b>Quality Assessment Tool for Genome Assemblies</b>
4506 by <a href="http://cab.spbu.ru" class='dark_bg_link'>CAB</a>
4507 </p>
4508 </div>
4509 </td>
4510 </tr>
4511 </table>
4512 </div>
4513 <div class="content">
4514 <div id='header'>
4515 <p id='report_date'></p>
4516
4517 <p id='icarus'></p>
4518 <p id='extrainfo'>Loading...</p>
4519 <p id='per_ref_msg'></p>
4520 <p id='krona'></p>
4521
4522 <p id="data_set_p">
4523 <span style="display: none;" id="reference_name">Aligned to
4524 "<span class='val'></span>"
4525 </span>
4526
4527 <span style="display: none;" id="combined_reference_name">
4528 Combined reference
4529 </span>
4530
4531 <span style="display: none;" id="est_reference_length">Estimated reference size:
4532 <span class='val'></span><span class='rhs'>&nbsp;</span>bp
4533 </span>
4534
4535 <span style="display: none;" id="reference_length">|
4536 <span class='val'></span><span class='rhs'>&nbsp;</span>bp
4537 </span>
4538
4539 <span style="display: none;" id="combined_reference_files">|
4540 <span class='val'></span><span class='rhs'>&nbsp;</span>reference<span style="display: none;" class='plural_ending'>s</span>
4541 </span>
4542
4543 <span style="display: none;" id="reference_fragments">|
4544 <span class='val'></span><span class='rhs'>&nbsp;</span>fragment<span style="display: none;" class='plural_ending'>s</span>
4545 </span>
4546
4547 <span style="display: none;" id="reference_gc">|
4548 <span class='val'></span><span class='rhs'>&nbsp;</span>% G+C
4549 </span>
4550
4551 <span style="display: none;" id="reference_chr">|
4552 <span class='val'></span> chromosome<span style="display: none;" class='plural_ending'>s</span>
4553 </span>
4554
4555 <span style="display: none;" id="total_reads"><br>
4556 <span class='val'></span> reads
4557 </span>
4558
4559 <span style="display: none;" id="reference_mapped_reads">|
4560 <span class='val'></span>% mapped
4561 </span>
4562
4563 <span style="display: none;" id="reference_paired_reads">|
4564 <span class='val'></span>% properly paired
4565 </span>
4566
4567 <span style="display: none;" id="reference_features"><br>
4568 <span class='val'></span> genomic features
4569 </span>
4570
4571 <span style="display: none;" id="reference_operons">|
4572 <span class='val'></span> operons
4573 </span>
4574 </p>
4575 </div>
4576
4577 <noscript>
4578 <div style="margin-left: 0;">
4579 Unfortunately, <span style="font-weight: bold">JavaScript</span> in your
4580 browser <span style="font-weight: bold">is disabled</span> or is not supported.</br>
4581 We need JavaScript to build report and plots.
4582 </div>
4583 </noscript>
4584
4585 <div class='report-and-plots'>
4586 <div class='report' id='main_report'>
4587 <div id="heatmap_header" style='display: none; float: left;'>
4588 <div style="padding-right: 10px; display: inline-block; vertical-align:top;">
4589 <canvas id="gradientHeatmap" width="150" height="6"></canvas>
4590 <div style="margin-left: 0; text-align: justify;">
4591 <span class="heatmap_legend">Worst</span>
4592 <span style="margin-left: -5px;" class="heatmap_legend">Median</span>
4593 <span class="heatmap_legend">Best</span>
4594 <span class="heatmap_legend" style='width: 100%; height: 0;'></span>
4595 </div>
4596 </div>
4597 <label for="heatmaps_chbox"><input type="checkbox" checked="checked" id="heatmaps_chbox">Show heatmap</label>
4598 </div>
4599 <div style="clear: both;"></div>
4600 </div>
4601 <div class='plots'>
4602 <table style='margin: -3px;'>
4603 <tr id='all-switches'>
4604 <td>
4605 <div id='plots-switches'></div>
4606 </td>
4607 <td style='text-align: right; padding-right: 22px;'>
4608 <span id='scale-placeholder'></span>
4609 </td>
4610 </tr>
4611 <tr>
4612 <td colspan="2">
4613 <div id='plot-placeholder' style=''></div>
4614 </td>
4615 <td>
4616 <div id='legend-placeholder'></div>
4617 </td>
4618 </tr>
4619 <tr>
4620 <td colspan="3" id="plot-caption" style="display: none;">
4621 <p id="contigs_are_ordered">Contigs are ordered from largest (contig #1) to smallest.</p>
4622 <p id="frc_info">FRCurve:
4623 Y is the total number of aligned bases divided by the reference length,
4624 in the contigs having the total number of <span class="frc_plot_name"></span> at most X.</p>
4625 <p id="gc_info">Contigs are broken into nonoverlapping 100 bp windows.
4626 Plot shows number of windows for each GC percentage.</p>
4627 <p id="gc_contigs_info">Plot shows number of contigs with GC percentage in a certain range.</p>
4628 </td>
4629 </tr>
4630 </table>
4631 </div>
4632
4633 <p>
4634 <span id="main_ref_genome"></span>
4635 </p>
4636
4637 <div style="clear: left"></div>
4638 <div style="clear: right"></div>
4639
4640 <div class='json-code'>
4641 <div id='total-report-json'>
4642 {"date":"07 July 2022, Thursday, 16:52:16","assembliesNames":["contig1","contig2"],"referenceName":"dataset_be05aefa-bbf2-47ec-ac87-32bf4b214023","order":[0,1],"report":[["Genome statistics",[{"metricName":"Genome fraction (%)","quality":"More is better","values":["71.579","100.000"],"isMain":true},{"metricName":"Duplication ratio","quality":"Less is better","values":["1.000","1.000"],"isMain":true},{"metricName":"# genomic features","quality":"More is better","values":["7 + 7 part","13 + 1 part"],"isMain":true},{"metricName":"Largest alignment","quality":"More is better","values":[2030,6650],"isMain":true},{"metricName":"Total aligned length","quality":"More is better","values":[4760,6650],"isMain":true},{"metricName":"NG50","quality":"More is better","values":[3980,6650],"isMain":false},{"metricName":"NG90","quality":"More is better","values":[1120,6650],"isMain":false},{"metricName":"auNG","quality":"More is better","values":["2960.4","6650.0"],"isMain":false},{"metricName":"NA50","quality":"More is better","values":[1610,6650],"isMain":false},{"metricName":"NA90","quality":"More is better","values":[null,6650],"isMain":false},{"metricName":"auNA","quality":"More is better","values":["1187.4","6650.0"],"isMain":false},{"metricName":"NGA50","quality":"More is better","values":[1610,6650],"isMain":true},{"metricName":"NGA90","quality":"More is better","values":[null,6650],"isMain":false},{"metricName":"auNGA","quality":"More is better","values":["1198.1","6650.0"],"isMain":false},{"metricName":"LG50","quality":"Less is better","values":[1,1],"isMain":false},{"metricName":"LG90","quality":"Less is better","values":[3,1],"isMain":false},{"metricName":"LA50","quality":"Less is better","values":[2,1],"isMain":false},{"metricName":"LA90","quality":"Less is better","values":[null,1],"isMain":false},{"metricName":"LGA50","quality":"Less is better","values":[2,1],"isMain":true},{"metricName":"LGA90","quality":"Less is better","values":[null,1],"isMain":false},{"metricName":"Complete BUSCO (%)","quality":"More is better","values":["0.00","0.00"],"isMain":true},{"metricName":"Partial BUSCO (%)","quality":"Less is better","values":["0.68","0.00"],"isMain":true}]],["Reads mapping",[]],["Misassemblies",[{"metricName":"# misassemblies","quality":"Less is better","values":[0,0],"isMain":true},{"metricName":" # relocations","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":" # translocations","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":" # inversions","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":"# misassembled contigs","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":"Misassembled contigs length","quality":"Less is better","values":[0,0],"isMain":true},{"metricName":"# local misassemblies","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":"# scaffold gap ext. mis.","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":"# scaffold gap loc. mis.","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":"# unaligned mis. contigs","quality":"Less is better","values":[0,0],"isMain":false}]],["Unaligned",[{"metricName":"# fully unaligned contigs","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":"Fully unaligned length","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":"# partially unaligned contigs","quality":"Less is better","values":[1,0],"isMain":false},{"metricName":"Partially unaligned length","quality":"Less is better","values":[1950,0],"isMain":false}]],["Mismatches",[{"metricName":"# mismatches per 100 kbp","quality":"Less is better","values":["0.00","0.00"],"isMain":true},{"metricName":"# mismatches","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":"# indels per 100 kbp","quality":"Less is better","values":["0.00","0.00"],"isMain":true},{"metricName":"# indels","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":" # indels (<= 5 bp)","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":" # indels (> 5 bp)","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":"Indels length","quality":"Less is better","values":[0,0],"isMain":false},{"metricName":"# N's per 100 kbp","quality":"Less is better","values":["0.00","0.00"],"isMain":true},{"metricName":"# N's","quality":"Less is better","values":[0,0],"isMain":false}]],["Statistics without reference",[{"metricName":"# contigs","quality":"Equal","values":[3,1],"isMain":true},{"metricName":"# contigs (>= 0 bp)","quality":"Equal","values":[3,1],"isMain":false},{"metricName":"# contigs (>= 1000 bp)","quality":"Equal","values":[3,1],"isMain":false},{"metricName":"Largest contig","quality":"More is better","values":[3980,6650],"isMain":true},{"metricName":"Total length","quality":"More is better","values":[6710,6650],"isMain":true},{"metricName":"Total length (>= 0 bp)","quality":"More is better","values":[6710,6650],"isMain":false},{"metricName":"Total length (>= 1000 bp)","quality":"More is better","values":[6710,6650],"isMain":true},{"metricName":"N50","quality":"More is better","values":[3980,6650],"isMain":false},{"metricName":"N90","quality":"More is better","values":[1120,6650],"isMain":false},{"metricName":"auN","quality":"More is better","values":["2934.0","6650.0"],"isMain":false},{"metricName":"L50","quality":"Less is better","values":[1,1],"isMain":false},{"metricName":"L90","quality":"Less is better","values":[3,1],"isMain":false},{"metricName":"GC (%)","quality":"Equal","values":["51.28","52.00"],"isMain":false}]],["K-mer-based statistics",[{"metricName":"K-mer-based compl. (%)","quality":"More is better","values":["68.09","100.00"],"isMain":true},{"metricName":"K-mer-based cor. length (%)","quality":"More is better","values":["100.00","100.00"],"isMain":false},{"metricName":"K-mer-based mis. length (%)","quality":"Less is better","values":["0.00","0.00"],"isMain":false},{"metricName":"K-mer-based undef. length (%)","quality":"Less is better","values":["0.00","0.00"],"isMain":false},{"metricName":"# k-mer-based misjoins","quality":"Less is better","values":[0,0],"isMain":true},{"metricName":" # k-mer-based translocations","quality":"Equal","values":[0,0],"isMain":false},{"metricName":" # k-mer-based 100kbp relocations","quality":"Equal","values":[0,0],"isMain":false}]],["Predicted genes",[{"metricName":"# predicted rRNA genes","quality":"More is better","values":["0 + 0 part","0 + 0 part"],"isMain":true}]],["Similarity statistics",[{"metricName":"# similar correct contigs","quality":"Equal","values":[0,0],"isMain":false},{"metricName":"# similar misassembled blocks","quality":"Equal","values":[0,0],"isMain":false}]],["Reference statistics",[{"metricName":"Reference length","quality":"Equal","values":[6650,6650],"isMain":false},{"metricName":"Reference fragments","quality":"Equal","values":[1,1],"isMain":false},{"metricName":"Reference GC (%)","quality":"Equal","values":["52.00","52.00"],"isMain":false},{"metricName":"Reference genomic features","quality":"Equal","values":[14,14],"isMain":false},{"metricName":"Reference operons","quality":"Equal","values":[0,0],"isMain":false}]]],"subreferences":[],"subreports":[],"minContig":500}
4643 </div>
4644 <div id='qualities-json'>
4645 {{ qualities }}
4646 </div>
4647 <div id='main-metrics-json'>
4648 {{ mainMetrics }}
4649 </div>
4650
4651 <div id="contigs-lengths-json">
4652 {"filenames":["contig1","contig2"],"lists_of_lengths":[[3980,1610,1120],[6650]]}
4653 </div>
4654 <div id='assemblies-lengths-json'>
4655 {"filenames":["contig1","contig2"],"assemblies_lengths":[6710,6650]}
4656 </div>
4657 <div id='reference-length-json'>
4658 {"reflen":[6650]}
4659 </div>
4660 <div id='tick-x-json'>
4661 {"tickX":1}
4662 </div>
4663 <div id='coord-nx-json'>
4664 {"coord_x":[[0.0,1e-10,59.31445603576751,59.314456035867515,83.30849478390462,83.30849478400462,100.0,100.0000000001],[0.0,1e-10,100.0,100.0000000001]],"coord_y":[[3980,3980,3980,1610,1610,1120,1120,0.0],[6650,6650,6650,0.0]],"filenames":["contig1","contig2"]}
4665 </div>
4666 <div id='coord-ngx-json'>
4667 {"coord_x":[[0.0,1e-10,59.849624060150376,59.84962406025038,84.06015037593986,84.06015037603986,100.90225563909775,100.90225563919775],[0.0,1e-10,100.0,100.0000000001]],"coord_y":[[3980,3980,3980,1610,1610,1120,1120,0.0],[6650,6650,6650,0.0]],"filenames":["contig1","contig2"]}
4668 </div>
4669 <div id='coord-nax-json'>
4670 {"coord_x":[[0.0,1e-10,30.253353204172875,30.253353204272873,54.24739195230998,54.247391952409984,70.93889716840536,70.93889716850536],[0.0,1e-10,100.0,100.0000000001]],"coord_y":[[2030,2030,2030,1610,1610,1120,1120,0.0],[6650,6650,6650,0.0]],"filenames":["contig1","contig2"]}
4671 </div>
4672 <div id='coord-ngax-json'>
4673 {"coord_x":[[0.0,1e-10,30.526315789473685,30.526315789573683,54.73684210526316,54.73684210536316,71.57894736842105,71.57894736852106],[0.0,1e-10,100.0,100.0000000001]],"coord_y":[[2030,2030,2030,1610,1610,1120,1120,0.0],[6650,6650,6650,0.0]],"filenames":["contig1","contig2"]}
4674 </div>
4675 <div id='coord-misassemblies-json'>
4676 {"coord_x":[[0,1],[0,1]],"coord_y":[[71.57894736842105,71.57894736842105],[100.0,100.0]],"filenames":["contig1","contig2"]}
4677 </div>
4678 <div id='features-in-contigs-json'>
4679 {"filenames":["contig1","contig2"],"features_in_contigs":{"contig1":[5,0,2],"contig2":[13]},"ref_features_number":14}
4680 </div>
4681 <div id='operons-in-contigs-json'>
4682 {{ operonsInContigs }}
4683 </div>
4684 <div id='summary-json'>
4685 [{{ num_contigs }},
4686 {{ Largest_alignment }},
4687 {{ Total_aligned_length }},
4688 {{ num_misassemblies }},
4689 {{ Misassembled_contigs_length }},
4690 {{ num_mismatches_per_100_kbp }},
4691 {{ num_indels_per_100_kbp }},
4692 {{ num_N's_per_100_kbp }},
4693 {{ Genome_fraction }},
4694 {{ Duplication_ratio }},
4695 {{ NGA50 }}]
4696 </div>
4697 <div id='misassemblies-json'>
4698 {{ allMisassemblies }}
4699 </div>
4700 <div id='krona-json'>
4701 {{ krona }}
4702 </div>
4703 <div id='gc-json'>
4704 {"filenames":["contig1","contig2"],"reference_index":2,"list_of_GC_distributions":[[[0.0,1.0,2.0,3.0,4.0,5.0,6.0,7.0,8.0,9.0,10.0,11.0,12.0,13.0,14.0,15.0,16.0,17.0,18.0,19.0,20.0,21.0,22.0,23.0,24.0,25.0,26.0,27.0,28.0,29.0,30.0,31.0,32.0,33.0,34.0,35.0,36.0,37.0,38.0,39.0,40.0,41.0,42.0,43.0,44.0,45.0,46.0,47.0,48.0,49.0,50.0,51.0,52.0,53.0,54.0,55.0,56.0,57.0,58.0,59.0,60.0,61.0,62.0,63.0,64.0,65.0,66.0,67.0,68.0,69.0,70.0,71.0,72.0,73.0,74.0,75.0,76.0,77.0,78.0,79.0,80.0,81.0,82.0,83.0,84.0,85.0,86.0,87.0,88.0,89.0,90.0,91.0,92.0,93.0,94.0,95.0,96.0,97.0,98.0,99.0,100.0],[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,1,0,1,0,0,3,1,0,1,2,1,5,5,5,2,5,4,4,7,1,6,2,5,1,0,1,1,1,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]],[[0.0,1.0,2.0,3.0,4.0,5.0,6.0,7.0,8.0,9.0,10.0,11.0,12.0,13.0,14.0,15.0,16.0,17.0,18.0,19.0,20.0,21.0,22.0,23.0,24.0,25.0,26.0,27.0,28.0,29.0,30.0,31.0,32.0,33.0,34.0,35.0,36.0,37.0,38.0,39.0,40.0,41.0,42.0,43.0,44.0,45.0,46.0,47.0,48.0,49.0,50.0,51.0,52.0,53.0,54.0,55.0,56.0,57.0,58.0,59.0,60.0,61.0,62.0,63.0,64.0,65.0,66.0,67.0,68.0,69.0,70.0,71.0,72.0,73.0,74.0,75.0,76.0,77.0,78.0,79.0,80.0,81.0,82.0,83.0,84.0,85.0,86.0,87.0,88.0,89.0,90.0,91.0,92.0,93.0,94.0,95.0,96.0,97.0,98.0,99.0,100.0],[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,3,2,1,0,0,5,3,4,4,7,3,5,2,4,7,0,10,1,1,2,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]],[[0.0,1.0,2.0,3.0,4.0,5.0,6.0,7.0,8.0,9.0,10.0,11.0,12.0,13.0,14.0,15.0,16.0,17.0,18.0,19.0,20.0,21.0,22.0,23.0,24.0,25.0,26.0,27.0,28.0,29.0,30.0,31.0,32.0,33.0,34.0,35.0,36.0,37.0,38.0,39.0,40.0,41.0,42.0,43.0,44.0,45.0,46.0,47.0,48.0,49.0,50.0,51.0,52.0,53.0,54.0,55.0,56.0,57.0,58.0,59.0,60.0,61.0,62.0,63.0,64.0,65.0,66.0,67.0,68.0,69.0,70.0,71.0,72.0,73.0,74.0,75.0,76.0,77.0,78.0,79.0,80.0,81.0,82.0,83.0,84.0,85.0,86.0,87.0,88.0,89.0,90.0,91.0,92.0,93.0,94.0,95.0,96.0,97.0,98.0,99.0,100.0],[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,3,2,1,0,0,5,3,4,4,7,3,5,2,4,7,0,10,1,1,2,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]]],"list_of_GC_contigs_distributions":[[[0,5,10,15,20,25,30,35,40,45,50,55,60,65,70,75,80,85,90,95,100],[0,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,0,0,0]],[[0,5,10,15,20,25,30,35,40,45,50,55,60,65,70,75,80,85,90,95,100],[0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0]]],"lists_of_gc_info":null}
4705 </div>
4706 <div id='icarus-json'>
4707 {"links":["icarus_viewers/alignment_viewer.html"],"links_names":["View in Icarus contig browser"]}
4708 </div>
4709 </div>
4710 </div>
4711
4712 <div class='json-code'>
4713 <div id='glossary-json'>
4714 {
4715 "# contigs" : "<span>is the total number of contigs in the assembly.</span>",
4716 "Largest contig" : "<span>is the length of the longest contig in the assembly.</span>",
4717 "Total length" : "<span>is the total number of bases in the assembly.</span>",
4718 "Reference length" : "<span>is the total number of bases in the reference.</span>",
4719
4720 "# contigs (>= 0 bp)" : "<span>is the total number of contigs in the assembly that have size greater than or equal to 0 bp.</span>",
4721 "Total length (>= 0 bp)" : "<span>is the total number of bases in the contigs having size greater than or equal to 0 bp.</span>",
4722
4723 "N50" : "<span>is the contig length such that using longer or equal length contigs produces half (50%) of the bases of the assembly. Usually there is no value that produces exactly 50%, so the technical definition is the maximum length x such that using contigs of length at least x accounts for at least 50% of the total assembly length. Similarly, Nx for any x between 0 and 100 could be computed (x% of assembly).</span>",
4724 "NG50" : "<span>is the contig length such that using longer or equal length contigs produces half (50%) of the bases of the reference genome. This metric is computed only if a reference genome is provided. Similarly, NGx for any x between 0 and 100 could be computed (x% of the reference).</span>",
4725
4726 "L50" : "<span>is the minimum number of contigs that produce half (50%) of the bases of the assembly. In other words, it's the number of contigs of length at least N50. Similarly, Lx for any x between 0 and 100 could be computed.</span>",
4727 "LG50" : "<span>is the minimum number of contigs that produce half (50%) of the bases of the reference genome. In other words, it's the number of contigs of length at least NG50. This metric is computed only if a reference genome is provided. Similarly, LGx for any x between 0 and 100 could be computed.</span>",
4728
4729 "NA50" : "<span>is N50 where the lengths of aligned blocks are counted instead of contig lengths. I.e., if a contig has a misassembly with respect to the reference, the contig is broken into smaller pieces. This metric is computed only if a reference genome is provided. Similarly, NAx for any x between 0 and 100 could be computed.</span>",
4730 "NGA50" : "<span>is NG50 where the lengths of aligned blocks are counted instead of contig lengths. I.e., if a contig has a misassembly with respect to the reference, the contig is broken into smaller pieces. This metric is computed only if a reference genome is provided. Similarly, NGAx for any x between 0 and 100 could be computed.</span>",
4731
4732 "LA50" : "<span>is L50 where aligned blocks are counted instead of contigs. I.e., if a contig has a misassembly with respect to the reference, the contig is broken into smaller pieces. Similarly, LAx for any x between 0 and 100 could be computed.</span>",
4733 "LGA50" : "<span>is LG50 where aligned blocks are counted instead of contigs. I.e., if a contig has a misassembly with respect to the reference, the contig is broken into smaller pieces. Similarly, LGAx for any x between 0 and 100 could be computed.</span>",
4734
4735 "auN" : "<span>is the area under the Nx curve.</span>",
4736 "auNG" : "<span>is the area under the NGx curve.</span>",
4737 "auNA" : "<span>is the area under the NAx curve.</span>",
4738 "auNGA" : "<span>is the area under the NGAx curve.</span>",
4739
4740 "Average %IDY" : "<span>is the average of alignment identity percent (alignment accuracy) among all contigs.</span>",
4741 "# misassemblies" : "<span>is the number of positions in the assembled contigs where the left flanking sequence aligns over 1 kbp away from the right flanking sequence on the reference (<i>relocation</i>) or they overlap on more than 1 kbp (<i>relocation</i>) or flanking sequences align on different strands (<i>inversion</i>) or different chromosomes (<i>translocation</i>).</span>",
4742 "# large block misassemblies" : "<span>is the number of misassemblies between alignments with length greater than or equal to 3 kbp and with the misassembly threshold equal to 5 kbp (instead of default 1 kbp for regular misassemblies).</span>",
4743 "# misassembled contigs" : "<span>is the number of contigs that contain misassembly events.</span>",
4744 "Misassembled contigs length" : "<span>is the number of total bases contained in all contigs that have one or more misassemblies.</span>",
4745
4746 "# relocations" : "<span>is the number of relocation events among all misassembly events. Relocation is a misassembly where the left flanking sequence aligns over 1 kbp away from the right flanking sequence on the reference, or they overlap by more than 1 kbp and both flanking sequences align on the same chromosome.</span>",
4747 "# translocations" : "<span>is the number of translocation events among all misassembly events. Translocation is a misassembly where the flanking sequences align on different chromosomes.</span>",
4748 "# interspecies translocations" : "<span>is the number of interspecies translocation events among all misassembly events. Interspecies translocation is a misassembly where the flanking sequences align on different references (based on alignments to the combined reference).</span>",
4749 "# inversions" : "<span>is the number of inversion events among all misassembly events. Inversion is a misassembly where it is not a <i>relocation</i> and the flanking sequences align on opposite strands of the same chromosome.</span>",
4750 "# large relocations" : "<span>is the number of relocation events among all large block misassemblies. Relocation is a misassembly where the left flanking sequence aligns over 5 kbp away from the right flanking sequence on the reference, or they overlap by more than 5 kbp and both flanking sequences align on the same chromosome.</span>",
4751 "# large translocations" : "<span>is the number of translocation events among all large block misassemblies. Translocation is a misassembly where the flanking sequences align on different chromosomes.</span>",
4752 "# large i/s translocations" : "<span>is the number of interspecies translocation events among all large block misassemblies. Interspecies translocation is a misassembly where the flanking sequences align on different references (based on alignments to the combined reference).</span>",
4753 "# large inversions" : "<span>is the number of inversion events among all large block misassemblies. Inversion is a misassembly where it is not a <i>relocation</i> and the flanking sequences align on opposite strands of the same chromosome.</span>",
4754 "# local misassemblies" : "<span>is the number of local misassemblies. We define a local misassembly breakpoint as a breakpoint that satisfies these conditions: <ol> <li>Two or more distinct alignments cover the breakpoint.</li> <li>The gap between left and right flanking sequences is less than the misassembly threshold (1 kbp by default).</li> <li>The left and right flanking sequences both are on the same strand of the same chromosome of the reference genome.</li> </ol> </span>",
4755 "# scaffold gap ext. mis." : "<span>is the number of scaffold gap size extensive misassemblies. We define a scaffold gap size misassembly as a breakpoint where the flanking sequences are combined in a scaffold on the wrong distance. These misassemblies are not included in the total number of misassemblies. </span>",
4756 "# scaffold gap loc. mis." : "<span>is the number of scaffold gap size local misassemblies. Such breakpoints satisfy the local misassembly conditions but they occur inside scaffolds. These misassemblies are not included in the total number of local misassemblies. </span>",
4757 "# possibly misassembled contigs": "<span>is the number of contigs that contain large unaligned fragment (default min length is 500 bp) and thus could possibly contain interspecies translocation with unknown reference.</span>",
4758 "# possible misassemblies" : "<span>is the number of putative interspecies translocations in possibly misassembled contigs if each large unaligned fragment is supposed to be a fragment of unknown reference.</span>",
4759 "# intergenomic misassemblies" : "<span>is the number of all found and putative (possible) interspecies translocations.</span>",
4760 "# structural variations" : "<span>is the number of misassemblies matched with structural variations.</span>",
4761 "# possible TEs" : "<span>is the number of misassemblies possibly caused by transposable elements (TEs). We define a possible TE as an event that satisfies these conditions: <ol> <li>There are two misassembly breakpoints of the same type around a short alignment (less than 7 kbp by default)</li> <li>The gap between two long flanking sequences on the sides of the short alignment is less than 7 kbp.</li> <li> The long flanking sequences both are on the same strand of the same chromosome of the reference genome.</li> </ol> </span>",
4762 "# unaligned mis. contigs" : "<span>is the number of contigs that have the number of unaligned bases more than 50% of the contig length and a misassembly event in their aligned fragment. Note that such misassemblies are not counted in <i># misassemblies</i> and other <i>misassemblies</i> statistics.</span>",
4763
4764 "# fully unaligned contigs" : "<span>is the number of contigs that have no alignment to the reference sequence.</span>",
4765 "Fully unaligned length" : "<span>is the total number of bases contained in all fully unaligned contigs. Uncalled bases (N's) are not counted.</span>",
4766 "# partially unaligned contigs" : "<span>is the number of contigs that have at least one alignment to the reference sequence but also have at least one unaligned fragment of length &ge; <i>unaligned-part-size threshold</i> (uncalled bases (N's) are not counted towards the fragment length).</span>",
4767 "Partially unaligned length" : "<span>is the total number of unaligned bases in all partially unaligned contigs. Uncalled bases (N's) are not counted.</span>",
4768
4769 "# ambiguous contigs" : "<span>is the number of contigs that have reference alignments of equal quality in multiple locations on the reference.</span>",
4770 "Ambiguous contigs length" : "<span>is the total number of bases contained in all ambiguous contigs.</span>",
4771
4772 "Genome fraction (%)" : "<span>is the total number of aligned bases in the reference, divided by the genome size. A base in the reference genome is counted as aligned if there is at least one contig with at least one alignment to this base. Contigs from repeat regions may map to multiple places, and thus may be counted multiple times in this quantity.</span>",
4773 "GC (%)" : "<span>is the total number of G and C nucleotides in the assembly, divided by the total length of the assembly.</span>",
4774 "Reference GC (%)" : "<span>is the total number of G and C nucleotides in the reference, divided by the total length of the reference.</span>",
4775
4776 "# mismatches per 100 kbp" : "<span>is the average number of mismatches per 100,000 aligned bases in the assembly.</span>",
4777 "# mismatches" : "<span>is the number of mismatches in all aligned bases in the assembly.</span>",
4778 "# indels per 100 kbp" : "<span>is the average number of indels per 100,000 aligned bases in the assembly.</span>",
4779 "# indels" : "<span>is the number of indels in all aligned bases in the assembly.</span>",
4780 "# indels (<= 5 bp)" : "<span>is the number of indels of length less than or equal to 5 bp.</span>",
4781 "# indels (> 5 bp)" : "<span>is the number of indels of length greater than 5 bp.</span>",
4782 "Indels length" : "<span>is the number of total bases contained in all indels.</span>",
4783
4784 "# genomic features" : "<span>is the number of genomic features (genes, transcripts, CDS) in the assembly (complete and partial), based on a user-provided annotated list of gene positions in the reference genome. A feature counts as 'partially covered' if the assembly contains at least 100 bp of this feature but not the whole feature.</span>",
4785 "# operons" : "<span>is the number of operons in the assembly (complete and partial), based on a user-provided annotated list of operon positions in the reference genome. An operon counts as 'partially covered' if the assembly contains at least 100 bp of this operon but not the whole operon.</span>",
4786 "# predicted genes (unique)" : "<span>is the number of unique genes in the assembly found by a gene prediction tool.</span>",
4787 "# predicted genes (>= 0 bp)" : "<span>is the number of found genes having length greater than or equal to 0 bp.</span>",
4788
4789 "Complete BUSCO (%)" : "<span>is the percent of BUSCO (Universal Single-Copy Ortholog) genes found in the assembly in a complete form.</span>",
4790 "Partial BUSCO (%)" : "<span>is the percent of BUSCO (Universal Single-Copy Ortholog) genes found in the assembly in a partial form.</span>",
4791
4792 "Cumulative length" : "<span>plot shows the growth of assembly contig lengths. On the x-axis, contigs are ordered from largest (contig #1) to smallest. The y-axis gives the size of the x largest contigs in the assembly.</span>",
4793 "Nx" : "<span>plot shows the Nx metric value as x varies from 0 to 100.</span> <span>Nx is the minimum contig length <b>y</b> such that using contigs of length at least <b>y</b> accounts for at least x% of the total assembly length.</span>",
4794 "NGx" : "<span>plot shows the NGx metric value as x varies from 0 to 100.</span> <span>NGx is the minimum contig length <b>y</b> such that using contigs of length at least <b>y</b> accounts for at least x% of the bases of the reference genome. This metric is computed only if a reference genome is provided.</span>",
4795 "NAx" : "<span>plot shows the NAx metric value as x varies from 0 to 100.</span> <span>NAx is computed similarly to Nx, but based on lengths of aligned blocks instead of contig lengths. Contigs are broken into aligned blocks at misassembly breakpoints. NAx is the minimum block length <b>y</b> such that using blocks of length at least <b>y</b> accounts for at least x% of the bases of the assembly. This metric is computed only if a reference genome is provided.</span>",
4796 "NGAx" : "<span>plot shows the NGAx metric value as x varies from 0 to 100.</span><span>NGAx is computed similarly to NGx, but based on lengths of aligned blocks instead of contig lengths. Contigs are broken at misassembly breakpoints. NGAx is the minimum block length <b>y</b> such that using blocks of length at least <b>y</b> accounts for at least x% of the bases of the reference genome. This metric is computed only if a reference genome is provided.</span>",
4797 "GC content" : "<span>plot shows the distribution of GC percentage among the contigs, i.e., the total number of bases in contigs with such GC content. Typically, the distribution is approximately Gaussian. However, for some genomes it is not Gaussian. For assembly projects with contaminants, the GC distribution of the contaminants often differs from the reference genome and may give a superposition of multiple curves with different peaks.</span>",
4798
4799 "Duplication ratio" : "<span>is the total number of aligned bases in the assembly, divided by the total number of aligned bases in the reference (see the <b>Genome fraction (%)</b> metric). If the assembly contains many contigs that cover the same regions of the reference, its <i>Duplication ratio</i> may be much larger than 1. This may occur due to overestimating repeat multiplicities and due to small overlaps between contigs, among other reasons.</span>",
4800 "Largest alignment" : "<span>is the length of the largest continuous alignment in the assembly. This metric is always equal to the <i>Largest contig</i> metric but it can be smaller if the largest contig of the assembly contains a misassembly event.</span>",
4801 "Total aligned length" : "<span>is the total number of aligned bases in the assembly.</span>",
4802 "Avg contig read support" : "<span>is the average coverage of contigs that have large unique alignments to the reference. Read coverage is extracted from contig names (SPAdes/Velvet naming scheme only).</span>",
4803
4804 "# N's" : "<span>is the total number of uncalled bases (N's) in the assembly.</span>",
4805 "# N's per 100 kbp" : "<span>is the average number of uncalled bases (N's) per 100,000 assembly bases.</span>",
4806
4807 "# mapped" : "<span>is the number of reads that mapped to the assembly.</span>",
4808 "Mapped (%)" : "<span>is the percent of reads that mapped to the assembly.</span>",
4809 "# properly paired" : "<span>is the number of reads that mapped within expected range and orientation of each other to the assembly.</span>",
4810 "Properly paired (%)" : "<span>is the percent of reads that mapped within expected range and orientation of each other to the assembly.</span>",
4811 "# singletons" : "<span>is the number of reads which do not overlap any other reads.</span>",
4812 "Singletons (%)" : "<span>is the percent of reads which do not overlap any other reads.</span>",
4813 "# misjoint mates" : "<span>is the number of reads with mate mapped to a different contig.</span>",
4814 "Misjoint mates (%)" : "<span>is the percent of reads with mate mapped to a different contig.</span>",
4815 "Avg. coverage depth" : "<span>is the average depth of coverage.</span>",
4816 "Coverage >= 1x (%)" : "<span>is the total number of bases with at least 1x coverage, divided by the total length of the assembly.</span>",
4817
4818 "# similar correct contigs" : "<span>is the number of correct contigs similar among > 50% assemblies (see Icarus for visualization).</span>",
4819 "# similar misassembled blocks" : "<span>is the number of misassembled blocks similar among > 50% assemblies (see Icarus for visualization).</span>"
4820 }
4821
4822 </div>
4823 </div>
4824 </div>
4825 </body>
4826 </html>