sequenceserver 3.1.2 → 3.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/sequenceserver/blast/tasks.rb +1 -1
- data/lib/sequenceserver/routes.rb +1 -1
- data/lib/sequenceserver/version.rb +1 -1
- data/lib/sequenceserver.rb +1 -1
- data/public/css/app.min.css +1 -1
- data/public/css/sequenceserver.css +0 -18
- data/public/css/sequenceserver.min.css +2 -2
- data/public/js/alignment_exporter.js +16 -28
- data/public/js/cloud_share_modal.js +42 -42
- data/public/js/form.js +12 -10
- data/public/js/grapher.js +4 -4
- data/public/js/hit.js +3 -3
- data/public/js/hits.js +276 -0
- data/public/js/jquery_world.js +1 -1
- data/public/js/mailto.js +1 -3
- data/public/js/null_plugins/report_plugins.js +1 -0
- data/public/js/options.js +2 -6
- data/public/js/query.js +1 -1
- data/public/js/report.js +68 -252
- data/public/js/report_root.js +7 -5
- data/public/js/search.js +28 -11
- data/public/js/sequence.js +158 -158
- data/public/js/sequence_modal.js +28 -36
- data/public/js/sidebar.js +7 -6
- data/public/js/tests/alignment_exporter.spec.js +38 -0
- data/public/js/tests/cloud_share_modal.spec.js +75 -0
- data/public/js/tests/report.spec.js +37 -15
- data/public/packages/jquery-ui@1.13.3.js +19070 -0
- data/public/sequenceserver-report.min.js +3 -2481
- data/public/sequenceserver-report.min.js.LICENSE.txt +300 -0
- data/public/sequenceserver-report.min.js.map +1 -0
- data/public/sequenceserver-search.min.js +3 -2382
- data/public/sequenceserver-search.min.js.LICENSE.txt +292 -0
- data/public/sequenceserver-search.min.js.map +1 -0
- data/views/layout.erb +3 -7
- data/views/search.erb +1 -1
- data/views/search_layout.erb +1 -1
- metadata +11 -5
- data/public/config.js +0 -147
- data/public/packages/jquery-ui@1.11.4.js +0 -16624
    
        data/public/js/sequence.js
    CHANGED
    
    | @@ -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: <startVal1>, end: <endVal1> [, id:<idVal1>] [, color: <HTMLColor>] [, background: <HTMLColor>]}, | 
| 49 | 
            +
                 *    	{ start: <startVal1>, end: <endVal1> [, id:<idVal1>] [, color: <HTMLColor>] [, background: <HTMLColor>]},
         | 
| 50 50 | 
             
                 *    	//
         | 
| 51 51 | 
             
                 *    	// Any others highlights
         | 
| 52 | 
            -
                 *    	..., | 
| 53 | 
            -
                 *    	// | 
| 52 | 
            +
                 *    	...,
         | 
| 53 | 
            +
                 *    	//
         | 
| 54 54 | 
             
                 *    	{ start: <startValN>, end: <endValN> [, id:<idValN>] [, color: <HTMLColor>] [, background: <HTMLColor>]}
         | 
| 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: <numCols>, spacedEach: <numCols>}
         | 
| 67 | 
            -
                 * | 
| 68 | 
            -
                 * @option {Object} [selection] | 
| 67 | 
            +
                 *
         | 
| 68 | 
            +
                 * @option {Object} [selection]
         | 
| 69 69 | 
             
                 * 	  Positions for the current selected region. Syntax: { start: <startValue>, end: <endValue>}
         | 
| 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: <name>, | 
| 77 | 
            -
                 *                html: <message>, | 
| 78 | 
            -
                 *                color: <color_code>, | 
| 79 | 
            -
                 *                regions: [{ start: <startVal1>, end: <endVal1> color: <HTMLColor>}, ...,{ start: <startValN>, end: <endValN>, color: <HTMLColor>}] | 
| 80 | 
            -
                 *              }, | 
| 81 | 
            -
                 * | 
| 76 | 
            +
                 *              { name: <name>,
         | 
| 77 | 
            +
                 *                html: <message>,
         | 
| 78 | 
            +
                 *                color: <color_code>,
         | 
| 79 | 
            +
                 *                regions: [{ start: <startVal1>, end: <endVal1> color: <HTMLColor>}, ...,{ start: <startValN>, end: <endValN>, color: <HTMLColor>}]
         | 
| 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:"<br> Example of <b>HTML</b>", | 
| 122 | 
            -
                 *          color:"green", | 
| 120 | 
            +
                 *        { name:"TEST",
         | 
| 121 | 
            +
                 *          html:"<br> Example of <b>HTML</b>",
         | 
| 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 | 
            -
             | 
| 358 | 
            -
             | 
| 359 | 
            -
             | 
| 360 | 
            -
             | 
| 361 | 
            -
             | 
| 362 | 
            -
             | 
| 363 | 
            -
                                         | 
| 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:"<br> Example of <b>HTML</b>", | 
| 1358 | 
            -
                    *    color:"green", | 
| 1357 | 
            +
                    *    name:"UNIPROT",
         | 
| 1358 | 
            +
                    *    html:"<br> Example of <b>HTML</b>",
         | 
| 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: <value>, color: <HTMLColorCode>, html: <HTMLString>, regions: [{ start: <startVal1>, end: <endVal1>}, ...,  { start: <startValN>, end: <endValN>}] }
         | 
| 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"]}
         |