sequenceserver 3.1.2 → 3.1.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (41) hide show
  1. checksums.yaml +4 -4
  2. data/lib/sequenceserver/blast/tasks.rb +1 -1
  3. data/lib/sequenceserver/routes.rb +1 -1
  4. data/lib/sequenceserver/version.rb +1 -1
  5. data/lib/sequenceserver.rb +1 -1
  6. data/public/css/app.min.css +1 -1
  7. data/public/css/sequenceserver.css +0 -18
  8. data/public/css/sequenceserver.min.css +2 -2
  9. data/public/js/alignment_exporter.js +16 -28
  10. data/public/js/cloud_share_modal.js +42 -42
  11. data/public/js/form.js +12 -10
  12. data/public/js/grapher.js +4 -4
  13. data/public/js/hit.js +3 -3
  14. data/public/js/hits.js +276 -0
  15. data/public/js/jquery_world.js +1 -1
  16. data/public/js/mailto.js +1 -3
  17. data/public/js/null_plugins/report_plugins.js +1 -0
  18. data/public/js/options.js +2 -6
  19. data/public/js/query.js +1 -1
  20. data/public/js/report.js +68 -252
  21. data/public/js/report_root.js +7 -5
  22. data/public/js/search.js +28 -11
  23. data/public/js/sequence.js +158 -158
  24. data/public/js/sequence_modal.js +28 -36
  25. data/public/js/sidebar.js +7 -6
  26. data/public/js/tests/alignment_exporter.spec.js +38 -0
  27. data/public/js/tests/cloud_share_modal.spec.js +75 -0
  28. data/public/js/tests/report.spec.js +37 -15
  29. data/public/packages/jquery-ui@1.13.3.js +19070 -0
  30. data/public/sequenceserver-report.min.js +3 -2481
  31. data/public/sequenceserver-report.min.js.LICENSE.txt +300 -0
  32. data/public/sequenceserver-report.min.js.map +1 -0
  33. data/public/sequenceserver-search.min.js +3 -2382
  34. data/public/sequenceserver-search.min.js.LICENSE.txt +292 -0
  35. data/public/sequenceserver-search.min.js.map +1 -0
  36. data/views/layout.erb +3 -7
  37. data/views/search.erb +1 -1
  38. data/views/search_layout.erb +1 -1
  39. metadata +11 -5
  40. data/public/config.js +0 -147
  41. data/public/packages/jquery-ui@1.11.4.js +0 -16624
@@ -9,78 +9,78 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
9
9
  * THIS FILE HAS BEEN MODIFIED FROM THE ORIGINAL
10
10
  * (https://github.com/ljgarcia/biojs-vis-sequence/blob/master/lib/index.js).
11
11
  *
12
- * Sequence component
13
- *
12
+ * Sequence component
13
+ *
14
14
  * @class
15
15
  * @extends Biojs
16
- *
16
+ *
17
17
  * @author <a href="mailto:johncar@gmail.com">John Gomez</a>, <a href="mailto:secevalliv@gmail.com">Jose Villaveces</a>
18
18
  * @version 1.0.0
19
19
  * @category 3
20
- *
20
+ *
21
21
  * @requires <a href='http://blog.jquery.com/2011/09/12/jquery-1-6-4-released/'>jQuery Core 1.6.4</a>
22
22
  * @dependency <script language="JavaScript" type="text/javascript" src="../biojs/dependencies/jquery/jquery-1.4.2.min.js"></script>
23
- *
23
+ *
24
24
  * @requires <a href='http://jqueryui.com/download'>jQuery UI 1.8.16</a>
25
25
  * @dependency <script language="JavaScript" type="text/javascript" src="../biojs/dependencies/jquery/jquery-ui-1.8.2.custom.min.js"></script>
26
26
  *
27
27
  * @requires <a href='Biojs.Tooltip.css'>Biojs.Tooltip</a>
28
28
  * @dependency <script language="JavaScript" type="text/javascript" src="src/Biojs.Tooltip.js"></script>
29
- *
29
+ *
30
30
  * @param {Object} options An object with the options for Sequence component.
31
- *
32
- * @option {string} target
31
+ *
32
+ * @option {string} target
33
33
  * Identifier of the DIV tag where the component should be displayed.
34
- *
35
- * @option {string} sequence
34
+ *
35
+ * @option {string} sequence
36
36
  * The sequence to be displayed.
37
- *
38
- * @option {string} [id]
37
+ *
38
+ * @option {string} [id]
39
39
  * Sequence identifier if apply.
40
- *
41
- * @option {string} [format="FASTA"]
40
+ *
41
+ * @option {string} [format="FASTA"]
42
42
  * The display format for the sequence representation.
43
- *
44
- * @option {Object[]} [highlights]
45
- * For highlighting multiple regions.
46
- * <pre class="brush: js" title="Syntax:">
43
+ *
44
+ * @option {Object[]} [highlights]
45
+ * For highlighting multiple regions.
46
+ * <pre class="brush: js" title="Syntax:">
47
47
  * [
48
48
  * // Highlight aminoacids from 'start' to 'end' of the current strand using the specified 'color' (optional) and 'background' (optional).
49
- * { start: &lt;startVal1&gt;, end: &lt;endVal1&gt; [, id:&lt;idVal1&gt;] [, color: &lt;HTMLColor&gt;] [, background: &lt;HTMLColor&gt;]},
49
+ * { start: &lt;startVal1&gt;, end: &lt;endVal1&gt; [, id:&lt;idVal1&gt;] [, color: &lt;HTMLColor&gt;] [, background: &lt;HTMLColor&gt;]},
50
50
  * //
51
51
  * // Any others highlights
52
- * ...,
53
- * //
52
+ * ...,
53
+ * //
54
54
  * { start: &lt;startValN&gt;, end: &lt;endValN&gt; [, id:&lt;idValN&gt;] [, color: &lt;HTMLColor&gt;] [, background: &lt;HTMLColor&gt;]}
55
55
  * ]</pre>
56
- *
57
- * <pre class="brush: js" title="Example:">
56
+ *
57
+ * <pre class="brush: js" title="Example:">
58
58
  * highlights : [
59
59
  * { start:30, end:42, color:"white", background:"green", id:"spin1" },
60
- * { start:139, end:140 },
60
+ * { start:139, end:140 },
61
61
  * { start:631, end:633, color:"white", background:"blue" }
62
62
  * ]
63
63
  * </pre>
64
- *
65
- * @option {Object} [columns={size:40,spacedEach:10}]
64
+ *
65
+ * @option {Object} [columns={size:40,spacedEach:10}]
66
66
  * Options for displaying the columns. Syntax: { size: &lt;numCols&gt;, spacedEach: &lt;numCols&gt;}
67
- *
68
- * @option {Object} [selection]
67
+ *
68
+ * @option {Object} [selection]
69
69
  * Positions for the current selected region. Syntax: { start: &lt;startValue&gt;, end: &lt;endValue&gt;}
70
- *
71
- * @option {Object[]} [annotations]
70
+ *
71
+ * @option {Object[]} [annotations]
72
72
  * Set of overlapping annotations. Must be an array of objects following the syntax:
73
73
  * <pre class="brush: js" title="Syntax:">
74
- * [
74
+ * [
75
75
  * // An annotation:
76
- * { name: &lt;name&gt;,
77
- * html: &lt;message&gt;,
78
- * color: &lt;color_code&gt;,
79
- * regions: [{ start: &lt;startVal1&gt;, end: &lt;endVal1&gt; color: &lt;HTMLColor&gt;}, ...,{ start: &lt;startValN&gt;, end: &lt;endValN&gt;, color: &lt;HTMLColor&gt;}]
80
- * },
81
- *
76
+ * { name: &lt;name&gt;,
77
+ * html: &lt;message&gt;,
78
+ * color: &lt;color_code&gt;,
79
+ * regions: [{ start: &lt;startVal1&gt;, end: &lt;endVal1&gt; color: &lt;HTMLColor&gt;}, ...,{ start: &lt;startValN&gt;, end: &lt;endValN&gt;, color: &lt;HTMLColor&gt;}]
80
+ * },
81
+ *
82
82
  * // ...
83
- * // more annotations here
83
+ * // more annotations here
84
84
  * // ...
85
85
  * ]
86
86
  * </pre>
@@ -92,19 +92,19 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
92
92
  * <li><b>regions</b> array of objects defining the intervals which belongs to the annotation.</li>
93
93
  * <li><b>regions[i].start</b> is the starting character for the i-th interval.</li>
94
94
  * <li><b>regions[i].end</b> is the ending character for the i-th interval.</li>
95
- * <li><b>regions[i].color</b> is an optional color for the i-th interval.
96
- * </ul>
97
- *
98
- * @option {Object} [formatOptions={title:true, footer:true}]
95
+ * <li><b>regions[i].color</b> is an optional color for the i-th interval.
96
+ * </ul>
97
+ *
98
+ * @option {Object} [formatOptions={title:true, footer:true}]
99
99
  * Options for displaying the title. by now just affecting the CODATA format.
100
- * <pre class="brush: js" title="Syntax:">
100
+ * <pre class="brush: js" title="Syntax:">
101
101
  * formatOptions : {
102
102
  * title:false,
103
103
  * footer:false
104
104
  * }
105
105
  * </pre>
106
- *
107
- * @example
106
+ *
107
+ * @example
108
108
  * var theSequence = "METLCQRLNVCQDKILTHYENDSTDLRDHIDYWKHMRLECAIYYKAREMGFKHINHQVVPTLAVSKNKALQAIELQLTLETIYNSQYSNEKWTLQDVSLEVYLTAPTGCIKKHGYTVEVQFDGDICNTMHYTNWTHIYICEEAojs SVTVVEGQVDYYGLYYVHEGIRTYFVQFKDDAEKYSKNKVWEVHAGGQVILCPTSVFSSNEVSSPEIIRQHLANHPAATHTKAVALGTEETQTTIQRPRSEPDTGNPCHTTKLLHRDSVDSAPILTAFNSSHKGRINCNSNTTPIVHLKGDANTLKCLRYRFKKHCTLYTAVSSTWHWTGHNVKHKSAIVTLTYDSEWQRDQFLSQVKIPKTITVSTGFMSI";
109
109
  * var mySequence = new Sequence({
110
110
  * sequence : theSequence,
@@ -112,14 +112,14 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
112
112
  * format : 'CODATA',
113
113
  * id : 'P918283',
114
114
  * annotations: [
115
- * { name:"CATH",
116
- * color:"#F0F020",
117
- * html: "Using color code #F0F020 ",
115
+ * { name:"CATH",
116
+ * color:"#F0F020",
117
+ * html: "Using color code #F0F020 ",
118
118
  * regions: [{start: 122, end: 135}]
119
119
  * },
120
- * { name:"TEST",
121
- * html:"&lt;br&gt; Example of &lt;b&gt;HTML&lt;/b&gt;",
122
- * color:"green",
120
+ * { name:"TEST",
121
+ * html:"&lt;br&gt; Example of &lt;b&gt;HTML&lt;/b&gt;",
122
+ * color:"green",
123
123
  * regions: [
124
124
  * {start: 285, end: 292},
125
125
  * {start: 293, end: 314, color: "#2E4988"}]
@@ -127,11 +127,11 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
127
127
  * ],
128
128
  * highlights : [
129
129
  * { start:30, end:42, color:"white", background:"green", id:"spin1" },
130
- * { start:139, end:140 },
130
+ * { start:139, end:140 },
131
131
  * { start:631, end:633, color:"white", background:"blue" }
132
132
  * ]
133
- * });
134
- *
133
+ * });
134
+ *
135
135
  */
136
136
 
137
137
  var Class = require('js-class');
@@ -162,8 +162,9 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
162
162
  // legacy: copy target id
163
163
  this.opt.target = this._container[0].id;
164
164
 
165
- // Lazy initialization
165
+ // Lazy initialization
166
166
  this._container.ready(function () {
167
+ this._ready = false;
167
168
  self._initialize();
168
169
  });
169
170
  },
@@ -184,7 +185,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
184
185
  annotations: [],
185
186
  sequenceUrl: 'http://www.ebi.ac.uk/das-srv/uniprot/das/uniprot/sequence',
186
187
 
187
- // Styles
188
+ // Styles
188
189
  selectionColor: 'Yellow',
189
190
  selectionFontColor: 'black',
190
191
  highlightFontColor: 'red',
@@ -209,13 +210,13 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
209
210
  * @eventData {string} type The name of the event.
210
211
  * @eventData {int} start A number indicating the start of the selection.
211
212
  * @eventData {int} end A number indicating the ending of selection.
212
- * @example
213
+ * @example
213
214
  * mySequence.onSelectionChanged(
214
215
  * function( objEvent ) {
215
216
  * alert("Selected: " + objEvent.start + ", " + objEvent.end );
216
217
  * }
217
- * );
218
- *
218
+ * );
219
+ *
219
220
  * */
220
221
  'onSelectionChanged',
221
222
 
@@ -227,14 +228,14 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
227
228
  * @eventData {string} type The name of the event.
228
229
  * @eventData {int} start A number indicating the start of the selection.
229
230
  * @eventData {int} end A number indicating the ending of selection.
230
- * @example
231
+ * @example
231
232
  * mySequence.onSelectionChange(
232
233
  * function( objEvent ) {
233
234
  * alert("Selection in progress: " + objEvent.start + ", " + objEvent.end );
234
235
  * }
235
- * );
236
- *
237
- *
236
+ * );
237
+ *
238
+ *
238
239
  * */
239
240
  'onSelectionChange',
240
241
 
@@ -246,13 +247,13 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
246
247
  * @eventData {string} type The name of the event.
247
248
  * @eventData {string} name The name of the selected annotation.
248
249
  * @eventData {int} pos A number indicating the position of the selected amino acid.
249
- * @example
250
+ * @example
250
251
  * mySequence.onAnnotationClicked(
251
252
  * function( objEvent ) {
252
253
  * alert("Clicked " + objEvent.name + " on position " + objEvent.pos );
253
254
  * }
254
- * );
255
- *
255
+ * );
256
+ *
256
257
  * */
257
258
  'onAnnotationClicked'
258
259
  ],
@@ -283,7 +284,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
283
284
  // DIV for the sequence
284
285
  this._contentDiv = jQuery('<div/>').appendTo(this._container);
285
286
 
286
- // Initialize highlighting
287
+ // Initialize highlighting
287
288
  this._highlights = this.opt.highlights;
288
289
 
289
290
  // Initialize annotations
@@ -315,6 +316,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
315
316
  this.clearSequence('No sequence available', '../biojs/css/images/warning_icon.png');
316
317
  }
317
318
 
319
+ this._ready = true;
318
320
  },
319
321
 
320
322
 
@@ -322,10 +324,10 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
322
324
  * Shows the columns indicated by the indexes array.
323
325
  * @param {string} seq The sequence strand.
324
326
  * @param {string} [identifier] Sequence identifier.
325
- *
326
- * @example
327
+ *
328
+ * @example
327
329
  * mySequence.setSequence("P99999");
328
- *
330
+ *
329
331
  */
330
332
  setSequence: function (seq, identifier) {
331
333
 
@@ -353,23 +355,18 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
353
355
  jQuery.ajax({
354
356
  url: self.opt.sequenceUrl,
355
357
  dataType: 'xml',
356
- data: { segment: accession },
357
- success: function (xml) {
358
- try {
359
-
360
- var sequenceNode = jQuery(xml).find('SEQUENCE:first');
361
- self.setSequence(sequenceNode.text(), sequenceNode.attr('id'), sequenceNode.attr('label'));
362
-
363
- } catch (e) {
364
- console.log('Error decoding response data: ' + e.message);
365
- self.clearSequence('No sequence available', '../biojs/css/images/warning_icon.png');
366
- }
367
-
368
- },
369
- error: function (jqXHR, textStatus, errorThrown) {
370
- console.log('Error decoding response data: ' + textStatus);
371
- self.clearSequence('Error requesting the sequence to the server ' + this.url, '../biojs/css/images/warning_icon.png');
358
+ data: { segment: accession }
359
+ }).done(function(xml) {
360
+ try {
361
+ var sequenceNode = jQuery(xml).find('SEQUENCE:first');
362
+ self.setSequence(sequenceNode.text(), sequenceNode.attr('id'), sequenceNode.attr('label'));
363
+ } catch (e) {
364
+ console.log('Error decoding response data: ' + e.message);
365
+ self.clearSequence('No sequence available', '../biojs/css/images/warning_icon.png');
372
366
  }
367
+ }).fail(function(jqXHR, textStatus, errorThrown) {
368
+ console.log('Error requesting the sequence: ' + textStatus);
369
+ self.clearSequence('Error requesting the sequence to the server ' + this.url, '../biojs/css/images/warning_icon.png');
373
370
  });
374
371
  },
375
372
 
@@ -377,10 +374,10 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
377
374
  * Shows the columns indicated by the indexes array.
378
375
  * @param {string} [showMessage] Message to be showed.
379
376
  * @param {string} [icon] Icon to be showed a side of the message
380
- *
381
- * @example
377
+ *
378
+ * @example
382
379
  * mySequence.clearSequence("No sequence available", "../biojs/css/images/warning_icon.png");
383
- *
380
+ *
384
381
  */
385
382
  clearSequence: function (showMessage, icon) {
386
383
 
@@ -414,9 +411,9 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
414
411
  * Set the current selection in the sequence causing the event {@link Sequence#onSelectionChanged}
415
412
  *
416
413
  * @example
417
- * // set selection from the position 100 to 150
414
+ * // set selection from the position 100 to 150
418
415
  * mySequence.setSelection(100, 150);
419
- *
416
+ *
420
417
  * @param {int} start The starting character of the selection.
421
418
  * @param {int} end The ending character of the selection
422
419
  */
@@ -440,6 +437,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
440
437
  _buildFormatSelector: function () {
441
438
  var self = this;
442
439
 
440
+ console.log('build format selector container', this._container);
443
441
  this._headerDiv = jQuery('<div></div>').appendTo(this._container);
444
442
  this._headerDiv.append('Format: ');
445
443
 
@@ -465,11 +463,11 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
465
463
  * @example
466
464
  * // highlight the characters within the position 100 to 150, included.
467
465
  * mySequence.addHighlight( { "start": 100, "end": 150, "color": "white", "background": "red", "id": "aaa" } );
468
- *
466
+ *
469
467
  * @param {Object} h The highlight defined as follows:
470
- *
471
- *
472
- * @return {int} representing the id of the highlight on the internal array. Returns -1 on failure
468
+ *
469
+ *
470
+ * @return {int} representing the id of the highlight on the internal array. Returns -1 on failure
473
471
  */
474
472
  addHighlight: function (h) {
475
473
  var id = '-1';
@@ -492,14 +490,17 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
492
490
 
493
491
  return id;
494
492
  },
495
- /*
493
+ /*
496
494
  * Function: Sequence._applyHighlight
497
495
  * Purpose: Apply the specified color and background to a region between 'start' and 'end'.
498
496
  * Returns: -
499
- * Inputs: highlight -> {Object} An object containing the fields start (int), end (int),
497
+ * Inputs: highlight -> {Object} An object containing the fields start (int), end (int),
500
498
  * color (HTML color string) and background (HTML color string).
501
499
  */
502
500
  _applyHighlight: function (highlight) {
501
+ var zindex = 0,
502
+ z = 0,
503
+ o = 0;
503
504
  var seq = this._contentDiv.find('.sequence');
504
505
  for (var i = highlight.start - 1; i < highlight.end; i++) {
505
506
  zindex = jQuery(seq[i]).css('z-index');
@@ -521,7 +522,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
521
522
  .addClass('highlighted');
522
523
  }
523
524
  },
524
- /*
525
+ /*
525
526
  * Function: Sequence._applyHighlights
526
527
  * Purpose: Apply the specified highlights.
527
528
  * Returns: -
@@ -532,7 +533,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
532
533
  this._applyHighlight(highlights[i]);
533
534
  }
534
535
  },
535
- /*
536
+ /*
536
537
  * Function: Sequence._restoreHighlights
537
538
  * Purpose: Repaint the highlights in the specified region.
538
539
  * Returns: -
@@ -563,10 +564,10 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
563
564
  }
564
565
  }
565
566
  },
566
- /*
567
+ /*
567
568
  * Function: Sequence._restoreSelection
568
- * Purpose: Repaint the current selection in the specified region.
569
- * It is used in the case of any highlight do overriding of the current selection.
569
+ * Purpose: Repaint the current selection in the specified region.
570
+ * It is used in the case of any highlight do overriding of the current selection.
570
571
  * Returns: -
571
572
  * Inputs: start -> {int} Start of the region to be restored.
572
573
  * end -> {int} End of the region to be restored.
@@ -594,7 +595,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
594
595
  * @example
595
596
  * // Clear the highlighted characters within the position 100 to 150, included.
596
597
  * mySequence.removeHighlight("spin1");
597
- *
598
+ *
598
599
  * @param {string} id The id of the highlight on the internal array. This value is returned by method highlight.
599
600
  */
600
601
  removeHighlight: function (id) {
@@ -631,7 +632,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
631
632
  * @example
632
633
  * // Set format to 'FASTA'.
633
634
  * mySequence.setFormat('FASTA');
634
- *
635
+ *
635
636
  * @param {string} format The format for the sequence to be displayed.
636
637
  */
637
638
  setFormat: function (format) {
@@ -655,7 +656,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
655
656
  * @example
656
657
  * // Set the number of columns to 70.
657
658
  * mySequence.setNumCols(70);
658
- *
659
+ *
659
660
  * @param {int} numCols The number of columns.
660
661
  */
661
662
  setNumCols: function (numCols) {
@@ -665,7 +666,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
665
666
 
666
667
  /**
667
668
  * Set the visibility of the drop-down list of formats.
668
- *
669
+ *
669
670
  * @param {boolean} visible true: show; false: hide.
670
671
  */
671
672
  formatSelectorVisible: function (visible) {
@@ -682,7 +683,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
682
683
  * @example
683
684
  * // Shows the format selector.
684
685
  * mySequence.showFormatSelector();
685
- *
686
+ *
686
687
  */
687
688
  showFormatSelector: function () {
688
689
  this._headerDiv.show();
@@ -690,11 +691,11 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
690
691
 
691
692
  /**
692
693
  * This is similar to a {Biojs.Protein3D#formatSelectorVisible} with the 'false' argument.
693
- *
694
+ *
694
695
  * @example
695
696
  * // Hides the format selector.
696
697
  * mySequence.hideFormatSelector();
697
- *
698
+ *
698
699
  */
699
700
  hideFormatSelector: function () {
700
701
  this._headerDiv.hide();
@@ -702,7 +703,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
702
703
 
703
704
  /**
704
705
  * Hides the whole component.
705
- *
706
+ *
706
707
  */
707
708
  hide: function () {
708
709
  this._headerDiv.hide();
@@ -711,15 +712,15 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
711
712
 
712
713
  /**
713
714
  * Shows the whole component.
714
- *
715
+ *
715
716
  */
716
717
  show: function () {
717
718
  this._headerDiv.show();
718
719
  this._contentDiv.show();
719
720
  },
720
- /*
721
+ /*
721
722
  * Function: Sequence._setSelection
722
- * Purpose: Update the current selection.
723
+ * Purpose: Update the current selection.
723
724
  * Returns: -
724
725
  * Inputs: start -> {int} Start of the region to be selected.
725
726
  * end -> {int} End of the region to be selected.
@@ -757,9 +758,9 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
757
758
  current.end = end;
758
759
  },
759
760
 
760
- /*
761
+ /*
761
762
  * Function: Sequence._repaintSelection
762
- * Purpose: Repaint the whole current selection.
763
+ * Purpose: Repaint the whole current selection.
763
764
  * Returns: -
764
765
  * Inputs: -
765
766
  */
@@ -769,9 +770,9 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
769
770
  this._setSelection(s.start, s.end);
770
771
  },
771
772
 
772
- /*
773
+ /*
773
774
  * Function: Sequence._redraw
774
- * Purpose: Repaint the current sequence.
775
+ * Purpose: Repaint the current sequence.
775
776
  * Returns: -
776
777
  * Inputs: -
777
778
  */
@@ -783,7 +784,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
783
784
  //this._contentDiv.text('');
784
785
  this._contentDiv.children().remove();
785
786
 
786
- // Rebuild the spans of the sequence
787
+ // Rebuild the spans of the sequence
787
788
  // according to format
788
789
  if (this.opt.format == 'RAW') {
789
790
  this._drawRaw();
@@ -801,9 +802,9 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
801
802
  this._repaintSelection();
802
803
  this._addSpanEvents();
803
804
  },
804
- /*
805
+ /*
805
806
  * Function: Sequence._drawFasta
806
- * Purpose: Repaint the current sequence using FASTA format.
807
+ * Purpose: Repaint the current sequence using FASTA format.
807
808
  * Returns: -
808
809
  * Inputs: -
809
810
  */
@@ -832,9 +833,9 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
832
833
 
833
834
  this._drawAnnotations(opt);
834
835
  },
835
- /*
836
+ /*
836
837
  * Function: Sequence._drawCodata
837
- * Purpose: Repaint the current sequence using CODATA format.
838
+ * Purpose: Repaint the current sequence using CODATA format.
838
839
  * Returns: -
839
840
  * Inputs: -
840
841
  */
@@ -884,11 +885,11 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
884
885
 
885
886
  this._drawAnnotations(opt);
886
887
  },
887
- /*
888
+ /*
888
889
  * Function: Sequence._drawAnnotations
889
- * Purpose: Paint the annotations on the sequence.
890
+ * Purpose: Paint the annotations on the sequence.
890
891
  * Returns: -
891
- * Inputs: settings -> {object}
892
+ * Inputs: settings -> {object}
892
893
  */
893
894
  _drawAnnotations: function (settings) {
894
895
 
@@ -961,9 +962,9 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
961
962
  });
962
963
 
963
964
  },
964
- /*
965
+ /*
965
966
  * Function: Sequence._getAnnotationString
966
- * Purpose: Get the annotation text message for the tooltip
967
+ * Purpose: Get the annotation text message for the tooltip
967
968
  * Returns: {string} Annotation text for the annotation
968
969
  * Inputs: id -> {int} index of the internal annotation array
969
970
  */
@@ -972,12 +973,12 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
972
973
  return annotation.name + '<br/>' + ((annotation.html) ? annotation.html : '');
973
974
  },
974
975
 
975
- /*
976
+ /*
976
977
  * Function: Sequence._getHTMLRowAnnot
977
978
  * Purpose: Build an annotation
978
979
  * Returns: HTML of the annotation
979
980
  * Inputs: currentPos -> {int}
980
- * annotation -> {Object}
981
+ * annotation -> {Object}
981
982
  * settings -> {Object}
982
983
  */
983
984
  _getHTMLRowAnnot: function (currentPos, annotation, settings) {
@@ -1030,9 +1031,9 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
1030
1031
 
1031
1032
  return (str.indexOf('span') == -1) ? '' : str;
1032
1033
  },
1033
- /*
1034
+ /*
1034
1035
  * Function: Sequence._drawRaw
1035
- * Purpose: Repaint the current sequence using RAW format.
1036
+ * Purpose: Repaint the current sequence using RAW format.
1036
1037
  * Returns: -
1037
1038
  * Inputs: -
1038
1039
  */
@@ -1059,9 +1060,9 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
1059
1060
 
1060
1061
  this._drawAnnotations(opt);
1061
1062
  },
1062
- /*
1063
+ /*
1063
1064
  * Function: Sequence._drawPride
1064
- * Purpose: Repaint the current sequence using PRIDE format.
1065
+ * Purpose: Repaint the current sequence using PRIDE format.
1065
1066
  * Returns: -
1066
1067
  * Inputs: -
1067
1068
  */
@@ -1087,9 +1088,9 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
1087
1088
  this._drawSequence(seq, opt);
1088
1089
  this._drawAnnotations(opt);
1089
1090
  },
1090
- /*
1091
+ /*
1091
1092
  * Function: Sequence._drawSequence
1092
- * Purpose: Repaint the current sequence using CUSTOM format.
1093
+ * Purpose: Repaint the current sequence using CUSTOM format.
1093
1094
  * Returns: -
1094
1095
  * Inputs: a -> {char[]} a The sequence strand.
1095
1096
  * opt -> {Object} opt The CUSTOM format.
@@ -1216,11 +1217,11 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
1216
1217
 
1217
1218
  return str;
1218
1219
  },
1219
- /*
1220
+ /*
1220
1221
  * Function: Sequence._formatIndex
1221
1222
  * Purpose: Build the HTML corresponding to counting numbers (top, left, right) in the strand.
1222
1223
  * Returns: -
1223
- * Inputs: number -> {int} The number
1224
+ * Inputs: number -> {int} The number
1224
1225
  * size -> {int} Number of bins to suit the number.
1225
1226
  * fillingChar -> {char} Character to be used for filling out blank bins.
1226
1227
  * alignLeft -> {bool} Tell if aligned to the left.
@@ -1241,7 +1242,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
1241
1242
  }
1242
1243
  return str;
1243
1244
  },
1244
- /*
1245
+ /*
1245
1246
  * Function: Sequence._addSpanEvents
1246
1247
  * Purpose: Add the event handlers to the strand.
1247
1248
  * Returns: -
@@ -1313,7 +1314,7 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
1313
1314
  })
1314
1315
  .css('cursor', 'pointer');
1315
1316
  },
1316
- /*
1317
+ /*
1317
1318
  * Function: Sequence._addTooltip
1318
1319
  * Purpose: Add a tooltip around the target DOM element provided as argument
1319
1320
  * Returns: -
@@ -1349,22 +1350,22 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
1349
1350
 
1350
1351
  /**
1351
1352
  * Annotate a set of intervals provided in the argument.
1352
- *
1353
+ *
1353
1354
  * @example
1354
1355
  * // Annotations using regions with different colors.
1355
1356
  * mySequence.addAnnotation({
1356
- * name:"UNIPROT",
1357
- * html:"&lt;br&gt; Example of &lt;b&gt;HTML&lt;/b&gt;",
1358
- * color:"green",
1357
+ * name:"UNIPROT",
1358
+ * html:"&lt;br&gt; Example of &lt;b&gt;HTML&lt;/b&gt;",
1359
+ * color:"green",
1359
1360
  * regions: [
1360
1361
  * {start: 540, end: 560},
1361
- * {start: 561, end:580, color: "#FFA010"},
1362
- * {start: 581, end:590, color: "red"},
1362
+ * {start: 561, end:580, color: "#FFA010"},
1363
+ * {start: 581, end:590, color: "red"},
1363
1364
  * {start: 690, end:710}]
1364
1365
  * });
1365
- *
1366
- *
1367
- * @param {Object} annotation The intervals belonging to the same annotation.
1366
+ *
1367
+ *
1368
+ * @param {Object} annotation The intervals belonging to the same annotation.
1368
1369
  * Syntax: { name: &lt;value&gt;, color: &lt;HTMLColorCode&gt;, html: &lt;HTMLString&gt;, regions: [{ start: &lt;startVal1&gt;, end: &lt;endVal1&gt;}, ..., { start: &lt;startValN&gt;, end: &lt;endValN&gt;}] }
1369
1370
  */
1370
1371
  addAnnotation: function (annotation) {
@@ -1374,13 +1375,13 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
1374
1375
 
1375
1376
  /**
1376
1377
  * Removes an annotation by means of its name.
1377
- *
1378
- * @example
1378
+ *
1379
+ * @example
1379
1380
  * // Remove the UNIPROT annotation.
1380
- * mySequence.removeAnnotation('UNIPROT');
1381
- *
1381
+ * mySequence.removeAnnotation('UNIPROT');
1382
+ *
1382
1383
  * @param {string} name The name of the annotation to be removed.
1383
- *
1384
+ *
1384
1385
  */
1385
1386
  removeAnnotation: function (name) {
1386
1387
  for (var i = 0; i < this._annotations.length; i++) {
@@ -1393,10 +1394,10 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
1393
1394
  },
1394
1395
  /**
1395
1396
  * Removes all the current annotations.
1396
- *
1397
- * @example
1398
- * mySequence.removeAllAnnotations();
1399
- *
1397
+ *
1398
+ * @example
1399
+ * mySequence.removeAllAnnotations();
1400
+ *
1400
1401
  */
1401
1402
  removeAllAnnotations: function () {
1402
1403
  this._annotations = [];
@@ -2454,4 +2455,3 @@ require = (function e(t, n, r) { function s(o, u) { if (!n[o]) { if (!t[o]) { va
2454
2455
 
2455
2456
  }, { './lib/index': 1 }]
2456
2457
  }, {}, ['biojs-vis-sequence']);
2457
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/lib/index.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-events/index.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-events/node_modules/backbone-events-standalone/backbone-events-standalone.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-events/node_modules/backbone-events-standalone/index.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/lib/generic_reader.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/lib/parser.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/lib/strings.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/lib/utils.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/lib/writer.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/node_modules/biojs-model/src/index.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/node_modules/biojs-model/src/seq.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/node_modules/nets/index.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/node_modules/nets/node_modules/xhr/index.js","node_modules/biojs-io-fasta/node_modules/nets/node_modules/xhr/node_modules/global/window.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/node_modules/nets/node_modules/xhr/node_modules/once/once.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/node_modules/nets/node_modules/xhr/node_modules/parse-headers/node_modules/for-each/index.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/node_modules/nets/node_modules/xhr/node_modules/parse-headers/node_modules/for-each/node_modules/is-function/index.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/node_modules/nets/node_modules/xhr/node_modules/parse-headers/node_modules/trim/index.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/node_modules/nets/node_modules/xhr/node_modules/parse-headers/parse-headers.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/jquery-browser-plugin/index.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/jquery-browser-plugin/jquery.browser.js","node_modules/js-class/class.js","/Users/priyam/sequenceserver/node_modules/biojs-vis-sequence/node_modules/biojs-io-fasta/lib/index.js","./index.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC75CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrRA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACjLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC9GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AChIA;AACA;AACA;AACA;AACA;;ACJA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","// legacy!!\n$.browser = require(\"jquery-browser-plugin\");\n\n/** \n * Sequence component \n * \n * @class\n * @extends Biojs\n * \n * @author <a href=\"mailto:johncar@gmail.com\">John Gomez</a>, <a href=\"mailto:secevalliv@gmail.com\">Jose Villaveces</a>\n * @version 1.0.0\n * @category 3\n * \n * @requires <a href='http://blog.jquery.com/2011/09/12/jquery-1-6-4-released/'>jQuery Core 1.6.4</a>\n * @dependency <script language=\"JavaScript\" type=\"text/javascript\" src=\"../biojs/dependencies/jquery/jquery-1.4.2.min.js\"></script>\n * \n * @requires <a href='http://jqueryui.com/download'>jQuery UI 1.8.16</a>\n * @dependency <script language=\"JavaScript\" type=\"text/javascript\" src=\"../biojs/dependencies/jquery/jquery-ui-1.8.2.custom.min.js\"></script>\n *\n * @requires <a href='Biojs.Tooltip.css'>Biojs.Tooltip</a>\n * @dependency <script language=\"JavaScript\" type=\"text/javascript\" src=\"src/Biojs.Tooltip.js\"></script>\n * \n * @param {Object} options An object with the options for Sequence component.\n *    \n * @option {string} target \n *    Identifier of the DIV tag where the component should be displayed.\n *    \n * @option {string} sequence \n *    The sequence to be displayed.\n *    \n * @option {string} [id] \n *    Sequence identifier if apply.\n *    \n * @option {string} [format=\"FASTA\"] \n *    The display format for the sequence representation.\n *    \n * @option {Object[]} [highlights] \n * \t  For highlighting multiple regions. \n *    <pre class=\"brush: js\" title=\"Syntax:\"> \n *    [\n *    \t// Highlight aminoacids from 'start' to 'end' of the current strand using the specified 'color' (optional) and 'background' (optional).\n *    \t{ start: &lt;startVal1&gt;, end: &lt;endVal1&gt; [, id:&lt;idVal1&gt;] [, color: &lt;HTMLColor&gt;] [, background: &lt;HTMLColor&gt;]}, \n *    \t//\n *    \t// Any others highlights\n *    \t...,  \n *    \t// \n *    \t{ start: &lt;startValN&gt;, end: &lt;endValN&gt; [, id:&lt;idValN&gt;] [, color: &lt;HTMLColor&gt;] [, background: &lt;HTMLColor&gt;]}\n *    ]</pre>\n * \n * <pre class=\"brush: js\" title=\"Example:\"> \n * highlights : [\n * \t\t{ start:30, end:42, color:\"white\", background:\"green\", id:\"spin1\" },\n *\t\t{ start:139, end:140 }, \n *\t\t{ start:631, end:633, color:\"white\", background:\"blue\" }\n *\t]\n * </pre>\n * \n * @option {Object} [columns={size:40,spacedEach:10}] \n * \t  Options for displaying the columns. Syntax: { size: &lt;numCols&gt;, spacedEach: &lt;numCols&gt;}\n * \n * @option {Object} [selection] \n * \t  Positions for the current selected region. Syntax: { start: &lt;startValue&gt;, end: &lt;endValue&gt;}\n * \n * @option {Object[]} [annotations] \n *    Set of overlapping annotations. Must be an array of objects following the syntax:\n *     \t\t<pre class=\"brush: js\" title=\"Syntax:\">\n *            [ \n *              // An annotation:\n *              { name: &lt;name&gt;, \n *                html: &lt;message&gt;, \n *                color: &lt;color_code&gt;, \n *                regions: [{ start: &lt;startVal1&gt;, end: &lt;endVal1&gt; color: &lt;HTMLColor&gt;}, ...,{ start: &lt;startValN&gt;, end: &lt;endValN&gt;, color: &lt;HTMLColor&gt;}] \n *              }, \n *              \n *              // ...\n *              // more annotations here \n *              // ...\n *            ]\n *    \t\t </pre>\n *    where:\n *      <ul>\n *        <li><b>name</b> is the unique name for the annotation</li>\n *        <li><b>html</b> is the message (can be HTML) to be displayed in the tool tip.</li>\n *        <li><b>color</b> is the default HTML color code for all the regions.</li>\n *        <li><b>regions</b> array of objects defining the intervals which belongs to the annotation.</li>\n *        <li><b>regions[i].start</b> is the starting character for the i-th interval.</li>\n *        <li><b>regions[i].end</b> is the ending character for the i-th interval.</li>\n *        <li><b>regions[i].color</b> is an optional color for the i-th interval.   \n *      </ul> \n *      \n * @option {Object} [formatOptions={title:true, footer:true}] \n * \t  Options for displaying the title. by now just affecting the CODATA format.\n *    <pre class=\"brush: js\" title=\"Syntax:\"> \n * \t\tformatOptions : {\n * \t\t\ttitle:false,\n * \t\t\tfooter:false\n * \t\t}\n *    </pre>\n *    \n * @example \n * var theSequence = \"METLCQRLNVCQDKILTHYENDSTDLRDHIDYWKHMRLECAIYYKAREMGFKHINHQVVPTLAVSKNKALQAIELQLTLETIYNSQYSNEKWTLQDVSLEVYLTAPTGCIKKHGYTVEVQFDGDICNTMHYTNWTHIYICEEAojs SVTVVEGQVDYYGLYYVHEGIRTYFVQFKDDAEKYSKNKVWEVHAGGQVILCPTSVFSSNEVSSPEIIRQHLANHPAATHTKAVALGTEETQTTIQRPRSEPDTGNPCHTTKLLHRDSVDSAPILTAFNSSHKGRINCNSNTTPIVHLKGDANTLKCLRYRFKKHCTLYTAVSSTWHWTGHNVKHKSAIVTLTYDSEWQRDQFLSQVKIPKTITVSTGFMSI\";\n * var mySequence = new Sequence({\n * \t\tsequence : theSequence,\n * \t\ttarget : \"YourOwnDivId\",\n * \t\tformat : 'CODATA',\n * \t\tid : 'P918283',\n * \t\tannotations: [\n *        { name:\"CATH\", \n * \t  \t\tcolor:\"#F0F020\", \n * \t  \t\thtml: \"Using color code #F0F020 \", \n * \t  \t\tregions: [{start: 122, end: 135}]\n * \t\t  },\n *        { name:\"TEST\", \n *          html:\"&lt;br&gt; Example of &lt;b&gt;HTML&lt;/b&gt;\", \n *          color:\"green\", \n *          regions: [\n *            {start: 285, end: 292},\n *            {start: 293, end: 314, color: \"#2E4988\"}]\n *        }\n *      ],\n *      highlights : [\n *      \t{ start:30, end:42, color:\"white\", background:\"green\", id:\"spin1\" },\n *      \t{ start:139, end:140 }, \n *      \t{ start:631, end:633, color:\"white\", background:\"blue\" }\n *      ]\n * });\t\n * \n */\n\nvar Class = require('js-class');\n\nvar EVT_ON_SELECTION_CHANGE= \"onSelectionChange\";\nvar EVT_ON_SELECTION_CHANGED= \"onSelectionChanged\";\nvar EVT_ON_ANNOTATION_CLICKED= \"onAnnotationClicked\";\n\nSequence = Class(\n/** @lends Sequence# */\n{\t\n\tconstructor: function (options) {\n\t\tvar self = this;\n\n    this.opt = jQuery.extend(this.opt,options);\n\n    this._container = jQuery(this.opt.target );\n    \n    // legacy support (target id without '#')\n    if(this._container.length == 0){\n      this._container = jQuery( \"#\" + this.opt.target )\n    }\n\n    if(this._container.length == 0){\n      console.log(\"empty target container\");\n    }\n\n    // legacy: copy target id\n    this.opt.target = this._container[0].id;\n\t\t\n\t\t// Lazy initialization \n\t\tthis._container.ready(function() {\n\t\t\tself._initialize();\n\t\t});\n\t},\n\t\n\t/**\n\t * Default values for the options\n\t * @name Sequence-opt\n\t */\n\topt : {\n\t\t\n\t\tsequence : \"\",\n\t\tid : \"\",\n\t\ttarget : \"\",\n\t\tformat : \"FASTA\",\n\t\tselection: { start: 0, end: 0 },\n\t\tcolumns: { size: 35, spacedEach: 10 },\n\t\thighlights : [],\n\t\tannotations: [],\n\t\tsequenceUrl: 'http://www.ebi.ac.uk/das-srv/uniprot/das/uniprot/sequence',\n\t\t\n\t\t// Styles \n\t\tselectionColor : 'Yellow',\n\t\tselectionFontColor : 'black',\n\t\thighlightFontColor : 'red',\n\t\thighlightBackgroundColor : 'white',\n\t\tfontFamily: '\"Andale mono\", courier, monospace',\n\t\tfontSize: '12px',\n\t\tfontColor : 'inherit',\n\t\tbackgroundColor : 'inherit',\n\t\twidth: undefined,\n\t\theight: undefined,\n\t\tformatSelectorVisible: true\n\t},\n\t\n\t/**\n\t * Array containing the supported event names\n\t * @name Sequence-eventTypes\n\t */\n\teventTypes : [\n\t\t/**\n\t\t * @name Sequence#onSelectionChanged\n\t\t * @event\n\t\t * @param {function} actionPerformed An function which receives an {@link Biojs.Event} object as argument.\n\t\t * @eventData {Object} source The component which did triggered the event.\n\t\t * @eventData {string} type The name of the event.\n\t\t * @eventData {int} start A number indicating the start of the selection.\n\t\t * @eventData {int} end A number indicating the ending of selection.\n\t\t * @example \n\t\t * mySequence.onSelectionChanged(\n\t\t *    function( objEvent ) {\n\t\t *       alert(\"Selected: \" + objEvent.start + \", \" + objEvent.end );\n\t\t *    }\n\t\t * ); \n\t\t * \n\t\t * */\n\t\t\"onSelectionChanged\",\n\t\t\n\t\t/**\n\t\t * @name Sequence#onSelectionChange\n\t\t * @event\n\t\t * @param {function} actionPerformed An function which receives an {@link Biojs.Event} object as argument.\n\t\t * @eventData {Object} source The component which did triggered the event.\n\t\t * @eventData {string} type The name of the event.\n\t\t * @eventData {int} start A number indicating the start of the selection.\n\t\t * @eventData {int} end A number indicating the ending of selection.\n\t\t * @example \n\t\t * mySequence.onSelectionChange(\n\t\t *    function( objEvent ) {\n\t\t *       alert(\"Selection in progress: \" + objEvent.start + \", \" + objEvent.end );\n\t\t *    }\n\t\t * );  \n\t\t * \n\t\t * \n\t\t * */\n\t\t\"onSelectionChange\",\n\t\t\n\t\t/**\n\t\t * @name Sequence#onAnnotationClicked\n\t\t * @event\n\t\t * @param {function} actionPerformed An function which receives an {@link Biojs.Event} object as argument.\n\t\t * @eventData {Object} source The component which did triggered the event.\n\t\t * @eventData {string} type The name of the event.\n\t\t * @eventData {string} name The name of the selected annotation.\n\t\t * @eventData {int} pos A number indicating the position of the selected amino acid.\n\t\t * @example \n\t\t * mySequence.onAnnotationClicked(\n\t\t *    function( objEvent ) {\n\t\t *       alert(\"Clicked \" + objEvent.name + \" on position \" + objEvent.pos );\n\t\t *    }\n\t\t * );  \n\t\t * \n\t\t * */\n\t\t\"onAnnotationClicked\"\n\t],\n\n  getId : function () {\n    return this.opt.id;\n  },\n\n\t// internal members\n\t_headerDiv : null,\n\t_contentDiv : null,\n\t\n\t// Methods\n\n\t_initialize: function () {\n\t\t\n\t\tif ( this.opt.width !== undefined ) {\n\t\t\tthis._container.width( this.opt.width );\n\t\t}\n\t\t\n\t\tif ( this.opt.height !== undefined ) {\n\t\t\tthis._container.height( this.opt.height );\n\t\t}\n\t\t\n\t\t// Disable text selection\n\t\t\n\t\tthis._container.css({\n\t\t\t'-moz-user-select':'none',\n\t\t\t'-webkit-user-select':'none',\n\t\t\t'user-select':'none'\n        });\n\t\t\n\t\t// DIV for the format selector\n\t\tthis._buildFormatSelector();\n\t\t\n\t\t// DIV for the sequence\n\t\tthis._contentDiv = jQuery('<div></div>').appendTo(this._container);\n\t\tthis._contentDiv.css({\n\t\t\t\t'font-family': this.opt.fontFamily,\n\t\t\t\t'font-size': this.opt.fontSize,\n\t\t\t\t'text-align': 'left'\n\t\t\t});\n\t\t\n\t\t// Initialize highlighting \n\t\tthis._highlights = this.opt.highlights;\n\t\t\n\t\t// Initialize annotations\n\t\tthis._annotations = this.opt.annotations;\n\t\t\n\t\t//Initialize tooltip\n\t\tvar tooltip = \"sequenceTip\" + this.opt.target ;\n\t\tjQuery('<div id=\"' + tooltip + '\"></div>') \n\t        .css({\t\n\t        \t'position': \"absolute\",\n\t        \t'z-index': \"999999\",\n\t        \t'color': \"#fff\",\n\t        \t'font-size': \"12px\",\n\t        \t'width': \"auto\",\n\t        \t'display': 'none'\n\t        })\n\t        .addClass(\"tooltip\")\n\t        .appendTo(\"body\")\n\t        .hide();\n\t\tthis.opt._tooltip = document.getElementById(tooltip);\n\n\t\tif ( (this.opt.sequence) ) {\n\t\t\tthis._redraw();\n\t\t\t\n\t\t} else if (  (this.opt.id) ) {\n\t\t\tthis._requestSequence( this.opt.id );\n\t\t\t\n\t\t} else {\n\t\t\tthis.clearSequence(\"No sequence available\", \"../biojs/css/images/warning_icon.png\");\n\t\t}\n\t\t\n\t},\n\t\n\t\n\t/**\n\t * Shows the columns indicated by the indexes array.\n\t * @param {string} seq The sequence strand.\n\t * @param {string} [identifier] Sequence identifier.\n\t * \n\t * @example \n\t * mySequence.setSequence(\"P99999\");\n\t * \n\t */\n    setSequence: function ( seq, identifier ) {\n\n    \tif ( seq.match(/^([A-N,R-Z][0-9][A-Z][A-Z, 0-9][A-Z, 0-9][0-9])|([O,P,Q][0-9][A-Z, 0-9][A-Z, 0-9][A-Z, 0-9][0-9])(\\.\\d+)?$/i) ) {\n    \t\tthis._requestSequence( arguments[0] );\n    \t\t\n    \t} else {\n    \t\tthis.opt.sequence = seq;\n        \tthis.opt.id = identifier; \n        \tthis._highlights = [];\n    \t\tthis._highlightsCount = 0;\n    \t\tthis.opt.selection = { start: 0, end: 0 };\n    \t\tthis._annotations = [];\n    \t\t\n    \t\tthis._contentDiv.children().remove();\n    \t\tthis._redraw();\n    \t}\n    },\n    \n    _requestSequence: function ( accession ) {\n\t\tvar self = this;\n    \t\n    \tconsole.log(\"Requesting sequence for: \" + accession );\n\n\t\tjQuery.ajax({ \n\t\t\turl: self.opt.sequenceUrl,\n\t\t\tdataType: \"xml\",\n\t\t\tdata: { segment: accession },\n\t\t\tsuccess: function ( xml  ) {\n\t\t\t\ttry {\n\t\t\t\t\t\n\t\t\t\t\tvar sequenceNode = jQuery(xml).find('SEQUENCE:first');\n\t\t\t\t\tself.setSequence( sequenceNode.text(), sequenceNode.attr(\"id\"), sequenceNode.attr(\"label\") );\n\t\t\t\t\t\n\t\t\t\t} catch (e) {\n\t\t\t\t\tconsole.log(\"Error decoding response data: \" + e.message );\n\t\t\t\t\tself.clearSequence(\"No sequence available\", \"../biojs/css/images/warning_icon.png\");\n\t\t\t\t}\n\n\t\t\t},\n\t\t\terror: function (jqXHR, textStatus, errorThrown) {\n\t\t\t\tconsole.log(\"Error decoding response data: \" + textStatus );\n\t\t\t\tself.clearSequence(\"Error requesting the sequence to the server \" + this.url , \"../biojs/css/images/warning_icon.png\");\n\t\t\t}\n\t\t});\n    },\n\t\n    /**\n\t * Shows the columns indicated by the indexes array.\n\t * @param {string} [showMessage] Message to be showed.\n\t * @param {string} [icon] Icon to be showed a side of the message\n\t * \n\t * @example \n\t * mySequence.clearSequence(\"No sequence available\", \"../biojs/css/images/warning_icon.png\");\n\t * \n\t */\n    clearSequence: function ( showMessage, icon ) {\n    \t\n    \tvar message = undefined;\n    \t\t\n    \tthis.opt.sequence = \"\";\n    \tthis.opt.id = \"\"; \n    \tthis._highlights = [];\n\t\tthis._highlightsCount = 0;\n\t\tthis.opt.selection = { start: 0, end: 0 };\n\t\tthis._annotations = [];\n\t\tthis._contentDiv.children().remove();\n\t\t\n\t\tthis._headerDiv.hide();\n\t\t\n\t\tif ( undefined !== showMessage ) {\n\t\t\tmessage = jQuery('<div>' + showMessage + '</div>')\n\t\t\t\t.appendTo(this._contentDiv)\n\t\t\t\t.addClass(\"message\");\n\t\t\t\n\t\t\tif ( undefined !== icon ) {\n\t\t\t\tmessage.css({\n\t\t\t\t\t'background': 'transparent url(\"' + icon + '\") no-repeat center left',\n\t\t\t\t\t'padding-left': '20px'\n\t\t\t\t});\n\t\t\t}\n\t\t}\n    },\n\t\n\t/**\n    * Set the current selection in the sequence causing the event {@link Sequence#onSelectionChanged}\n    *\n    * @example\n    * // set selection from the position 100 to 150 \n    * mySequence.setSelection(100, 150);\n    * \n    * @param {int} start The starting character of the selection.\n    * @param {int} end The ending character of the selection\n    */\n\tsetSelection : function(start, end) {\n\t\tif(start > end) {\n\t\t\tvar aux = end;\n\t\t\tend = start;\n\t\t\tstart = aux;\n\n\t\t}\n\n\t\tif(start != this.opt.selection.start || end != this.opt.selection.end) {\n\t\t\tthis._setSelection(start, end);\n\t\t\tthis.trigger(\n\t\t\t\t\tEVT_ON_SELECTION_CHANGED, \n\t\t\t\t\t{ \"start\" : start, \"end\" : end }\n\t\t\t);\n\t\t}\n\t},\n\t\n\t_buildFormatSelector: function () {\n\t\tvar self = this;\n\t\t\n\t\tthis._headerDiv = jQuery('<div></div>').appendTo(this._container);\n\t\tthis._headerDiv.css({\n\t\t\t'font-family': '\"Heveltica Neue\", Arial, \"sans serif\"',\n\t\t\t'font-size': '14px'\t\n\t\t}).append('Format: ');\n\t\t\n\t\tthis._formatSelector = jQuery('<select> '+\n\t\t\t\t'<option value=\"FASTA\">FASTA</option>'+\n\t\t\t\t'<option value=\"CODATA\">CODATA</option>'+\n\t\t\t\t'<option value=\"PRIDE\">PRIDE</option>'+\n\t\t\t\t'<option value=\"RAW\">RAW</option></select>').appendTo(self._headerDiv);\n\n\t\tthis._formatSelector.change(function(e) {\n\t\t\tself.opt.format = jQuery(this).val();\n\t\t\tself._redraw();\n\t\t});\n\t\t\n\t\tthis._formatSelector.val(self.opt.format);\t\n\t\t\n\t\tthis.formatSelectorVisible( this.opt.formatSelectorVisible );\n\t},\n\t\n\t/**\n    * Highlights a region using the font color defined in {Biojs.Protein3D#highlightFontColor} by default is red.\n    *\n    * @deprecated use addHighlight instead.\n    * \n    * @param {int} start The starting character of the highlighting.\n    * @param {int} end The ending character of the highlighting.\n    * @param {string} [color] HTML color code.\n    * @param {string} [background] HTML color code.\n    * @param {string} [id] Custom identifier.\n    * \n    * @return {int} representing the id of the highlight on the internal array. Returns -1 on failure  \n    */\n\thighlight : function (start, end, color, background, id ) {\n\t\treturn this.addHighlight({ \"start\": start, \"end\": end, \"color\": color, \"background\": background, \"id\": id });\n\t},\n\t\n\t/**\n    * Highlights a region using the font color defined in {Sequence#highlightFontColor} by default is red.\n    *\n    * @example\n    * // highlight the characters within the position 100 to 150, included.\n    * mySequence.addHighlight( { \"start\": 100, \"end\": 150, \"color\": \"white\", \"background\": \"red\", \"id\": \"aaa\" } );\n    * \n    * @param {Object} h The highlight defined as follows:\n    * \t\n    * \n    * @return {int} representing the id of the highlight on the internal array. Returns -1 on failure  \n    */\n\taddHighlight : function ( h ) {\n\t\tvar id = '-1';\n\t\tvar color = \"\";\n\t\tvar background = \"\";\n\t\tvar highlight = {};\n\t\t\n\t\tif ( h instanceof Object && h.start <= h.end ) {\n\t\t\t\n\t\t\tcolor = ( \"string\" == typeof h.color )? h.color : this.opt.highlightFontColor;\n\t\t\tbackground = ( \"string\" == typeof h.background )? h.background : this.opt.highlightBackgroundColor;\n\t\t\tid = ( \"string\" == typeof h.id )? h.id : (new Number(this._highlightsCount++)).toString();\n\t\t\t\n\t\t\thighlight = { \"start\": h.start, \"end\": h.end, \"color\": color, \"background\": background, \"id\": id };\n\t\t\t\n\t\t\tthis._highlights.push(highlight);\n\t\t\tthis._applyHighlight(highlight);\n\t\t\tthis._restoreSelection(h.start,h.end);\n\t\t} \n\t\t\n\t\treturn id;\n\t},\n\t/* \n     * Function: Sequence._applyHighlight\n     * Purpose:  Apply the specified color and background to a region between 'start' and 'end'.\n     * Returns:  -\n     * Inputs: highlight -> {Object} An object containing the fields start (int), end (int), \n     * \t\t\t\t\t\tcolor (HTML color string) and background (HTML color string).\n     */\n\t_applyHighlight: function ( highlight ) {\t\t\n\t\tvar seq = this._contentDiv.find('.sequence');\n\t\tfor ( var i = highlight.start - 1; i < highlight.end; i++ ){\n\t\t\tzindex = jQuery(seq[i]).css(\"z-index\");\n\t\t\tif (zindex==\"auto\"){\n\t\t\t\t z = 1;\n\t\t\t\t o = 1;\n\t\t\t }\n\t\t\t else{\n\t\t\t\t z = 0;\n\t\t\t\t o = 0.5;\n\t\t\t }\n\t\t\tjQuery(seq[i])\n\t\t\t\t.css({ \n\t\t\t\t\t\"color\": highlight.color,\n\t\t\t\t\t\"background-color\": highlight.background,\n\t\t\t\t\t\"z-index\": z,\n\t\t\t\t\t\"opacity\": o\n\t\t\t\t\t})\n\t\t\t\t.addClass(\"highlighted\");\n\t\t}\n\t},\n\t/* \n     * Function: Sequence._applyHighlights\n     * Purpose:  Apply the specified highlights.\n     * Returns:  -\n     * Inputs: highlights -> {Object[]} An array containing the highlights to be applied.\n     */\n\t_applyHighlights: function ( highlights ) {\n\t\tfor ( var i in highlights ) {\n\t\t\tthis._applyHighlight(highlights[i]);\n\t\t}\n\t},\n\t/* \n     * Function: Sequence._restoreHighlights\n     * Purpose:  Repaint the highlights in the specified region.\n     * Returns:  -\n     * Inputs: start -> {int} Start of the region to be restored.\n     * \t\t   end -> {int} End of the region to be restored.\n     */\n\t_restoreHighlights: function ( start, end ) {\n\t\tvar h = this._highlights;\n\t\t// paint the region using default blank settings\n\t\tthis._applyHighlight({\n\t\t\t\"start\": start, \n\t\t\t\"end\": end, \n\t\t\t\"color\": this.opt.fontColor, \n\t\t\t\"background\": this.opt.backgroundColor \n\t\t});\n\t\t// restore highlights in that region\n\t\tfor ( var i in h ) {\n\t\t\t// interval intersects with highlight i ?\n\t\t\tif ( !( h[i].start > end || h[i].end < start ) ) {\n\t\t\t\ta = ( h[i].start < start ) ? start : h[i].start;\n\t\t\t\tb = ( h[i].end > end ) ? end : h[i].end;\n\t\t\t\tthis._applyHighlight({\n\t\t\t\t\t\"start\": a, \n\t\t\t\t\t\"end\": b, \n\t\t\t\t\t\"color\": h[i].color, \n\t\t\t\t\t\"background\": h[i].background \n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t},\n\t/* \n     * Function: Sequence._restoreSelection\n     * Purpose:  Repaint the current selection in the specified region. \n     * \t\t\t It is used in the case of any highlight do overriding of the current selection. \n     * Returns:  -\n     * Inputs: start -> {int} Start of the region to be restored.\n     * \t\t   end -> {int} End of the region to be restored.\n     */\n\t_restoreSelection: function ( start, end ) {\n\t\tvar sel = this.opt.selection;\n\t\t// interval intersects with current selection ?\n\t\t// restore selection\n\t\tif ( !( start > sel.end || end < sel.start ) ) {\n\t\t\ta = ( start < sel.start ) ? sel.start : start;\n\t\t\tb = ( end > sel.end ) ? sel.end : end;\n\t\t\t\n\t\t\tthis._applyHighlight({\n\t\t\t\t\"start\": a, \n\t\t\t\t\"end\": b, \n\t\t\t\t\"color\": this.opt.selectionFontColor, \n\t\t\t\t\"background\": this.opt.selectionColor,\n\t\t\t});\n\t\t}\n\t},\n\t\n\t/**\n    * Clear a highlighted region using.\n    *\n    * @deprecated use removeHighlight instead.\n    * \n    * @param {int} id The id of the highlight on the internal array. This value is returned by method highlight.\n    */\n\tunHighlight : function (id) {\t\n\t\tthis.removeHighlight(id);\n\t},\n\t\n\t/**\n    * Remove a highlight.\n    *\n    * @example\n    * // Clear the highlighted characters within the position 100 to 150, included.\n    * mySequence.removeHighlight(\"spin1\");\n    * \n    * @param {string} id The id of the highlight on the internal array. This value is returned by method highlight.\n    */\n\tremoveHighlight : function (id) {\t\n\t\tvar h = this._highlights;\n\t\tfor ( i in h ) {\n\t\t\tif ( h[i].id == id ) {\n\t\t\t\tstart = h[i].start;\n\t\t\t\tend = h[i].end;\n\t\t\t\th.splice(i,1);\n\t\t\t\t\n\t\t\t\tthis._restoreHighlights(start,end);\n\t\t\t\tthis._restoreSelection(start,end);\n\t\t\t\t\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t},\n\t\n\t/**\n    * Clear the highlights of whole sequence.\n    * @deprecated use removeAllHighlights instead.\n    */\n\tunHighlightAll : function () {\n\t\tthis.removeAllHighlights();\n\t},\n\t\n\t/**\n    * Remove all the highlights of whole sequence.\n    *\n    * @example\n    * mySequence.removeAllHighlights();\n    */\n\tremoveAllHighlights : function () {\n\t\tthis._highlights = [];\n\t\tthis._restoreHighlights(1,this.opt.sequence.length);\n\t\tthis._restoreSelection(1,this.opt.sequence.length);\n\t},\n\t\n\t/**\n    * Changes the current displaying format of the sequence.\n    *\n    * @example\n    * // Set format to 'FASTA'.\n    * mySequence.setFormat('FASTA');\n    * \n    * @param {string} format The format for the sequence to be displayed.\n    */\n\tsetFormat : function(format) {\n\t\tif ( this.opt.format != format.toUpperCase() ) {\n\t\t\tthis.opt.format = format.toUpperCase();\n\t\t\tthis._redraw();\n\t\t}\n\n\t\tvar self = this;\n\t\t// Changes the option in the combo box\n\t\tthis._headerDiv.find('option').each(function() {\n\t\t\tif(jQuery(this).val() == self.opt.format.toUpperCase()) {\n\t\t\t\tjQuery(this).attr('selected', 'selected');\n\t\t\t}\n\t\t});\n\t},\n\t\n\t/**\n    * Changes the current number of columns in the displayed sequence.\n    *\n    * @example\n    * // Set the number of columns to 70.\n    * mySequence.setNumCols(70);\n    * \n    * @param {int} numCols The number of columns.\n    */\n\tsetNumCols : function(numCols) {\n\t\tthis.opt.columns.size = numCols;\n\t\tthis._redraw();\n\t},\n\t\n\t/**\n    * Set the visibility of the drop-down list of formats.\n    * \n    * @param {boolean} visible true: show; false: hide.\n    */\n\tformatSelectorVisible : function (visible){\n\t\tif (visible) {\n\t\t\tthis._headerDiv.show();\n\t\t} else {\n\t\t\tthis._headerDiv.hide();\n\t\t}\n\t},\n\t\n\t/**\n    * This is similar to a {Biojs.Protein3D#formatSelectorVisible} with the 'true' argument.\n    *\n    * @example\n    * // Shows the format selector.\n    * mySequence.showFormatSelector();\n    * \n    */\n\tshowFormatSelector : function() {\n\t\tthis._headerDiv.show();\n\t},\n\t\n\t/**\n    * This is similar to a {Biojs.Protein3D#formatSelectorVisible} with the 'false' argument.\n    * \n    * @example\n    * // Hides the format selector.\n    * mySequence.hideFormatSelector();\n    * \n    */\n\thideFormatSelector : function() {\n\t\tthis._headerDiv.hide();\n\t},\n\t\n\t/**\n    * Hides the whole component.\n    * \n    */\n\thide : function () {\n\t\tthis._headerDiv.hide();\n\t\tthis._contentDiv.hide();\n\t},\n\n\t/**\n    * Shows the whole component.\n    * \n    */\n\tshow : function () {\n\t\tthis._headerDiv.show();\n\t\tthis._contentDiv.show();\n\t},\n\t/* \n     * Function: Sequence._setSelection\n     * Purpose:  Update the current selection. \n     * Returns:  -\n     * Inputs: start -> {int} Start of the region to be selected.\n     * \t\t   end -> {int} End of the region to be selected.\n     */\n\t_setSelection : function(start, end) {\n\t\t//alert(\"adsas\");\n\t\t\n\t\tvar current = this.opt.selection;\n\t\tvar change = {};\n\t\t\n\t\t// Which is the change on selection?\n\t\tif ( current.start == start ) {\n\t\t\t// forward?\n\t\t\tif ( current.end < end ) {\n\t\t\t\tchange.start = current.end;\n\t\t\t\tchange.end = end;\n\t\t\t} else {\n\t\t\t\tthis._restoreHighlights(end+1, current.end);\n\t\t\t}\n\t\t} else if ( current.end == end ) {\n\t\t\t// forward?\n\t\t\tif ( current.start > start ) {\n\t\t\t\tchange.start = start;\n\t\t\t\tchange.end = current.start;\t\t\t\t\n\t\t\t} else {\n\t\t\t\tthis._restoreHighlights(current.start, start-1);\n\t\t\t}\n\t\t} else {\n\t\t\tthis._restoreHighlights(current.start, current.end);\n\t\t\tchange.start = start;\n\t\t\tchange.end = end;\n\t\t}\n\n\t\tcurrent.start = start;\n\t\tcurrent.end = end;\n\n\t\tif ( change.start != undefined ) {\n\t\t\tthis._applyHighlight({\n\t\t\t\t\"start\": change.start, \n\t\t\t\t\"end\": change.end, \n\t\t\t\t\"color\": this.opt.selectionFontColor, \n\t\t\t\t\"background\": this.opt.selectionColor \n\t\t\t});\n\t\t}\n\t\t\n\t},\n\t\n\t/* \n     * Function: Sequence._repaintSelection\n     * Purpose:  Repaint the whole current selection. \n     * Returns:  -\n     * Inputs: -\n     */\n\t_repaintSelection: function(){\n\t\tvar s = this.opt.selection;\n\t\tthis._setSelection(0,0);\n\t\tthis._setSelection(s.start,s.end);\n\t},\n\t\n\t/* \n     * Function: Sequence._redraw\n     * Purpose:  Repaint the current sequence. \n     * Returns:  -\n     * Inputs: -\n     */\n\t_redraw : function() {\n\t\tvar i = 0;\t\n\t\tvar self = this;\n\t\t\n\t\t// Reset the content\n\t\t//this._contentDiv.text('');\n\t\tthis._contentDiv.children().remove();\n\t\t\n\t\t// Rebuild the spans of the sequence \n\t\t// according to format\n\t\tif(this.opt.format == 'RAW') {\n\t\t\tthis._drawRaw();\n\t\t} else if(this.opt.format == 'CODATA') {\n\t\t\tthis._drawCodata();\n\t\t} else if (this.opt.format == 'FASTA'){\n\t\t\tthis._drawFasta();\n\t\t} else {\n\t\t\tthis.opt.format = 'PRIDE';\n\t\t\tthis._drawPride();\n\t\t}\n\t\t\n\t\t// Restore the highlighted regions\n\t\tthis._applyHighlights(this._highlights);\n\t\tthis._repaintSelection();\n\t\tthis._addSpanEvents();\n\t},\n\t/* \n     * Function: Sequence._drawFasta\n     * Purpose:  Repaint the current sequence using FASTA format.  \n     * Returns:  -\n     * Inputs: -\n     */\n\t_drawFasta : function() {\n\t\tvar self = this;\n\t\tvar a = this.opt.sequence.toUpperCase().split('');\n\t\tvar pre = jQuery('<pre></pre>').appendTo(this._contentDiv);\n\n\t\tvar i = 1;\n\t\tvar arr = [];\n\t    var str = '>' + this.opt.id + ' ' + a.length + ' bp<br/>';\n\t\t\n\t\t/* Correct column size in case the sequence is as small peptide */\n\t\tvar numCols = this.opt.columns.size;\n\t\tif ( this.opt.sequence.length < this.opt.columns.size ) {\n\t\t\tnumCols = this.opt.sequence.length;\t\n\t\t}\n\t\t\n\t    var opt = {\n\t\t\tnumCols: numCols,\n\t\t    numColsForSpace: 0\n\t\t};\n\n\t\tstr += this._drawSequence(a, opt);\n\t\tpre.html(str);\n\t\t\n\t\tthis._drawAnnotations(opt);\n\t},\n\t/* \n     * Function: Sequence._drawCodata\n     * Purpose:  Repaint the current sequence using CODATA format.  \n     * Returns:  -\n     * Inputs: -\n     */\n\t_drawCodata : function() {\n\t\t\n\t\tvar self = this;\n\t\tvar a = this.opt.sequence.toUpperCase().split('');\n\t\tvar pre = jQuery('<pre style=\"white-space:pre\"></pre>').appendTo(this._contentDiv);\n\n\t\tvar i = 0;\n\t\tvar str = 'ENTRY           ' + this.opt.id + '<br/>';\n\t\tstr += 'SEQUENCE<br/>';\n\t\tif ( this.opt.formatOptions !== undefined ){\n\t\t\tif(this.opt.formatOptions.title !== undefined ){\n\t\t\t\tif (this.opt.formatOptions.title == false) {\n\t\t\t\t\tstr = '';\n\t\t\t\t}\t\t\t\n\t\t\t}\n\t\t} \n\t\t\n\t\t/* Correct column size in case the sequence is as small peptide */\n\t\tvar numCols = this.opt.columns.size;\n\t\tif ( this.opt.sequence.length < this.opt.columns.size ) {\n\t\t\tnumCols = this.opt.sequence.length;\t\n\t\t}\n\t\t\n\t\tvar opt = {\n\t\t\t\tnumLeft: true,\n\t\t\t\tnumLeftSize: 7,\n\t\t\t\tnumLeftPad:' ',\n\t\t\t\tnumTop: true,\n\t\t\t\tnumTopEach: 5,\n\t\t\t\tnumCols: numCols,\n\t\t\t    numColsForSpace: 0,\n\t\t\t    spaceBetweenChars: true\n\t\t};\n\t\t\n\t\tstr += this._drawSequence(a, opt);\n\t\t\n\t\tvar footer = '<br/>///';\n\t\tif (this.opt.formatOptions !== undefined) {\n\t\t\tif (this.opt.formatOptions.footer !== undefined) {\n\t\t\t\tif (this.opt.formatOptions.footer == false) {\n\t\t\t\t\tfooter = '';\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tstr += footer;\n\t\tpre.html(str);\n\t\t\n\t\tthis._drawAnnotations(opt);\n\t},\n\t/* \n     * Function: Sequence._drawAnnotations\n     * Purpose:  Paint the annotations on the sequence.  \n     * Returns:  -\n     * Inputs: settings -> {object} \n     */\n    _drawAnnotations: function ( settings ){ \n    \t\n    \tvar self = this;\n    \tvar a = this.opt.sequence.toLowerCase().split('');    \t\n    \tvar annotations = this._annotations;\n    \tvar leftSpaces = '';\n    \tvar row = '';\n    \tvar annot = '';\n    \t\n    \t// Index at the left?\n\t\tif ( settings.numLeft ) {\n\t\t\tleftSpaces += this._formatIndex(' ', settings.numLeftSize+2, ' ');\n\t\t}\n\n\t\tfor ( var i = 0; i < a.length; i += settings.numCols ){\n\t\t\trow = '';\n\t\t\tfor ( var key in annotations ){\n\t\t\t\tannotations[key].id = this.getId() + \"_\" + key;\n\t\t\t\tannot = this._getHTMLRowAnnot(i+1, annotations[key], settings);\t\t\t\t\n\t\t\t\tif (annot.length > 0) {\n\t\t\t\t\trow += '<br/>';\n\t\t\t\t\trow += leftSpaces;\n\t\t\t\t\trow += annot;\n\t\t\t\t\trow += '<br/>';\n\t\t\t\t} \n\t\t\t}\n\t\t\t\n\t\t\tvar numCols = settings.numCols;\n\t\t\tvar charRemaining = a.length-i;\n\t\t\tif(charRemaining < numCols){\n\t\t\t\tnumCols\t= charRemaining;\n\t\t\t}\n\t\t\t\n\t\t\tif ( settings.numRight ) {\n\t\t\t\tjQuery(row).insertAfter('div#'+self.opt.target+' div pre span#numRight_' + this.getId() + '_' + (i + numCols) );\n\t\t\t} else {\n\t\t\t\tjQuery(row).insertAfter('div#'+self.opt.target+' div pre span#'+ this.getId() + '_' + (i + numCols) );\n\t\t\t}\n\t\t}\n\t\t\n\t\t// add tool tips and background' coloring effect\n\t\tjQuery(this._contentDiv).find('.annotation').each( function(){\n\t\t\tself._addToolTip( this, function() {\n\t\t\t\treturn self._getAnnotationString( jQuery(this).attr(\"id\") );\n\t\t\t});\n\t\t\t\n\t\t\tjQuery(this).mouseover(function(e) {\n\t\t\t\tjQuery('.annotation.'+jQuery(e.target).attr(\"id\")).each(function(){\n\t\t\t\t\tjQuery(this).css(\"background-color\", jQuery(this).attr(\"color\") );\n\t\t\t\t});\n\t\t    }).mouseout(function() {\n\t\t    \tjQuery('.annotation').css(\"background-color\", \"transparent\"); \n\t\t    \t\n\t\t    }).click(function(e) {\n\t\t    \t\tvar name = undefined;\n\t\t    \t\tvar id = jQuery(e.target).attr(\"id\");\n\t\t    \t\tfor(var i =0; i < self._annotations.length;i++){\n              if(self._annotations[i].id == id){\n                name = self._annotations[i].name;\n                continue;\n              }\n            }\n\t\t    \tself.trigger( EVT_ON_ANNOTATION_CLICKED, {\n\t    \t\t\"name\": name,\n\t\t    \t\t//\"pos\": parseInt( jQuery(e.target).attr(\"pos\") )\n\t\t    \t});\n\t\t    });\n\t\t\t\n\t\t});\n\n    },\n    /* \n     * Function: Sequence._getAnnotationString\n     * Purpose:  Get the annotation text message for the tooltip \n     * Returns:  {string} Annotation text for the annotation\n     * Inputs:   id -> {int} index of the internal annotation array\n     */\n    _getAnnotationString: function ( id ) {\n\t\tvar annotation = this._annotations[id.substr(id.indexOf(\"_\") + 1)];\n\t\treturn annotation.name + \"<br/>\" + ((annotation.html)? annotation.html : '');\n    },\n    \n    /* \n     * Function: Sequence._getHTMLRowAnnot\n     * Purpose:  Build an annotation\n     * Returns:  HTML of the annotation\n     * Inputs:   currentPos -> {int}\n     * \t\t\t annotation -> {Object} \n     *  \t\t settings -> {Object}\n     */\n    _getHTMLRowAnnot : function (currentPos, annotation, settings) {\n    \tvar styleBegin = 'border-left:1px solid; border-bottom:1px solid; border-color:';\n    \tvar styleOn = 'border-bottom:1px solid; border-color:';\n    \tvar styleEnd = 'border-bottom:1px solid; border-right:1px solid; border-color:';\n\t\tvar styleBeginAndEnd = 'border-left:1px solid; border-right:1px solid; border-bottom:1px solid; border-color:';\n    \t\n    \tvar row = [];\n    \tvar end = (currentPos + settings.numCols);\n    \tvar spaceBetweenChars = (settings.spaceBetweenChars)? ' ' : '';    \t\n    \tvar defaultColor = annotation.color;\n    \tvar id = annotation.id;\n    \tfor ( var pos=currentPos; pos < end ; pos++ ) {\n\t\t\t// regions\n\t\t\tfor ( var r in annotation.regions ) {\n\t\t\t\tregion = annotation.regions[r];\n\t\t\t\t\n\t\t\t\tspaceAfter = '';\n\t\t\t\tspaceAfter += (pos % settings.numColsForSpace == 0 )? ' ' : '';\n\t\t\t\tspaceAfter += spaceBetweenChars;\n\t\t\t\t\n\t\t\t\tcolor = ((region.color)? region.color : defaultColor);\n\t\t\t\tdata = 'class=\"annotation '+id+'\" id=\"'+id+'\" color=\"'+color+'\" pos=\"'+pos+'\"';\n\t\t\t\t\n\t\t\t\tif ( pos == region.start && pos == region.end) {\n\t\t\t\t\trow[pos] = '<span style=\"'+styleBeginAndEnd+color+'\" '+data+'> ';\n\t\t\t\t\trow[pos] += spaceAfter;\n\t\t\t\t\trow[pos] += '</span>';\n\t\t\t\t} else if ( pos == region.start ) {\n\t\t\t\t\trow[pos] = '<span style=\"'+styleBegin+color+'\" '+data+'> ';\n\t\t\t\t\trow[pos] += spaceAfter;\n\t\t\t\t\trow[pos] += '</span>';\n\t\t\t\t} else if ( pos == region.end ) {\n\t\t\t\t\trow[pos] = '<span style=\"'+styleEnd+color+' \" '+data+'> ';\n\t\t\t\t\t//row[pos] += spaceAfter;\n\t\t\t\t\trow[pos] += '</span>';\n\t\t\t\t} else if ( pos > region.start && pos < region.end ) {\n\t\t\t\t\trow[pos] = '<span style=\"'+styleOn+color+'\" '+data+'> ';\n\t\t\t\t\trow[pos] += spaceAfter;\n\t\t\t\t\trow[pos] += '</span>';\n\t\t\t\t} else if (!row[pos]) {\n\t\t\t\t\trow[pos] = ' ';\n\t\t\t\t\trow[pos] += spaceAfter;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n       \tvar str = row.join(\"\");\n    \t\n    \treturn ( str.indexOf(\"span\") == -1 )? \"\" : str;\n    },\n    /* \n     * Function: Sequence._drawRaw\n     * Purpose:  Repaint the current sequence using RAW format.  \n     * Returns:  -\n     * Inputs: -\n     */\n\t_drawRaw : function() {\n\t\tvar self = this;\n\t\tvar a = this.opt.sequence.toLowerCase().split('');\n\t\tvar i = 0;\n\t\tvar arr = [];\n\t\tvar pre = jQuery('<pre></pre>').appendTo(this._contentDiv);\n\t\t\n\t\t/* Correct column size in case the sequence is as small peptide */\n\t\tvar numCols = this.opt.columns.size;\n\t\tif ( this.opt.sequence.length < this.opt.columns.size ) {\n\t\t\tnumCols = this.opt.sequence.length;\t\n\t\t}\n\n\t\tvar opt = {\n\t\t\tnumCols: numCols\n\t\t};\n\t\t\n\t\tpre.html(\n\t\t\tthis._drawSequence(a, opt)\n\t\t);\n\t\t\n\t\tthis._drawAnnotations(opt);\n\t},\n\t/* \n     * Function: Sequence._drawPride\n     * Purpose:  Repaint the current sequence using PRIDE format.  \n     * Returns:  -\n     * Inputs: -\n     */\n\t_drawPride : function() {\n\t\tvar self = this;\n\t\tvar a = this.opt.sequence.toUpperCase().split('');\n\t\tvar pre = jQuery('<pre></pre>').appendTo(this._contentDiv);\n\t\t\n\t\t/* Correct column size in case the sequence is as small peptide */\n\t\tvar numCols = this.opt.columns.size;\n\t\tif ( this.opt.sequence.length < this.opt.columns.size ) {\n\t\t\tnumCols = this.opt.sequence.length;\t\n\t\t}\n\t\n\t\topt = {\n\t\t\tnumLeft: true,\n\t\t\tnumLeftSize: 5,\n\t\t\tnumLeftPad:'0',\n\t\t\tnumRight: true,\n\t\t\tnumRightSize: 5,\n\t\t\tnumRightPad: '0',\n\t\t\tnumCols: numCols,\n\t\t    numColsForSpace: self.opt.columns.spacedEach\n\t\t};\n\t\t\n\t\tpre.html(\n\t\t\tthis._drawSequence(a, opt)\n\t\t);\n\t\t\n\t\tthis._drawAnnotations(opt);\n\t},\n\t/* \n     * Function: Sequence._drawSequence\n     * Purpose:  Repaint the current sequence using CUSTOM format.  \n     * Returns:  -\n     * Inputs:   a -> {char[]} a The sequence strand.\n     * \t\t\t opt -> {Object} opt The CUSTOM format.\n     */\n\t_drawSequence : function(a, opt) {\n\t\tvar str = '';\n\n\t\tvar spaceStyle =  \"white-space: pre;\";\n\t\t\n\t\t// Index at top?\n\t\tif( opt.numTop )\n\t\t{\n\t\t\tstr += '<span style=\"'+spaceStyle+'\" class=\"numTop\">'\n\t\t\tvar size = (opt.spaceBetweenChars)? opt.numTopEach*2: opt.numTopEach;\n\t\t\t\n\t\t\tif (opt.numLeft) {\n\t\t\t\tstr += this._formatIndex(' ', opt.numLeftSize, ' ');\n\t\t\t}\n\t\t\t\n\t\t\tstr += this._formatIndex(' ', size, ' ');\n\t\t\t\n\t\t\tfor(var x = opt.numTopEach; x < opt.numCols; x += opt.numTopEach) {\n\t\t\t\tstr += this._formatIndex(x, size, ' ', true);\n\t\t\t}\n\t\t\tstr += '</span><br/>'\n\t\t}\n\t\t\n\t\t\n\t\t// Index at the left?\n\t\tif (opt.numLeft) {\n\t\t\tstr += this._formatIndex(1, opt.numLeftSize, opt.numLeftPad);\n\t\t\tstr += '  ';\n\t\t}\n\n\t\tvar j=1;\n\t\tfor (var i=1; i <= a.length; i++) {\n\n\t\t\tif( i % opt.numCols == 0) {\t\n\t\t\t\tstr += '<span class=\"sequence\" id=\"' + this.getId() + '_' + i + '\">' + a[i-1] + '</span>';\n\t\t\t\t\n\t\t\t\tif (opt.numRight) {\n\t\t\t\t\tstr += '<span style=\"'+spaceStyle+'\" id=\"numRight_' + this.getId() + '_' + i + '\">';\n\t\t\t\t\tstr += '  ';\n\t\t\t\t\tstr += this._formatIndex(i, opt.numRightSize, opt.numRightPad);\t\n\t\t\t\t\tstr += '</span>';\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tstr += '<br/>';\n\t\t\t\t\n\t\t\t\tvar aaRemaining = a.length - i;\n\t\t\t\tif (opt.numLeft && aaRemaining > 0) {\n\t\t\t\t\tstr += '<span id=\"numLeft_' + this.getId() + '_' + i + '\">';\n\t\t\t\t\tstr += this._formatIndex(i+1, opt.numLeftSize, opt.numLeftPad);\n\t\t\t\t\tstr += '  ';\n\t\t\t\t\tstr += '</span>';\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tj = 1;\n\t\t\t\t\n\t\t\t} else {\n                str += '<span class=\"sequence\" style=\"'+spaceStyle+'\" id=\"' + this.getId() + '_' + i + '\">' + a[i-1];\n\t\t\t\tstr += ( j % opt.numColsForSpace == 0)? ' ' : '';\n\t\t\t\tstr += (opt.spaceBetweenChars)? ' ' : '';\n\t\t\t\tstr += '</span>';\n\t\t\t\tj++;\n\t\t\t}\n\t\t}\n\t\t\n\t\tstr += '<br/>'\t\n\t\t\t\n\t\tif (jQuery.browser.msie) {\n\t\t\tstr = \"<pre>\" + str + \"</pre>\";\n\t\t}\t\n\t\t\t\n\t\treturn str;\n\t},\n\t/* \n     * Function: Sequence._formatIndex\n     * Purpose:  Build the HTML corresponding to counting numbers (top, left, right) in the strand.\n     * Returns:  -\n     * Inputs:   number -> {int} The number \n     * \t\t\t size -> {int} Number of bins to suit the number.\n     * \t\t\t fillingChar -> {char} Character to be used for filling out blank bins.\n     * \t\t\t alignLeft -> {bool} Tell if aligned to the left.\n     */\n\t_formatIndex : function( number, size, fillingChar, alignLeft) {\n\t\tvar str = number.toString();\n\t\tvar filling = '';\n\t\tvar padding = size - str.length;\t\n\t\tif ( padding > 0 ) {\n\t\t\twhile ( padding-- > 0 ) {\n\t\t\t\tfilling += (\"<span>\"+fillingChar+\"</span>\");\n\t\t\t}\n\t\t\tif (alignLeft){\n\t\t\t\tstr = number+filling;\n\t\t\t} else {\n\t\t\t\tstr = filling+number;\n\t\t\t}\n\t\t}\n\t\treturn str;\n\t},\n\t/* \n     * Function: Sequence._addSpanEvents\n     * Purpose:  Add the event handlers to the strand.\n     * Returns:  -\n     * Inputs:   -\n     */\n\t_addSpanEvents : function() {\n\t\tvar self = this;\n\t\tvar isMouseDown = false;\n\t\tvar currentPos;\n\n\t\tself._contentDiv.find('.sequence').each( function () {\t\n\t\t\t\n\t\t\t// Register the starting position\n\t\t\tjQuery(this).mousedown(function() {\n\t\t\t\tvar id = jQuery(this).attr('id');\n\t\t\t\tcurrentPos = parseInt(id.substr(id.indexOf(\"_\") + 1));\n\t\t\t\tclickPos = currentPos;\n\t\t\t\tself._setSelection(clickPos,currentPos);\n\t\t\t\tisMouseDown = true;\n\t\t\t\t\n\t\t\t\t// Selection is happening, raise an event\n\t\t\t\tself.trigger(\n\t\t\t\t\tEVT_ON_SELECTION_CHANGE, \n\t\t\t\t\t{ \n\t\t\t\t\t\t\"start\" : self.opt.selection.start, \n\t\t\t\t\t\t\"end\" : self.opt.selection.end \n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\n\t\t\t}).mouseover(function() {\n\t\t\t\t// Update selection\n\t\t\t\t// Show tooltip containing the position\n\t\t\t\tvar id = jQuery(this).attr('id');\n\t\t\t\tcurrentPos = parseInt(id.substr(id.indexOf(\"_\") + 1));\n\t\t\t\t\n\t\t\t\tif(isMouseDown) {\n\t\t\t\t\tif( currentPos > clickPos ) {\n\t\t\t\t\t\tself._setSelection(clickPos, currentPos);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tself._setSelection(currentPos, clickPos);\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\t// Selection is happening, raise an event\n\t\t\t\t\tself.trigger( EVT_ON_SELECTION_CHANGE, { \n\t\t\t\t\t\t\"start\" : self.opt.selection.start, \n\t\t\t\t\t\t\"end\" : self.opt.selection.end \n\t\t\t\t\t});\n\t\t\t\t} \n\t\t\t\t\n\t\t\t}).mouseup(function() {\n\t\t\t\tisMouseDown = false;\n\t\t\t\t// Selection is done, raise an event\n\t\t\t\tself.trigger( EVT_ON_SELECTION_CHANGED, { \n\t\t\t\t\t\"start\" : self.opt.selection.start, \n\t\t\t\t\t\"end\" : self.opt.selection.end \n\t\t\t\t});\n\t\t\t});\n\t\t\t\n\t\t\t// Add a tooltip for this sequence base.\n\t\t\tself._addToolTip.call( self, this, function( ) {\n\t\t\t\tif (isMouseDown) {\n\t     \t\t\treturn \"[\" + self.opt.selection.start +\", \" + self.opt.selection.end + \"]\";\n\t     \t\t} else {\n\t     \t\t\treturn currentPos;\n\t     \t\t}\n\t\t\t});\n\t\t\t\n\t\t})\n\t\t.css('cursor', 'pointer');\n\t},\n\t/* \n     * Function: Sequence._addTooltip\n     * Purpose:  Add a tooltip around the target DOM element provided as argument\n     * Returns:  -\n     * Inputs:   target -> {Element} DOM element wich is the targeted focus for the tooltip.\n     * \t\t\t cbGetMessageFunction -> {function} A callback function wich returns the message to be displayed in the tip.\n     */\n\t_addToolTip : function ( target, cbGetMessageFunction ) {\n\t\t\n \t\tvar tipId = this.opt._tooltip;\n\t\t\n\t\tjQuery(target).mouseover(function(e) {\n\t\t\t\n\t \t\tvar offset = jQuery(e.target).offset();\n\n\t\t\tif ( ! jQuery( tipId ).is(':visible') ) {\n\t\t        jQuery( tipId ) \n\t\t        \t.css({\n\t\t        \t\t'background-color': \"#000\",\n\t\t        \t\t'padding': \"3px 10px 3px 10px\",\n\t\t        \t\t'top': offset.top + jQuery(e.target).height() + \"px\",\n\t\t        \t\t'left': offset.left + jQuery(e.target).width() + \"px\"\n\t\t        \t})\n\t\t\t        .animate( {opacity: '0.85'}, 10)\n\t\t\t        .html( cbGetMessageFunction.call( target ) )\n\t\t\t        .show();\n\t\t\t}\n\n\t    }).mouseout(function() {\n\t        //Remove the appended tooltip template\n\t        jQuery( tipId ).hide();\t         \n\t    });\n\t},\n\t\n   /**\n    * Annotate a set of intervals provided in the argument.\n\t* \n\t* @deprecated Use addAnnotation() instead.\n    * \n    * @param {Object} annotation The intervals belonging to the same annotation. \n    * Syntax: { name: &lt;value&gt;, color: &lt;HTMLColorCode&gt;, html: &lt;HTMLString&gt;, regions: [{ start: &lt;startVal1&gt;, end: &lt;endVal1&gt;}, ...,  { start: &lt;startValN&gt;, end: &lt;endValN&gt;}] }\n    */\n\tsetAnnotation: function ( annotation ) {\n\t\tthis.addAnnotation(annotation);\n\t},\n\t\n\t/**\n    * Annotate a set of intervals provided in the argument.\n    * \n    * @example\n    * // Annotations using regions with different colors.\n    * mySequence.addAnnotation({\n\t*    name:\"UNIPROT\", \n\t*    html:\"&lt;br&gt; Example of &lt;b&gt;HTML&lt;/b&gt;\", \n\t*    color:\"green\", \n\t*    regions: [\n\t*       {start: 540, end: 560},\n\t*       {start: 561, end:580, color: \"#FFA010\"}, \n\t*       {start: 581, end:590, color: \"red\"}, \n\t*       {start: 690, end:710}]\n\t* });\n\t* \n    * \n    * @param {Object} annotation The intervals belonging to the same annotation. \n    * Syntax: { name: &lt;value&gt;, color: &lt;HTMLColorCode&gt;, html: &lt;HTMLString&gt;, regions: [{ start: &lt;startVal1&gt;, end: &lt;endVal1&gt;}, ...,  { start: &lt;startValN&gt;, end: &lt;endValN&gt;}] }\n    */\n\taddAnnotation: function ( annotation ) {\n\t\tthis._annotations.push(annotation);\n\t\tthis._redraw();\n\t},\n\t\n\t/**\n    * Removes an annotation by means of its name.\n    * \n    * @example \n    * // Remove the UNIPROT annotation.\n    * mySequence.removeAnnotation('UNIPROT'); \n    * \n    * @param {string} name The name of the annotation to be removed.\n    * \n    */\n\tremoveAnnotation: function ( name ) {\n\t\tfor (var i=0; i < this._annotations.length ; i++ ){\n\t\t\tif(name != this._annotations[i].name){\n\t\t\t\tthis._annotations.splice(i,1);\n\t\t\t\tthis._redraw();\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t},\n\t/**\n    * Removes all the current annotations.\n    * \n    * @example \n    * mySequence.removeAllAnnotations(); \n    * \n    */\n\tremoveAllAnnotations: function () {\n\t\tthis._annotations = [];\n\t\tthis._redraw();\n\t},\n\n\t\n});\n\nrequire(\"biojs-events\").mixin(Sequence.prototype);\nmodule.exports = Sequence;\n","var events = require(\"backbone-events-standalone\");\n\nevents.onAll = function(callback,context){\n  this.on(\"all\", callback,context);\n  return this;\n};\n\n// Mixin utility\nevents.oldMixin = events.mixin;\nevents.mixin = function(proto) {\n  events.oldMixin(proto);\n  // add custom onAll\n  var exports = ['onAll'];\n  for(var i=0; i < exports.length;i++){\n    var name = exports[i];\n    proto[name] = this[name];\n  }\n  return proto;\n};\n\nmodule.exports = events;\n","/**\n * Standalone extraction of Backbone.Events, no external dependency required.\n * Degrades nicely when Backone/underscore are already available in the current\n * global context.\n *\n * Note that docs suggest to use underscore's `_.extend()` method to add Events\n * support to some given object. A `mixin()` method has been added to the Events\n * prototype to avoid using underscore for that sole purpose:\n *\n *     var myEventEmitter = BackboneEvents.mixin({});\n *\n * Or for a function constructor:\n *\n *     function MyConstructor(){}\n *     MyConstructor.prototype.foo = function(){}\n *     BackboneEvents.mixin(MyConstructor.prototype);\n *\n * (c) 2009-2013 Jeremy Ashkenas, DocumentCloud Inc.\n * (c) 2013 Nicolas Perriault\n */\n/* global exports:true, define, module */\n(function() {\n  var root = this,\n      breaker = {},\n      nativeForEach = Array.prototype.forEach,\n      hasOwnProperty = Object.prototype.hasOwnProperty,\n      slice = Array.prototype.slice,\n      idCounter = 0;\n\n  // Returns a partial implementation matching the minimal API subset required\n  // by Backbone.Events\n  function miniscore() {\n    return {\n      keys: Object.keys || function (obj) {\n        if (typeof obj !== \"object\" && typeof obj !== \"function\" || obj === null) {\n          throw new TypeError(\"keys() called on a non-object\");\n        }\n        var key, keys = [];\n        for (key in obj) {\n          if (obj.hasOwnProperty(key)) {\n            keys[keys.length] = key;\n          }\n        }\n        return keys;\n      },\n\n      uniqueId: function(prefix) {\n        var id = ++idCounter + '';\n        return prefix ? prefix + id : id;\n      },\n\n      has: function(obj, key) {\n        return hasOwnProperty.call(obj, key);\n      },\n\n      each: function(obj, iterator, context) {\n        if (obj == null) return;\n        if (nativeForEach && obj.forEach === nativeForEach) {\n          obj.forEach(iterator, context);\n        } else if (obj.length === +obj.length) {\n          for (var i = 0, l = obj.length; i < l; i++) {\n            if (iterator.call(context, obj[i], i, obj) === breaker) return;\n          }\n        } else {\n          for (var key in obj) {\n            if (this.has(obj, key)) {\n              if (iterator.call(context, obj[key], key, obj) === breaker) return;\n            }\n          }\n        }\n      },\n\n      once: function(func) {\n        var ran = false, memo;\n        return function() {\n          if (ran) return memo;\n          ran = true;\n          memo = func.apply(this, arguments);\n          func = null;\n          return memo;\n        };\n      }\n    };\n  }\n\n  var _ = miniscore(), Events;\n\n  // Backbone.Events\n  // ---------------\n\n  // A module that can be mixed in to *any object* in order to provide it with\n  // custom events. You may bind with `on` or remove with `off` callback\n  // functions to an event; `trigger`-ing an event fires all callbacks in\n  // succession.\n  //\n  //     var object = {};\n  //     _.extend(object, Backbone.Events);\n  //     object.on('expand', function(){ alert('expanded'); });\n  //     object.trigger('expand');\n  //\n  Events = {\n\n    // Bind an event to a `callback` function. Passing `\"all\"` will bind\n    // the callback to all events fired.\n    on: function(name, callback, context) {\n      if (!eventsApi(this, 'on', name, [callback, context]) || !callback) return this;\n      this._events || (this._events = {});\n      var events = this._events[name] || (this._events[name] = []);\n      events.push({callback: callback, context: context, ctx: context || this});\n      return this;\n    },\n\n    // Bind an event to only be triggered a single time. After the first time\n    // the callback is invoked, it will be removed.\n    once: function(name, callback, context) {\n      if (!eventsApi(this, 'once', name, [callback, context]) || !callback) return this;\n      var self = this;\n      var once = _.once(function() {\n        self.off(name, once);\n        callback.apply(this, arguments);\n      });\n      once._callback = callback;\n      return this.on(name, once, context);\n    },\n\n    // Remove one or many callbacks. If `context` is null, removes all\n    // callbacks with that function. If `callback` is null, removes all\n    // callbacks for the event. If `name` is null, removes all bound\n    // callbacks for all events.\n    off: function(name, callback, context) {\n      var retain, ev, events, names, i, l, j, k;\n      if (!this._events || !eventsApi(this, 'off', name, [callback, context])) return this;\n      if (!name && !callback && !context) {\n        this._events = {};\n        return this;\n      }\n\n      names = name ? [name] : _.keys(this._events);\n      for (i = 0, l = names.length; i < l; i++) {\n        name = names[i];\n        if (events = this._events[name]) {\n          this._events[name] = retain = [];\n          if (callback || context) {\n            for (j = 0, k = events.length; j < k; j++) {\n              ev = events[j];\n              if ((callback && callback !== ev.callback && callback !== ev.callback._callback) ||\n                  (context && context !== ev.context)) {\n                retain.push(ev);\n              }\n            }\n          }\n          if (!retain.length) delete this._events[name];\n        }\n      }\n\n      return this;\n    },\n\n    // Trigger one or many events, firing all bound callbacks. Callbacks are\n    // passed the same arguments as `trigger` is, apart from the event name\n    // (unless you're listening on `\"all\"`, which will cause your callback to\n    // receive the true name of the event as the first argument).\n    trigger: function(name) {\n      if (!this._events) return this;\n      var args = slice.call(arguments, 1);\n      if (!eventsApi(this, 'trigger', name, args)) return this;\n      var events = this._events[name];\n      var allEvents = this._events.all;\n      if (events) triggerEvents(events, args);\n      if (allEvents) triggerEvents(allEvents, arguments);\n      return this;\n    },\n\n    // Tell this object to stop listening to either specific events ... or\n    // to every object it's currently listening to.\n    stopListening: function(obj, name, callback) {\n      var listeners = this._listeners;\n      if (!listeners) return this;\n      var deleteListener = !name && !callback;\n      if (typeof name === 'object') callback = this;\n      if (obj) (listeners = {})[obj._listenerId] = obj;\n      for (var id in listeners) {\n        listeners[id].off(name, callback, this);\n        if (deleteListener) delete this._listeners[id];\n      }\n      return this;\n    }\n\n  };\n\n  // Regular expression used to split event strings.\n  var eventSplitter = /\\s+/;\n\n  // Implement fancy features of the Events API such as multiple event\n  // names `\"change blur\"` and jQuery-style event maps `{change: action}`\n  // in terms of the existing API.\n  var eventsApi = function(obj, action, name, rest) {\n    if (!name) return true;\n\n    // Handle event maps.\n    if (typeof name === 'object') {\n      for (var key in name) {\n        obj[action].apply(obj, [key, name[key]].concat(rest));\n      }\n      return false;\n    }\n\n    // Handle space separated event names.\n    if (eventSplitter.test(name)) {\n      var names = name.split(eventSplitter);\n      for (var i = 0, l = names.length; i < l; i++) {\n        obj[action].apply(obj, [names[i]].concat(rest));\n      }\n      return false;\n    }\n\n    return true;\n  };\n\n  // A difficult-to-believe, but optimized internal dispatch function for\n  // triggering events. Tries to keep the usual cases speedy (most internal\n  // Backbone events have 3 arguments).\n  var triggerEvents = function(events, args) {\n    var ev, i = -1, l = events.length, a1 = args[0], a2 = args[1], a3 = args[2];\n    switch (args.length) {\n      case 0: while (++i < l) (ev = events[i]).callback.call(ev.ctx); return;\n      case 1: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1); return;\n      case 2: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2); return;\n      case 3: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2, a3); return;\n      default: while (++i < l) (ev = events[i]).callback.apply(ev.ctx, args);\n    }\n  };\n\n  var listenMethods = {listenTo: 'on', listenToOnce: 'once'};\n\n  // Inversion-of-control versions of `on` and `once`. Tell *this* object to\n  // listen to an event in another object ... keeping track of what it's\n  // listening to.\n  _.each(listenMethods, function(implementation, method) {\n    Events[method] = function(obj, name, callback) {\n      var listeners = this._listeners || (this._listeners = {});\n      var id = obj._listenerId || (obj._listenerId = _.uniqueId('l'));\n      listeners[id] = obj;\n      if (typeof name === 'object') callback = this;\n      obj[implementation](name, callback, this);\n      return this;\n    };\n  });\n\n  // Aliases for backwards compatibility.\n  Events.bind   = Events.on;\n  Events.unbind = Events.off;\n\n  // Mixin utility\n  Events.mixin = function(proto) {\n    var exports = ['on', 'once', 'off', 'trigger', 'stopListening', 'listenTo',\n                   'listenToOnce', 'bind', 'unbind'];\n    _.each(exports, function(name) {\n      proto[name] = this[name];\n    }, this);\n    return proto;\n  };\n\n  // Export Events as BackboneEvents depending on current context\n  if (typeof define === \"function\") {\n    define(function() {\n      return Events;\n    });\n  } else if (typeof exports !== 'undefined') {\n    if (typeof module !== 'undefined' && module.exports) {\n      exports = module.exports = Events;\n    }\n    exports.BackboneEvents = Events;\n  } else {\n    root.BackboneEvents = Events;\n  }\n})(this);\n","module.exports = require('./backbone-events-standalone');\n","// Generated by CoffeeScript 1.8.0\nvar GenericReader, xhr;\n\nxhr = require('nets');\n\nmodule.exports = GenericReader = (function() {\n  function GenericReader() {}\n\n  GenericReader.read = function(url, callback) {\n    var onret;\n    onret = (function(_this) {\n      return function(err, response, text) {\n        return _this._onRetrieval(text, callback);\n      };\n    })(this);\n    return xhr(url, onret);\n  };\n\n  GenericReader._onRetrieval = function(text, callback) {\n    var rText;\n    rText = this.parse(text);\n    return callback(rText);\n  };\n\n  return GenericReader;\n\n})();\n","// Generated by CoffeeScript 1.8.0\nvar Fasta, GenericReader, Seq, Str,\n  __hasProp = {}.hasOwnProperty,\n  __extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; };\n\nStr = require(\"./strings\");\n\nGenericReader = require(\"./generic_reader\");\n\nSeq = require(\"biojs-model\").seq;\n\nmodule.exports = Fasta = (function(_super) {\n  __extends(Fasta, _super);\n\n  function Fasta() {\n    return Fasta.__super__.constructor.apply(this, arguments);\n  }\n\n  Fasta.parse = function(text) {\n    var currentSeq, database, databaseID, identifiers, k, label, line, seqs, _i, _len;\n    seqs = [];\n    if (Object.prototype.toString.call(text) !== '[object Array]') {\n      text = text.split(\"\\n\");\n    }\n    for (_i = 0, _len = text.length; _i < _len; _i++) {\n      line = text[_i];\n      if (line[0] === \">\" || line[0] === \";\") {\n        label = line.slice(1);\n        currentSeq = new Seq(\"\", label, seqs.length);\n        seqs.push(currentSeq);\n        if (Str.contains(\"|\", line)) {\n          identifiers = label.split(\"|\");\n          k = 1;\n          while (k < identifiers.length) {\n            database = identifiers[k];\n            databaseID = identifiers[k + 1];\n            currentSeq.meta[database] = databaseID;\n            k += 2;\n          }\n          currentSeq.name = identifiers[identifiers.length - 1];\n        }\n      } else {\n        currentSeq.seq += line;\n      }\n    }\n    return seqs;\n  };\n\n  return Fasta;\n\n})(GenericReader);\n","// Generated by CoffeeScript 1.8.0\nvar strings;\n\nstrings = {\n  contains: function(text, search) {\n    return ''.indexOf.call(text, search, 0) !== -1;\n  }\n};\n\nmodule.exports = strings;\n","// Generated by CoffeeScript 1.8.0\nvar Utils;\n\nUtils = {};\n\nUtils.splitNChars = function(txt, num) {\n  var i, result, _i, _ref;\n  result = [];\n  for (i = _i = 0, _ref = txt.length - 1; num > 0 ? _i <= _ref : _i >= _ref; i = _i += num) {\n    result.push(txt.substr(i, num));\n  }\n  return result;\n};\n\nmodule.exports = Utils;\n","// Generated by CoffeeScript 1.8.0\nvar FastaExporter, Utils;\n\nUtils = require(\"./utils\");\n\nmodule.exports = FastaExporter = (function() {\n  function FastaExporter() {}\n\n  FastaExporter[\"export\"] = function(seqs, access) {\n    var seq, text, _i, _len;\n    text = \"\";\n    for (_i = 0, _len = seqs.length; _i < _len; _i++) {\n      seq = seqs[_i];\n      if (access != null) {\n        seq = access(seq);\n      }\n      text += \">\" + seq.name + \"\\n\";\n      text += (Utils.splitNChars(seq.seq, 80)).join(\"\\n\");\n      text += \"\\n\";\n    }\n    return text;\n  };\n\n  return FastaExporter;\n\n})();\n","module.exports.seq = require(\"./seq\");\n","module.exports = function(seq, name, id) {\n    this.seq = seq;\n    this.name = name;\n    this.id = id;\n    this.meta = {};\n};\n","var req = require('request')\n\nmodule.exports = Nets\n\nfunction Nets(uri, opts, cb) {\n  req(uri, opts, cb)\n}","var window = require(\"global/window\")\nvar once = require(\"once\")\nvar parseHeaders = require('parse-headers')\n\nvar messages = {\n    \"0\": \"Internal XMLHttpRequest Error\",\n    \"4\": \"4xx Client Error\",\n    \"5\": \"5xx Server Error\"\n}\n\nvar XHR = window.XMLHttpRequest || noop\nvar XDR = \"withCredentials\" in (new XHR()) ? XHR : window.XDomainRequest\n\nmodule.exports = createXHR\n\nfunction createXHR(options, callback) {\n    if (typeof options === \"string\") {\n        options = { uri: options }\n    }\n\n    options = options || {}\n    callback = once(callback)\n\n    var xhr = options.xhr || null\n\n    if (!xhr) {\n        if (options.cors || options.useXDR) {\n            xhr = new XDR()\n        }else{\n            xhr = new XHR()\n        }\n    }\n\n    var uri = xhr.url = options.uri || options.url\n    var method = xhr.method = options.method || \"GET\"\n    var body = options.body || options.data\n    var headers = xhr.headers = options.headers || {}\n    var sync = !!options.sync\n    var isJson = false\n    var key\n    var load = options.response ? loadResponse : loadXhr\n\n    if (\"json\" in options) {\n        isJson = true\n        headers[\"Accept\"] = \"application/json\"\n        if (method !== \"GET\" && method !== \"HEAD\") {\n            headers[\"Content-Type\"] = \"application/json\"\n            body = JSON.stringify(options.json)\n        }\n    }\n\n    xhr.onreadystatechange = readystatechange\n    xhr.onload = load\n    xhr.onerror = error\n    // IE9 must have onprogress be set to a unique function.\n    xhr.onprogress = function () {\n        // IE must die\n    }\n    // hate IE\n    xhr.ontimeout = noop\n    xhr.open(method, uri, !sync)\n                                    //backward compatibility\n    if (options.withCredentials || (options.cors && options.withCredentials !== false)) {\n        xhr.withCredentials = true\n    }\n\n    // Cannot set timeout with sync request\n    if (!sync) {\n        xhr.timeout = \"timeout\" in options ? options.timeout : 5000\n    }\n\n    if (xhr.setRequestHeader) {\n        for(key in headers){\n            if(headers.hasOwnProperty(key)){\n                xhr.setRequestHeader(key, headers[key])\n            }\n        }\n    } else if (options.headers) {\n        throw new Error(\"Headers cannot be set on an XDomainRequest object\")\n    }\n\n    if (\"responseType\" in options) {\n        xhr.responseType = options.responseType\n    }\n    \n    if (\"beforeSend\" in options && \n        typeof options.beforeSend === \"function\"\n    ) {\n        options.beforeSend(xhr)\n    }\n\n    xhr.send(body)\n\n    return xhr\n\n    function readystatechange() {\n        if (xhr.readyState === 4) {\n            load()\n        }\n    }\n\n    function getBody() {\n        // Chrome with requestType=blob throws errors arround when even testing access to responseText\n        var body = null\n\n        if (xhr.response) {\n            body = xhr.response\n        } else if (xhr.responseType === 'text' || !xhr.responseType) {\n            body = xhr.responseText || xhr.responseXML\n        }\n\n        if (isJson) {\n            try {\n                body = JSON.parse(body)\n            } catch (e) {}\n        }\n\n        return body\n    }\n\n    function getStatusCode() {\n        return xhr.status === 1223 ? 204 : xhr.status\n    }\n\n    // if we're getting a none-ok statusCode, build & return an error\n    function errorFromStatusCode(status, body) {\n        var error = null\n        if (status === 0 || (status >= 400 && status < 600)) {\n            var message = (typeof body === \"string\" ? body : false) ||\n                messages[String(status).charAt(0)]\n            error = new Error(message)\n            error.statusCode = status\n        }\n\n        return error\n    }\n\n    // will load the data & process the response in a special response object\n    function loadResponse() {\n        var status = getStatusCode()\n        var body = getBody()\n        var error = errorFromStatusCode(status, body)\n        var response = {\n            body: body,\n            statusCode: status,\n            statusText: xhr.statusText,\n            raw: xhr\n        }\n        if(xhr.getAllResponseHeaders){ //remember xhr can in fact be XDR for CORS in IE\n            response.headers = parseHeaders(xhr.getAllResponseHeaders())\n        } else {\n            response.headers = {}\n        }\n\n        callback(error, response, response.body)\n    }\n\n    // will load the data and add some response properties to the source xhr\n    // and then respond with that\n    function loadXhr() {\n        var status = getStatusCode()\n        var error = errorFromStatusCode(status)\n\n        xhr.status = xhr.statusCode = status\n        xhr.body = getBody()\n        xhr.headers = parseHeaders(xhr.getAllResponseHeaders())\n\n        callback(error, xhr, xhr.body)\n    }\n\n    function error(evt) {\n        callback(evt, xhr)\n    }\n}\n\n\nfunction noop() {}\n","if (typeof window !== \"undefined\") {\n    module.exports = window;\n} else if (typeof global !== \"undefined\") {\n    module.exports = global;\n} else if (typeof self !== \"undefined\"){\n    module.exports = self;\n} else {\n    module.exports = {};\n}\n","module.exports = once\n\nonce.proto = once(function () {\n  Object.defineProperty(Function.prototype, 'once', {\n    value: function () {\n      return once(this)\n    },\n    configurable: true\n  })\n})\n\nfunction once (fn) {\n  var called = false\n  return function () {\n    if (called) return\n    called = true\n    return fn.apply(this, arguments)\n  }\n}\n","var isFunction = require('is-function')\n\nmodule.exports = forEach\n\nvar toString = Object.prototype.toString\nvar hasOwnProperty = Object.prototype.hasOwnProperty\n\nfunction forEach(list, iterator, context) {\n    if (!isFunction(iterator)) {\n        throw new TypeError('iterator must be a function')\n    }\n\n    if (arguments.length < 3) {\n        context = this\n    }\n    \n    if (toString.call(list) === '[object Array]')\n        forEachArray(list, iterator, context)\n    else if (typeof list === 'string')\n        forEachString(list, iterator, context)\n    else\n        forEachObject(list, iterator, context)\n}\n\nfunction forEachArray(array, iterator, context) {\n    for (var i = 0, len = array.length; i < len; i++) {\n        if (hasOwnProperty.call(array, i)) {\n            iterator.call(context, array[i], i, array)\n        }\n    }\n}\n\nfunction forEachString(string, iterator, context) {\n    for (var i = 0, len = string.length; i < len; i++) {\n        // no such thing as a sparse string.\n        iterator.call(context, string.charAt(i), i, string)\n    }\n}\n\nfunction forEachObject(object, iterator, context) {\n    for (var k in object) {\n        if (hasOwnProperty.call(object, k)) {\n            iterator.call(context, object[k], k, object)\n        }\n    }\n}\n","module.exports = isFunction\n\nvar toString = Object.prototype.toString\n\nfunction isFunction (fn) {\n  var string = toString.call(fn)\n  return string === '[object Function]' ||\n    (typeof fn === 'function' && string !== '[object RegExp]') ||\n    (typeof window !== 'undefined' &&\n     // IE8 and below\n     (fn === window.setTimeout ||\n      fn === window.alert ||\n      fn === window.confirm ||\n      fn === window.prompt))\n};\n","\nexports = module.exports = trim;\n\nfunction trim(str){\n  return str.replace(/^\\s*|\\s*$/g, '');\n}\n\nexports.left = function(str){\n  return str.replace(/^\\s*/, '');\n};\n\nexports.right = function(str){\n  return str.replace(/\\s*$/, '');\n};\n","var trim = require('trim')\n  , forEach = require('for-each')\n  , isArray = function(arg) {\n      return Object.prototype.toString.call(arg) === '[object Array]';\n    }\n\nmodule.exports = function (headers) {\n  if (!headers)\n    return {}\n\n  var result = {}\n\n  forEach(\n      trim(headers).split('\\n')\n    , function (row) {\n        var index = row.indexOf(':')\n          , key = trim(row.slice(0, index)).toLowerCase()\n          , value = trim(row.slice(index + 1))\n\n        if (typeof(result[key]) === 'undefined') {\n          result[key] = value\n        } else if (isArray(result[key])) {\n          result[key].push(value)\n        } else {\n          result[key] = [ result[key], value ]\n        }\n      }\n  )\n\n  return result\n}","module.exports = require('./jquery.browser');\n","/*!\n * jQuery Browser Plugin v0.0.6\n * https://github.com/gabceb/jquery-browser-plugin\n *\n * Original jquery-browser code Copyright 2005, 2013 jQuery Foundation, Inc. and other contributors\n * http://jquery.org/license\n *\n * Modifications Copyright 2013 Gabriel Cebrian\n * https://github.com/gabceb\n *\n * Released under the MIT license\n *\n * Date: 2013-07-29T17:23:27-07:00\n */\n\n\nvar matched, browser;\n\nvar uaMatch = function( ua ) {\n  ua = ua.toLowerCase();\n\n  var match = /(opr)[\\/]([\\w.]+)/.exec( ua ) ||\n    /(chrome)[ \\/]([\\w.]+)/.exec( ua ) ||\n    /(version)[ \\/]([\\w.]+).*(safari)[ \\/]([\\w.]+)/.exec( ua ) ||\n    /(webkit)[ \\/]([\\w.]+)/.exec( ua ) ||\n    /(opera)(?:.*version|)[ \\/]([\\w.]+)/.exec( ua ) ||\n    /(msie) ([\\w.]+)/.exec( ua ) ||\n    ua.indexOf(\"trident\") >= 0 && /(rv)(?::| )([\\w.]+)/.exec( ua ) ||\n    ua.indexOf(\"compatible\") < 0 && /(mozilla)(?:.*? rv:([\\w.]+)|)/.exec( ua ) ||\n    [];\n\n  var platform_match = /(ipad)/.exec( ua ) ||\n    /(iphone)/.exec( ua ) ||\n    /(android)/.exec( ua ) ||\n    /(windows phone)/.exec( ua ) ||\n    /(win)/.exec( ua ) ||\n    /(mac)/.exec( ua ) ||\n    /(linux)/.exec( ua ) ||\n    /(cros)/i.exec( ua ) ||\n    [];\n\n  return {\n    browser: match[ 3 ] || match[ 1 ] || \"\",\n    version: match[ 2 ] || \"0\",\n    platform: platform_match[ 0 ] || \"\"\n  };\n};\n\nmatched = uaMatch( window.navigator.userAgent );\nbrowser = {};\nbrowser.uaMatch = uaMatch;\n\nif ( matched.browser ) {\n  browser[ matched.browser ] = true;\n  browser.version = matched.version;\n  browser.versionNumber = parseInt(matched.version);\n}\n\nif ( matched.platform ) {\n  browser[ matched.platform ] = true;\n}\n\n// These are all considered mobile platforms, meaning they run a mobile browser\nif ( browser.android || browser.ipad || browser.iphone || browser[ \"windows phone\" ] ) {\n  browser.mobile = true;\n}\n\n// These are all considered desktop platforms, meaning they run a desktop browser\nif ( browser.cros || browser.mac || browser.linux || browser.win ) {\n  browser.desktop = true;\n}\n\n// Chrome, Opera 15+ and Safari are webkit based browsers\nif ( browser.chrome || browser.opr || browser.safari ) {\n  browser.webkit = true;\n}\n\n// IE11 has a new token so we will assign it msie to avoid breaking changes\nif ( browser.rv )\n{\n  var ie = \"msie\";\n\n  matched.browser = ie;\n  browser[ie] = true;\n}\n\n// Opera 15+ are identified as opr\nif ( browser.opr )\n{\n  var opera = \"opera\";\n\n  matched.browser = opera;\n  browser[opera] = true;\n}\n\n// Stock Android browsers are marked as Safari on Android.\nif ( browser.safari && browser.android )\n{\n  var android = \"android\";\n\n  matched.browser = android;\n  browser[android] = true;\n}\n\n// Assign the name and platform variable\nbrowser.name = matched.browser;\nbrowser.platform = matched.platform;\n\n\nmodule.exports = browser;\n","/** @preserve http://github.com/easeway/js-class */\n\n// Class Definition using ECMA5 prototype chain\n\nfunction inherit(dest, src, noParent) {\n    while (src && src !== Object.prototype) {\n        Object.getOwnPropertyNames(src).forEach(function (name) {\n            if (name != '.class' && !dest.hasOwnProperty(name)) {\n                var desc = Object.getOwnPropertyDescriptor(src, name);\n                Object.defineProperty(dest, name, desc);\n            }\n        });\n        if (noParent) {\n            break;\n        }\n        src = src.__proto__;\n    }\n    return dest;\n}\n\nvar Class = function (base, proto, options) {\n    if (typeof(base) != 'function') {\n        options = proto;\n        proto = base;\n        base = Object;\n    }\n    if (!proto) {\n        proto = {};\n    }\n    if (!options) {\n        options = {};\n    }\n    \n    var meta = {\n        name: options.name,\n        base: base,\n        implements: []\n    }\n    var classProto = Class.clone(proto);\n    if (options.implements) {\n        (Array.isArray(options.implements) ? options.implements : [options.implements])\n            .forEach(function (implementedType) {\n                if (typeof(implementedType) == 'function' && implementedType.prototype) {\n                    meta.implements.push(implementedType);\n                    Class.extend(classProto, implementedType.prototype);\n                }\n            });\n    }\n    classProto.__proto__ = base.prototype;\n    var theClass = function () {\n        if (typeof(this.constructor) == 'function') {\n            this.constructor.apply(this, arguments);\n        }\n    };\n    meta.type = theClass;\n    theClass.prototype = classProto;\n    Object.defineProperty(theClass, '.class.meta', { value: meta, enumerable: false, configurable: false, writable: false });\n    Object.defineProperty(classProto, '.class', { value: theClass, enumerable: false, configurable: false, writable: false });\n    if (options.statics) {\n        Class.extend(theClass, options.statics);\n    }\n    return theClass;\n};\n\nClass.extend = inherit;\n\nClass.clone = function (object) {\n    return inherit({}, object);\n};\n\nfunction findType(meta, type) {\n    while (meta) {\n        if (meta.type.prototype === type.prototype) {\n            return true;\n        }\n        for (var i in meta.implements) {\n            var implType = meta.implements[i];\n            var implMeta = implType['.class.meta'];\n            if (implMeta) {\n                if (findType(implMeta, type)) {\n                    return true;\n                }\n            } else {\n                for (var proto = implType.prototype; proto; proto = proto.__proto__) {\n                    if (proto === type.prototype) {\n                        return true;\n                    }\n                }\n            }\n        }\n        meta = meta.base ? meta.base['.class.meta'] : undefined;\n    }\n    return false;\n}\n\nvar Checker = Class({\n    constructor: function (object) {\n        this.object = object;\n    },\n    \n    typeOf: function (type) {\n        if (this.object instanceof type) {\n            return true;\n        }\n        var meta = Class.typeInfo(this.object);\n        return meta && findType(meta, type);\n    }\n});\n\n// aliases\nChecker.prototype.a = Checker.prototype.typeOf;\nChecker.prototype.an = Checker.prototype.typeOf;\n\nClass.is = function (object) {\n    return new Checker(object);\n};\n\nClass.typeInfo = function (object) {\n    var theClass = object.__proto__['.class'];\n    return theClass ? theClass['.class.meta'] : undefined;\n};\n\nClass.VERSION = [0, 0, 2];\n\nif (module) {\n    module.exports = Class;\n} else {\n    global.Class = Class;   // for browser\n}","// Generated by CoffeeScript 1.8.0\nmodule.exports.parse = require(\"./parser\");\n\nmodule.exports.writer = require(\"./writer\");\n","module.exports = require(\"./lib/index\");\n"]}