2011-11-15 12:03:12 -05:00
< html > < head > < meta http-equiv = "content-type" content = "text/html; charset=utf-8" > < style >
.KEYW {color: #933;}
.COMM {color: #bbb; font-style: italic;}
.NUMB {color: #393;}
.STRN {color: #393;}
.REGX {color: #339;}
.line {border-right: 1px dotted #666; color: #666; font-style: normal;}
< / style > < / head > < body > < pre > < span class = 'line' > 1< / span > < span class = "COMM" > /**
< span class = 'line' > 2< / span > * Template module for simple javascript templating
< span class = 'line' > 3< / span > */< / span > < span class = "WHIT" >
< span class = 'line' > 4< / span > < / span > < span class = "PUNC" > (< / span > < span class = "KEYW" > function< / span > < span class = "PUNC" > (< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 5< / span > < / span > < span class = "WHIT" > < / span > < span class = "STRN" > "use strict"< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 6< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 7< / span > < / span > < span class = "COMM" > //This module relies on some others for simplicity< / span > < span class = "WHIT" >
< span class = 'line' > 8< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > //so, if they aren't there, don't initialize the module< / span > < span class = "WHIT" >
< span class = 'line' > 9< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > if< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > $_.ajax< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > ===< / span > < span class = "WHIT" > < / span > < span class = "STRN" > "undefined"< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 10< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 11< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > return< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 12< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 13< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 14< / span > < / span > < span class = "KEYW" > var< / span > < span class = "WHIT" > < / span > < span class = "NAME" > t< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "NAME" > _t< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "NAME" > _p< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 15< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 16< / span >
< span class = 'line' > 17< / span > < / span > < span class = "COMM" > //Private object to store retrieved templates< / span > < span class = "WHIT" >
< span class = 'line' > 18< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > _t< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "PUNC" > }< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 19< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 20< / span > < / span > < span class = "COMM" > //Private object to store parsed templates< / span > < span class = "WHIT" >
< span class = 'line' > 21< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > _p< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "PUNC" > }< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 22< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 23< / span >
< span class = 'line' > 24< / span > < / span > < span class = "COMM" > /**
< span class = 'line' > 25< / span > * Module for html templating. Requires ajax module.
< span class = 'line' > 26< / span > *
< span class = 'line' > 27< / span > * @name template
< span class = 'line' > 28< / span > * @namespace
< span class = 'line' > 29< / span > * @memberOf $_
< span class = 'line' > 30< / span > */< / span > < span class = "WHIT" >
< span class = 'line' > 31< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > t< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 32< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > /**
< span class = 'line' > 33< / span > * Retrieves a template
< span class = 'line' > 34< / span > *
< span class = 'line' > 35< / span > * @memberOf $_.template
< span class = 'line' > 36< / span > * @name get
< span class = 'line' > 37< / span > * @param string name
< span class = 'line' > 38< / span > * @return string
< span class = 'line' > 39< / span > * @function
< span class = 'line' > 40< / span > * @type string
< span class = 'line' > 41< / span > */< / span > < span class = "WHIT" >
< span class = 'line' > 42< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > get< / span > < span class = "PUNC" > :< / span > < span class = "WHIT" > < / span > < span class = "KEYW" > function< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 43< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 44< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > var< / span > < span class = "WHIT" > < / span > < span class = "NAME" > res< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 45< / span >
< span class = 'line' > 46< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > res< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > this.el.innerHTML< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 47< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 48< / span > < / span > < span class = "KEYW" > if< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > res< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > ===< / span > < span class = "WHIT" > < / span > < span class = "STRN" > ""< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 49< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 50< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > console.log< / span > < span class = "PUNC" > (< / span > < span class = "STRN" > "Template is empty or cannot be found"< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 51< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > return< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 52< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 53< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 54< / span > < / span > < span class = "NAME" > _t< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ]< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > res< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 55< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > return< / span > < span class = "WHIT" > < / span > < span class = "NAME" > res< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 56< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 57< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > /**
< span class = 'line' > 58< / span > * Formats a template
< span class = 'line' > 59< / span > *
< span class = 'line' > 60< / span > * @memberOf $_.template
< span class = 'line' > 61< / span > * @name parse
< span class = 'line' > 62< / span > * @param string template_name
< span class = 'line' > 63< / span > * @param object replace_data
< span class = 'line' > 64< / span > * @return string
< span class = 'line' > 65< / span > * @function
< span class = 'line' > 66< / span > * @type string
< span class = 'line' > 67< / span > */< / span > < span class = "WHIT" >
< span class = 'line' > 68< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > parse< / span > < span class = "PUNC" > :< / span > < span class = "WHIT" > < / span > < span class = "KEYW" > function< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "NAME" > data< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 69< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 70< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > var< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > _t< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 71< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > pairs< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > [< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
2011-11-22 15:23:50 -05:00
< span class = 'line' > 72< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > pair_reg< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "REGX" > /\{([A-Z0-9_\-]+)\}(.*)\{\/\1\}/gim< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 73< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > var_reg< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "REGX" > /\{([A-Z0-9_\-]+)\}/gim< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 74< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > pseudos< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > [< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 75< / span > < / span > < span class = "NAME" > num_pairs< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NUMB" > 0< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 76< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > num_pseudos< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NUMB" > 0< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 77< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > i< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NUMB" > 0< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 78< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > j< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NUMB" > 0< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 79< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > var_name< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "STRN" > ''< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 80< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > rep_data< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "PUNC" > }< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 81< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp_data< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "STRN" > ''< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 82< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > data_len< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 83< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > frag< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 84< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > frag_section< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 85< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > emptys< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 86< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > x< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 87< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 88< / span > < / span > < span class = "NAME" > tmp< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > String< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > tmp< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 89< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 90< / span > < / span > < span class = "COMM" > //Remove newlines and tabs from template because< / span > < span class = "WHIT" >
< span class = 'line' > 91< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > //those whitespace characters are extra bandwidth< / span > < span class = "WHIT" >
< span class = 'line' > 92< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp.replace< / span > < span class = "PUNC" > (< / span > < span class = "REGX" > /\s+/gim< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "STRN" > " "< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 93< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp.replace< / span > < span class = "PUNC" > (< / span > < span class = "REGX" > />\s+< /gim< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "STRN" > ">< "< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 94< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp.replace< / span > < span class = "PUNC" > (< / span > < span class = "REGX" > />\s+\{/gim< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "STRN" > ">{"< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 95< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp.replace< / span > < span class = "PUNC" > (< / span > < span class = "REGX" > /\}\s+< /gim< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "STRN" > "}< "< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 96< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 97< / span > < / span > < span class = "COMM" > //Match all the looped sections of content< / span > < span class = "WHIT" >
< span class = 'line' > 98< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > pairs< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp.match< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > pair_reg< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 99< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 100< / span > < / span > < span class = "KEYW" > if< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > pairs< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > !=< / span > < span class = "WHIT" > < / span > < span class = "KEYW" > null< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 101< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 102< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > num_pairs< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > pairs.length< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 103< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 104< / span > < / span > < span class = "COMM" > //Go through the template, and match the pairs< / span > < span class = "WHIT" >
< span class = 'line' > 105< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > for< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > =< / span > < span class = "NUMB" > 0< / span > < span class = "PUNC" > ;< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > < < / span > < span class = "NAME" > num_pairs< / span > < span class = "PUNC" > ;< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > ++< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 106< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 107< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > //Put the loop in a placeholder< / span > < span class = "WHIT" >
< span class = 'line' > 108< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp.replace< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > pairs< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "STRN" > "{"< / span > < span class = "PUNC" > +< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > +< / span > < span class = "STRN" > "}"< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 109< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 110< / span > < / span > < span class = "COMM" > //Create a place to store looped data< / span > < span class = "WHIT" >
< span class = 'line' > 111< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp_data< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "STRN" > ""< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 112< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 113< / span > < / span > < span class = "COMM" > //The replace variable is the name of the tag< / span > < span class = "WHIT" >
< span class = 'line' > 114< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > var_name< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > String< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > pairs< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > .< / span > < span class = "NAME" > match< / span > < span class = "PUNC" > (< / span > < span class = "REGX" > /^\{([A-Z0-9_\-]+)\}/i< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 115< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > rep_data< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > data< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > var_name< / span > < span class = "PUNC" > [< / span > < span class = "NUMB" > 1< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 116< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 117< / span > < / span > < span class = "COMM" > //Make sure there are loops< / span > < span class = "WHIT" >
< span class = 'line' > 118< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > if< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > rep_data.length< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > >< / span > < span class = "WHIT" > < / span > < span class = "NUMB" > 0< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 119< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 120< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > data_len< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > rep_data.length< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 121< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 122< / span > < / span > < span class = "COMM" > //Get rid of the loop tags< / span > < span class = "WHIT" >
< span class = 'line' > 123< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > pairs< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > ]< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > pairs< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > .< / span > < span class = "NAME" > replace< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > pair_reg< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "STRN" > "$2"< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 124< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 125< / span > < / span > < span class = "COMM" > //Replace psudovariables with data< / span > < span class = "WHIT" >
< span class = 'line' > 126< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > for< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > j< / span > < span class = "PUNC" > =< / span > < span class = "NUMB" > 0< / span > < span class = "PUNC" > ;< / span > < span class = "NAME" > j< / span > < span class = "PUNC" > < < / span > < span class = "NAME" > data_len< / span > < span class = "PUNC" > ;< / span > < span class = "NAME" > j< / span > < span class = "PUNC" > ++< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 127< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 128< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > //Is there a better way to do this, rather than an inline function?< / span > < span class = "WHIT" >
< span class = 'line' > 129< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp_data< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > +< / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > pairs< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > .< / span > < span class = "NAME" > replace< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > var_reg< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "KEYW" > function< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > _< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "NAME" > varName< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 130< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > return< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > (< / span > < span class = "NAME" > rep_data< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > j< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > varName< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > ?< / span > < span class = "WHIT" > < / span > < span class = "NAME" > rep_data< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > j< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > varName< / span > < span class = "PUNC" > ]< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > :< / span > < span class = "WHIT" > < / span > < span class = "STRN" > ""< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 131< / span > < / span > < span class = "PUNC" > }< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 132< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 133< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 134< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 135< / span > < / span > < span class = "COMM" > //Replace the looped content< / span > < span class = "WHIT" >
< span class = 'line' > 136< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp.replace< / span > < span class = "PUNC" > (< / span > < span class = "STRN" > "{"< / span > < span class = "PUNC" > +< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > +< / span > < span class = "STRN" > "}"< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp_data< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 137< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 138< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 139< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 140< / span > < / span > < span class = "COMM" > //Replace all the rest of the psudeovariables< / span > < span class = "WHIT" >
< span class = 'line' > 141< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > pseudos< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp.match< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > var_reg< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 142< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 143< / span > < / span > < span class = "KEYW" > if< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > pseudos< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > !=< / span > < span class = "WHIT" > < / span > < span class = "KEYW" > null< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 144< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 145< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > num_pseudos< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > pseudos.length< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 146< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 147< / span > < / span > < span class = "KEYW" > for< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > =< / span > < span class = "NUMB" > 0< / span > < span class = "PUNC" > ;< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > < < / span > < span class = "NAME" > num_pseudos< / span > < span class = "PUNC" > ;< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > ++< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 148< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 149< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > //Remove the {} from the pseudos< / span > < span class = "WHIT" >
< span class = 'line' > 150< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > var_name< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > pseudos< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > .< / span > < span class = "NAME" > replace< / span > < span class = "PUNC" > (< / span > < span class = "STRN" > '{'< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "STRN" > ''< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 151< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > var_name< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > var_name.replace< / span > < span class = "PUNC" > (< / span > < span class = "STRN" > '}'< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "STRN" > ''< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 152< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 153< / span > < / span > < span class = "COMM" > //Replace each pseudovariable with the value of the object< / span > < span class = "WHIT" >
< span class = 'line' > 154< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > //property of the same name< / span > < span class = "WHIT" >
< span class = 'line' > 155< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp.replace< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > pseudos< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > i< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "NAME" > data< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > var_name< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 156< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 157< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 158< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 159< / span > < / span > < span class = "COMM" > //Create an empty fragement< / span > < span class = "WHIT" >
< span class = 'line' > 160< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > frag< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > document.createDocumentFragment< / span > < span class = "PUNC" > (< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 161< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 162< / span > < / span > < span class = "COMM" > //Insert the html< / span > < span class = "WHIT" >
< span class = 'line' > 163< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > frag.appendChild< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > document.createElement< / span > < span class = "PUNC" > (< / span > < span class = "STRN" > 'section'< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 164< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > frag_section< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > frag.querySelectorAll< / span > < span class = "PUNC" > (< / span > < span class = "STRN" > 'section'< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > [< / span > < span class = "NUMB" > 0< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 165< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > frag_section.innerHTML< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 166< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 167< / span > < / span > < span class = "COMM" > //Remove bad elements in the fragment, should be faster than being done live< / span > < span class = "WHIT" >
< span class = 'line' > 168< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > emptys< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > frag_section.querySelectorAll< / span > < span class = "PUNC" > (< / span > < span class = "STRN" > '[src=""], [href=""]'< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 169< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 170< / span > < / span > < span class = "KEYW" > for< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > x< / span > < span class = "WHIT" > < / span > < span class = "KEYW" > in< / span > < span class = "WHIT" > < / span > < span class = "NAME" > emptys< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 171< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 172< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > if< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > emptys< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > x< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > .< / span > < span class = "NAME" > parentNode< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 173< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 174< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > emptys< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > x< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > .< / span > < span class = "NAME" > parentNode.removeChild< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > emptys< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > x< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 175< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 176< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 177< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 178< / span > < / span > < span class = "COMM" > //Save the parsed template in an object for later retrieval< / span > < span class = "WHIT" >
< span class = 'line' > 179< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > _p< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ]< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 180< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 181< / span > < / span > < span class = "KEYW" > return< / span > < span class = "WHIT" > < / span > < span class = "NAME" > tmp< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 182< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" >
< span class = 'line' > 183< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > /**
< span class = 'line' > 184< / span > * Inserts the formatted template into the page. If the url and data parameters
< span class = 'line' > 185< / span > * are passed, it will retrieve a template file from the same domain, parse,
< span class = 'line' > 186< / span > * and insert the template into the page.
< span class = 'line' > 187< / span > *
< span class = 'line' > 188< / span > * @memberOf $_.template
< span class = 'line' > 189< / span > * @name apply
< span class = 'line' > 190< / span > * @function
< span class = 'line' > 191< / span > * @param string parsed_template/template_name
< span class = 'line' > 192< / span > * @param [string] url
< span class = 'line' > 193< / span > * @param [object] data
< span class = 'line' > 194< / span > */< / span > < span class = "WHIT" >
< span class = 'line' > 195< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > apply< / span > < span class = "PUNC" > :< / span > < span class = "WHIT" > < / span > < span class = "KEYW" > function< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "NAME" > url< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "NAME" > data< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 196< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 197< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > //If the parsed template is supplied, just apply it to the passed selector< / span > < span class = "WHIT" >
< span class = 'line' > 198< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > if< / span > < span class = "PUNC" > (< / span > < span class = "KEYW" > typeof< / span > < span class = "WHIT" > < / span > < span class = "NAME" > url< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > ===< / span > < span class = "WHIT" > < / span > < span class = "STRN" > "undefined"< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > & & < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > typeof< / span > < span class = "WHIT" > < / span > < span class = "NAME" > data< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > ===< / span > < span class = "WHIT" > < / span > < span class = "STRN" > "undefined"< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 199< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 200< / span > < / span > < span class = "WHIT" > < / span > < span class = "COMM" > //If the "name" variable is in the _p object, set that< / span > < span class = "WHIT" >
< span class = 'line' > 201< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > if< / span > < span class = "PUNC" > (< / span > < span class = "KEYW" > typeof< / span > < span class = "WHIT" > < / span > < span class = "NAME" > _p< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ]< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > !==< / span > < span class = "WHIT" > < / span > < span class = "STRN" > "undefined"< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 202< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 203< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > this.el.innerHTML< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > _p< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ]< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 204< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > return< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 205< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 206< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 207< / span > < / span > < span class = "COMM" > //Otherwise, set the passed string to the current selector< / span > < span class = "WHIT" >
< span class = 'line' > 208< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > this.el.innerHTML< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 209< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > return< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 210< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 211< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 212< / span > < / span > < span class = "COMM" > //Otherwise, get the template, parse it, and apply it< / span > < span class = "WHIT" >
< span class = 'line' > 213< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > $_.get< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > url< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "PUNC" > }< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "KEYW" > function< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > res< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 214< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > var< / span > < span class = "WHIT" > < / span > < span class = "NAME" > parsed< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 215< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 216< / span > < / span > < span class = "KEYW" > if< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > res< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > ===< / span > < span class = "WHIT" > < / span > < span class = "STRN" > ""< / span > < span class = "PUNC" > )< / span > < span class = "WHIT" >
< span class = 'line' > 217< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > {< / span > < span class = "WHIT" >
< span class = 'line' > 218< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > console.log< / span > < span class = "PUNC" > (< / span > < span class = "STRN" > "Template is empty or can not be found"< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 219< / span > < / span > < span class = "WHIT" > < / span > < span class = "KEYW" > return< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 220< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 221< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 222< / span > < / span > < span class = "COMM" > //Cache the template in an object for later use< / span > < span class = "WHIT" >
< span class = 'line' > 223< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > _t< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ]< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > res< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 224< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > parsed< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > this.parse< / span > < span class = "PUNC" > (< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "NAME" > data< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 225< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > _p< / span > < span class = "PUNC" > [< / span > < span class = "NAME" > name< / span > < span class = "PUNC" > ]< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > parsed< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 226< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 227< / span > < / span > < span class = "NAME" > this.el.innerHTML< / span > < span class = "WHIT" > < / span > < span class = "PUNC" > =< / span > < span class = "WHIT" > < / span > < span class = "NAME" > parsed< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 228< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 229< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "WHIT" >
< span class = 'line' > 230< / span > < / span > < span class = "WHIT" > < / span > < span class = "PUNC" > }< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 231< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 232< / span > < / span > < span class = "COMM" > //Add the module to the library< / span > < span class = "WHIT" >
< span class = 'line' > 233< / span > < / span > < span class = "WHIT" > < / span > < span class = "NAME" > $_.ext< / span > < span class = "PUNC" > (< / span > < span class = "STRN" > 'template'< / span > < span class = "PUNC" > ,< / span > < span class = "WHIT" > < / span > < span class = "NAME" > t< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < span class = "WHIT" >
< span class = 'line' > 234< / span > < / span > < span class = "WHIT" >
< span class = 'line' > 235< / span > < / span > < span class = "PUNC" > }< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > (< / span > < span class = "PUNC" > )< / span > < span class = "PUNC" > ;< / span > < / pre > < / body > < / html >