backbone_generator 0.0.3 → 0.0.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (48) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +1 -0
  3. data/.rspec +2 -0
  4. data/LICENSE.txt +1 -1
  5. data/README.md +10 -7
  6. data/backbone_generator.gemspec +9 -15
  7. data/bin/backbone_generator +6 -0
  8. data/lib/backbone_generator.rb +13 -1
  9. data/lib/backbone_generator/auxilliary.rb +44 -0
  10. data/lib/backbone_generator/cli.rb +79 -0
  11. data/lib/backbone_generator/generators/collections/collections_generator.rb +35 -0
  12. data/lib/backbone_generator/generators/collections/template/Collection.tt +29 -0
  13. data/lib/backbone_generator/generators/library/library_generator.rb +17 -0
  14. data/lib/backbone_generator/generators/models/models_generator.rb +35 -0
  15. data/lib/backbone_generator/generators/models/template/Model.tt +44 -0
  16. data/lib/backbone_generator/generators/new/new_generator.rb +89 -0
  17. data/lib/backbone_generator/generators/new/template/.gitignore +1 -0
  18. data/lib/backbone_generator/generators/new/template/README.tt +9 -0
  19. data/lib/backbone_generator/generators/new/template/css/main.css +43 -0
  20. data/lib/backbone_generator/generators/new/template/img/backbone.png +0 -0
  21. data/lib/backbone_generator/generators/new/template/index.html +15 -0
  22. data/lib/backbone_generator/generators/new/template/js/libs/backbone/backbone-1.1.0.js +1498 -0
  23. data/lib/backbone_generator/generators/new/template/js/libs/jquery/jquery-2.0.3.min.js +6 -0
  24. data/lib/backbone_generator/generators/new/template/js/libs/requirejs-text/text-2.0.10.js +332 -0
  25. data/lib/backbone_generator/generators/new/template/js/libs/requirejs/require-2.1.9.js +2019 -0
  26. data/lib/backbone_generator/generators/new/template/js/libs/underscore/underscore-1.5.2.js +1226 -0
  27. data/lib/backbone_generator/generators/new/template/js/views/Main.View.tt +39 -0
  28. data/lib/backbone_generator/generators/new/template/main.tt +45 -0
  29. data/lib/backbone_generator/generators/route/route_generator.rb +36 -0
  30. data/lib/backbone_generator/generators/route/template/Routes.tt +27 -0
  31. data/lib/backbone_generator/generators/templates/template/Template.tt +10 -0
  32. data/lib/backbone_generator/generators/templates/templates_generator.rb +35 -0
  33. data/lib/backbone_generator/generators/tests/template/mainview.js +48 -0
  34. data/lib/backbone_generator/generators/tests/tests_generator.rb +17 -0
  35. data/lib/backbone_generator/generators/utilities/template/Utility.tt +28 -0
  36. data/lib/backbone_generator/generators/utilities/utilities_generator.rb +35 -0
  37. data/lib/backbone_generator/generators/views/template/View.tt +50 -0
  38. data/lib/backbone_generator/generators/views/views_generator.rb +36 -0
  39. data/lib/backbone_generator/post_install_message.rb +21 -0
  40. data/lib/backbone_generator/version.rb +1 -1
  41. data/spec/backbone_generator/post_install_message.rb +20 -0
  42. data/spec/backbone_generator/version.rb +3 -0
  43. data/spec/backbone_generator_spec.rb +5 -0
  44. data/spec/cli_spec.rb +34 -0
  45. data/spec/post_install_message_spec.rb +6 -0
  46. data/spec/spec_helper.rb +17 -0
  47. data/spec/version_spec.rb +5 -0
  48. metadata +105 -21
@@ -0,0 +1,6 @@
1
+ /*! jQuery v2.0.3 | (c) 2005, 2013 jQuery Foundation, Inc. | jquery.org/license
2
+ //@ sourceMappingURL=jquery-2.0.3.min.map
3
+ */
4
+ (function(e,undefined){var t,n,r=typeof undefined,i=e.location,o=e.document,s=o.documentElement,a=e.jQuery,u=e.$,l={},c=[],p="2.0.3",f=c.concat,h=c.push,d=c.slice,g=c.indexOf,m=l.toString,y=l.hasOwnProperty,v=p.trim,x=function(e,n){return new x.fn.init(e,n,t)},b=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,w=/\S+/g,T=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,C=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,k=/^-ms-/,N=/-([\da-z])/gi,E=function(e,t){return t.toUpperCase()},S=function(){o.removeEventListener("DOMContentLoaded",S,!1),e.removeEventListener("load",S,!1),x.ready()};x.fn=x.prototype={jquery:p,constructor:x,init:function(e,t,n){var r,i;if(!e)return this;if("string"==typeof e){if(r="<"===e.charAt(0)&&">"===e.charAt(e.length-1)&&e.length>=3?[null,e,null]:T.exec(e),!r||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof x?t[0]:t,x.merge(this,x.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:o,!0)),C.test(r[1])&&x.isPlainObject(t))for(r in t)x.isFunction(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return i=o.getElementById(r[2]),i&&i.parentNode&&(this.length=1,this[0]=i),this.context=o,this.selector=e,this}return e.nodeType?(this.context=this[0]=e,this.length=1,this):x.isFunction(e)?n.ready(e):(e.selector!==undefined&&(this.selector=e.selector,this.context=e.context),x.makeArray(e,this))},selector:"",length:0,toArray:function(){return d.call(this)},get:function(e){return null==e?this.toArray():0>e?this[this.length+e]:this[e]},pushStack:function(e){var t=x.merge(this.constructor(),e);return t.prevObject=this,t.context=this.context,t},each:function(e,t){return x.each(this,e,t)},ready:function(e){return x.ready.promise().done(e),this},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(0>e?t:0);return this.pushStack(n>=0&&t>n?[this[n]]:[])},map:function(e){return this.pushStack(x.map(this,function(t,n){return e.call(t,n,t)}))},end:function(){return this.prevObject||this.constructor(null)},push:h,sort:[].sort,splice:[].splice},x.fn.init.prototype=x.fn,x.extend=x.fn.extend=function(){var e,t,n,r,i,o,s=arguments[0]||{},a=1,u=arguments.length,l=!1;for("boolean"==typeof s&&(l=s,s=arguments[1]||{},a=2),"object"==typeof s||x.isFunction(s)||(s={}),u===a&&(s=this,--a);u>a;a++)if(null!=(e=arguments[a]))for(t in e)n=s[t],r=e[t],s!==r&&(l&&r&&(x.isPlainObject(r)||(i=x.isArray(r)))?(i?(i=!1,o=n&&x.isArray(n)?n:[]):o=n&&x.isPlainObject(n)?n:{},s[t]=x.extend(l,o,r)):r!==undefined&&(s[t]=r));return s},x.extend({expando:"jQuery"+(p+Math.random()).replace(/\D/g,""),noConflict:function(t){return e.$===x&&(e.$=u),t&&e.jQuery===x&&(e.jQuery=a),x},isReady:!1,readyWait:1,holdReady:function(e){e?x.readyWait++:x.ready(!0)},ready:function(e){(e===!0?--x.readyWait:x.isReady)||(x.isReady=!0,e!==!0&&--x.readyWait>0||(n.resolveWith(o,[x]),x.fn.trigger&&x(o).trigger("ready").off("ready")))},isFunction:function(e){return"function"===x.type(e)},isArray:Array.isArray,isWindow:function(e){return null!=e&&e===e.window},isNumeric:function(e){return!isNaN(parseFloat(e))&&isFinite(e)},type:function(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?l[m.call(e)]||"object":typeof e},isPlainObject:function(e){if("object"!==x.type(e)||e.nodeType||x.isWindow(e))return!1;try{if(e.constructor&&!y.call(e.constructor.prototype,"isPrototypeOf"))return!1}catch(t){return!1}return!0},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},error:function(e){throw Error(e)},parseHTML:function(e,t,n){if(!e||"string"!=typeof e)return null;"boolean"==typeof t&&(n=t,t=!1),t=t||o;var r=C.exec(e),i=!n&&[];return r?[t.createElement(r[1])]:(r=x.buildFragment([e],t,i),i&&x(i).remove(),x.merge([],r.childNodes))},parseJSON:JSON.parse,parseXML:function(e){var t,n;if(!e||"string"!=typeof e)return null;try{n=new DOMParser,t=n.parseFromString(e,"text/xml")}catch(r){t=undefined}return(!t||t.getElementsByTagName("parsererror").length)&&x.error("Invalid XML: "+e),t},noop:function(){},globalEval:function(e){var t,n=eval;e=x.trim(e),e&&(1===e.indexOf("use strict")?(t=o.createElement("script"),t.text=e,o.head.appendChild(t).parentNode.removeChild(t)):n(e))},camelCase:function(e){return e.replace(k,"ms-").replace(N,E)},nodeName:function(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()},each:function(e,t,n){var r,i=0,o=e.length,s=j(e);if(n){if(s){for(;o>i;i++)if(r=t.apply(e[i],n),r===!1)break}else for(i in e)if(r=t.apply(e[i],n),r===!1)break}else if(s){for(;o>i;i++)if(r=t.call(e[i],i,e[i]),r===!1)break}else for(i in e)if(r=t.call(e[i],i,e[i]),r===!1)break;return e},trim:function(e){return null==e?"":v.call(e)},makeArray:function(e,t){var n=t||[];return null!=e&&(j(Object(e))?x.merge(n,"string"==typeof e?[e]:e):h.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:g.call(t,e,n)},merge:function(e,t){var n=t.length,r=e.length,i=0;if("number"==typeof n)for(;n>i;i++)e[r++]=t[i];else while(t[i]!==undefined)e[r++]=t[i++];return e.length=r,e},grep:function(e,t,n){var r,i=[],o=0,s=e.length;for(n=!!n;s>o;o++)r=!!t(e[o],o),n!==r&&i.push(e[o]);return i},map:function(e,t,n){var r,i=0,o=e.length,s=j(e),a=[];if(s)for(;o>i;i++)r=t(e[i],i,n),null!=r&&(a[a.length]=r);else for(i in e)r=t(e[i],i,n),null!=r&&(a[a.length]=r);return f.apply([],a)},guid:1,proxy:function(e,t){var n,r,i;return"string"==typeof t&&(n=e[t],t=e,e=n),x.isFunction(e)?(r=d.call(arguments,2),i=function(){return e.apply(t||this,r.concat(d.call(arguments)))},i.guid=e.guid=e.guid||x.guid++,i):undefined},access:function(e,t,n,r,i,o,s){var a=0,u=e.length,l=null==n;if("object"===x.type(n)){i=!0;for(a in n)x.access(e,t,a,n[a],!0,o,s)}else if(r!==undefined&&(i=!0,x.isFunction(r)||(s=!0),l&&(s?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(x(e),n)})),t))for(;u>a;a++)t(e[a],n,s?r:r.call(e[a],a,t(e[a],n)));return i?e:l?t.call(e):u?t(e[0],n):o},now:Date.now,swap:function(e,t,n,r){var i,o,s={};for(o in t)s[o]=e.style[o],e.style[o]=t[o];i=n.apply(e,r||[]);for(o in t)e.style[o]=s[o];return i}}),x.ready.promise=function(t){return n||(n=x.Deferred(),"complete"===o.readyState?setTimeout(x.ready):(o.addEventListener("DOMContentLoaded",S,!1),e.addEventListener("load",S,!1))),n.promise(t)},x.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(e,t){l["[object "+t+"]"]=t.toLowerCase()});function j(e){var t=e.length,n=x.type(e);return x.isWindow(e)?!1:1===e.nodeType&&t?!0:"array"===n||"function"!==n&&(0===t||"number"==typeof t&&t>0&&t-1 in e)}t=x(o),function(e,undefined){var t,n,r,i,o,s,a,u,l,c,p,f,h,d,g,m,y,v="sizzle"+-new Date,b=e.document,w=0,T=0,C=st(),k=st(),N=st(),E=!1,S=function(e,t){return e===t?(E=!0,0):0},j=typeof undefined,D=1<<31,A={}.hasOwnProperty,L=[],q=L.pop,H=L.push,O=L.push,F=L.slice,P=L.indexOf||function(e){var t=0,n=this.length;for(;n>t;t++)if(this[t]===e)return t;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",W="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",$=W.replace("w","w#"),B="\\["+M+"*("+W+")"+M+"*(?:([*^$|!~]?=)"+M+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+$+")|)|)"+M+"*\\]",I=":("+W+")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|"+B.replace(3,8)+")*)|.*)\\)|)",z=RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=RegExp("^"+M+"*,"+M+"*"),X=RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=RegExp(M+"*[+~]"),Y=RegExp("="+M+"*([^\\]'\"]*)"+M+"*\\]","g"),V=RegExp(I),G=RegExp("^"+$+"$"),J={ID:RegExp("^#("+W+")"),CLASS:RegExp("^\\.("+W+")"),TAG:RegExp("^("+W.replace("w","w*")+")"),ATTR:RegExp("^"+B),PSEUDO:RegExp("^"+I),CHILD:RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:RegExp("^(?:"+R+")$","i"),needsContext:RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Q=/^[^{]+\{\s*\[native \w/,K=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,Z=/^(?:input|select|textarea|button)$/i,et=/^h\d$/i,tt=/'|\\/g,nt=RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),rt=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:0>r?String.fromCharCode(r+65536):String.fromCharCode(55296|r>>10,56320|1023&r)};try{O.apply(L=F.call(b.childNodes),b.childNodes),L[b.childNodes.length].nodeType}catch(it){O={apply:L.length?function(e,t){H.apply(e,F.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function ot(e,t,r,i){var o,s,a,u,l,f,g,m,x,w;if((t?t.ownerDocument||t:b)!==p&&c(t),t=t||p,r=r||[],!e||"string"!=typeof e)return r;if(1!==(u=t.nodeType)&&9!==u)return[];if(h&&!i){if(o=K.exec(e))if(a=o[1]){if(9===u){if(s=t.getElementById(a),!s||!s.parentNode)return r;if(s.id===a)return r.push(s),r}else if(t.ownerDocument&&(s=t.ownerDocument.getElementById(a))&&y(t,s)&&s.id===a)return r.push(s),r}else{if(o[2])return O.apply(r,t.getElementsByTagName(e)),r;if((a=o[3])&&n.getElementsByClassName&&t.getElementsByClassName)return O.apply(r,t.getElementsByClassName(a)),r}if(n.qsa&&(!d||!d.test(e))){if(m=g=v,x=t,w=9===u&&e,1===u&&"object"!==t.nodeName.toLowerCase()){f=gt(e),(g=t.getAttribute("id"))?m=g.replace(tt,"\\$&"):t.setAttribute("id",m),m="[id='"+m+"'] ",l=f.length;while(l--)f[l]=m+mt(f[l]);x=U.test(e)&&t.parentNode||t,w=f.join(",")}if(w)try{return O.apply(r,x.querySelectorAll(w)),r}catch(T){}finally{g||t.removeAttribute("id")}}}return kt(e.replace(z,"$1"),t,r,i)}function st(){var e=[];function t(n,r){return e.push(n+=" ")>i.cacheLength&&delete t[e.shift()],t[n]=r}return t}function at(e){return e[v]=!0,e}function ut(e){var t=p.createElement("div");try{return!!e(t)}catch(n){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function lt(e,t){var n=e.split("|"),r=e.length;while(r--)i.attrHandle[n[r]]=t}function ct(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&(~t.sourceIndex||D)-(~e.sourceIndex||D);if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function pt(e){return function(t){var n=t.nodeName.toLowerCase();return"input"===n&&t.type===e}}function ft(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function ht(e){return at(function(t){return t=+t,at(function(n,r){var i,o=e([],n.length,t),s=o.length;while(s--)n[i=o[s]]&&(n[i]=!(r[i]=n[i]))})})}s=ot.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return t?"HTML"!==t.nodeName:!1},n=ot.support={},c=ot.setDocument=function(e){var t=e?e.ownerDocument||e:b,r=t.defaultView;return t!==p&&9===t.nodeType&&t.documentElement?(p=t,f=t.documentElement,h=!s(t),r&&r.attachEvent&&r!==r.top&&r.attachEvent("onbeforeunload",function(){c()}),n.attributes=ut(function(e){return e.className="i",!e.getAttribute("className")}),n.getElementsByTagName=ut(function(e){return e.appendChild(t.createComment("")),!e.getElementsByTagName("*").length}),n.getElementsByClassName=ut(function(e){return e.innerHTML="<div class='a'></div><div class='a i'></div>",e.firstChild.className="i",2===e.getElementsByClassName("i").length}),n.getById=ut(function(e){return f.appendChild(e).id=v,!t.getElementsByName||!t.getElementsByName(v).length}),n.getById?(i.find.ID=function(e,t){if(typeof t.getElementById!==j&&h){var n=t.getElementById(e);return n&&n.parentNode?[n]:[]}},i.filter.ID=function(e){var t=e.replace(nt,rt);return function(e){return e.getAttribute("id")===t}}):(delete i.find.ID,i.filter.ID=function(e){var t=e.replace(nt,rt);return function(e){var n=typeof e.getAttributeNode!==j&&e.getAttributeNode("id");return n&&n.value===t}}),i.find.TAG=n.getElementsByTagName?function(e,t){return typeof t.getElementsByTagName!==j?t.getElementsByTagName(e):undefined}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},i.find.CLASS=n.getElementsByClassName&&function(e,t){return typeof t.getElementsByClassName!==j&&h?t.getElementsByClassName(e):undefined},g=[],d=[],(n.qsa=Q.test(t.querySelectorAll))&&(ut(function(e){e.innerHTML="<select><option selected=''></option></select>",e.querySelectorAll("[selected]").length||d.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll(":checked").length||d.push(":checked")}),ut(function(e){var n=t.createElement("input");n.setAttribute("type","hidden"),e.appendChild(n).setAttribute("t",""),e.querySelectorAll("[t^='']").length&&d.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll(":enabled").length||d.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),d.push(",.*:")})),(n.matchesSelector=Q.test(m=f.webkitMatchesSelector||f.mozMatchesSelector||f.oMatchesSelector||f.msMatchesSelector))&&ut(function(e){n.disconnectedMatch=m.call(e,"div"),m.call(e,"[s!='']:x"),g.push("!=",I)}),d=d.length&&RegExp(d.join("|")),g=g.length&&RegExp(g.join("|")),y=Q.test(f.contains)||f.compareDocumentPosition?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},S=f.compareDocumentPosition?function(e,r){if(e===r)return E=!0,0;var i=r.compareDocumentPosition&&e.compareDocumentPosition&&e.compareDocumentPosition(r);return i?1&i||!n.sortDetached&&r.compareDocumentPosition(e)===i?e===t||y(b,e)?-1:r===t||y(b,r)?1:l?P.call(l,e)-P.call(l,r):0:4&i?-1:1:e.compareDocumentPosition?-1:1}:function(e,n){var r,i=0,o=e.parentNode,s=n.parentNode,a=[e],u=[n];if(e===n)return E=!0,0;if(!o||!s)return e===t?-1:n===t?1:o?-1:s?1:l?P.call(l,e)-P.call(l,n):0;if(o===s)return ct(e,n);r=e;while(r=r.parentNode)a.unshift(r);r=n;while(r=r.parentNode)u.unshift(r);while(a[i]===u[i])i++;return i?ct(a[i],u[i]):a[i]===b?-1:u[i]===b?1:0},t):p},ot.matches=function(e,t){return ot(e,null,null,t)},ot.matchesSelector=function(e,t){if((e.ownerDocument||e)!==p&&c(e),t=t.replace(Y,"='$1']"),!(!n.matchesSelector||!h||g&&g.test(t)||d&&d.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(i){}return ot(t,p,null,[e]).length>0},ot.contains=function(e,t){return(e.ownerDocument||e)!==p&&c(e),y(e,t)},ot.attr=function(e,t){(e.ownerDocument||e)!==p&&c(e);var r=i.attrHandle[t.toLowerCase()],o=r&&A.call(i.attrHandle,t.toLowerCase())?r(e,t,!h):undefined;return o===undefined?n.attributes||!h?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null:o},ot.error=function(e){throw Error("Syntax error, unrecognized expression: "+e)},ot.uniqueSort=function(e){var t,r=[],i=0,o=0;if(E=!n.detectDuplicates,l=!n.sortStable&&e.slice(0),e.sort(S),E){while(t=e[o++])t===e[o]&&(i=r.push(o));while(i--)e.splice(r[i],1)}return e},o=ot.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else for(;t=e[r];r++)n+=o(t);return n},i=ot.selectors={cacheLength:50,createPseudo:at,match:J,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(nt,rt),e[3]=(e[4]||e[5]||"").replace(nt,rt),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||ot.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&ot.error(e[0]),e},PSEUDO:function(e){var t,n=!e[5]&&e[2];return J.CHILD.test(e[0])?null:(e[3]&&e[4]!==undefined?e[2]=e[4]:n&&V.test(n)&&(t=gt(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(nt,rt).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=C[e+" "];return t||(t=RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&C(e,function(e){return t.test("string"==typeof e.className&&e.className||typeof e.getAttribute!==j&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=ot.attr(r,e);return null==i?"!="===t:t?(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i+" ").indexOf(n)>-1:"|="===t?i===n||i.slice(0,n.length+1)===n+"-":!1):!0}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),s="last"!==e.slice(-4),a="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,p,f,h,d,g=o!==s?"nextSibling":"previousSibling",m=t.parentNode,y=a&&t.nodeName.toLowerCase(),x=!u&&!a;if(m){if(o){while(g){p=t;while(p=p[g])if(a?p.nodeName.toLowerCase()===y:1===p.nodeType)return!1;d=g="only"===e&&!d&&"nextSibling"}return!0}if(d=[s?m.firstChild:m.lastChild],s&&x){c=m[v]||(m[v]={}),l=c[e]||[],h=l[0]===w&&l[1],f=l[0]===w&&l[2],p=h&&m.childNodes[h];while(p=++h&&p&&p[g]||(f=h=0)||d.pop())if(1===p.nodeType&&++f&&p===t){c[e]=[w,h,f];break}}else if(x&&(l=(t[v]||(t[v]={}))[e])&&l[0]===w)f=l[1];else while(p=++h&&p&&p[g]||(f=h=0)||d.pop())if((a?p.nodeName.toLowerCase()===y:1===p.nodeType)&&++f&&(x&&((p[v]||(p[v]={}))[e]=[w,f]),p===t))break;return f-=i,f===r||0===f%r&&f/r>=0}}},PSEUDO:function(e,t){var n,r=i.pseudos[e]||i.setFilters[e.toLowerCase()]||ot.error("unsupported pseudo: "+e);return r[v]?r(t):r.length>1?(n=[e,e,"",t],i.setFilters.hasOwnProperty(e.toLowerCase())?at(function(e,n){var i,o=r(e,t),s=o.length;while(s--)i=P.call(e,o[s]),e[i]=!(n[i]=o[s])}):function(e){return r(e,0,n)}):r}},pseudos:{not:at(function(e){var t=[],n=[],r=a(e.replace(z,"$1"));return r[v]?at(function(e,t,n,i){var o,s=r(e,null,i,[]),a=e.length;while(a--)(o=s[a])&&(e[a]=!(t[a]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),!n.pop()}}),has:at(function(e){return function(t){return ot(e,t).length>0}}),contains:at(function(e){return function(t){return(t.textContent||t.innerText||o(t)).indexOf(e)>-1}}),lang:at(function(e){return G.test(e||"")||ot.error("unsupported lang: "+e),e=e.replace(nt,rt).toLowerCase(),function(t){var n;do if(n=h?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return n=n.toLowerCase(),n===e||0===n.indexOf(e+"-");while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===f},focus:function(e){return e===p.activeElement&&(!p.hasFocus||p.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:function(e){return e.disabled===!1},disabled:function(e){return e.disabled===!0},checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,e.selected===!0},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeName>"@"||3===e.nodeType||4===e.nodeType)return!1;return!0},parent:function(e){return!i.pseudos.empty(e)},header:function(e){return et.test(e.nodeName)},input:function(e){return Z.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||t.toLowerCase()===e.type)},first:ht(function(){return[0]}),last:ht(function(e,t){return[t-1]}),eq:ht(function(e,t,n){return[0>n?n+t:n]}),even:ht(function(e,t){var n=0;for(;t>n;n+=2)e.push(n);return e}),odd:ht(function(e,t){var n=1;for(;t>n;n+=2)e.push(n);return e}),lt:ht(function(e,t,n){var r=0>n?n+t:n;for(;--r>=0;)e.push(r);return e}),gt:ht(function(e,t,n){var r=0>n?n+t:n;for(;t>++r;)e.push(r);return e})}},i.pseudos.nth=i.pseudos.eq;for(t in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})i.pseudos[t]=pt(t);for(t in{submit:!0,reset:!0})i.pseudos[t]=ft(t);function dt(){}dt.prototype=i.filters=i.pseudos,i.setFilters=new dt;function gt(e,t){var n,r,o,s,a,u,l,c=k[e+" "];if(c)return t?0:c.slice(0);a=e,u=[],l=i.preFilter;while(a){(!n||(r=_.exec(a)))&&(r&&(a=a.slice(r[0].length)||a),u.push(o=[])),n=!1,(r=X.exec(a))&&(n=r.shift(),o.push({value:n,type:r[0].replace(z," ")}),a=a.slice(n.length));for(s in i.filter)!(r=J[s].exec(a))||l[s]&&!(r=l[s](r))||(n=r.shift(),o.push({value:n,type:s,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?ot.error(e):k(e,u).slice(0)}function mt(e){var t=0,n=e.length,r="";for(;n>t;t++)r+=e[t].value;return r}function yt(e,t,n){var i=t.dir,o=n&&"parentNode"===i,s=T++;return t.first?function(t,n,r){while(t=t[i])if(1===t.nodeType||o)return e(t,n,r)}:function(t,n,a){var u,l,c,p=w+" "+s;if(a){while(t=t[i])if((1===t.nodeType||o)&&e(t,n,a))return!0}else while(t=t[i])if(1===t.nodeType||o)if(c=t[v]||(t[v]={}),(l=c[i])&&l[0]===p){if((u=l[1])===!0||u===r)return u===!0}else if(l=c[i]=[p],l[1]=e(t,n,a)||r,l[1]===!0)return!0}}function vt(e){return e.length>1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function xt(e,t,n,r,i){var o,s=[],a=0,u=e.length,l=null!=t;for(;u>a;a++)(o=e[a])&&(!n||n(o,r,i))&&(s.push(o),l&&t.push(a));return s}function bt(e,t,n,r,i,o){return r&&!r[v]&&(r=bt(r)),i&&!i[v]&&(i=bt(i,o)),at(function(o,s,a,u){var l,c,p,f=[],h=[],d=s.length,g=o||Ct(t||"*",a.nodeType?[a]:a,[]),m=!e||!o&&t?g:xt(g,f,e,a,u),y=n?i||(o?e:d||r)?[]:s:m;if(n&&n(m,y,a,u),r){l=xt(y,h),r(l,[],a,u),c=l.length;while(c--)(p=l[c])&&(y[h[c]]=!(m[h[c]]=p))}if(o){if(i||e){if(i){l=[],c=y.length;while(c--)(p=y[c])&&l.push(m[c]=p);i(null,y=[],l,u)}c=y.length;while(c--)(p=y[c])&&(l=i?P.call(o,p):f[c])>-1&&(o[l]=!(s[l]=p))}}else y=xt(y===s?y.splice(d,y.length):y),i?i(null,s,y,u):O.apply(s,y)})}function wt(e){var t,n,r,o=e.length,s=i.relative[e[0].type],a=s||i.relative[" "],l=s?1:0,c=yt(function(e){return e===t},a,!0),p=yt(function(e){return P.call(t,e)>-1},a,!0),f=[function(e,n,r){return!s&&(r||n!==u)||((t=n).nodeType?c(e,n,r):p(e,n,r))}];for(;o>l;l++)if(n=i.relative[e[l].type])f=[yt(vt(f),n)];else{if(n=i.filter[e[l].type].apply(null,e[l].matches),n[v]){for(r=++l;o>r;r++)if(i.relative[e[r].type])break;return bt(l>1&&vt(f),l>1&&mt(e.slice(0,l-1).concat({value:" "===e[l-2].type?"*":""})).replace(z,"$1"),n,r>l&&wt(e.slice(l,r)),o>r&&wt(e=e.slice(r)),o>r&&mt(e))}f.push(n)}return vt(f)}function Tt(e,t){var n=0,o=t.length>0,s=e.length>0,a=function(a,l,c,f,h){var d,g,m,y=[],v=0,x="0",b=a&&[],T=null!=h,C=u,k=a||s&&i.find.TAG("*",h&&l.parentNode||l),N=w+=null==C?1:Math.random()||.1;for(T&&(u=l!==p&&l,r=n);null!=(d=k[x]);x++){if(s&&d){g=0;while(m=e[g++])if(m(d,l,c)){f.push(d);break}T&&(w=N,r=++n)}o&&((d=!m&&d)&&v--,a&&b.push(d))}if(v+=x,o&&x!==v){g=0;while(m=t[g++])m(b,y,l,c);if(a){if(v>0)while(x--)b[x]||y[x]||(y[x]=q.call(f));y=xt(y)}O.apply(f,y),T&&!a&&y.length>0&&v+t.length>1&&ot.uniqueSort(f)}return T&&(w=N,u=C),b};return o?at(a):a}a=ot.compile=function(e,t){var n,r=[],i=[],o=N[e+" "];if(!o){t||(t=gt(e)),n=t.length;while(n--)o=wt(t[n]),o[v]?r.push(o):i.push(o);o=N(e,Tt(i,r))}return o};function Ct(e,t,n){var r=0,i=t.length;for(;i>r;r++)ot(e,t[r],n);return n}function kt(e,t,r,o){var s,u,l,c,p,f=gt(e);if(!o&&1===f.length){if(u=f[0]=f[0].slice(0),u.length>2&&"ID"===(l=u[0]).type&&n.getById&&9===t.nodeType&&h&&i.relative[u[1].type]){if(t=(i.find.ID(l.matches[0].replace(nt,rt),t)||[])[0],!t)return r;e=e.slice(u.shift().value.length)}s=J.needsContext.test(e)?0:u.length;while(s--){if(l=u[s],i.relative[c=l.type])break;if((p=i.find[c])&&(o=p(l.matches[0].replace(nt,rt),U.test(u[0].type)&&t.parentNode||t))){if(u.splice(s,1),e=o.length&&mt(u),!e)return O.apply(r,o),r;break}}}return a(e,f)(o,t,!h,r,U.test(e)),r}n.sortStable=v.split("").sort(S).join("")===v,n.detectDuplicates=E,c(),n.sortDetached=ut(function(e){return 1&e.compareDocumentPosition(p.createElement("div"))}),ut(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||lt("type|href|height|width",function(e,t,n){return n?undefined:e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),n.attributes&&ut(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||lt("value",function(e,t,n){return n||"input"!==e.nodeName.toLowerCase()?undefined:e.defaultValue}),ut(function(e){return null==e.getAttribute("disabled")})||lt(R,function(e,t,n){var r;return n?undefined:(r=e.getAttributeNode(t))&&r.specified?r.value:e[t]===!0?t.toLowerCase():null}),x.find=ot,x.expr=ot.selectors,x.expr[":"]=x.expr.pseudos,x.unique=ot.uniqueSort,x.text=ot.getText,x.isXMLDoc=ot.isXML,x.contains=ot.contains}(e);var D={};function A(e){var t=D[e]={};return x.each(e.match(w)||[],function(e,n){t[n]=!0}),t}x.Callbacks=function(e){e="string"==typeof e?D[e]||A(e):x.extend({},e);var t,n,r,i,o,s,a=[],u=!e.once&&[],l=function(p){for(t=e.memory&&p,n=!0,s=i||0,i=0,o=a.length,r=!0;a&&o>s;s++)if(a[s].apply(p[0],p[1])===!1&&e.stopOnFalse){t=!1;break}r=!1,a&&(u?u.length&&l(u.shift()):t?a=[]:c.disable())},c={add:function(){if(a){var n=a.length;(function s(t){x.each(t,function(t,n){var r=x.type(n);"function"===r?e.unique&&c.has(n)||a.push(n):n&&n.length&&"string"!==r&&s(n)})})(arguments),r?o=a.length:t&&(i=n,l(t))}return this},remove:function(){return a&&x.each(arguments,function(e,t){var n;while((n=x.inArray(t,a,n))>-1)a.splice(n,1),r&&(o>=n&&o--,s>=n&&s--)}),this},has:function(e){return e?x.inArray(e,a)>-1:!(!a||!a.length)},empty:function(){return a=[],o=0,this},disable:function(){return a=u=t=undefined,this},disabled:function(){return!a},lock:function(){return u=undefined,t||c.disable(),this},locked:function(){return!u},fireWith:function(e,t){return!a||n&&!u||(t=t||[],t=[e,t.slice?t.slice():t],r?u.push(t):l(t)),this},fire:function(){return c.fireWith(this,arguments),this},fired:function(){return!!n}};return c},x.extend({Deferred:function(e){var t=[["resolve","done",x.Callbacks("once memory"),"resolved"],["reject","fail",x.Callbacks("once memory"),"rejected"],["notify","progress",x.Callbacks("memory")]],n="pending",r={state:function(){return n},always:function(){return i.done(arguments).fail(arguments),this},then:function(){var e=arguments;return x.Deferred(function(n){x.each(t,function(t,o){var s=o[0],a=x.isFunction(e[t])&&e[t];i[o[1]](function(){var e=a&&a.apply(this,arguments);e&&x.isFunction(e.promise)?e.promise().done(n.resolve).fail(n.reject).progress(n.notify):n[s+"With"](this===r?n.promise():this,a?[e]:arguments)})}),e=null}).promise()},promise:function(e){return null!=e?x.extend(e,r):r}},i={};return r.pipe=r.then,x.each(t,function(e,o){var s=o[2],a=o[3];r[o[1]]=s.add,a&&s.add(function(){n=a},t[1^e][2].disable,t[2][2].lock),i[o[0]]=function(){return i[o[0]+"With"](this===i?r:this,arguments),this},i[o[0]+"With"]=s.fireWith}),r.promise(i),e&&e.call(i,i),i},when:function(e){var t=0,n=d.call(arguments),r=n.length,i=1!==r||e&&x.isFunction(e.promise)?r:0,o=1===i?e:x.Deferred(),s=function(e,t,n){return function(r){t[e]=this,n[e]=arguments.length>1?d.call(arguments):r,n===a?o.notifyWith(t,n):--i||o.resolveWith(t,n)}},a,u,l;if(r>1)for(a=Array(r),u=Array(r),l=Array(r);r>t;t++)n[t]&&x.isFunction(n[t].promise)?n[t].promise().done(s(t,l,n)).fail(o.reject).progress(s(t,u,a)):--i;return i||o.resolveWith(l,n),o.promise()}}),x.support=function(t){var n=o.createElement("input"),r=o.createDocumentFragment(),i=o.createElement("div"),s=o.createElement("select"),a=s.appendChild(o.createElement("option"));return n.type?(n.type="checkbox",t.checkOn=""!==n.value,t.optSelected=a.selected,t.reliableMarginRight=!0,t.boxSizingReliable=!0,t.pixelPosition=!1,n.checked=!0,t.noCloneChecked=n.cloneNode(!0).checked,s.disabled=!0,t.optDisabled=!a.disabled,n=o.createElement("input"),n.value="t",n.type="radio",t.radioValue="t"===n.value,n.setAttribute("checked","t"),n.setAttribute("name","t"),r.appendChild(n),t.checkClone=r.cloneNode(!0).cloneNode(!0).lastChild.checked,t.focusinBubbles="onfocusin"in e,i.style.backgroundClip="content-box",i.cloneNode(!0).style.backgroundClip="",t.clearCloneStyle="content-box"===i.style.backgroundClip,x(function(){var n,r,s="padding:0;margin:0;border:0;display:block;-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box",a=o.getElementsByTagName("body")[0];a&&(n=o.createElement("div"),n.style.cssText="border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px",a.appendChild(n).appendChild(i),i.innerHTML="",i.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%",x.swap(a,null!=a.style.zoom?{zoom:1}:{},function(){t.boxSizing=4===i.offsetWidth}),e.getComputedStyle&&(t.pixelPosition="1%"!==(e.getComputedStyle(i,null)||{}).top,t.boxSizingReliable="4px"===(e.getComputedStyle(i,null)||{width:"4px"}).width,r=i.appendChild(o.createElement("div")),r.style.cssText=i.style.cssText=s,r.style.marginRight=r.style.width="0",i.style.width="1px",t.reliableMarginRight=!parseFloat((e.getComputedStyle(r,null)||{}).marginRight)),a.removeChild(n))}),t):t}({});var L,q,H=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,O=/([A-Z])/g;function F(){Object.defineProperty(this.cache={},0,{get:function(){return{}}}),this.expando=x.expando+Math.random()}F.uid=1,F.accepts=function(e){return e.nodeType?1===e.nodeType||9===e.nodeType:!0},F.prototype={key:function(e){if(!F.accepts(e))return 0;var t={},n=e[this.expando];if(!n){n=F.uid++;try{t[this.expando]={value:n},Object.defineProperties(e,t)}catch(r){t[this.expando]=n,x.extend(e,t)}}return this.cache[n]||(this.cache[n]={}),n},set:function(e,t,n){var r,i=this.key(e),o=this.cache[i];if("string"==typeof t)o[t]=n;else if(x.isEmptyObject(o))x.extend(this.cache[i],t);else for(r in t)o[r]=t[r];return o},get:function(e,t){var n=this.cache[this.key(e)];return t===undefined?n:n[t]},access:function(e,t,n){var r;return t===undefined||t&&"string"==typeof t&&n===undefined?(r=this.get(e,t),r!==undefined?r:this.get(e,x.camelCase(t))):(this.set(e,t,n),n!==undefined?n:t)},remove:function(e,t){var n,r,i,o=this.key(e),s=this.cache[o];if(t===undefined)this.cache[o]={};else{x.isArray(t)?r=t.concat(t.map(x.camelCase)):(i=x.camelCase(t),t in s?r=[t,i]:(r=i,r=r in s?[r]:r.match(w)||[])),n=r.length;while(n--)delete s[r[n]]}},hasData:function(e){return!x.isEmptyObject(this.cache[e[this.expando]]||{})},discard:function(e){e[this.expando]&&delete this.cache[e[this.expando]]}},L=new F,q=new F,x.extend({acceptData:F.accepts,hasData:function(e){return L.hasData(e)||q.hasData(e)},data:function(e,t,n){return L.access(e,t,n)},removeData:function(e,t){L.remove(e,t)},_data:function(e,t,n){return q.access(e,t,n)},_removeData:function(e,t){q.remove(e,t)}}),x.fn.extend({data:function(e,t){var n,r,i=this[0],o=0,s=null;if(e===undefined){if(this.length&&(s=L.get(i),1===i.nodeType&&!q.get(i,"hasDataAttrs"))){for(n=i.attributes;n.length>o;o++)r=n[o].name,0===r.indexOf("data-")&&(r=x.camelCase(r.slice(5)),P(i,r,s[r]));q.set(i,"hasDataAttrs",!0)}return s}return"object"==typeof e?this.each(function(){L.set(this,e)}):x.access(this,function(t){var n,r=x.camelCase(e);if(i&&t===undefined){if(n=L.get(i,e),n!==undefined)return n;if(n=L.get(i,r),n!==undefined)return n;if(n=P(i,r,undefined),n!==undefined)return n}else this.each(function(){var n=L.get(this,r);L.set(this,r,t),-1!==e.indexOf("-")&&n!==undefined&&L.set(this,e,t)})},null,t,arguments.length>1,null,!0)},removeData:function(e){return this.each(function(){L.remove(this,e)})}});function P(e,t,n){var r;if(n===undefined&&1===e.nodeType)if(r="data-"+t.replace(O,"-$1").toLowerCase(),n=e.getAttribute(r),"string"==typeof n){try{n="true"===n?!0:"false"===n?!1:"null"===n?null:+n+""===n?+n:H.test(n)?JSON.parse(n):n}catch(i){}L.set(e,t,n)}else n=undefined;return n}x.extend({queue:function(e,t,n){var r;return e?(t=(t||"fx")+"queue",r=q.get(e,t),n&&(!r||x.isArray(n)?r=q.access(e,t,x.makeArray(n)):r.push(n)),r||[]):undefined},dequeue:function(e,t){t=t||"fx";var n=x.queue(e,t),r=n.length,i=n.shift(),o=x._queueHooks(e,t),s=function(){x.dequeue(e,t)
5
+ };"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,s,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return q.get(e,n)||q.access(e,n,{empty:x.Callbacks("once memory").add(function(){q.remove(e,[t+"queue",n])})})}}),x.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),n>arguments.length?x.queue(this[0],e):t===undefined?this:this.each(function(){var n=x.queue(this,e,t);x._queueHooks(this,e),"fx"===e&&"inprogress"!==n[0]&&x.dequeue(this,e)})},dequeue:function(e){return this.each(function(){x.dequeue(this,e)})},delay:function(e,t){return e=x.fx?x.fx.speeds[e]||e:e,t=t||"fx",this.queue(t,function(t,n){var r=setTimeout(t,e);n.stop=function(){clearTimeout(r)}})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=x.Deferred(),o=this,s=this.length,a=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=undefined),e=e||"fx";while(s--)n=q.get(o[s],e+"queueHooks"),n&&n.empty&&(r++,n.empty.add(a));return a(),i.promise(t)}});var R,M,W=/[\t\r\n\f]/g,$=/\r/g,B=/^(?:input|select|textarea|button)$/i;x.fn.extend({attr:function(e,t){return x.access(this,x.attr,e,t,arguments.length>1)},removeAttr:function(e){return this.each(function(){x.removeAttr(this,e)})},prop:function(e,t){return x.access(this,x.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each(function(){delete this[x.propFix[e]||e]})},addClass:function(e){var t,n,r,i,o,s=0,a=this.length,u="string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).addClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];a>s;s++)if(n=this[s],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(W," "):" ")){o=0;while(i=t[o++])0>r.indexOf(" "+i+" ")&&(r+=i+" ");n.className=x.trim(r)}return this},removeClass:function(e){var t,n,r,i,o,s=0,a=this.length,u=0===arguments.length||"string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).removeClass(e.call(this,t,this.className))});if(u)for(t=(e||"").match(w)||[];a>s;s++)if(n=this[s],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(W," "):"")){o=0;while(i=t[o++])while(r.indexOf(" "+i+" ")>=0)r=r.replace(" "+i+" "," ");n.className=e?x.trim(r):""}return this},toggleClass:function(e,t){var n=typeof e;return"boolean"==typeof t&&"string"===n?t?this.addClass(e):this.removeClass(e):x.isFunction(e)?this.each(function(n){x(this).toggleClass(e.call(this,n,this.className,t),t)}):this.each(function(){if("string"===n){var t,i=0,o=x(this),s=e.match(w)||[];while(t=s[i++])o.hasClass(t)?o.removeClass(t):o.addClass(t)}else(n===r||"boolean"===n)&&(this.className&&q.set(this,"__className__",this.className),this.className=this.className||e===!1?"":q.get(this,"__className__")||"")})},hasClass:function(e){var t=" "+e+" ",n=0,r=this.length;for(;r>n;n++)if(1===this[n].nodeType&&(" "+this[n].className+" ").replace(W," ").indexOf(t)>=0)return!0;return!1},val:function(e){var t,n,r,i=this[0];{if(arguments.length)return r=x.isFunction(e),this.each(function(n){var i;1===this.nodeType&&(i=r?e.call(this,n,x(this).val()):e,null==i?i="":"number"==typeof i?i+="":x.isArray(i)&&(i=x.map(i,function(e){return null==e?"":e+""})),t=x.valHooks[this.type]||x.valHooks[this.nodeName.toLowerCase()],t&&"set"in t&&t.set(this,i,"value")!==undefined||(this.value=i))});if(i)return t=x.valHooks[i.type]||x.valHooks[i.nodeName.toLowerCase()],t&&"get"in t&&(n=t.get(i,"value"))!==undefined?n:(n=i.value,"string"==typeof n?n.replace($,""):null==n?"":n)}}}),x.extend({valHooks:{option:{get:function(e){var t=e.attributes.value;return!t||t.specified?e.value:e.text}},select:{get:function(e){var t,n,r=e.options,i=e.selectedIndex,o="select-one"===e.type||0>i,s=o?null:[],a=o?i+1:r.length,u=0>i?a:o?i:0;for(;a>u;u++)if(n=r[u],!(!n.selected&&u!==i||(x.support.optDisabled?n.disabled:null!==n.getAttribute("disabled"))||n.parentNode.disabled&&x.nodeName(n.parentNode,"optgroup"))){if(t=x(n).val(),o)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=x.makeArray(t),s=i.length;while(s--)r=i[s],(r.selected=x.inArray(x(r).val(),o)>=0)&&(n=!0);return n||(e.selectedIndex=-1),o}}},attr:function(e,t,n){var i,o,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return typeof e.getAttribute===r?x.prop(e,t,n):(1===s&&x.isXMLDoc(e)||(t=t.toLowerCase(),i=x.attrHooks[t]||(x.expr.match.bool.test(t)?M:R)),n===undefined?i&&"get"in i&&null!==(o=i.get(e,t))?o:(o=x.find.attr(e,t),null==o?undefined:o):null!==n?i&&"set"in i&&(o=i.set(e,n,t))!==undefined?o:(e.setAttribute(t,n+""),n):(x.removeAttr(e,t),undefined))},removeAttr:function(e,t){var n,r,i=0,o=t&&t.match(w);if(o&&1===e.nodeType)while(n=o[i++])r=x.propFix[n]||n,x.expr.match.bool.test(n)&&(e[r]=!1),e.removeAttribute(n)},attrHooks:{type:{set:function(e,t){if(!x.support.radioValue&&"radio"===t&&x.nodeName(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},propFix:{"for":"htmlFor","class":"className"},prop:function(e,t,n){var r,i,o,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return o=1!==s||!x.isXMLDoc(e),o&&(t=x.propFix[t]||t,i=x.propHooks[t]),n!==undefined?i&&"set"in i&&(r=i.set(e,n,t))!==undefined?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){return e.hasAttribute("tabindex")||B.test(e.nodeName)||e.href?e.tabIndex:-1}}}}),M={set:function(e,t,n){return t===!1?x.removeAttr(e,n):e.setAttribute(n,n),n}},x.each(x.expr.match.bool.source.match(/\w+/g),function(e,t){var n=x.expr.attrHandle[t]||x.find.attr;x.expr.attrHandle[t]=function(e,t,r){var i=x.expr.attrHandle[t],o=r?undefined:(x.expr.attrHandle[t]=undefined)!=n(e,t,r)?t.toLowerCase():null;return x.expr.attrHandle[t]=i,o}}),x.support.optSelected||(x.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null}}),x.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){x.propFix[this.toLowerCase()]=this}),x.each(["radio","checkbox"],function(){x.valHooks[this]={set:function(e,t){return x.isArray(t)?e.checked=x.inArray(x(e).val(),t)>=0:undefined}},x.support.checkOn||(x.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})});var I=/^key/,z=/^(?:mouse|contextmenu)|click/,_=/^(?:focusinfocus|focusoutblur)$/,X=/^([^.]*)(?:\.(.+)|)$/;function U(){return!0}function Y(){return!1}function V(){try{return o.activeElement}catch(e){}}x.event={global:{},add:function(e,t,n,i,o){var s,a,u,l,c,p,f,h,d,g,m,y=q.get(e);if(y){n.handler&&(s=n,n=s.handler,o=s.selector),n.guid||(n.guid=x.guid++),(l=y.events)||(l=y.events={}),(a=y.handle)||(a=y.handle=function(e){return typeof x===r||e&&x.event.triggered===e.type?undefined:x.event.dispatch.apply(a.elem,arguments)},a.elem=e),t=(t||"").match(w)||[""],c=t.length;while(c--)u=X.exec(t[c])||[],d=m=u[1],g=(u[2]||"").split(".").sort(),d&&(f=x.event.special[d]||{},d=(o?f.delegateType:f.bindType)||d,f=x.event.special[d]||{},p=x.extend({type:d,origType:m,data:i,handler:n,guid:n.guid,selector:o,needsContext:o&&x.expr.match.needsContext.test(o),namespace:g.join(".")},s),(h=l[d])||(h=l[d]=[],h.delegateCount=0,f.setup&&f.setup.call(e,i,g,a)!==!1||e.addEventListener&&e.addEventListener(d,a,!1)),f.add&&(f.add.call(e,p),p.handler.guid||(p.handler.guid=n.guid)),o?h.splice(h.delegateCount++,0,p):h.push(p),x.event.global[d]=!0);e=null}},remove:function(e,t,n,r,i){var o,s,a,u,l,c,p,f,h,d,g,m=q.hasData(e)&&q.get(e);if(m&&(u=m.events)){t=(t||"").match(w)||[""],l=t.length;while(l--)if(a=X.exec(t[l])||[],h=g=a[1],d=(a[2]||"").split(".").sort(),h){p=x.event.special[h]||{},h=(r?p.delegateType:p.bindType)||h,f=u[h]||[],a=a[2]&&RegExp("(^|\\.)"+d.join("\\.(?:.*\\.|)")+"(\\.|$)"),s=o=f.length;while(o--)c=f[o],!i&&g!==c.origType||n&&n.guid!==c.guid||a&&!a.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(f.splice(o,1),c.selector&&f.delegateCount--,p.remove&&p.remove.call(e,c));s&&!f.length&&(p.teardown&&p.teardown.call(e,d,m.handle)!==!1||x.removeEvent(e,h,m.handle),delete u[h])}else for(h in u)x.event.remove(e,h+t[l],n,r,!0);x.isEmptyObject(u)&&(delete m.handle,q.remove(e,"events"))}},trigger:function(t,n,r,i){var s,a,u,l,c,p,f,h=[r||o],d=y.call(t,"type")?t.type:t,g=y.call(t,"namespace")?t.namespace.split("."):[];if(a=u=r=r||o,3!==r.nodeType&&8!==r.nodeType&&!_.test(d+x.event.triggered)&&(d.indexOf(".")>=0&&(g=d.split("."),d=g.shift(),g.sort()),c=0>d.indexOf(":")&&"on"+d,t=t[x.expando]?t:new x.Event(d,"object"==typeof t&&t),t.isTrigger=i?2:3,t.namespace=g.join("."),t.namespace_re=t.namespace?RegExp("(^|\\.)"+g.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,t.result=undefined,t.target||(t.target=r),n=null==n?[t]:x.makeArray(n,[t]),f=x.event.special[d]||{},i||!f.trigger||f.trigger.apply(r,n)!==!1)){if(!i&&!f.noBubble&&!x.isWindow(r)){for(l=f.delegateType||d,_.test(l+d)||(a=a.parentNode);a;a=a.parentNode)h.push(a),u=a;u===(r.ownerDocument||o)&&h.push(u.defaultView||u.parentWindow||e)}s=0;while((a=h[s++])&&!t.isPropagationStopped())t.type=s>1?l:f.bindType||d,p=(q.get(a,"events")||{})[t.type]&&q.get(a,"handle"),p&&p.apply(a,n),p=c&&a[c],p&&x.acceptData(a)&&p.apply&&p.apply(a,n)===!1&&t.preventDefault();return t.type=d,i||t.isDefaultPrevented()||f._default&&f._default.apply(h.pop(),n)!==!1||!x.acceptData(r)||c&&x.isFunction(r[d])&&!x.isWindow(r)&&(u=r[c],u&&(r[c]=null),x.event.triggered=d,r[d](),x.event.triggered=undefined,u&&(r[c]=u)),t.result}},dispatch:function(e){e=x.event.fix(e);var t,n,r,i,o,s=[],a=d.call(arguments),u=(q.get(this,"events")||{})[e.type]||[],l=x.event.special[e.type]||{};if(a[0]=e,e.delegateTarget=this,!l.preDispatch||l.preDispatch.call(this,e)!==!1){s=x.event.handlers.call(this,e,u),t=0;while((i=s[t++])&&!e.isPropagationStopped()){e.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!e.isImmediatePropagationStopped())(!e.namespace_re||e.namespace_re.test(o.namespace))&&(e.handleObj=o,e.data=o.data,r=((x.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,a),r!==undefined&&(e.result=r)===!1&&(e.preventDefault(),e.stopPropagation()))}return l.postDispatch&&l.postDispatch.call(this,e),e.result}},handlers:function(e,t){var n,r,i,o,s=[],a=t.delegateCount,u=e.target;if(a&&u.nodeType&&(!e.button||"click"!==e.type))for(;u!==this;u=u.parentNode||this)if(u.disabled!==!0||"click"!==e.type){for(r=[],n=0;a>n;n++)o=t[n],i=o.selector+" ",r[i]===undefined&&(r[i]=o.needsContext?x(i,this).index(u)>=0:x.find(i,this,null,[u]).length),r[i]&&r.push(o);r.length&&s.push({elem:u,handlers:r})}return t.length>a&&s.push({elem:this,handlers:t.slice(a)}),s},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(e,t){return null==e.which&&(e.which=null!=t.charCode?t.charCode:t.keyCode),e}},mouseHooks:{props:"button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(e,t){var n,r,i,s=t.button;return null==e.pageX&&null!=t.clientX&&(n=e.target.ownerDocument||o,r=n.documentElement,i=n.body,e.pageX=t.clientX+(r&&r.scrollLeft||i&&i.scrollLeft||0)-(r&&r.clientLeft||i&&i.clientLeft||0),e.pageY=t.clientY+(r&&r.scrollTop||i&&i.scrollTop||0)-(r&&r.clientTop||i&&i.clientTop||0)),e.which||s===undefined||(e.which=1&s?1:2&s?3:4&s?2:0),e}},fix:function(e){if(e[x.expando])return e;var t,n,r,i=e.type,s=e,a=this.fixHooks[i];a||(this.fixHooks[i]=a=z.test(i)?this.mouseHooks:I.test(i)?this.keyHooks:{}),r=a.props?this.props.concat(a.props):this.props,e=new x.Event(s),t=r.length;while(t--)n=r[t],e[n]=s[n];return e.target||(e.target=o),3===e.target.nodeType&&(e.target=e.target.parentNode),a.filter?a.filter(e,s):e},special:{load:{noBubble:!0},focus:{trigger:function(){return this!==V()&&this.focus?(this.focus(),!1):undefined},delegateType:"focusin"},blur:{trigger:function(){return this===V()&&this.blur?(this.blur(),!1):undefined},delegateType:"focusout"},click:{trigger:function(){return"checkbox"===this.type&&this.click&&x.nodeName(this,"input")?(this.click(),!1):undefined},_default:function(e){return x.nodeName(e.target,"a")}},beforeunload:{postDispatch:function(e){e.result!==undefined&&(e.originalEvent.returnValue=e.result)}}},simulate:function(e,t,n,r){var i=x.extend(new x.Event,n,{type:e,isSimulated:!0,originalEvent:{}});r?x.event.trigger(i,null,t):x.event.dispatch.call(t,i),i.isDefaultPrevented()&&n.preventDefault()}},x.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n,!1)},x.Event=function(e,t){return this instanceof x.Event?(e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||e.getPreventDefault&&e.getPreventDefault()?U:Y):this.type=e,t&&x.extend(this,t),this.timeStamp=e&&e.timeStamp||x.now(),this[x.expando]=!0,undefined):new x.Event(e,t)},x.Event.prototype={isDefaultPrevented:Y,isPropagationStopped:Y,isImmediatePropagationStopped:Y,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=U,e&&e.preventDefault&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=U,e&&e.stopPropagation&&e.stopPropagation()},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=U,this.stopPropagation()}},x.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(e,t){x.event.special[e]={delegateType:t,bindType:t,handle:function(e){var n,r=this,i=e.relatedTarget,o=e.handleObj;return(!i||i!==r&&!x.contains(r,i))&&(e.type=o.origType,n=o.handler.apply(this,arguments),e.type=t),n}}}),x.support.focusinBubbles||x.each({focus:"focusin",blur:"focusout"},function(e,t){var n=0,r=function(e){x.event.simulate(t,e.target,x.event.fix(e),!0)};x.event.special[t]={setup:function(){0===n++&&o.addEventListener(e,r,!0)},teardown:function(){0===--n&&o.removeEventListener(e,r,!0)}}}),x.fn.extend({on:function(e,t,n,r,i){var o,s;if("object"==typeof e){"string"!=typeof t&&(n=n||t,t=undefined);for(s in e)this.on(s,t,n,e[s],i);return this}if(null==n&&null==r?(r=t,n=t=undefined):null==r&&("string"==typeof t?(r=n,n=undefined):(r=n,n=t,t=undefined)),r===!1)r=Y;else if(!r)return this;return 1===i&&(o=r,r=function(e){return x().off(e),o.apply(this,arguments)},r.guid=o.guid||(o.guid=x.guid++)),this.each(function(){x.event.add(this,e,r,n,t)})},one:function(e,t,n,r){return this.on(e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,x(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return(t===!1||"function"==typeof t)&&(n=t,t=undefined),n===!1&&(n=Y),this.each(function(){x.event.remove(this,e,n,t)})},trigger:function(e,t){return this.each(function(){x.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];return n?x.event.trigger(e,t,n,!0):undefined}});var G=/^.[^:#\[\.,]*$/,J=/^(?:parents|prev(?:Until|All))/,Q=x.expr.match.needsContext,K={children:!0,contents:!0,next:!0,prev:!0};x.fn.extend({find:function(e){var t,n=[],r=this,i=r.length;if("string"!=typeof e)return this.pushStack(x(e).filter(function(){for(t=0;i>t;t++)if(x.contains(r[t],this))return!0}));for(t=0;i>t;t++)x.find(e,r[t],n);return n=this.pushStack(i>1?x.unique(n):n),n.selector=this.selector?this.selector+" "+e:e,n},has:function(e){var t=x(e,this),n=t.length;return this.filter(function(){var e=0;for(;n>e;e++)if(x.contains(this,t[e]))return!0})},not:function(e){return this.pushStack(et(this,e||[],!0))},filter:function(e){return this.pushStack(et(this,e||[],!1))},is:function(e){return!!et(this,"string"==typeof e&&Q.test(e)?x(e):e||[],!1).length},closest:function(e,t){var n,r=0,i=this.length,o=[],s=Q.test(e)||"string"!=typeof e?x(e,t||this.context):0;for(;i>r;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(11>n.nodeType&&(s?s.index(n)>-1:1===n.nodeType&&x.find.matchesSelector(n,e))){n=o.push(n);break}return this.pushStack(o.length>1?x.unique(o):o)},index:function(e){return e?"string"==typeof e?g.call(x(e),this[0]):g.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){var n="string"==typeof e?x(e,t):x.makeArray(e&&e.nodeType?[e]:e),r=x.merge(this.get(),n);return this.pushStack(x.unique(r))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function Z(e,t){while((e=e[t])&&1!==e.nodeType);return e}x.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return x.dir(e,"parentNode")},parentsUntil:function(e,t,n){return x.dir(e,"parentNode",n)},next:function(e){return Z(e,"nextSibling")},prev:function(e){return Z(e,"previousSibling")},nextAll:function(e){return x.dir(e,"nextSibling")},prevAll:function(e){return x.dir(e,"previousSibling")},nextUntil:function(e,t,n){return x.dir(e,"nextSibling",n)},prevUntil:function(e,t,n){return x.dir(e,"previousSibling",n)},siblings:function(e){return x.sibling((e.parentNode||{}).firstChild,e)},children:function(e){return x.sibling(e.firstChild)},contents:function(e){return e.contentDocument||x.merge([],e.childNodes)}},function(e,t){x.fn[e]=function(n,r){var i=x.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=x.filter(r,i)),this.length>1&&(K[e]||x.unique(i),J.test(e)&&i.reverse()),this.pushStack(i)}}),x.extend({filter:function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?x.find.matchesSelector(r,e)?[r]:[]:x.find.matches(e,x.grep(t,function(e){return 1===e.nodeType}))},dir:function(e,t,n){var r=[],i=n!==undefined;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&x(e).is(n))break;r.push(e)}return r},sibling:function(e,t){var n=[];for(;e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n}});function et(e,t,n){if(x.isFunction(t))return x.grep(e,function(e,r){return!!t.call(e,r,e)!==n});if(t.nodeType)return x.grep(e,function(e){return e===t!==n});if("string"==typeof t){if(G.test(t))return x.filter(t,e,n);t=x.filter(t,e)}return x.grep(e,function(e){return g.call(t,e)>=0!==n})}var tt=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,nt=/<([\w:]+)/,rt=/<|&#?\w+;/,it=/<(?:script|style|link)/i,ot=/^(?:checkbox|radio)$/i,st=/checked\s*(?:[^=]|=\s*.checked.)/i,at=/^$|\/(?:java|ecma)script/i,ut=/^true\/(.*)/,lt=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,ct={option:[1,"<select multiple='multiple'>","</select>"],thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};ct.optgroup=ct.option,ct.tbody=ct.tfoot=ct.colgroup=ct.caption=ct.thead,ct.th=ct.td,x.fn.extend({text:function(e){return x.access(this,function(e){return e===undefined?x.text(this):this.empty().append((this[0]&&this[0].ownerDocument||o).createTextNode(e))},null,e,arguments.length)},append:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=pt(this,e);t.appendChild(e)}})},prepend:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=pt(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},remove:function(e,t){var n,r=e?x.filter(e,this):this,i=0;for(;null!=(n=r[i]);i++)t||1!==n.nodeType||x.cleanData(mt(n)),n.parentNode&&(t&&x.contains(n.ownerDocument,n)&&dt(mt(n,"script")),n.parentNode.removeChild(n));return this},empty:function(){var e,t=0;for(;null!=(e=this[t]);t++)1===e.nodeType&&(x.cleanData(mt(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null==e?!1:e,t=null==t?e:t,this.map(function(){return x.clone(this,e,t)})},html:function(e){return x.access(this,function(e){var t=this[0]||{},n=0,r=this.length;if(e===undefined&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!it.test(e)&&!ct[(nt.exec(e)||["",""])[1].toLowerCase()]){e=e.replace(tt,"<$1></$2>");try{for(;r>n;n++)t=this[n]||{},1===t.nodeType&&(x.cleanData(mt(t,!1)),t.innerHTML=e);t=0}catch(i){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var e=x.map(this,function(e){return[e.nextSibling,e.parentNode]}),t=0;return this.domManip(arguments,function(n){var r=e[t++],i=e[t++];i&&(r&&r.parentNode!==i&&(r=this.nextSibling),x(this).remove(),i.insertBefore(n,r))},!0),t?this:this.remove()},detach:function(e){return this.remove(e,!0)},domManip:function(e,t,n){e=f.apply([],e);var r,i,o,s,a,u,l=0,c=this.length,p=this,h=c-1,d=e[0],g=x.isFunction(d);if(g||!(1>=c||"string"!=typeof d||x.support.checkClone)&&st.test(d))return this.each(function(r){var i=p.eq(r);g&&(e[0]=d.call(this,r,i.html())),i.domManip(e,t,n)});if(c&&(r=x.buildFragment(e,this[0].ownerDocument,!1,!n&&this),i=r.firstChild,1===r.childNodes.length&&(r=i),i)){for(o=x.map(mt(r,"script"),ft),s=o.length;c>l;l++)a=r,l!==h&&(a=x.clone(a,!0,!0),s&&x.merge(o,mt(a,"script"))),t.call(this[l],a,l);if(s)for(u=o[o.length-1].ownerDocument,x.map(o,ht),l=0;s>l;l++)a=o[l],at.test(a.type||"")&&!q.access(a,"globalEval")&&x.contains(u,a)&&(a.src?x._evalUrl(a.src):x.globalEval(a.textContent.replace(lt,"")))}return this}}),x.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,t){x.fn[e]=function(e){var n,r=[],i=x(e),o=i.length-1,s=0;for(;o>=s;s++)n=s===o?this:this.clone(!0),x(i[s])[t](n),h.apply(r,n.get());return this.pushStack(r)}}),x.extend({clone:function(e,t,n){var r,i,o,s,a=e.cloneNode(!0),u=x.contains(e.ownerDocument,e);if(!(x.support.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||x.isXMLDoc(e)))for(s=mt(a),o=mt(e),r=0,i=o.length;i>r;r++)yt(o[r],s[r]);if(t)if(n)for(o=o||mt(e),s=s||mt(a),r=0,i=o.length;i>r;r++)gt(o[r],s[r]);else gt(e,a);return s=mt(a,"script"),s.length>0&&dt(s,!u&&mt(e,"script")),a},buildFragment:function(e,t,n,r){var i,o,s,a,u,l,c=0,p=e.length,f=t.createDocumentFragment(),h=[];for(;p>c;c++)if(i=e[c],i||0===i)if("object"===x.type(i))x.merge(h,i.nodeType?[i]:i);else if(rt.test(i)){o=o||f.appendChild(t.createElement("div")),s=(nt.exec(i)||["",""])[1].toLowerCase(),a=ct[s]||ct._default,o.innerHTML=a[1]+i.replace(tt,"<$1></$2>")+a[2],l=a[0];while(l--)o=o.lastChild;x.merge(h,o.childNodes),o=f.firstChild,o.textContent=""}else h.push(t.createTextNode(i));f.textContent="",c=0;while(i=h[c++])if((!r||-1===x.inArray(i,r))&&(u=x.contains(i.ownerDocument,i),o=mt(f.appendChild(i),"script"),u&&dt(o),n)){l=0;while(i=o[l++])at.test(i.type||"")&&n.push(i)}return f},cleanData:function(e){var t,n,r,i,o,s,a=x.event.special,u=0;for(;(n=e[u])!==undefined;u++){if(F.accepts(n)&&(o=n[q.expando],o&&(t=q.cache[o]))){if(r=Object.keys(t.events||{}),r.length)for(s=0;(i=r[s])!==undefined;s++)a[i]?x.event.remove(n,i):x.removeEvent(n,i,t.handle);q.cache[o]&&delete q.cache[o]}delete L.cache[n[L.expando]]}},_evalUrl:function(e){return x.ajax({url:e,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})}});function pt(e,t){return x.nodeName(e,"table")&&x.nodeName(1===t.nodeType?t:t.firstChild,"tr")?e.getElementsByTagName("tbody")[0]||e.appendChild(e.ownerDocument.createElement("tbody")):e}function ft(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function ht(e){var t=ut.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function dt(e,t){var n=e.length,r=0;for(;n>r;r++)q.set(e[r],"globalEval",!t||q.get(t[r],"globalEval"))}function gt(e,t){var n,r,i,o,s,a,u,l;if(1===t.nodeType){if(q.hasData(e)&&(o=q.access(e),s=q.set(t,o),l=o.events)){delete s.handle,s.events={};for(i in l)for(n=0,r=l[i].length;r>n;n++)x.event.add(t,i,l[i][n])}L.hasData(e)&&(a=L.access(e),u=x.extend({},a),L.set(t,u))}}function mt(e,t){var n=e.getElementsByTagName?e.getElementsByTagName(t||"*"):e.querySelectorAll?e.querySelectorAll(t||"*"):[];return t===undefined||t&&x.nodeName(e,t)?x.merge([e],n):n}function yt(e,t){var n=t.nodeName.toLowerCase();"input"===n&&ot.test(e.type)?t.checked=e.checked:("input"===n||"textarea"===n)&&(t.defaultValue=e.defaultValue)}x.fn.extend({wrapAll:function(e){var t;return x.isFunction(e)?this.each(function(t){x(this).wrapAll(e.call(this,t))}):(this[0]&&(t=x(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this)},wrapInner:function(e){return x.isFunction(e)?this.each(function(t){x(this).wrapInner(e.call(this,t))}):this.each(function(){var t=x(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=x.isFunction(e);return this.each(function(n){x(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(){return this.parent().each(function(){x.nodeName(this,"body")||x(this).replaceWith(this.childNodes)}).end()}});var vt,xt,bt=/^(none|table(?!-c[ea]).+)/,wt=/^margin/,Tt=RegExp("^("+b+")(.*)$","i"),Ct=RegExp("^("+b+")(?!px)[a-z%]+$","i"),kt=RegExp("^([+-])=("+b+")","i"),Nt={BODY:"block"},Et={position:"absolute",visibility:"hidden",display:"block"},St={letterSpacing:0,fontWeight:400},jt=["Top","Right","Bottom","Left"],Dt=["Webkit","O","Moz","ms"];function At(e,t){if(t in e)return t;var n=t.charAt(0).toUpperCase()+t.slice(1),r=t,i=Dt.length;while(i--)if(t=Dt[i]+n,t in e)return t;return r}function Lt(e,t){return e=t||e,"none"===x.css(e,"display")||!x.contains(e.ownerDocument,e)}function qt(t){return e.getComputedStyle(t,null)}function Ht(e,t){var n,r,i,o=[],s=0,a=e.length;for(;a>s;s++)r=e[s],r.style&&(o[s]=q.get(r,"olddisplay"),n=r.style.display,t?(o[s]||"none"!==n||(r.style.display=""),""===r.style.display&&Lt(r)&&(o[s]=q.access(r,"olddisplay",Rt(r.nodeName)))):o[s]||(i=Lt(r),(n&&"none"!==n||!i)&&q.set(r,"olddisplay",i?n:x.css(r,"display"))));for(s=0;a>s;s++)r=e[s],r.style&&(t&&"none"!==r.style.display&&""!==r.style.display||(r.style.display=t?o[s]||"":"none"));return e}x.fn.extend({css:function(e,t){return x.access(this,function(e,t,n){var r,i,o={},s=0;if(x.isArray(t)){for(r=qt(e),i=t.length;i>s;s++)o[t[s]]=x.css(e,t[s],!1,r);return o}return n!==undefined?x.style(e,t,n):x.css(e,t)},e,t,arguments.length>1)},show:function(){return Ht(this,!0)},hide:function(){return Ht(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){Lt(this)?x(this).show():x(this).hide()})}}),x.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=vt(e,"opacity");return""===n?"1":n}}}},cssNumber:{columnCount:!0,fillOpacity:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":"cssFloat"},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,s,a=x.camelCase(t),u=e.style;return t=x.cssProps[a]||(x.cssProps[a]=At(u,a)),s=x.cssHooks[t]||x.cssHooks[a],n===undefined?s&&"get"in s&&(i=s.get(e,!1,r))!==undefined?i:u[t]:(o=typeof n,"string"===o&&(i=kt.exec(n))&&(n=(i[1]+1)*i[2]+parseFloat(x.css(e,t)),o="number"),null==n||"number"===o&&isNaN(n)||("number"!==o||x.cssNumber[a]||(n+="px"),x.support.clearCloneStyle||""!==n||0!==t.indexOf("background")||(u[t]="inherit"),s&&"set"in s&&(n=s.set(e,n,r))===undefined||(u[t]=n)),undefined)}},css:function(e,t,n,r){var i,o,s,a=x.camelCase(t);return t=x.cssProps[a]||(x.cssProps[a]=At(e.style,a)),s=x.cssHooks[t]||x.cssHooks[a],s&&"get"in s&&(i=s.get(e,!0,n)),i===undefined&&(i=vt(e,t,r)),"normal"===i&&t in St&&(i=St[t]),""===n||n?(o=parseFloat(i),n===!0||x.isNumeric(o)?o||0:i):i}}),vt=function(e,t,n){var r,i,o,s=n||qt(e),a=s?s.getPropertyValue(t)||s[t]:undefined,u=e.style;return s&&(""!==a||x.contains(e.ownerDocument,e)||(a=x.style(e,t)),Ct.test(a)&&wt.test(t)&&(r=u.width,i=u.minWidth,o=u.maxWidth,u.minWidth=u.maxWidth=u.width=a,a=s.width,u.width=r,u.minWidth=i,u.maxWidth=o)),a};function Ot(e,t,n){var r=Tt.exec(t);return r?Math.max(0,r[1]-(n||0))+(r[2]||"px"):t}function Ft(e,t,n,r,i){var o=n===(r?"border":"content")?4:"width"===t?1:0,s=0;for(;4>o;o+=2)"margin"===n&&(s+=x.css(e,n+jt[o],!0,i)),r?("content"===n&&(s-=x.css(e,"padding"+jt[o],!0,i)),"margin"!==n&&(s-=x.css(e,"border"+jt[o]+"Width",!0,i))):(s+=x.css(e,"padding"+jt[o],!0,i),"padding"!==n&&(s+=x.css(e,"border"+jt[o]+"Width",!0,i)));return s}function Pt(e,t,n){var r=!0,i="width"===t?e.offsetWidth:e.offsetHeight,o=qt(e),s=x.support.boxSizing&&"border-box"===x.css(e,"boxSizing",!1,o);if(0>=i||null==i){if(i=vt(e,t,o),(0>i||null==i)&&(i=e.style[t]),Ct.test(i))return i;r=s&&(x.support.boxSizingReliable||i===e.style[t]),i=parseFloat(i)||0}return i+Ft(e,t,n||(s?"border":"content"),r,o)+"px"}function Rt(e){var t=o,n=Nt[e];return n||(n=Mt(e,t),"none"!==n&&n||(xt=(xt||x("<iframe frameborder='0' width='0' height='0'/>").css("cssText","display:block !important")).appendTo(t.documentElement),t=(xt[0].contentWindow||xt[0].contentDocument).document,t.write("<!doctype html><html><body>"),t.close(),n=Mt(e,t),xt.detach()),Nt[e]=n),n}function Mt(e,t){var n=x(t.createElement(e)).appendTo(t.body),r=x.css(n[0],"display");return n.remove(),r}x.each(["height","width"],function(e,t){x.cssHooks[t]={get:function(e,n,r){return n?0===e.offsetWidth&&bt.test(x.css(e,"display"))?x.swap(e,Et,function(){return Pt(e,t,r)}):Pt(e,t,r):undefined},set:function(e,n,r){var i=r&&qt(e);return Ot(e,n,r?Ft(e,t,r,x.support.boxSizing&&"border-box"===x.css(e,"boxSizing",!1,i),i):0)}}}),x(function(){x.support.reliableMarginRight||(x.cssHooks.marginRight={get:function(e,t){return t?x.swap(e,{display:"inline-block"},vt,[e,"marginRight"]):undefined}}),!x.support.pixelPosition&&x.fn.position&&x.each(["top","left"],function(e,t){x.cssHooks[t]={get:function(e,n){return n?(n=vt(e,t),Ct.test(n)?x(e).position()[t]+"px":n):undefined}}})}),x.expr&&x.expr.filters&&(x.expr.filters.hidden=function(e){return 0>=e.offsetWidth&&0>=e.offsetHeight},x.expr.filters.visible=function(e){return!x.expr.filters.hidden(e)}),x.each({margin:"",padding:"",border:"Width"},function(e,t){x.cssHooks[e+t]={expand:function(n){var r=0,i={},o="string"==typeof n?n.split(" "):[n];for(;4>r;r++)i[e+jt[r]+t]=o[r]||o[r-2]||o[0];return i}},wt.test(e)||(x.cssHooks[e+t].set=Ot)});var Wt=/%20/g,$t=/\[\]$/,Bt=/\r?\n/g,It=/^(?:submit|button|image|reset|file)$/i,zt=/^(?:input|select|textarea|keygen)/i;x.fn.extend({serialize:function(){return x.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=x.prop(this,"elements");return e?x.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!x(this).is(":disabled")&&zt.test(this.nodeName)&&!It.test(e)&&(this.checked||!ot.test(e))}).map(function(e,t){var n=x(this).val();return null==n?null:x.isArray(n)?x.map(n,function(e){return{name:t.name,value:e.replace(Bt,"\r\n")}}):{name:t.name,value:n.replace(Bt,"\r\n")}}).get()}}),x.param=function(e,t){var n,r=[],i=function(e,t){t=x.isFunction(t)?t():null==t?"":t,r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(t)};if(t===undefined&&(t=x.ajaxSettings&&x.ajaxSettings.traditional),x.isArray(e)||e.jquery&&!x.isPlainObject(e))x.each(e,function(){i(this.name,this.value)});else for(n in e)_t(n,e[n],t,i);return r.join("&").replace(Wt,"+")};function _t(e,t,n,r){var i;if(x.isArray(t))x.each(t,function(t,i){n||$t.test(e)?r(e,i):_t(e+"["+("object"==typeof i?t:"")+"]",i,n,r)});else if(n||"object"!==x.type(t))r(e,t);else for(i in t)_t(e+"["+i+"]",t[i],n,r)}x.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),function(e,t){x.fn[t]=function(e,n){return arguments.length>0?this.on(t,null,e,n):this.trigger(t)}}),x.fn.extend({hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)},bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)
6
+ },delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)}});var Xt,Ut,Yt=x.now(),Vt=/\?/,Gt=/#.*$/,Jt=/([?&])_=[^&]*/,Qt=/^(.*?):[ \t]*([^\r\n]*)$/gm,Kt=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Zt=/^(?:GET|HEAD)$/,en=/^\/\//,tn=/^([\w.+-]+:)(?:\/\/([^\/?#:]*)(?::(\d+)|)|)/,nn=x.fn.load,rn={},on={},sn="*/".concat("*");try{Ut=i.href}catch(an){Ut=o.createElement("a"),Ut.href="",Ut=Ut.href}Xt=tn.exec(Ut.toLowerCase())||[];function un(e){return function(t,n){"string"!=typeof t&&(n=t,t="*");var r,i=0,o=t.toLowerCase().match(w)||[];if(x.isFunction(n))while(r=o[i++])"+"===r[0]?(r=r.slice(1)||"*",(e[r]=e[r]||[]).unshift(n)):(e[r]=e[r]||[]).push(n)}}function ln(e,t,n,r){var i={},o=e===on;function s(a){var u;return i[a]=!0,x.each(e[a]||[],function(e,a){var l=a(t,n,r);return"string"!=typeof l||o||i[l]?o?!(u=l):undefined:(t.dataTypes.unshift(l),s(l),!1)}),u}return s(t.dataTypes[0])||!i["*"]&&s("*")}function cn(e,t){var n,r,i=x.ajaxSettings.flatOptions||{};for(n in t)t[n]!==undefined&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&x.extend(!0,e,r),e}x.fn.load=function(e,t,n){if("string"!=typeof e&&nn)return nn.apply(this,arguments);var r,i,o,s=this,a=e.indexOf(" ");return a>=0&&(r=e.slice(a),e=e.slice(0,a)),x.isFunction(t)?(n=t,t=undefined):t&&"object"==typeof t&&(i="POST"),s.length>0&&x.ajax({url:e,type:i,dataType:"html",data:t}).done(function(e){o=arguments,s.html(r?x("<div>").append(x.parseHTML(e)).find(r):e)}).complete(n&&function(e,t){s.each(n,o||[e.responseText,t,e])}),this},x.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){x.fn[t]=function(e){return this.on(t,e)}}),x.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Ut,type:"GET",isLocal:Kt.test(Xt[1]),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":sn,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":x.parseJSON,"text xml":x.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?cn(cn(e,x.ajaxSettings),t):cn(x.ajaxSettings,e)},ajaxPrefilter:un(rn),ajaxTransport:un(on),ajax:function(e,t){"object"==typeof e&&(t=e,e=undefined),t=t||{};var n,r,i,o,s,a,u,l,c=x.ajaxSetup({},t),p=c.context||c,f=c.context&&(p.nodeType||p.jquery)?x(p):x.event,h=x.Deferred(),d=x.Callbacks("once memory"),g=c.statusCode||{},m={},y={},v=0,b="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(2===v){if(!o){o={};while(t=Qt.exec(i))o[t[1].toLowerCase()]=t[2]}t=o[e.toLowerCase()]}return null==t?null:t},getAllResponseHeaders:function(){return 2===v?i:null},setRequestHeader:function(e,t){var n=e.toLowerCase();return v||(e=y[n]=y[n]||e,m[e]=t),this},overrideMimeType:function(e){return v||(c.mimeType=e),this},statusCode:function(e){var t;if(e)if(2>v)for(t in e)g[t]=[g[t],e[t]];else T.always(e[T.status]);return this},abort:function(e){var t=e||b;return n&&n.abort(t),k(0,t),this}};if(h.promise(T).complete=d.add,T.success=T.done,T.error=T.fail,c.url=((e||c.url||Ut)+"").replace(Gt,"").replace(en,Xt[1]+"//"),c.type=t.method||t.type||c.method||c.type,c.dataTypes=x.trim(c.dataType||"*").toLowerCase().match(w)||[""],null==c.crossDomain&&(a=tn.exec(c.url.toLowerCase()),c.crossDomain=!(!a||a[1]===Xt[1]&&a[2]===Xt[2]&&(a[3]||("http:"===a[1]?"80":"443"))===(Xt[3]||("http:"===Xt[1]?"80":"443")))),c.data&&c.processData&&"string"!=typeof c.data&&(c.data=x.param(c.data,c.traditional)),ln(rn,c,t,T),2===v)return T;u=c.global,u&&0===x.active++&&x.event.trigger("ajaxStart"),c.type=c.type.toUpperCase(),c.hasContent=!Zt.test(c.type),r=c.url,c.hasContent||(c.data&&(r=c.url+=(Vt.test(r)?"&":"?")+c.data,delete c.data),c.cache===!1&&(c.url=Jt.test(r)?r.replace(Jt,"$1_="+Yt++):r+(Vt.test(r)?"&":"?")+"_="+Yt++)),c.ifModified&&(x.lastModified[r]&&T.setRequestHeader("If-Modified-Since",x.lastModified[r]),x.etag[r]&&T.setRequestHeader("If-None-Match",x.etag[r])),(c.data&&c.hasContent&&c.contentType!==!1||t.contentType)&&T.setRequestHeader("Content-Type",c.contentType),T.setRequestHeader("Accept",c.dataTypes[0]&&c.accepts[c.dataTypes[0]]?c.accepts[c.dataTypes[0]]+("*"!==c.dataTypes[0]?", "+sn+"; q=0.01":""):c.accepts["*"]);for(l in c.headers)T.setRequestHeader(l,c.headers[l]);if(c.beforeSend&&(c.beforeSend.call(p,T,c)===!1||2===v))return T.abort();b="abort";for(l in{success:1,error:1,complete:1})T[l](c[l]);if(n=ln(on,c,t,T)){T.readyState=1,u&&f.trigger("ajaxSend",[T,c]),c.async&&c.timeout>0&&(s=setTimeout(function(){T.abort("timeout")},c.timeout));try{v=1,n.send(m,k)}catch(C){if(!(2>v))throw C;k(-1,C)}}else k(-1,"No Transport");function k(e,t,o,a){var l,m,y,b,w,C=t;2!==v&&(v=2,s&&clearTimeout(s),n=undefined,i=a||"",T.readyState=e>0?4:0,l=e>=200&&300>e||304===e,o&&(b=pn(c,T,o)),b=fn(c,b,T,l),l?(c.ifModified&&(w=T.getResponseHeader("Last-Modified"),w&&(x.lastModified[r]=w),w=T.getResponseHeader("etag"),w&&(x.etag[r]=w)),204===e||"HEAD"===c.type?C="nocontent":304===e?C="notmodified":(C=b.state,m=b.data,y=b.error,l=!y)):(y=C,(e||!C)&&(C="error",0>e&&(e=0))),T.status=e,T.statusText=(t||C)+"",l?h.resolveWith(p,[m,C,T]):h.rejectWith(p,[T,C,y]),T.statusCode(g),g=undefined,u&&f.trigger(l?"ajaxSuccess":"ajaxError",[T,c,l?m:y]),d.fireWith(p,[T,C]),u&&(f.trigger("ajaxComplete",[T,c]),--x.active||x.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return x.get(e,t,n,"json")},getScript:function(e,t){return x.get(e,undefined,t,"script")}}),x.each(["get","post"],function(e,t){x[t]=function(e,n,r,i){return x.isFunction(n)&&(i=i||r,r=n,n=undefined),x.ajax({url:e,type:t,dataType:i,data:n,success:r})}});function pn(e,t,n){var r,i,o,s,a=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),r===undefined&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in a)if(a[i]&&a[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}s||(s=i)}o=o||s}return o?(o!==u[0]&&u.unshift(o),n[o]):undefined}function fn(e,t,n,r){var i,o,s,a,u,l={},c=e.dataTypes.slice();if(c[1])for(s in e.converters)l[s.toLowerCase()]=e.converters[s];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(s=l[u+" "+o]||l["* "+o],!s)for(i in l)if(a=i.split(" "),a[1]===o&&(s=l[u+" "+a[0]]||l["* "+a[0]])){s===!0?s=l[i]:l[i]!==!0&&(o=a[0],c.unshift(a[1]));break}if(s!==!0)if(s&&e["throws"])t=s(t);else try{t=s(t)}catch(p){return{state:"parsererror",error:s?p:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}x.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/(?:java|ecma)script/},converters:{"text script":function(e){return x.globalEval(e),e}}}),x.ajaxPrefilter("script",function(e){e.cache===undefined&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),x.ajaxTransport("script",function(e){if(e.crossDomain){var t,n;return{send:function(r,i){t=x("<script>").prop({async:!0,charset:e.scriptCharset,src:e.url}).on("load error",n=function(e){t.remove(),n=null,e&&i("error"===e.type?404:200,e.type)}),o.head.appendChild(t[0])},abort:function(){n&&n()}}}});var hn=[],dn=/(=)\?(?=&|$)|\?\?/;x.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=hn.pop()||x.expando+"_"+Yt++;return this[e]=!0,e}}),x.ajaxPrefilter("json jsonp",function(t,n,r){var i,o,s,a=t.jsonp!==!1&&(dn.test(t.url)?"url":"string"==typeof t.data&&!(t.contentType||"").indexOf("application/x-www-form-urlencoded")&&dn.test(t.data)&&"data");return a||"jsonp"===t.dataTypes[0]?(i=t.jsonpCallback=x.isFunction(t.jsonpCallback)?t.jsonpCallback():t.jsonpCallback,a?t[a]=t[a].replace(dn,"$1"+i):t.jsonp!==!1&&(t.url+=(Vt.test(t.url)?"&":"?")+t.jsonp+"="+i),t.converters["script json"]=function(){return s||x.error(i+" was not called"),s[0]},t.dataTypes[0]="json",o=e[i],e[i]=function(){s=arguments},r.always(function(){e[i]=o,t[i]&&(t.jsonpCallback=n.jsonpCallback,hn.push(i)),s&&x.isFunction(o)&&o(s[0]),s=o=undefined}),"script"):undefined}),x.ajaxSettings.xhr=function(){try{return new XMLHttpRequest}catch(e){}};var gn=x.ajaxSettings.xhr(),mn={0:200,1223:204},yn=0,vn={};e.ActiveXObject&&x(e).on("unload",function(){for(var e in vn)vn[e]();vn=undefined}),x.support.cors=!!gn&&"withCredentials"in gn,x.support.ajax=gn=!!gn,x.ajaxTransport(function(e){var t;return x.support.cors||gn&&!e.crossDomain?{send:function(n,r){var i,o,s=e.xhr();if(s.open(e.type,e.url,e.async,e.username,e.password),e.xhrFields)for(i in e.xhrFields)s[i]=e.xhrFields[i];e.mimeType&&s.overrideMimeType&&s.overrideMimeType(e.mimeType),e.crossDomain||n["X-Requested-With"]||(n["X-Requested-With"]="XMLHttpRequest");for(i in n)s.setRequestHeader(i,n[i]);t=function(e){return function(){t&&(delete vn[o],t=s.onload=s.onerror=null,"abort"===e?s.abort():"error"===e?r(s.status||404,s.statusText):r(mn[s.status]||s.status,s.statusText,"string"==typeof s.responseText?{text:s.responseText}:undefined,s.getAllResponseHeaders()))}},s.onload=t(),s.onerror=t("error"),t=vn[o=yn++]=t("abort"),s.send(e.hasContent&&e.data||null)},abort:function(){t&&t()}}:undefined});var xn,bn,wn=/^(?:toggle|show|hide)$/,Tn=RegExp("^(?:([+-])=|)("+b+")([a-z%]*)$","i"),Cn=/queueHooks$/,kn=[An],Nn={"*":[function(e,t){var n=this.createTween(e,t),r=n.cur(),i=Tn.exec(t),o=i&&i[3]||(x.cssNumber[e]?"":"px"),s=(x.cssNumber[e]||"px"!==o&&+r)&&Tn.exec(x.css(n.elem,e)),a=1,u=20;if(s&&s[3]!==o){o=o||s[3],i=i||[],s=+r||1;do a=a||".5",s/=a,x.style(n.elem,e,s+o);while(a!==(a=n.cur()/r)&&1!==a&&--u)}return i&&(s=n.start=+s||+r||0,n.unit=o,n.end=i[1]?s+(i[1]+1)*i[2]:+i[2]),n}]};function En(){return setTimeout(function(){xn=undefined}),xn=x.now()}function Sn(e,t,n){var r,i=(Nn[t]||[]).concat(Nn["*"]),o=0,s=i.length;for(;s>o;o++)if(r=i[o].call(n,t,e))return r}function jn(e,t,n){var r,i,o=0,s=kn.length,a=x.Deferred().always(function(){delete u.elem}),u=function(){if(i)return!1;var t=xn||En(),n=Math.max(0,l.startTime+l.duration-t),r=n/l.duration||0,o=1-r,s=0,u=l.tweens.length;for(;u>s;s++)l.tweens[s].run(o);return a.notifyWith(e,[l,o,n]),1>o&&u?n:(a.resolveWith(e,[l]),!1)},l=a.promise({elem:e,props:x.extend({},t),opts:x.extend(!0,{specialEasing:{}},n),originalProperties:t,originalOptions:n,startTime:xn||En(),duration:n.duration,tweens:[],createTween:function(t,n){var r=x.Tween(e,l.opts,t,n,l.opts.specialEasing[t]||l.opts.easing);return l.tweens.push(r),r},stop:function(t){var n=0,r=t?l.tweens.length:0;if(i)return this;for(i=!0;r>n;n++)l.tweens[n].run(1);return t?a.resolveWith(e,[l,t]):a.rejectWith(e,[l,t]),this}}),c=l.props;for(Dn(c,l.opts.specialEasing);s>o;o++)if(r=kn[o].call(l,e,c,l.opts))return r;return x.map(c,Sn,l),x.isFunction(l.opts.start)&&l.opts.start.call(e,l),x.fx.timer(x.extend(u,{elem:e,anim:l,queue:l.opts.queue})),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always)}function Dn(e,t){var n,r,i,o,s;for(n in e)if(r=x.camelCase(n),i=t[r],o=e[n],x.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),s=x.cssHooks[r],s&&"expand"in s){o=s.expand(o),delete e[r];for(n in o)n in e||(e[n]=o[n],t[n]=i)}else t[r]=i}x.Animation=x.extend(jn,{tweener:function(e,t){x.isFunction(e)?(t=e,e=["*"]):e=e.split(" ");var n,r=0,i=e.length;for(;i>r;r++)n=e[r],Nn[n]=Nn[n]||[],Nn[n].unshift(t)},prefilter:function(e,t){t?kn.unshift(e):kn.push(e)}});function An(e,t,n){var r,i,o,s,a,u,l=this,c={},p=e.style,f=e.nodeType&&Lt(e),h=q.get(e,"fxshow");n.queue||(a=x._queueHooks(e,"fx"),null==a.unqueued&&(a.unqueued=0,u=a.empty.fire,a.empty.fire=function(){a.unqueued||u()}),a.unqueued++,l.always(function(){l.always(function(){a.unqueued--,x.queue(e,"fx").length||a.empty.fire()})})),1===e.nodeType&&("height"in t||"width"in t)&&(n.overflow=[p.overflow,p.overflowX,p.overflowY],"inline"===x.css(e,"display")&&"none"===x.css(e,"float")&&(p.display="inline-block")),n.overflow&&(p.overflow="hidden",l.always(function(){p.overflow=n.overflow[0],p.overflowX=n.overflow[1],p.overflowY=n.overflow[2]}));for(r in t)if(i=t[r],wn.exec(i)){if(delete t[r],o=o||"toggle"===i,i===(f?"hide":"show")){if("show"!==i||!h||h[r]===undefined)continue;f=!0}c[r]=h&&h[r]||x.style(e,r)}if(!x.isEmptyObject(c)){h?"hidden"in h&&(f=h.hidden):h=q.access(e,"fxshow",{}),o&&(h.hidden=!f),f?x(e).show():l.done(function(){x(e).hide()}),l.done(function(){var t;q.remove(e,"fxshow");for(t in c)x.style(e,t,c[t])});for(r in c)s=Sn(f?h[r]:0,r,l),r in h||(h[r]=s.start,f&&(s.end=s.start,s.start="width"===r||"height"===r?1:0))}}function Ln(e,t,n,r,i){return new Ln.prototype.init(e,t,n,r,i)}x.Tween=Ln,Ln.prototype={constructor:Ln,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||"swing",this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(x.cssNumber[n]?"":"px")},cur:function(){var e=Ln.propHooks[this.prop];return e&&e.get?e.get(this):Ln.propHooks._default.get(this)},run:function(e){var t,n=Ln.propHooks[this.prop];return this.pos=t=this.options.duration?x.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):Ln.propHooks._default.set(this),this}},Ln.prototype.init.prototype=Ln.prototype,Ln.propHooks={_default:{get:function(e){var t;return null==e.elem[e.prop]||e.elem.style&&null!=e.elem.style[e.prop]?(t=x.css(e.elem,e.prop,""),t&&"auto"!==t?t:0):e.elem[e.prop]},set:function(e){x.fx.step[e.prop]?x.fx.step[e.prop](e):e.elem.style&&(null!=e.elem.style[x.cssProps[e.prop]]||x.cssHooks[e.prop])?x.style(e.elem,e.prop,e.now+e.unit):e.elem[e.prop]=e.now}}},Ln.propHooks.scrollTop=Ln.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},x.each(["toggle","show","hide"],function(e,t){var n=x.fn[t];x.fn[t]=function(e,r,i){return null==e||"boolean"==typeof e?n.apply(this,arguments):this.animate(qn(t,!0),e,r,i)}}),x.fn.extend({fadeTo:function(e,t,n,r){return this.filter(Lt).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(e,t,n,r){var i=x.isEmptyObject(e),o=x.speed(t,n,r),s=function(){var t=jn(this,x.extend({},e),o);(i||q.get(this,"finish"))&&t.stop(!0)};return s.finish=s,i||o.queue===!1?this.each(s):this.queue(o.queue,s)},stop:function(e,t,n){var r=function(e){var t=e.stop;delete e.stop,t(n)};return"string"!=typeof e&&(n=t,t=e,e=undefined),t&&e!==!1&&this.queue(e||"fx",[]),this.each(function(){var t=!0,i=null!=e&&e+"queueHooks",o=x.timers,s=q.get(this);if(i)s[i]&&s[i].stop&&r(s[i]);else for(i in s)s[i]&&s[i].stop&&Cn.test(i)&&r(s[i]);for(i=o.length;i--;)o[i].elem!==this||null!=e&&o[i].queue!==e||(o[i].anim.stop(n),t=!1,o.splice(i,1));(t||!n)&&x.dequeue(this,e)})},finish:function(e){return e!==!1&&(e=e||"fx"),this.each(function(){var t,n=q.get(this),r=n[e+"queue"],i=n[e+"queueHooks"],o=x.timers,s=r?r.length:0;for(n.finish=!0,x.queue(this,e,[]),i&&i.stop&&i.stop.call(this,!0),t=o.length;t--;)o[t].elem===this&&o[t].queue===e&&(o[t].anim.stop(!0),o.splice(t,1));for(t=0;s>t;t++)r[t]&&r[t].finish&&r[t].finish.call(this);delete n.finish})}});function qn(e,t){var n,r={height:e},i=0;for(t=t?1:0;4>i;i+=2-t)n=jt[i],r["margin"+n]=r["padding"+n]=e;return t&&(r.opacity=r.width=e),r}x.each({slideDown:qn("show"),slideUp:qn("hide"),slideToggle:qn("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,t){x.fn[e]=function(e,n,r){return this.animate(t,e,n,r)}}),x.speed=function(e,t,n){var r=e&&"object"==typeof e?x.extend({},e):{complete:n||!n&&t||x.isFunction(e)&&e,duration:e,easing:n&&t||t&&!x.isFunction(t)&&t};return r.duration=x.fx.off?0:"number"==typeof r.duration?r.duration:r.duration in x.fx.speeds?x.fx.speeds[r.duration]:x.fx.speeds._default,(null==r.queue||r.queue===!0)&&(r.queue="fx"),r.old=r.complete,r.complete=function(){x.isFunction(r.old)&&r.old.call(this),r.queue&&x.dequeue(this,r.queue)},r},x.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2}},x.timers=[],x.fx=Ln.prototype.init,x.fx.tick=function(){var e,t=x.timers,n=0;for(xn=x.now();t.length>n;n++)e=t[n],e()||t[n]!==e||t.splice(n--,1);t.length||x.fx.stop(),xn=undefined},x.fx.timer=function(e){e()&&x.timers.push(e)&&x.fx.start()},x.fx.interval=13,x.fx.start=function(){bn||(bn=setInterval(x.fx.tick,x.fx.interval))},x.fx.stop=function(){clearInterval(bn),bn=null},x.fx.speeds={slow:600,fast:200,_default:400},x.fx.step={},x.expr&&x.expr.filters&&(x.expr.filters.animated=function(e){return x.grep(x.timers,function(t){return e===t.elem}).length}),x.fn.offset=function(e){if(arguments.length)return e===undefined?this:this.each(function(t){x.offset.setOffset(this,e,t)});var t,n,i=this[0],o={top:0,left:0},s=i&&i.ownerDocument;if(s)return t=s.documentElement,x.contains(t,i)?(typeof i.getBoundingClientRect!==r&&(o=i.getBoundingClientRect()),n=Hn(s),{top:o.top+n.pageYOffset-t.clientTop,left:o.left+n.pageXOffset-t.clientLeft}):o},x.offset={setOffset:function(e,t,n){var r,i,o,s,a,u,l,c=x.css(e,"position"),p=x(e),f={};"static"===c&&(e.style.position="relative"),a=p.offset(),o=x.css(e,"top"),u=x.css(e,"left"),l=("absolute"===c||"fixed"===c)&&(o+u).indexOf("auto")>-1,l?(r=p.position(),s=r.top,i=r.left):(s=parseFloat(o)||0,i=parseFloat(u)||0),x.isFunction(t)&&(t=t.call(e,n,a)),null!=t.top&&(f.top=t.top-a.top+s),null!=t.left&&(f.left=t.left-a.left+i),"using"in t?t.using.call(e,f):p.css(f)}},x.fn.extend({position:function(){if(this[0]){var e,t,n=this[0],r={top:0,left:0};return"fixed"===x.css(n,"position")?t=n.getBoundingClientRect():(e=this.offsetParent(),t=this.offset(),x.nodeName(e[0],"html")||(r=e.offset()),r.top+=x.css(e[0],"borderTopWidth",!0),r.left+=x.css(e[0],"borderLeftWidth",!0)),{top:t.top-r.top-x.css(n,"marginTop",!0),left:t.left-r.left-x.css(n,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent||s;while(e&&!x.nodeName(e,"html")&&"static"===x.css(e,"position"))e=e.offsetParent;return e||s})}}),x.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,n){var r="pageYOffset"===n;x.fn[t]=function(i){return x.access(this,function(t,i,o){var s=Hn(t);return o===undefined?s?s[n]:t[i]:(s?s.scrollTo(r?e.pageXOffset:o,r?o:e.pageYOffset):t[i]=o,undefined)},t,i,arguments.length,null)}});function Hn(e){return x.isWindow(e)?e:9===e.nodeType&&e.defaultView}x.each({Height:"height",Width:"width"},function(e,t){x.each({padding:"inner"+e,content:t,"":"outer"+e},function(n,r){x.fn[r]=function(r,i){var o=arguments.length&&(n||"boolean"!=typeof r),s=n||(r===!0||i===!0?"margin":"border");return x.access(this,function(t,n,r){var i;return x.isWindow(t)?t.document.documentElement["client"+e]:9===t.nodeType?(i=t.documentElement,Math.max(t.body["scroll"+e],i["scroll"+e],t.body["offset"+e],i["offset"+e],i["client"+e])):r===undefined?x.css(t,n,s):x.style(t,n,r,s)},t,o?r:undefined,o,null)}})}),x.fn.size=function(){return this.length},x.fn.andSelf=x.fn.addBack,"object"==typeof module&&module&&"object"==typeof module.exports?module.exports=x:"function"==typeof define&&define.amd&&define("jquery",[],function(){return x}),"object"==typeof e&&"object"==typeof e.document&&(e.jQuery=e.$=x)})(window);
@@ -0,0 +1,332 @@
1
+ /**
2
+ * @license RequireJS text 2.0.5 Copyright (c) 2010-2012, The Dojo Foundation All Rights Reserved.
3
+ * Available via the MIT or new BSD license.
4
+ * see: http://github.com/requirejs/text for details
5
+ */
6
+ /*jslint regexp: true */
7
+ /*global require: false, XMLHttpRequest: false, ActiveXObject: false,
8
+ define: false, window: false, process: false, Packages: false,
9
+ java: false, location: false */
10
+
11
+ define(['module'], function (module) {
12
+ 'use strict';
13
+
14
+ var text, fs,
15
+ progIds = ['Msxml2.XMLHTTP', 'Microsoft.XMLHTTP', 'Msxml2.XMLHTTP.4.0'],
16
+ xmlRegExp = /^\s*<\?xml(\s)+version=[\'\"](\d)*.(\d)*[\'\"](\s)*\?>/im,
17
+ bodyRegExp = /<body[^>]*>\s*([\s\S]+)\s*<\/body>/im,
18
+ hasLocation = typeof location !== 'undefined' && location.href,
19
+ defaultProtocol = hasLocation && location.protocol && location.protocol.replace(/\:/, ''),
20
+ defaultHostName = hasLocation && location.hostname,
21
+ defaultPort = hasLocation && (location.port || undefined),
22
+ buildMap = [],
23
+ masterConfig = (module.config && module.config()) || {};
24
+
25
+ text = {
26
+ version: '2.0.5',
27
+
28
+ strip: function (content) {
29
+ //Strips <?xml ...?> declarations so that external SVG and XML
30
+ //documents can be added to a document without worry. Also, if the string
31
+ //is an HTML document, only the part inside the body tag is returned.
32
+ if (content) {
33
+ content = content.replace(xmlRegExp, "");
34
+ var matches = content.match(bodyRegExp);
35
+ if (matches) {
36
+ content = matches[1];
37
+ }
38
+ } else {
39
+ content = "";
40
+ }
41
+ return content;
42
+ },
43
+
44
+ jsEscape: function (content) {
45
+ return content.replace(/(['\\])/g, '\\$1')
46
+ .replace(/[\f]/g, "\\f")
47
+ .replace(/[\b]/g, "\\b")
48
+ .replace(/[\n]/g, "\\n")
49
+ .replace(/[\t]/g, "\\t")
50
+ .replace(/[\r]/g, "\\r")
51
+ .replace(/[\u2028]/g, "\\u2028")
52
+ .replace(/[\u2029]/g, "\\u2029");
53
+ },
54
+
55
+ createXhr: masterConfig.createXhr || function () {
56
+ //Would love to dump the ActiveX crap in here. Need IE 6 to die first.
57
+ var xhr, i, progId;
58
+ if (typeof XMLHttpRequest !== "undefined") {
59
+ return new XMLHttpRequest();
60
+ } else if (typeof ActiveXObject !== "undefined") {
61
+ for (i = 0; i < 3; i += 1) {
62
+ progId = progIds[i];
63
+ try {
64
+ xhr = new ActiveXObject(progId);
65
+ } catch (e) {}
66
+
67
+ if (xhr) {
68
+ progIds = [progId]; // so faster next time
69
+ break;
70
+ }
71
+ }
72
+ }
73
+
74
+ return xhr;
75
+ },
76
+
77
+ /**
78
+ * Parses a resource name into its component parts. Resource names
79
+ * look like: module/name.ext!strip, where the !strip part is
80
+ * optional.
81
+ * @param {String} name the resource name
82
+ * @returns {Object} with properties "moduleName", "ext" and "strip"
83
+ * where strip is a boolean.
84
+ */
85
+ parseName: function (name) {
86
+ var modName, ext, temp,
87
+ strip = false,
88
+ index = name.indexOf("."),
89
+ isRelative = name.indexOf('./') === 0 ||
90
+ name.indexOf('../') === 0;
91
+
92
+ if (index !== -1 && (!isRelative || index > 1)) {
93
+ modName = name.substring(0, index);
94
+ ext = name.substring(index + 1, name.length);
95
+ } else {
96
+ modName = name;
97
+ }
98
+
99
+ temp = ext || modName;
100
+ index = temp.indexOf("!");
101
+ if (index !== -1) {
102
+ //Pull off the strip arg.
103
+ strip = temp.substring(index + 1) === "strip";
104
+ temp = temp.substring(0, index);
105
+ if (ext) {
106
+ ext = temp;
107
+ } else {
108
+ modName = temp;
109
+ }
110
+ }
111
+
112
+ return {
113
+ moduleName: modName,
114
+ ext: ext,
115
+ strip: strip
116
+ };
117
+ },
118
+
119
+ xdRegExp: /^((\w+)\:)?\/\/([^\/\\]+)/,
120
+
121
+ /**
122
+ * Is an URL on another domain. Only works for browser use, returns
123
+ * false in non-browser environments. Only used to know if an
124
+ * optimized .js version of a text resource should be loaded
125
+ * instead.
126
+ * @param {String} url
127
+ * @returns Boolean
128
+ */
129
+ useXhr: function (url, protocol, hostname, port) {
130
+ var uProtocol, uHostName, uPort,
131
+ match = text.xdRegExp.exec(url);
132
+ if (!match) {
133
+ return true;
134
+ }
135
+ uProtocol = match[2];
136
+ uHostName = match[3];
137
+
138
+ uHostName = uHostName.split(':');
139
+ uPort = uHostName[1];
140
+ uHostName = uHostName[0];
141
+
142
+ return (!uProtocol || uProtocol === protocol) &&
143
+ (!uHostName || uHostName.toLowerCase() === hostname.toLowerCase()) &&
144
+ ((!uPort && !uHostName) || uPort === port);
145
+ },
146
+
147
+ finishLoad: function (name, strip, content, onLoad) {
148
+ content = strip ? text.strip(content) : content;
149
+ if (masterConfig.isBuild) {
150
+ buildMap[name] = content;
151
+ }
152
+ onLoad(content);
153
+ },
154
+
155
+ load: function (name, req, onLoad, config) {
156
+ //Name has format: some.module.filext!strip
157
+ //The strip part is optional.
158
+ //if strip is present, then that means only get the string contents
159
+ //inside a body tag in an HTML string. For XML/SVG content it means
160
+ //removing the <?xml ...?> declarations so the content can be inserted
161
+ //into the current doc without problems.
162
+
163
+ // Do not bother with the work if a build and text will
164
+ // not be inlined.
165
+ if (config.isBuild && !config.inlineText) {
166
+ onLoad();
167
+ return;
168
+ }
169
+
170
+ masterConfig.isBuild = config.isBuild;
171
+
172
+ var parsed = text.parseName(name),
173
+ nonStripName = parsed.moduleName +
174
+ (parsed.ext ? '.' + parsed.ext : ''),
175
+ url = req.toUrl(nonStripName),
176
+ useXhr = (masterConfig.useXhr) ||
177
+ text.useXhr;
178
+
179
+ //Load the text. Use XHR if possible and in a browser.
180
+ if (!hasLocation || useXhr(url, defaultProtocol, defaultHostName, defaultPort)) {
181
+ text.get(url, function (content) {
182
+ text.finishLoad(name, parsed.strip, content, onLoad);
183
+ }, function (err) {
184
+ if (onLoad.error) {
185
+ onLoad.error(err);
186
+ }
187
+ });
188
+ } else {
189
+ //Need to fetch the resource across domains. Assume
190
+ //the resource has been optimized into a JS module. Fetch
191
+ //by the module name + extension, but do not include the
192
+ //!strip part to avoid file system issues.
193
+ req([nonStripName], function (content) {
194
+ text.finishLoad(parsed.moduleName + '.' + parsed.ext,
195
+ parsed.strip, content, onLoad);
196
+ });
197
+ }
198
+ },
199
+
200
+ write: function (pluginName, moduleName, write, config) {
201
+ if (buildMap.hasOwnProperty(moduleName)) {
202
+ var content = text.jsEscape(buildMap[moduleName]);
203
+ write.asModule(pluginName + "!" + moduleName,
204
+ "define(function () { return '" +
205
+ content +
206
+ "';});\n");
207
+ }
208
+ },
209
+
210
+ writeFile: function (pluginName, moduleName, req, write, config) {
211
+ var parsed = text.parseName(moduleName),
212
+ extPart = parsed.ext ? '.' + parsed.ext : '',
213
+ nonStripName = parsed.moduleName + extPart,
214
+ //Use a '.js' file name so that it indicates it is a
215
+ //script that can be loaded across domains.
216
+ fileName = req.toUrl(parsed.moduleName + extPart) + '.js';
217
+
218
+ //Leverage own load() method to load plugin value, but only
219
+ //write out values that do not have the strip argument,
220
+ //to avoid any potential issues with ! in file names.
221
+ text.load(nonStripName, req, function (value) {
222
+ //Use own write() method to construct full module value.
223
+ //But need to create shell that translates writeFile's
224
+ //write() to the right interface.
225
+ var textWrite = function (contents) {
226
+ return write(fileName, contents);
227
+ };
228
+ textWrite.asModule = function (moduleName, contents) {
229
+ return write.asModule(moduleName, fileName, contents);
230
+ };
231
+
232
+ text.write(pluginName, nonStripName, textWrite, config);
233
+ }, config);
234
+ }
235
+ };
236
+
237
+ if (masterConfig.env === 'node' || (!masterConfig.env &&
238
+ typeof process !== "undefined" &&
239
+ process.versions &&
240
+ !!process.versions.node)) {
241
+ //Using special require.nodeRequire, something added by r.js.
242
+ fs = require.nodeRequire('fs');
243
+
244
+ text.get = function (url, callback) {
245
+ var file = fs.readFileSync(url, 'utf8');
246
+ //Remove BOM (Byte Mark Order) from utf8 files if it is there.
247
+ if (file.indexOf('\uFEFF') === 0) {
248
+ file = file.substring(1);
249
+ }
250
+ callback(file);
251
+ };
252
+ } else if (masterConfig.env === 'xhr' || (!masterConfig.env &&
253
+ text.createXhr())) {
254
+ text.get = function (url, callback, errback, headers) {
255
+ var xhr = text.createXhr(), header;
256
+ xhr.open('GET', url, true);
257
+
258
+ //Allow plugins direct access to xhr headers
259
+ if (headers) {
260
+ for (header in headers) {
261
+ if (headers.hasOwnProperty(header)) {
262
+ xhr.setRequestHeader(header.toLowerCase(), headers[header]);
263
+ }
264
+ }
265
+ }
266
+
267
+ //Allow overrides specified in config
268
+ if (masterConfig.onXhr) {
269
+ masterConfig.onXhr(xhr, url);
270
+ }
271
+
272
+ xhr.onreadystatechange = function (evt) {
273
+ var status, err;
274
+ //Do not explicitly handle errors, those should be
275
+ //visible via console output in the browser.
276
+ if (xhr.readyState === 4) {
277
+ status = xhr.status;
278
+ if (status > 399 && status < 600) {
279
+ //An http 4xx or 5xx error. Signal an error.
280
+ err = new Error(url + ' HTTP status: ' + status);
281
+ err.xhr = xhr;
282
+ errback(err);
283
+ } else {
284
+ callback(xhr.responseText);
285
+ }
286
+ }
287
+ };
288
+ xhr.send(null);
289
+ };
290
+ } else if (masterConfig.env === 'rhino' || (!masterConfig.env &&
291
+ typeof Packages !== 'undefined' && typeof java !== 'undefined')) {
292
+ //Why Java, why is this so awkward?
293
+ text.get = function (url, callback) {
294
+ var stringBuffer, line,
295
+ encoding = "utf-8",
296
+ file = new java.io.File(url),
297
+ lineSeparator = java.lang.System.getProperty("line.separator"),
298
+ input = new java.io.BufferedReader(new java.io.InputStreamReader(new java.io.FileInputStream(file), encoding)),
299
+ content = '';
300
+ try {
301
+ stringBuffer = new java.lang.StringBuffer();
302
+ line = input.readLine();
303
+
304
+ // Byte Order Mark (BOM) - The Unicode Standard, version 3.0, page 324
305
+ // http://www.unicode.org/faq/utf_bom.html
306
+
307
+ // Note that when we use utf-8, the BOM should appear as "EF BB BF", but it doesn't due to this bug in the JDK:
308
+ // http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=4508058
309
+ if (line && line.length() && line.charAt(0) === 0xfeff) {
310
+ // Eat the BOM, since we've already found the encoding on this file,
311
+ // and we plan to concatenating this buffer with others; the BOM should
312
+ // only appear at the top of a file.
313
+ line = line.substring(1);
314
+ }
315
+
316
+ stringBuffer.append(line);
317
+
318
+ while ((line = input.readLine()) !== null) {
319
+ stringBuffer.append(lineSeparator);
320
+ stringBuffer.append(line);
321
+ }
322
+ //Make sure we return a JavaScript string and not a Java string.
323
+ content = String(stringBuffer.toString()); //String
324
+ } finally {
325
+ input.close();
326
+ }
327
+ callback(content);
328
+ };
329
+ }
330
+
331
+ return text;
332
+ });
@@ -0,0 +1,2019 @@
1
+ /** vim: et:ts=4:sw=4:sts=4
2
+ * @license RequireJS 2.1.5 Copyright (c) 2010-2012, The Dojo Foundation All Rights Reserved.
3
+ * Available via the MIT or new BSD license.
4
+ * see: http://github.com/jrburke/requirejs for details
5
+ */
6
+ //Not using strict: uneven strict support in browsers, #392, and causes
7
+ //problems with requirejs.exec()/transpiler plugins that may not be strict.
8
+ /*jslint regexp: true, nomen: true, sloppy: true */
9
+ /*global window, navigator, document, importScripts, setTimeout, opera */
10
+
11
+ var requirejs, require, define;
12
+ (function (global) {
13
+ var req, s, head, baseElement, dataMain, src,
14
+ interactiveScript, currentlyAddingScript, mainScript, subPath,
15
+ version = '2.1.5',
16
+ commentRegExp = /(\/\*([\s\S]*?)\*\/|([^:]|^)\/\/(.*)$)/mg,
17
+ cjsRequireRegExp = /[^.]\s*require\s*\(\s*["']([^'"\s]+)["']\s*\)/g,
18
+ jsSuffixRegExp = /\.js$/,
19
+ currDirRegExp = /^\.\//,
20
+ op = Object.prototype,
21
+ ostring = op.toString,
22
+ hasOwn = op.hasOwnProperty,
23
+ ap = Array.prototype,
24
+ apsp = ap.splice,
25
+ isBrowser = !!(typeof window !== 'undefined' && navigator && document),
26
+ isWebWorker = !isBrowser && typeof importScripts !== 'undefined',
27
+ //PS3 indicates loaded and complete, but need to wait for complete
28
+ //specifically. Sequence is 'loading', 'loaded', execution,
29
+ // then 'complete'. The UA check is unfortunate, but not sure how
30
+ //to feature test w/o causing perf issues.
31
+ readyRegExp = isBrowser && navigator.platform === 'PLAYSTATION 3' ?
32
+ /^complete$/ : /^(complete|loaded)$/,
33
+ defContextName = '_',
34
+ //Oh the tragedy, detecting opera. See the usage of isOpera for reason.
35
+ isOpera = typeof opera !== 'undefined' && opera.toString() === '[object Opera]',
36
+ contexts = {},
37
+ cfg = {},
38
+ globalDefQueue = [],
39
+ useInteractive = false;
40
+
41
+ function isFunction(it) {
42
+ return ostring.call(it) === '[object Function]';
43
+ }
44
+
45
+ function isArray(it) {
46
+ return ostring.call(it) === '[object Array]';
47
+ }
48
+
49
+ /**
50
+ * Helper function for iterating over an array. If the func returns
51
+ * a true value, it will break out of the loop.
52
+ */
53
+ function each(ary, func) {
54
+ if (ary) {
55
+ var i;
56
+ for (i = 0; i < ary.length; i += 1) {
57
+ if (ary[i] && func(ary[i], i, ary)) {
58
+ break;
59
+ }
60
+ }
61
+ }
62
+ }
63
+
64
+ /**
65
+ * Helper function for iterating over an array backwards. If the func
66
+ * returns a true value, it will break out of the loop.
67
+ */
68
+ function eachReverse(ary, func) {
69
+ if (ary) {
70
+ var i;
71
+ for (i = ary.length - 1; i > -1; i -= 1) {
72
+ if (ary[i] && func(ary[i], i, ary)) {
73
+ break;
74
+ }
75
+ }
76
+ }
77
+ }
78
+
79
+ function hasProp(obj, prop) {
80
+ return hasOwn.call(obj, prop);
81
+ }
82
+
83
+ function getOwn(obj, prop) {
84
+ return hasProp(obj, prop) && obj[prop];
85
+ }
86
+
87
+ /**
88
+ * Cycles over properties in an object and calls a function for each
89
+ * property value. If the function returns a truthy value, then the
90
+ * iteration is stopped.
91
+ */
92
+ function eachProp(obj, func) {
93
+ var prop;
94
+ for (prop in obj) {
95
+ if (hasProp(obj, prop)) {
96
+ if (func(obj[prop], prop)) {
97
+ break;
98
+ }
99
+ }
100
+ }
101
+ }
102
+
103
+ /**
104
+ * Simple function to mix in properties from source into target,
105
+ * but only if target does not already have a property of the same name.
106
+ */
107
+ function mixin(target, source, force, deepStringMixin) {
108
+ if (source) {
109
+ eachProp(source, function (value, prop) {
110
+ if (force || !hasProp(target, prop)) {
111
+ if (deepStringMixin && typeof value !== 'string') {
112
+ if (!target[prop]) {
113
+ target[prop] = {};
114
+ }
115
+ mixin(target[prop], value, force, deepStringMixin);
116
+ } else {
117
+ target[prop] = value;
118
+ }
119
+ }
120
+ });
121
+ }
122
+ return target;
123
+ }
124
+
125
+ //Similar to Function.prototype.bind, but the 'this' object is specified
126
+ //first, since it is easier to read/figure out what 'this' will be.
127
+ function bind(obj, fn) {
128
+ return function () {
129
+ return fn.apply(obj, arguments);
130
+ };
131
+ }
132
+
133
+ function scripts() {
134
+ return document.getElementsByTagName('script');
135
+ }
136
+
137
+ //Allow getting a global that expressed in
138
+ //dot notation, like 'a.b.c'.
139
+ function getGlobal(value) {
140
+ if (!value) {
141
+ return value;
142
+ }
143
+ var g = global;
144
+ each(value.split('.'), function (part) {
145
+ g = g[part];
146
+ });
147
+ return g;
148
+ }
149
+
150
+ /**
151
+ * Constructs an error with a pointer to an URL with more information.
152
+ * @param {String} id the error ID that maps to an ID on a web page.
153
+ * @param {String} message human readable error.
154
+ * @param {Error} [err] the original error, if there is one.
155
+ *
156
+ * @returns {Error}
157
+ */
158
+ function makeError(id, msg, err, requireModules) {
159
+ var e = new Error(msg + '\nhttp://requirejs.org/docs/errors.html#' + id);
160
+ e.requireType = id;
161
+ e.requireModules = requireModules;
162
+ if (err) {
163
+ e.originalError = err;
164
+ }
165
+ return e;
166
+ }
167
+
168
+ if (typeof define !== 'undefined') {
169
+ //If a define is already in play via another AMD loader,
170
+ //do not overwrite.
171
+ return;
172
+ }
173
+
174
+ if (typeof requirejs !== 'undefined') {
175
+ if (isFunction(requirejs)) {
176
+ //Do not overwrite and existing requirejs instance.
177
+ return;
178
+ }
179
+ cfg = requirejs;
180
+ requirejs = undefined;
181
+ }
182
+
183
+ //Allow for a require config object
184
+ if (typeof require !== 'undefined' && !isFunction(require)) {
185
+ //assume it is a config object.
186
+ cfg = require;
187
+ require = undefined;
188
+ }
189
+
190
+ function newContext(contextName) {
191
+ var inCheckLoaded, Module, context, handlers,
192
+ checkLoadedTimeoutId,
193
+ config = {
194
+ //Defaults. Do not set a default for map
195
+ //config to speed up normalize(), which
196
+ //will run faster if there is no default.
197
+ waitSeconds: 7,
198
+ baseUrl: './',
199
+ paths: {},
200
+ pkgs: {},
201
+ shim: {},
202
+ config: {}
203
+ },
204
+ registry = {},
205
+ //registry of just enabled modules, to speed
206
+ //cycle breaking code when lots of modules
207
+ //are registered, but not activated.
208
+ enabledRegistry = {},
209
+ undefEvents = {},
210
+ defQueue = [],
211
+ defined = {},
212
+ urlFetched = {},
213
+ requireCounter = 1,
214
+ unnormalizedCounter = 1;
215
+
216
+ /**
217
+ * Trims the . and .. from an array of path segments.
218
+ * It will keep a leading path segment if a .. will become
219
+ * the first path segment, to help with module name lookups,
220
+ * which act like paths, but can be remapped. But the end result,
221
+ * all paths that use this function should look normalized.
222
+ * NOTE: this method MODIFIES the input array.
223
+ * @param {Array} ary the array of path segments.
224
+ */
225
+ function trimDots(ary) {
226
+ var i, part;
227
+ for (i = 0; ary[i]; i += 1) {
228
+ part = ary[i];
229
+ if (part === '.') {
230
+ ary.splice(i, 1);
231
+ i -= 1;
232
+ } else if (part === '..') {
233
+ if (i === 1 && (ary[2] === '..' || ary[0] === '..')) {
234
+ //End of the line. Keep at least one non-dot
235
+ //path segment at the front so it can be mapped
236
+ //correctly to disk. Otherwise, there is likely
237
+ //no path mapping for a path starting with '..'.
238
+ //This can still fail, but catches the most reasonable
239
+ //uses of ..
240
+ break;
241
+ } else if (i > 0) {
242
+ ary.splice(i - 1, 2);
243
+ i -= 2;
244
+ }
245
+ }
246
+ }
247
+ }
248
+
249
+ /**
250
+ * Given a relative module name, like ./something, normalize it to
251
+ * a real name that can be mapped to a path.
252
+ * @param {String} name the relative name
253
+ * @param {String} baseName a real name that the name arg is relative
254
+ * to.
255
+ * @param {Boolean} applyMap apply the map config to the value. Should
256
+ * only be done if this normalization is for a dependency ID.
257
+ * @returns {String} normalized name
258
+ */
259
+ function normalize(name, baseName, applyMap) {
260
+ var pkgName, pkgConfig, mapValue, nameParts, i, j, nameSegment,
261
+ foundMap, foundI, foundStarMap, starI,
262
+ baseParts = baseName && baseName.split('/'),
263
+ normalizedBaseParts = baseParts,
264
+ map = config.map,
265
+ starMap = map && map['*'];
266
+
267
+ //Adjust any relative paths.
268
+ if (name && name.charAt(0) === '.') {
269
+ //If have a base name, try to normalize against it,
270
+ //otherwise, assume it is a top-level require that will
271
+ //be relative to baseUrl in the end.
272
+ if (baseName) {
273
+ if (getOwn(config.pkgs, baseName)) {
274
+ //If the baseName is a package name, then just treat it as one
275
+ //name to concat the name with.
276
+ normalizedBaseParts = baseParts = [baseName];
277
+ } else {
278
+ //Convert baseName to array, and lop off the last part,
279
+ //so that . matches that 'directory' and not name of the baseName's
280
+ //module. For instance, baseName of 'one/two/three', maps to
281
+ //'one/two/three.js', but we want the directory, 'one/two' for
282
+ //this normalization.
283
+ normalizedBaseParts = baseParts.slice(0, baseParts.length - 1);
284
+ }
285
+
286
+ name = normalizedBaseParts.concat(name.split('/'));
287
+ trimDots(name);
288
+
289
+ //Some use of packages may use a . path to reference the
290
+ //'main' module name, so normalize for that.
291
+ pkgConfig = getOwn(config.pkgs, (pkgName = name[0]));
292
+ name = name.join('/');
293
+ if (pkgConfig && name === pkgName + '/' + pkgConfig.main) {
294
+ name = pkgName;
295
+ }
296
+ } else if (name.indexOf('./') === 0) {
297
+ // No baseName, so this is ID is resolved relative
298
+ // to baseUrl, pull off the leading dot.
299
+ name = name.substring(2);
300
+ }
301
+ }
302
+
303
+ //Apply map config if available.
304
+ if (applyMap && map && (baseParts || starMap)) {
305
+ nameParts = name.split('/');
306
+
307
+ for (i = nameParts.length; i > 0; i -= 1) {
308
+ nameSegment = nameParts.slice(0, i).join('/');
309
+
310
+ if (baseParts) {
311
+ //Find the longest baseName segment match in the config.
312
+ //So, do joins on the biggest to smallest lengths of baseParts.
313
+ for (j = baseParts.length; j > 0; j -= 1) {
314
+ mapValue = getOwn(map, baseParts.slice(0, j).join('/'));
315
+
316
+ //baseName segment has config, find if it has one for
317
+ //this name.
318
+ if (mapValue) {
319
+ mapValue = getOwn(mapValue, nameSegment);
320
+ if (mapValue) {
321
+ //Match, update name to the new value.
322
+ foundMap = mapValue;
323
+ foundI = i;
324
+ break;
325
+ }
326
+ }
327
+ }
328
+ }
329
+
330
+ if (foundMap) {
331
+ break;
332
+ }
333
+
334
+ //Check for a star map match, but just hold on to it,
335
+ //if there is a shorter segment match later in a matching
336
+ //config, then favor over this star map.
337
+ if (!foundStarMap && starMap && getOwn(starMap, nameSegment)) {
338
+ foundStarMap = getOwn(starMap, nameSegment);
339
+ starI = i;
340
+ }
341
+ }
342
+
343
+ if (!foundMap && foundStarMap) {
344
+ foundMap = foundStarMap;
345
+ foundI = starI;
346
+ }
347
+
348
+ if (foundMap) {
349
+ nameParts.splice(0, foundI, foundMap);
350
+ name = nameParts.join('/');
351
+ }
352
+ }
353
+
354
+ return name;
355
+ }
356
+
357
+ function removeScript(name) {
358
+ if (isBrowser) {
359
+ each(scripts(), function (scriptNode) {
360
+ if (scriptNode.getAttribute('data-requiremodule') === name &&
361
+ scriptNode.getAttribute('data-requirecontext') === context.contextName) {
362
+ scriptNode.parentNode.removeChild(scriptNode);
363
+ return true;
364
+ }
365
+ });
366
+ }
367
+ }
368
+
369
+ function hasPathFallback(id) {
370
+ var pathConfig = getOwn(config.paths, id);
371
+ if (pathConfig && isArray(pathConfig) && pathConfig.length > 1) {
372
+ removeScript(id);
373
+ //Pop off the first array value, since it failed, and
374
+ //retry
375
+ pathConfig.shift();
376
+ context.require.undef(id);
377
+ context.require([id]);
378
+ return true;
379
+ }
380
+ }
381
+
382
+ //Turns a plugin!resource to [plugin, resource]
383
+ //with the plugin being undefined if the name
384
+ //did not have a plugin prefix.
385
+ function splitPrefix(name) {
386
+ var prefix,
387
+ index = name ? name.indexOf('!') : -1;
388
+ if (index > -1) {
389
+ prefix = name.substring(0, index);
390
+ name = name.substring(index + 1, name.length);
391
+ }
392
+ return [prefix, name];
393
+ }
394
+
395
+ /**
396
+ * Creates a module mapping that includes plugin prefix, module
397
+ * name, and path. If parentModuleMap is provided it will
398
+ * also normalize the name via require.normalize()
399
+ *
400
+ * @param {String} name the module name
401
+ * @param {String} [parentModuleMap] parent module map
402
+ * for the module name, used to resolve relative names.
403
+ * @param {Boolean} isNormalized: is the ID already normalized.
404
+ * This is true if this call is done for a define() module ID.
405
+ * @param {Boolean} applyMap: apply the map config to the ID.
406
+ * Should only be true if this map is for a dependency.
407
+ *
408
+ * @returns {Object}
409
+ */
410
+ function makeModuleMap(name, parentModuleMap, isNormalized, applyMap) {
411
+ var url, pluginModule, suffix, nameParts,
412
+ prefix = null,
413
+ parentName = parentModuleMap ? parentModuleMap.name : null,
414
+ originalName = name,
415
+ isDefine = true,
416
+ normalizedName = '';
417
+
418
+ //If no name, then it means it is a require call, generate an
419
+ //internal name.
420
+ if (!name) {
421
+ isDefine = false;
422
+ name = '_@r' + (requireCounter += 1);
423
+ }
424
+
425
+ nameParts = splitPrefix(name);
426
+ prefix = nameParts[0];
427
+ name = nameParts[1];
428
+
429
+ if (prefix) {
430
+ prefix = normalize(prefix, parentName, applyMap);
431
+ pluginModule = getOwn(defined, prefix);
432
+ }
433
+
434
+ //Account for relative paths if there is a base name.
435
+ if (name) {
436
+ if (prefix) {
437
+ if (pluginModule && pluginModule.normalize) {
438
+ //Plugin is loaded, use its normalize method.
439
+ normalizedName = pluginModule.normalize(name, function (name) {
440
+ return normalize(name, parentName, applyMap);
441
+ });
442
+ } else {
443
+ normalizedName = normalize(name, parentName, applyMap);
444
+ }
445
+ } else {
446
+ //A regular module.
447
+ normalizedName = normalize(name, parentName, applyMap);
448
+
449
+ //Normalized name may be a plugin ID due to map config
450
+ //application in normalize. The map config values must
451
+ //already be normalized, so do not need to redo that part.
452
+ nameParts = splitPrefix(normalizedName);
453
+ prefix = nameParts[0];
454
+ normalizedName = nameParts[1];
455
+ isNormalized = true;
456
+
457
+ url = context.nameToUrl(normalizedName);
458
+ }
459
+ }
460
+
461
+ //If the id is a plugin id that cannot be determined if it needs
462
+ //normalization, stamp it with a unique ID so two matching relative
463
+ //ids that may conflict can be separate.
464
+ suffix = prefix && !pluginModule && !isNormalized ?
465
+ '_unnormalized' + (unnormalizedCounter += 1) :
466
+ '';
467
+
468
+ return {
469
+ prefix: prefix,
470
+ name: normalizedName,
471
+ parentMap: parentModuleMap,
472
+ unnormalized: !!suffix,
473
+ url: url,
474
+ originalName: originalName,
475
+ isDefine: isDefine,
476
+ id: (prefix ?
477
+ prefix + '!' + normalizedName :
478
+ normalizedName) + suffix
479
+ };
480
+ }
481
+
482
+ function getModule(depMap) {
483
+ var id = depMap.id,
484
+ mod = getOwn(registry, id);
485
+
486
+ if (!mod) {
487
+ mod = registry[id] = new context.Module(depMap);
488
+ }
489
+
490
+ return mod;
491
+ }
492
+
493
+ function on(depMap, name, fn) {
494
+ var id = depMap.id,
495
+ mod = getOwn(registry, id);
496
+
497
+ if (hasProp(defined, id) &&
498
+ (!mod || mod.defineEmitComplete)) {
499
+ if (name === 'defined') {
500
+ fn(defined[id]);
501
+ }
502
+ } else {
503
+ getModule(depMap).on(name, fn);
504
+ }
505
+ }
506
+
507
+ function onError(err, errback) {
508
+ var ids = err.requireModules,
509
+ notified = false;
510
+
511
+ if (errback) {
512
+ errback(err);
513
+ } else {
514
+ each(ids, function (id) {
515
+ var mod = getOwn(registry, id);
516
+ if (mod) {
517
+ //Set error on module, so it skips timeout checks.
518
+ mod.error = err;
519
+ if (mod.events.error) {
520
+ notified = true;
521
+ mod.emit('error', err);
522
+ }
523
+ }
524
+ });
525
+
526
+ if (!notified) {
527
+ req.onError(err);
528
+ }
529
+ }
530
+ }
531
+
532
+ /**
533
+ * Internal method to transfer globalQueue items to this context's
534
+ * defQueue.
535
+ */
536
+ function takeGlobalQueue() {
537
+ //Push all the globalDefQueue items into the context's defQueue
538
+ if (globalDefQueue.length) {
539
+ //Array splice in the values since the context code has a
540
+ //local var ref to defQueue, so cannot just reassign the one
541
+ //on context.
542
+ apsp.apply(defQueue,
543
+ [defQueue.length - 1, 0].concat(globalDefQueue));
544
+ globalDefQueue = [];
545
+ }
546
+ }
547
+
548
+ handlers = {
549
+ 'require': function (mod) {
550
+ if (mod.require) {
551
+ return mod.require;
552
+ } else {
553
+ return (mod.require = context.makeRequire(mod.map));
554
+ }
555
+ },
556
+ 'exports': function (mod) {
557
+ mod.usingExports = true;
558
+ if (mod.map.isDefine) {
559
+ if (mod.exports) {
560
+ return mod.exports;
561
+ } else {
562
+ return (mod.exports = defined[mod.map.id] = {});
563
+ }
564
+ }
565
+ },
566
+ 'module': function (mod) {
567
+ if (mod.module) {
568
+ return mod.module;
569
+ } else {
570
+ return (mod.module = {
571
+ id: mod.map.id,
572
+ uri: mod.map.url,
573
+ config: function () {
574
+ return (config.config && getOwn(config.config, mod.map.id)) || {};
575
+ },
576
+ exports: defined[mod.map.id]
577
+ });
578
+ }
579
+ }
580
+ };
581
+
582
+ function cleanRegistry(id) {
583
+ //Clean up machinery used for waiting modules.
584
+ delete registry[id];
585
+ delete enabledRegistry[id];
586
+ }
587
+
588
+ function breakCycle(mod, traced, processed) {
589
+ var id = mod.map.id;
590
+
591
+ if (mod.error) {
592
+ mod.emit('error', mod.error);
593
+ } else {
594
+ traced[id] = true;
595
+ each(mod.depMaps, function (depMap, i) {
596
+ var depId = depMap.id,
597
+ dep = getOwn(registry, depId);
598
+
599
+ //Only force things that have not completed
600
+ //being defined, so still in the registry,
601
+ //and only if it has not been matched up
602
+ //in the module already.
603
+ if (dep && !mod.depMatched[i] && !processed[depId]) {
604
+ if (getOwn(traced, depId)) {
605
+ mod.defineDep(i, defined[depId]);
606
+ mod.check(); //pass false?
607
+ } else {
608
+ breakCycle(dep, traced, processed);
609
+ }
610
+ }
611
+ });
612
+ processed[id] = true;
613
+ }
614
+ }
615
+
616
+ function checkLoaded() {
617
+ var map, modId, err, usingPathFallback,
618
+ waitInterval = config.waitSeconds * 1000,
619
+ //It is possible to disable the wait interval by using waitSeconds of 0.
620
+ expired = waitInterval && (context.startTime + waitInterval) < new Date().getTime(),
621
+ noLoads = [],
622
+ reqCalls = [],
623
+ stillLoading = false,
624
+ needCycleCheck = true;
625
+
626
+ //Do not bother if this call was a result of a cycle break.
627
+ if (inCheckLoaded) {
628
+ return;
629
+ }
630
+
631
+ inCheckLoaded = true;
632
+
633
+ //Figure out the state of all the modules.
634
+ eachProp(enabledRegistry, function (mod) {
635
+ map = mod.map;
636
+ modId = map.id;
637
+
638
+ //Skip things that are not enabled or in error state.
639
+ if (!mod.enabled) {
640
+ return;
641
+ }
642
+
643
+ if (!map.isDefine) {
644
+ reqCalls.push(mod);
645
+ }
646
+
647
+ if (!mod.error) {
648
+ //If the module should be executed, and it has not
649
+ //been inited and time is up, remember it.
650
+ if (!mod.inited && expired) {
651
+ if (hasPathFallback(modId)) {
652
+ usingPathFallback = true;
653
+ stillLoading = true;
654
+ } else {
655
+ noLoads.push(modId);
656
+ removeScript(modId);
657
+ }
658
+ } else if (!mod.inited && mod.fetched && map.isDefine) {
659
+ stillLoading = true;
660
+ if (!map.prefix) {
661
+ //No reason to keep looking for unfinished
662
+ //loading. If the only stillLoading is a
663
+ //plugin resource though, keep going,
664
+ //because it may be that a plugin resource
665
+ //is waiting on a non-plugin cycle.
666
+ return (needCycleCheck = false);
667
+ }
668
+ }
669
+ }
670
+ });
671
+
672
+ if (expired && noLoads.length) {
673
+ //If wait time expired, throw error of unloaded modules.
674
+ err = makeError('timeout', 'Load timeout for modules: ' + noLoads, null, noLoads);
675
+ err.contextName = context.contextName;
676
+ return onError(err);
677
+ }
678
+
679
+ //Not expired, check for a cycle.
680
+ if (needCycleCheck) {
681
+ each(reqCalls, function (mod) {
682
+ breakCycle(mod, {}, {});
683
+ });
684
+ }
685
+
686
+ //If still waiting on loads, and the waiting load is something
687
+ //other than a plugin resource, or there are still outstanding
688
+ //scripts, then just try back later.
689
+ if ((!expired || usingPathFallback) && stillLoading) {
690
+ //Something is still waiting to load. Wait for it, but only
691
+ //if a timeout is not already in effect.
692
+ if ((isBrowser || isWebWorker) && !checkLoadedTimeoutId) {
693
+ checkLoadedTimeoutId = setTimeout(function () {
694
+ checkLoadedTimeoutId = 0;
695
+ checkLoaded();
696
+ }, 50);
697
+ }
698
+ }
699
+
700
+ inCheckLoaded = false;
701
+ }
702
+
703
+ Module = function (map) {
704
+ this.events = getOwn(undefEvents, map.id) || {};
705
+ this.map = map;
706
+ this.shim = getOwn(config.shim, map.id);
707
+ this.depExports = [];
708
+ this.depMaps = [];
709
+ this.depMatched = [];
710
+ this.pluginMaps = {};
711
+ this.depCount = 0;
712
+
713
+ /* this.exports this.factory
714
+ this.depMaps = [],
715
+ this.enabled, this.fetched
716
+ */
717
+ };
718
+
719
+ Module.prototype = {
720
+ init: function (depMaps, factory, errback, options) {
721
+ options = options || {};
722
+
723
+ //Do not do more inits if already done. Can happen if there
724
+ //are multiple define calls for the same module. That is not
725
+ //a normal, common case, but it is also not unexpected.
726
+ if (this.inited) {
727
+ return;
728
+ }
729
+
730
+ this.factory = factory;
731
+
732
+ if (errback) {
733
+ //Register for errors on this module.
734
+ this.on('error', errback);
735
+ } else if (this.events.error) {
736
+ //If no errback already, but there are error listeners
737
+ //on this module, set up an errback to pass to the deps.
738
+ errback = bind(this, function (err) {
739
+ this.emit('error', err);
740
+ });
741
+ }
742
+
743
+ //Do a copy of the dependency array, so that
744
+ //source inputs are not modified. For example
745
+ //"shim" deps are passed in here directly, and
746
+ //doing a direct modification of the depMaps array
747
+ //would affect that config.
748
+ this.depMaps = depMaps && depMaps.slice(0);
749
+
750
+ this.errback = errback;
751
+
752
+ //Indicate this module has be initialized
753
+ this.inited = true;
754
+
755
+ this.ignore = options.ignore;
756
+
757
+ //Could have option to init this module in enabled mode,
758
+ //or could have been previously marked as enabled. However,
759
+ //the dependencies are not known until init is called. So
760
+ //if enabled previously, now trigger dependencies as enabled.
761
+ if (options.enabled || this.enabled) {
762
+ //Enable this module and dependencies.
763
+ //Will call this.check()
764
+ this.enable();
765
+ } else {
766
+ this.check();
767
+ }
768
+ },
769
+
770
+ defineDep: function (i, depExports) {
771
+ //Because of cycles, defined callback for a given
772
+ //export can be called more than once.
773
+ if (!this.depMatched[i]) {
774
+ this.depMatched[i] = true;
775
+ this.depCount -= 1;
776
+ this.depExports[i] = depExports;
777
+ }
778
+ },
779
+
780
+ fetch: function () {
781
+ if (this.fetched) {
782
+ return;
783
+ }
784
+ this.fetched = true;
785
+
786
+ context.startTime = (new Date()).getTime();
787
+
788
+ var map = this.map;
789
+
790
+ //If the manager is for a plugin managed resource,
791
+ //ask the plugin to load it now.
792
+ if (this.shim) {
793
+ context.makeRequire(this.map, {
794
+ enableBuildCallback: true
795
+ })(this.shim.deps || [], bind(this, function () {
796
+ return map.prefix ? this.callPlugin() : this.load();
797
+ }));
798
+ } else {
799
+ //Regular dependency.
800
+ return map.prefix ? this.callPlugin() : this.load();
801
+ }
802
+ },
803
+
804
+ load: function () {
805
+ var url = this.map.url;
806
+
807
+ //Regular dependency.
808
+ if (!urlFetched[url]) {
809
+ urlFetched[url] = true;
810
+ context.load(this.map.id, url);
811
+ }
812
+ },
813
+
814
+ /**
815
+ * Checks if the module is ready to define itself, and if so,
816
+ * define it.
817
+ */
818
+ check: function () {
819
+ if (!this.enabled || this.enabling) {
820
+ return;
821
+ }
822
+
823
+ var err, cjsModule,
824
+ id = this.map.id,
825
+ depExports = this.depExports,
826
+ exports = this.exports,
827
+ factory = this.factory;
828
+
829
+ if (!this.inited) {
830
+ this.fetch();
831
+ } else if (this.error) {
832
+ this.emit('error', this.error);
833
+ } else if (!this.defining) {
834
+ //The factory could trigger another require call
835
+ //that would result in checking this module to
836
+ //define itself again. If already in the process
837
+ //of doing that, skip this work.
838
+ this.defining = true;
839
+
840
+ if (this.depCount < 1 && !this.defined) {
841
+ if (isFunction(factory)) {
842
+ //If there is an error listener, favor passing
843
+ //to that instead of throwing an error.
844
+ if (this.events.error) {
845
+ try {
846
+ exports = context.execCb(id, factory, depExports, exports);
847
+ } catch (e) {
848
+ err = e;
849
+ }
850
+ } else {
851
+ exports = context.execCb(id, factory, depExports, exports);
852
+ }
853
+
854
+ if (this.map.isDefine) {
855
+ //If setting exports via 'module' is in play,
856
+ //favor that over return value and exports. After that,
857
+ //favor a non-undefined return value over exports use.
858
+ cjsModule = this.module;
859
+ if (cjsModule &&
860
+ cjsModule.exports !== undefined &&
861
+ //Make sure it is not already the exports value
862
+ cjsModule.exports !== this.exports) {
863
+ exports = cjsModule.exports;
864
+ } else if (exports === undefined && this.usingExports) {
865
+ //exports already set the defined value.
866
+ exports = this.exports;
867
+ }
868
+ }
869
+
870
+ if (err) {
871
+ err.requireMap = this.map;
872
+ err.requireModules = [this.map.id];
873
+ err.requireType = 'define';
874
+ return onError((this.error = err));
875
+ }
876
+
877
+ } else {
878
+ //Just a literal value
879
+ exports = factory;
880
+ }
881
+
882
+ this.exports = exports;
883
+
884
+ if (this.map.isDefine && !this.ignore) {
885
+ defined[id] = exports;
886
+
887
+ if (req.onResourceLoad) {
888
+ req.onResourceLoad(context, this.map, this.depMaps);
889
+ }
890
+ }
891
+
892
+ //Clean up
893
+ cleanRegistry(id);
894
+
895
+ this.defined = true;
896
+ }
897
+
898
+ //Finished the define stage. Allow calling check again
899
+ //to allow define notifications below in the case of a
900
+ //cycle.
901
+ this.defining = false;
902
+
903
+ if (this.defined && !this.defineEmitted) {
904
+ this.defineEmitted = true;
905
+ this.emit('defined', this.exports);
906
+ this.defineEmitComplete = true;
907
+ }
908
+
909
+ }
910
+ },
911
+
912
+ callPlugin: function () {
913
+ var map = this.map,
914
+ id = map.id,
915
+ //Map already normalized the prefix.
916
+ pluginMap = makeModuleMap(map.prefix);
917
+
918
+ //Mark this as a dependency for this plugin, so it
919
+ //can be traced for cycles.
920
+ this.depMaps.push(pluginMap);
921
+
922
+ on(pluginMap, 'defined', bind(this, function (plugin) {
923
+ var load, normalizedMap, normalizedMod,
924
+ name = this.map.name,
925
+ parentName = this.map.parentMap ? this.map.parentMap.name : null,
926
+ localRequire = context.makeRequire(map.parentMap, {
927
+ enableBuildCallback: true
928
+ });
929
+
930
+ //If current map is not normalized, wait for that
931
+ //normalized name to load instead of continuing.
932
+ if (this.map.unnormalized) {
933
+ //Normalize the ID if the plugin allows it.
934
+ if (plugin.normalize) {
935
+ name = plugin.normalize(name, function (name) {
936
+ return normalize(name, parentName, true);
937
+ }) || '';
938
+ }
939
+
940
+ //prefix and name should already be normalized, no need
941
+ //for applying map config again either.
942
+ normalizedMap = makeModuleMap(map.prefix + '!' + name,
943
+ this.map.parentMap);
944
+ on(normalizedMap,
945
+ 'defined', bind(this, function (value) {
946
+ this.init([], function () { return value; }, null, {
947
+ enabled: true,
948
+ ignore: true
949
+ });
950
+ }));
951
+
952
+ normalizedMod = getOwn(registry, normalizedMap.id);
953
+ if (normalizedMod) {
954
+ //Mark this as a dependency for this plugin, so it
955
+ //can be traced for cycles.
956
+ this.depMaps.push(normalizedMap);
957
+
958
+ if (this.events.error) {
959
+ normalizedMod.on('error', bind(this, function (err) {
960
+ this.emit('error', err);
961
+ }));
962
+ }
963
+ normalizedMod.enable();
964
+ }
965
+
966
+ return;
967
+ }
968
+
969
+ load = bind(this, function (value) {
970
+ this.init([], function () { return value; }, null, {
971
+ enabled: true
972
+ });
973
+ });
974
+
975
+ load.error = bind(this, function (err) {
976
+ this.inited = true;
977
+ this.error = err;
978
+ err.requireModules = [id];
979
+
980
+ //Remove temp unnormalized modules for this module,
981
+ //since they will never be resolved otherwise now.
982
+ eachProp(registry, function (mod) {
983
+ if (mod.map.id.indexOf(id + '_unnormalized') === 0) {
984
+ cleanRegistry(mod.map.id);
985
+ }
986
+ });
987
+
988
+ onError(err);
989
+ });
990
+
991
+ //Allow plugins to load other code without having to know the
992
+ //context or how to 'complete' the load.
993
+ load.fromText = bind(this, function (text, textAlt) {
994
+ /*jslint evil: true */
995
+ var moduleName = map.name,
996
+ moduleMap = makeModuleMap(moduleName),
997
+ hasInteractive = useInteractive;
998
+
999
+ //As of 2.1.0, support just passing the text, to reinforce
1000
+ //fromText only being called once per resource. Still
1001
+ //support old style of passing moduleName but discard
1002
+ //that moduleName in favor of the internal ref.
1003
+ if (textAlt) {
1004
+ text = textAlt;
1005
+ }
1006
+
1007
+ //Turn off interactive script matching for IE for any define
1008
+ //calls in the text, then turn it back on at the end.
1009
+ if (hasInteractive) {
1010
+ useInteractive = false;
1011
+ }
1012
+
1013
+ //Prime the system by creating a module instance for
1014
+ //it.
1015
+ getModule(moduleMap);
1016
+
1017
+ //Transfer any config to this other module.
1018
+ if (hasProp(config.config, id)) {
1019
+ config.config[moduleName] = config.config[id];
1020
+ }
1021
+
1022
+ try {
1023
+ req.exec(text);
1024
+ } catch (e) {
1025
+ return onError(makeError('fromtexteval',
1026
+ 'fromText eval for ' + id +
1027
+ ' failed: ' + e,
1028
+ e,
1029
+ [id]));
1030
+ }
1031
+
1032
+ if (hasInteractive) {
1033
+ useInteractive = true;
1034
+ }
1035
+
1036
+ //Mark this as a dependency for the plugin
1037
+ //resource
1038
+ this.depMaps.push(moduleMap);
1039
+
1040
+ //Support anonymous modules.
1041
+ context.completeLoad(moduleName);
1042
+
1043
+ //Bind the value of that module to the value for this
1044
+ //resource ID.
1045
+ localRequire([moduleName], load);
1046
+ });
1047
+
1048
+ //Use parentName here since the plugin's name is not reliable,
1049
+ //could be some weird string with no path that actually wants to
1050
+ //reference the parentName's path.
1051
+ plugin.load(map.name, localRequire, load, config);
1052
+ }));
1053
+
1054
+ context.enable(pluginMap, this);
1055
+ this.pluginMaps[pluginMap.id] = pluginMap;
1056
+ },
1057
+
1058
+ enable: function () {
1059
+ enabledRegistry[this.map.id] = this;
1060
+ this.enabled = true;
1061
+
1062
+ //Set flag mentioning that the module is enabling,
1063
+ //so that immediate calls to the defined callbacks
1064
+ //for dependencies do not trigger inadvertent load
1065
+ //with the depCount still being zero.
1066
+ this.enabling = true;
1067
+
1068
+ //Enable each dependency
1069
+ each(this.depMaps, bind(this, function (depMap, i) {
1070
+ var id, mod, handler;
1071
+
1072
+ if (typeof depMap === 'string') {
1073
+ //Dependency needs to be converted to a depMap
1074
+ //and wired up to this module.
1075
+ depMap = makeModuleMap(depMap,
1076
+ (this.map.isDefine ? this.map : this.map.parentMap),
1077
+ false,
1078
+ !this.skipMap);
1079
+ this.depMaps[i] = depMap;
1080
+
1081
+ handler = getOwn(handlers, depMap.id);
1082
+
1083
+ if (handler) {
1084
+ this.depExports[i] = handler(this);
1085
+ return;
1086
+ }
1087
+
1088
+ this.depCount += 1;
1089
+
1090
+ on(depMap, 'defined', bind(this, function (depExports) {
1091
+ this.defineDep(i, depExports);
1092
+ this.check();
1093
+ }));
1094
+
1095
+ if (this.errback) {
1096
+ on(depMap, 'error', this.errback);
1097
+ }
1098
+ }
1099
+
1100
+ id = depMap.id;
1101
+ mod = registry[id];
1102
+
1103
+ //Skip special modules like 'require', 'exports', 'module'
1104
+ //Also, don't call enable if it is already enabled,
1105
+ //important in circular dependency cases.
1106
+ if (!hasProp(handlers, id) && mod && !mod.enabled) {
1107
+ context.enable(depMap, this);
1108
+ }
1109
+ }));
1110
+
1111
+ //Enable each plugin that is used in
1112
+ //a dependency
1113
+ eachProp(this.pluginMaps, bind(this, function (pluginMap) {
1114
+ var mod = getOwn(registry, pluginMap.id);
1115
+ if (mod && !mod.enabled) {
1116
+ context.enable(pluginMap, this);
1117
+ }
1118
+ }));
1119
+
1120
+ this.enabling = false;
1121
+
1122
+ this.check();
1123
+ },
1124
+
1125
+ on: function (name, cb) {
1126
+ var cbs = this.events[name];
1127
+ if (!cbs) {
1128
+ cbs = this.events[name] = [];
1129
+ }
1130
+ cbs.push(cb);
1131
+ },
1132
+
1133
+ emit: function (name, evt) {
1134
+ each(this.events[name], function (cb) {
1135
+ cb(evt);
1136
+ });
1137
+ if (name === 'error') {
1138
+ //Now that the error handler was triggered, remove
1139
+ //the listeners, since this broken Module instance
1140
+ //can stay around for a while in the registry.
1141
+ delete this.events[name];
1142
+ }
1143
+ }
1144
+ };
1145
+
1146
+ function callGetModule(args) {
1147
+ //Skip modules already defined.
1148
+ if (!hasProp(defined, args[0])) {
1149
+ getModule(makeModuleMap(args[0], null, true)).init(args[1], args[2]);
1150
+ }
1151
+ }
1152
+
1153
+ function removeListener(node, func, name, ieName) {
1154
+ //Favor detachEvent because of IE9
1155
+ //issue, see attachEvent/addEventListener comment elsewhere
1156
+ //in this file.
1157
+ if (node.detachEvent && !isOpera) {
1158
+ //Probably IE. If not it will throw an error, which will be
1159
+ //useful to know.
1160
+ if (ieName) {
1161
+ node.detachEvent(ieName, func);
1162
+ }
1163
+ } else {
1164
+ node.removeEventListener(name, func, false);
1165
+ }
1166
+ }
1167
+
1168
+ /**
1169
+ * Given an event from a script node, get the requirejs info from it,
1170
+ * and then removes the event listeners on the node.
1171
+ * @param {Event} evt
1172
+ * @returns {Object}
1173
+ */
1174
+ function getScriptData(evt) {
1175
+ //Using currentTarget instead of target for Firefox 2.0's sake. Not
1176
+ //all old browsers will be supported, but this one was easy enough
1177
+ //to support and still makes sense.
1178
+ var node = evt.currentTarget || evt.srcElement;
1179
+
1180
+ //Remove the listeners once here.
1181
+ removeListener(node, context.onScriptLoad, 'load', 'onreadystatechange');
1182
+ removeListener(node, context.onScriptError, 'error');
1183
+
1184
+ return {
1185
+ node: node,
1186
+ id: node && node.getAttribute('data-requiremodule')
1187
+ };
1188
+ }
1189
+
1190
+ function intakeDefines() {
1191
+ var args;
1192
+
1193
+ //Any defined modules in the global queue, intake them now.
1194
+ takeGlobalQueue();
1195
+
1196
+ //Make sure any remaining defQueue items get properly processed.
1197
+ while (defQueue.length) {
1198
+ args = defQueue.shift();
1199
+ if (args[0] === null) {
1200
+ return onError(makeError('mismatch', 'Mismatched anonymous define() module: ' + args[args.length - 1]));
1201
+ } else {
1202
+ //args are id, deps, factory. Should be normalized by the
1203
+ //define() function.
1204
+ callGetModule(args);
1205
+ }
1206
+ }
1207
+ }
1208
+
1209
+ context = {
1210
+ config: config,
1211
+ contextName: contextName,
1212
+ registry: registry,
1213
+ defined: defined,
1214
+ urlFetched: urlFetched,
1215
+ defQueue: defQueue,
1216
+ Module: Module,
1217
+ makeModuleMap: makeModuleMap,
1218
+ nextTick: req.nextTick,
1219
+ onError: onError,
1220
+
1221
+ /**
1222
+ * Set a configuration for the context.
1223
+ * @param {Object} cfg config object to integrate.
1224
+ */
1225
+ configure: function (cfg) {
1226
+ //Make sure the baseUrl ends in a slash.
1227
+ if (cfg.baseUrl) {
1228
+ if (cfg.baseUrl.charAt(cfg.baseUrl.length - 1) !== '/') {
1229
+ cfg.baseUrl += '/';
1230
+ }
1231
+ }
1232
+
1233
+ //Save off the paths and packages since they require special processing,
1234
+ //they are additive.
1235
+ var pkgs = config.pkgs,
1236
+ shim = config.shim,
1237
+ objs = {
1238
+ paths: true,
1239
+ config: true,
1240
+ map: true
1241
+ };
1242
+
1243
+ eachProp(cfg, function (value, prop) {
1244
+ if (objs[prop]) {
1245
+ if (prop === 'map') {
1246
+ if (!config.map) {
1247
+ config.map = {};
1248
+ }
1249
+ mixin(config[prop], value, true, true);
1250
+ } else {
1251
+ mixin(config[prop], value, true);
1252
+ }
1253
+ } else {
1254
+ config[prop] = value;
1255
+ }
1256
+ });
1257
+
1258
+ //Merge shim
1259
+ if (cfg.shim) {
1260
+ eachProp(cfg.shim, function (value, id) {
1261
+ //Normalize the structure
1262
+ if (isArray(value)) {
1263
+ value = {
1264
+ deps: value
1265
+ };
1266
+ }
1267
+ if ((value.exports || value.init) && !value.exportsFn) {
1268
+ value.exportsFn = context.makeShimExports(value);
1269
+ }
1270
+ shim[id] = value;
1271
+ });
1272
+ config.shim = shim;
1273
+ }
1274
+
1275
+ //Adjust packages if necessary.
1276
+ if (cfg.packages) {
1277
+ each(cfg.packages, function (pkgObj) {
1278
+ var location;
1279
+
1280
+ pkgObj = typeof pkgObj === 'string' ? { name: pkgObj } : pkgObj;
1281
+ location = pkgObj.location;
1282
+
1283
+ //Create a brand new object on pkgs, since currentPackages can
1284
+ //be passed in again, and config.pkgs is the internal transformed
1285
+ //state for all package configs.
1286
+ pkgs[pkgObj.name] = {
1287
+ name: pkgObj.name,
1288
+ location: location || pkgObj.name,
1289
+ //Remove leading dot in main, so main paths are normalized,
1290
+ //and remove any trailing .js, since different package
1291
+ //envs have different conventions: some use a module name,
1292
+ //some use a file name.
1293
+ main: (pkgObj.main || 'main')
1294
+ .replace(currDirRegExp, '')
1295
+ .replace(jsSuffixRegExp, '')
1296
+ };
1297
+ });
1298
+
1299
+ //Done with modifications, assing packages back to context config
1300
+ config.pkgs = pkgs;
1301
+ }
1302
+
1303
+ //If there are any "waiting to execute" modules in the registry,
1304
+ //update the maps for them, since their info, like URLs to load,
1305
+ //may have changed.
1306
+ eachProp(registry, function (mod, id) {
1307
+ //If module already has init called, since it is too
1308
+ //late to modify them, and ignore unnormalized ones
1309
+ //since they are transient.
1310
+ if (!mod.inited && !mod.map.unnormalized) {
1311
+ mod.map = makeModuleMap(id);
1312
+ }
1313
+ });
1314
+
1315
+ //If a deps array or a config callback is specified, then call
1316
+ //require with those args. This is useful when require is defined as a
1317
+ //config object before require.js is loaded.
1318
+ if (cfg.deps || cfg.callback) {
1319
+ context.require(cfg.deps || [], cfg.callback);
1320
+ }
1321
+ },
1322
+
1323
+ makeShimExports: function (value) {
1324
+ function fn() {
1325
+ var ret;
1326
+ if (value.init) {
1327
+ ret = value.init.apply(global, arguments);
1328
+ }
1329
+ return ret || (value.exports && getGlobal(value.exports));
1330
+ }
1331
+ return fn;
1332
+ },
1333
+
1334
+ makeRequire: function (relMap, options) {
1335
+ options = options || {};
1336
+
1337
+ function localRequire(deps, callback, errback) {
1338
+ var id, map, requireMod;
1339
+
1340
+ if (options.enableBuildCallback && callback && isFunction(callback)) {
1341
+ callback.__requireJsBuild = true;
1342
+ }
1343
+
1344
+ if (typeof deps === 'string') {
1345
+ if (isFunction(callback)) {
1346
+ //Invalid call
1347
+ return onError(makeError('requireargs', 'Invalid require call'), errback);
1348
+ }
1349
+
1350
+ //If require|exports|module are requested, get the
1351
+ //value for them from the special handlers. Caveat:
1352
+ //this only works while module is being defined.
1353
+ if (relMap && hasProp(handlers, deps)) {
1354
+ return handlers[deps](registry[relMap.id]);
1355
+ }
1356
+
1357
+ //Synchronous access to one module. If require.get is
1358
+ //available (as in the Node adapter), prefer that.
1359
+ if (req.get) {
1360
+ return req.get(context, deps, relMap, localRequire);
1361
+ }
1362
+
1363
+ //Normalize module name, if it contains . or ..
1364
+ map = makeModuleMap(deps, relMap, false, true);
1365
+ id = map.id;
1366
+
1367
+ if (!hasProp(defined, id)) {
1368
+ return onError(makeError('notloaded', 'Module name "' +
1369
+ id +
1370
+ '" has not been loaded yet for context: ' +
1371
+ contextName +
1372
+ (relMap ? '' : '. Use require([])')));
1373
+ }
1374
+ return defined[id];
1375
+ }
1376
+
1377
+ //Grab defines waiting in the global queue.
1378
+ intakeDefines();
1379
+
1380
+ //Mark all the dependencies as needing to be loaded.
1381
+ context.nextTick(function () {
1382
+ //Some defines could have been added since the
1383
+ //require call, collect them.
1384
+ intakeDefines();
1385
+
1386
+ requireMod = getModule(makeModuleMap(null, relMap));
1387
+
1388
+ //Store if map config should be applied to this require
1389
+ //call for dependencies.
1390
+ requireMod.skipMap = options.skipMap;
1391
+
1392
+ requireMod.init(deps, callback, errback, {
1393
+ enabled: true
1394
+ });
1395
+
1396
+ checkLoaded();
1397
+ });
1398
+
1399
+ return localRequire;
1400
+ }
1401
+
1402
+ mixin(localRequire, {
1403
+ isBrowser: isBrowser,
1404
+
1405
+ /**
1406
+ * Converts a module name + .extension into an URL path.
1407
+ * *Requires* the use of a module name. It does not support using
1408
+ * plain URLs like nameToUrl.
1409
+ */
1410
+ toUrl: function (moduleNamePlusExt) {
1411
+ var ext,
1412
+ index = moduleNamePlusExt.lastIndexOf('.'),
1413
+ segment = moduleNamePlusExt.split('/')[0],
1414
+ isRelative = segment === '.' || segment === '..';
1415
+
1416
+ //Have a file extension alias, and it is not the
1417
+ //dots from a relative path.
1418
+ if (index !== -1 && (!isRelative || index > 1)) {
1419
+ ext = moduleNamePlusExt.substring(index, moduleNamePlusExt.length);
1420
+ moduleNamePlusExt = moduleNamePlusExt.substring(0, index);
1421
+ }
1422
+
1423
+ return context.nameToUrl(normalize(moduleNamePlusExt,
1424
+ relMap && relMap.id, true), ext, true);
1425
+ },
1426
+
1427
+ defined: function (id) {
1428
+ return hasProp(defined, makeModuleMap(id, relMap, false, true).id);
1429
+ },
1430
+
1431
+ specified: function (id) {
1432
+ id = makeModuleMap(id, relMap, false, true).id;
1433
+ return hasProp(defined, id) || hasProp(registry, id);
1434
+ }
1435
+ });
1436
+
1437
+ //Only allow undef on top level require calls
1438
+ if (!relMap) {
1439
+ localRequire.undef = function (id) {
1440
+ //Bind any waiting define() calls to this context,
1441
+ //fix for #408
1442
+ takeGlobalQueue();
1443
+
1444
+ var map = makeModuleMap(id, relMap, true),
1445
+ mod = getOwn(registry, id);
1446
+
1447
+ delete defined[id];
1448
+ delete urlFetched[map.url];
1449
+ delete undefEvents[id];
1450
+
1451
+ if (mod) {
1452
+ //Hold on to listeners in case the
1453
+ //module will be attempted to be reloaded
1454
+ //using a different config.
1455
+ if (mod.events.defined) {
1456
+ undefEvents[id] = mod.events;
1457
+ }
1458
+
1459
+ cleanRegistry(id);
1460
+ }
1461
+ };
1462
+ }
1463
+
1464
+ return localRequire;
1465
+ },
1466
+
1467
+ /**
1468
+ * Called to enable a module if it is still in the registry
1469
+ * awaiting enablement. A second arg, parent, the parent module,
1470
+ * is passed in for context, when this method is overriden by
1471
+ * the optimizer. Not shown here to keep code compact.
1472
+ */
1473
+ enable: function (depMap) {
1474
+ var mod = getOwn(registry, depMap.id);
1475
+ if (mod) {
1476
+ getModule(depMap).enable();
1477
+ }
1478
+ },
1479
+
1480
+ /**
1481
+ * Internal method used by environment adapters to complete a load event.
1482
+ * A load event could be a script load or just a load pass from a synchronous
1483
+ * load call.
1484
+ * @param {String} moduleName the name of the module to potentially complete.
1485
+ */
1486
+ completeLoad: function (moduleName) {
1487
+ var found, args, mod,
1488
+ shim = getOwn(config.shim, moduleName) || {},
1489
+ shExports = shim.exports;
1490
+
1491
+ takeGlobalQueue();
1492
+
1493
+ while (defQueue.length) {
1494
+ args = defQueue.shift();
1495
+ if (args[0] === null) {
1496
+ args[0] = moduleName;
1497
+ //If already found an anonymous module and bound it
1498
+ //to this name, then this is some other anon module
1499
+ //waiting for its completeLoad to fire.
1500
+ if (found) {
1501
+ break;
1502
+ }
1503
+ found = true;
1504
+ } else if (args[0] === moduleName) {
1505
+ //Found matching define call for this script!
1506
+ found = true;
1507
+ }
1508
+
1509
+ callGetModule(args);
1510
+ }
1511
+
1512
+ //Do this after the cycle of callGetModule in case the result
1513
+ //of those calls/init calls changes the registry.
1514
+ mod = getOwn(registry, moduleName);
1515
+
1516
+ if (!found && !hasProp(defined, moduleName) && mod && !mod.inited) {
1517
+ if (config.enforceDefine && (!shExports || !getGlobal(shExports))) {
1518
+ if (hasPathFallback(moduleName)) {
1519
+ return;
1520
+ } else {
1521
+ return onError(makeError('nodefine',
1522
+ 'No define call for ' + moduleName,
1523
+ null,
1524
+ [moduleName]));
1525
+ }
1526
+ } else {
1527
+ //A script that does not call define(), so just simulate
1528
+ //the call for it.
1529
+ callGetModule([moduleName, (shim.deps || []), shim.exportsFn]);
1530
+ }
1531
+ }
1532
+
1533
+ checkLoaded();
1534
+ },
1535
+
1536
+ /**
1537
+ * Converts a module name to a file path. Supports cases where
1538
+ * moduleName may actually be just an URL.
1539
+ * Note that it **does not** call normalize on the moduleName,
1540
+ * it is assumed to have already been normalized. This is an
1541
+ * internal API, not a public one. Use toUrl for the public API.
1542
+ */
1543
+ nameToUrl: function (moduleName, ext, skipExt) {
1544
+ var paths, pkgs, pkg, pkgPath, syms, i, parentModule, url,
1545
+ parentPath;
1546
+
1547
+ //If a colon is in the URL, it indicates a protocol is used and it is just
1548
+ //an URL to a file, or if it starts with a slash, contains a query arg (i.e. ?)
1549
+ //or ends with .js, then assume the user meant to use an url and not a module id.
1550
+ //The slash is important for protocol-less URLs as well as full paths.
1551
+ if (req.jsExtRegExp.test(moduleName)) {
1552
+ //Just a plain path, not module name lookup, so just return it.
1553
+ //Add extension if it is included. This is a bit wonky, only non-.js things pass
1554
+ //an extension, this method probably needs to be reworked.
1555
+ url = moduleName + (ext || '');
1556
+ } else {
1557
+ //A module that needs to be converted to a path.
1558
+ paths = config.paths;
1559
+ pkgs = config.pkgs;
1560
+
1561
+ syms = moduleName.split('/');
1562
+ //For each module name segment, see if there is a path
1563
+ //registered for it. Start with most specific name
1564
+ //and work up from it.
1565
+ for (i = syms.length; i > 0; i -= 1) {
1566
+ parentModule = syms.slice(0, i).join('/');
1567
+ pkg = getOwn(pkgs, parentModule);
1568
+ parentPath = getOwn(paths, parentModule);
1569
+ if (parentPath) {
1570
+ //If an array, it means there are a few choices,
1571
+ //Choose the one that is desired
1572
+ if (isArray(parentPath)) {
1573
+ parentPath = parentPath[0];
1574
+ }
1575
+ syms.splice(0, i, parentPath);
1576
+ break;
1577
+ } else if (pkg) {
1578
+ //If module name is just the package name, then looking
1579
+ //for the main module.
1580
+ if (moduleName === pkg.name) {
1581
+ pkgPath = pkg.location + '/' + pkg.main;
1582
+ } else {
1583
+ pkgPath = pkg.location;
1584
+ }
1585
+ syms.splice(0, i, pkgPath);
1586
+ break;
1587
+ }
1588
+ }
1589
+
1590
+ //Join the path parts together, then figure out if baseUrl is needed.
1591
+ url = syms.join('/');
1592
+ url += (ext || (/\?/.test(url) || skipExt ? '' : '.js'));
1593
+ url = (url.charAt(0) === '/' || url.match(/^[\w\+\.\-]+:/) ? '' : config.baseUrl) + url;
1594
+ }
1595
+
1596
+ return config.urlArgs ? url +
1597
+ ((url.indexOf('?') === -1 ? '?' : '&') +
1598
+ config.urlArgs) : url;
1599
+ },
1600
+
1601
+ //Delegates to req.load. Broken out as a separate function to
1602
+ //allow overriding in the optimizer.
1603
+ load: function (id, url) {
1604
+ req.load(context, id, url);
1605
+ },
1606
+
1607
+ /**
1608
+ * Executes a module callack function. Broken out as a separate function
1609
+ * solely to allow the build system to sequence the files in the built
1610
+ * layer in the right sequence.
1611
+ *
1612
+ * @private
1613
+ */
1614
+ execCb: function (name, callback, args, exports) {
1615
+ return callback.apply(exports, args);
1616
+ },
1617
+
1618
+ /**
1619
+ * callback for script loads, used to check status of loading.
1620
+ *
1621
+ * @param {Event} evt the event from the browser for the script
1622
+ * that was loaded.
1623
+ */
1624
+ onScriptLoad: function (evt) {
1625
+ //Using currentTarget instead of target for Firefox 2.0's sake. Not
1626
+ //all old browsers will be supported, but this one was easy enough
1627
+ //to support and still makes sense.
1628
+ if (evt.type === 'load' ||
1629
+ (readyRegExp.test((evt.currentTarget || evt.srcElement).readyState))) {
1630
+ //Reset interactive script so a script node is not held onto for
1631
+ //to long.
1632
+ interactiveScript = null;
1633
+
1634
+ //Pull out the name of the module and the context.
1635
+ var data = getScriptData(evt);
1636
+ context.completeLoad(data.id);
1637
+ }
1638
+ },
1639
+
1640
+ /**
1641
+ * Callback for script errors.
1642
+ */
1643
+ onScriptError: function (evt) {
1644
+ var data = getScriptData(evt);
1645
+ if (!hasPathFallback(data.id)) {
1646
+ return onError(makeError('scripterror', 'Script error', evt, [data.id]));
1647
+ }
1648
+ }
1649
+ };
1650
+
1651
+ context.require = context.makeRequire();
1652
+ return context;
1653
+ }
1654
+
1655
+ /**
1656
+ * Main entry point.
1657
+ *
1658
+ * If the only argument to require is a string, then the module that
1659
+ * is represented by that string is fetched for the appropriate context.
1660
+ *
1661
+ * If the first argument is an array, then it will be treated as an array
1662
+ * of dependency string names to fetch. An optional function callback can
1663
+ * be specified to execute when all of those dependencies are available.
1664
+ *
1665
+ * Make a local req variable to help Caja compliance (it assumes things
1666
+ * on a require that are not standardized), and to give a short
1667
+ * name for minification/local scope use.
1668
+ */
1669
+ req = requirejs = function (deps, callback, errback, optional) {
1670
+
1671
+ //Find the right context, use default
1672
+ var context, config,
1673
+ contextName = defContextName;
1674
+
1675
+ // Determine if have config object in the call.
1676
+ if (!isArray(deps) && typeof deps !== 'string') {
1677
+ // deps is a config object
1678
+ config = deps;
1679
+ if (isArray(callback)) {
1680
+ // Adjust args if there are dependencies
1681
+ deps = callback;
1682
+ callback = errback;
1683
+ errback = optional;
1684
+ } else {
1685
+ deps = [];
1686
+ }
1687
+ }
1688
+
1689
+ if (config && config.context) {
1690
+ contextName = config.context;
1691
+ }
1692
+
1693
+ context = getOwn(contexts, contextName);
1694
+ if (!context) {
1695
+ context = contexts[contextName] = req.s.newContext(contextName);
1696
+ }
1697
+
1698
+ if (config) {
1699
+ context.configure(config);
1700
+ }
1701
+
1702
+ return context.require(deps, callback, errback);
1703
+ };
1704
+
1705
+ /**
1706
+ * Support require.config() to make it easier to cooperate with other
1707
+ * AMD loaders on globally agreed names.
1708
+ */
1709
+ req.config = function (config) {
1710
+ return req(config);
1711
+ };
1712
+
1713
+ /**
1714
+ * Execute something after the current tick
1715
+ * of the event loop. Override for other envs
1716
+ * that have a better solution than setTimeout.
1717
+ * @param {Function} fn function to execute later.
1718
+ */
1719
+ req.nextTick = typeof setTimeout !== 'undefined' ? function (fn) {
1720
+ setTimeout(fn, 4);
1721
+ } : function (fn) { fn(); };
1722
+
1723
+ /**
1724
+ * Export require as a global, but only if it does not already exist.
1725
+ */
1726
+ if (!require) {
1727
+ require = req;
1728
+ }
1729
+
1730
+ req.version = version;
1731
+
1732
+ //Used to filter out dependencies that are already paths.
1733
+ req.jsExtRegExp = /^\/|:|\?|\.js$/;
1734
+ req.isBrowser = isBrowser;
1735
+ s = req.s = {
1736
+ contexts: contexts,
1737
+ newContext: newContext
1738
+ };
1739
+
1740
+ //Create default context.
1741
+ req({});
1742
+
1743
+ //Exports some context-sensitive methods on global require.
1744
+ each([
1745
+ 'toUrl',
1746
+ 'undef',
1747
+ 'defined',
1748
+ 'specified'
1749
+ ], function (prop) {
1750
+ //Reference from contexts instead of early binding to default context,
1751
+ //so that during builds, the latest instance of the default context
1752
+ //with its config gets used.
1753
+ req[prop] = function () {
1754
+ var ctx = contexts[defContextName];
1755
+ return ctx.require[prop].apply(ctx, arguments);
1756
+ };
1757
+ });
1758
+
1759
+ if (isBrowser) {
1760
+ head = s.head = document.getElementsByTagName('head')[0];
1761
+ //If BASE tag is in play, using appendChild is a problem for IE6.
1762
+ //When that browser dies, this can be removed. Details in this jQuery bug:
1763
+ //http://dev.jquery.com/ticket/2709
1764
+ baseElement = document.getElementsByTagName('base')[0];
1765
+ if (baseElement) {
1766
+ head = s.head = baseElement.parentNode;
1767
+ }
1768
+ }
1769
+
1770
+ /**
1771
+ * Any errors that require explicitly generates will be passed to this
1772
+ * function. Intercept/override it if you want custom error handling.
1773
+ * @param {Error} err the error object.
1774
+ */
1775
+ req.onError = function (err) {
1776
+ throw err;
1777
+ };
1778
+
1779
+ /**
1780
+ * Does the request to load a module for the browser case.
1781
+ * Make this a separate function to allow other environments
1782
+ * to override it.
1783
+ *
1784
+ * @param {Object} context the require context to find state.
1785
+ * @param {String} moduleName the name of the module.
1786
+ * @param {Object} url the URL to the module.
1787
+ */
1788
+ req.load = function (context, moduleName, url) {
1789
+ var config = (context && context.config) || {},
1790
+ node;
1791
+ if (isBrowser) {
1792
+ //In the browser so use a script tag
1793
+ node = config.xhtml ?
1794
+ document.createElementNS('http://www.w3.org/1999/xhtml', 'html:script') :
1795
+ document.createElement('script');
1796
+ node.type = config.scriptType || 'text/javascript';
1797
+ node.charset = 'utf-8';
1798
+ node.async = true;
1799
+
1800
+ node.setAttribute('data-requirecontext', context.contextName);
1801
+ node.setAttribute('data-requiremodule', moduleName);
1802
+
1803
+ //Set up load listener. Test attachEvent first because IE9 has
1804
+ //a subtle issue in its addEventListener and script onload firings
1805
+ //that do not match the behavior of all other browsers with
1806
+ //addEventListener support, which fire the onload event for a
1807
+ //script right after the script execution. See:
1808
+ //https://connect.microsoft.com/IE/feedback/details/648057/script-onload-event-is-not-fired-immediately-after-script-execution
1809
+ //UNFORTUNATELY Opera implements attachEvent but does not follow the script
1810
+ //script execution mode.
1811
+ if (node.attachEvent &&
1812
+ //Check if node.attachEvent is artificially added by custom script or
1813
+ //natively supported by browser
1814
+ //read https://github.com/jrburke/requirejs/issues/187
1815
+ //if we can NOT find [native code] then it must NOT natively supported.
1816
+ //in IE8, node.attachEvent does not have toString()
1817
+ //Note the test for "[native code" with no closing brace, see:
1818
+ //https://github.com/jrburke/requirejs/issues/273
1819
+ !(node.attachEvent.toString && node.attachEvent.toString().indexOf('[native code') < 0) &&
1820
+ !isOpera) {
1821
+ //Probably IE. IE (at least 6-8) do not fire
1822
+ //script onload right after executing the script, so
1823
+ //we cannot tie the anonymous define call to a name.
1824
+ //However, IE reports the script as being in 'interactive'
1825
+ //readyState at the time of the define call.
1826
+ useInteractive = true;
1827
+
1828
+ node.attachEvent('onreadystatechange', context.onScriptLoad);
1829
+ //It would be great to add an error handler here to catch
1830
+ //404s in IE9+. However, onreadystatechange will fire before
1831
+ //the error handler, so that does not help. If addEventListener
1832
+ //is used, then IE will fire error before load, but we cannot
1833
+ //use that pathway given the connect.microsoft.com issue
1834
+ //mentioned above about not doing the 'script execute,
1835
+ //then fire the script load event listener before execute
1836
+ //next script' that other browsers do.
1837
+ //Best hope: IE10 fixes the issues,
1838
+ //and then destroys all installs of IE 6-9.
1839
+ //node.attachEvent('onerror', context.onScriptError);
1840
+ } else {
1841
+ node.addEventListener('load', context.onScriptLoad, false);
1842
+ node.addEventListener('error', context.onScriptError, false);
1843
+ }
1844
+ node.src = url;
1845
+
1846
+ //For some cache cases in IE 6-8, the script executes before the end
1847
+ //of the appendChild execution, so to tie an anonymous define
1848
+ //call to the module name (which is stored on the node), hold on
1849
+ //to a reference to this node, but clear after the DOM insertion.
1850
+ currentlyAddingScript = node;
1851
+ if (baseElement) {
1852
+ head.insertBefore(node, baseElement);
1853
+ } else {
1854
+ head.appendChild(node);
1855
+ }
1856
+ currentlyAddingScript = null;
1857
+
1858
+ return node;
1859
+ } else if (isWebWorker) {
1860
+ try {
1861
+ //In a web worker, use importScripts. This is not a very
1862
+ //efficient use of importScripts, importScripts will block until
1863
+ //its script is downloaded and evaluated. However, if web workers
1864
+ //are in play, the expectation that a build has been done so that
1865
+ //only one script needs to be loaded anyway. This may need to be
1866
+ //reevaluated if other use cases become common.
1867
+ importScripts(url);
1868
+
1869
+ //Account for anonymous modules
1870
+ context.completeLoad(moduleName);
1871
+ } catch (e) {
1872
+ context.onError(makeError('importscripts',
1873
+ 'importScripts failed for ' +
1874
+ moduleName + ' at ' + url,
1875
+ e,
1876
+ [moduleName]));
1877
+ }
1878
+ }
1879
+ };
1880
+
1881
+ function getInteractiveScript() {
1882
+ if (interactiveScript && interactiveScript.readyState === 'interactive') {
1883
+ return interactiveScript;
1884
+ }
1885
+
1886
+ eachReverse(scripts(), function (script) {
1887
+ if (script.readyState === 'interactive') {
1888
+ return (interactiveScript = script);
1889
+ }
1890
+ });
1891
+ return interactiveScript;
1892
+ }
1893
+
1894
+ //Look for a data-main script attribute, which could also adjust the baseUrl.
1895
+ if (isBrowser) {
1896
+ //Figure out baseUrl. Get it from the script tag with require.js in it.
1897
+ eachReverse(scripts(), function (script) {
1898
+ //Set the 'head' where we can append children by
1899
+ //using the script's parent.
1900
+ if (!head) {
1901
+ head = script.parentNode;
1902
+ }
1903
+
1904
+ //Look for a data-main attribute to set main script for the page
1905
+ //to load. If it is there, the path to data main becomes the
1906
+ //baseUrl, if it is not already set.
1907
+ dataMain = script.getAttribute('data-main');
1908
+ if (dataMain) {
1909
+ //Set final baseUrl if there is not already an explicit one.
1910
+ if (!cfg.baseUrl) {
1911
+ //Pull off the directory of data-main for use as the
1912
+ //baseUrl.
1913
+ src = dataMain.split('/');
1914
+ mainScript = src.pop();
1915
+ subPath = src.length ? src.join('/') + '/' : './';
1916
+
1917
+ cfg.baseUrl = subPath;
1918
+ dataMain = mainScript;
1919
+ }
1920
+
1921
+ //Strip off any trailing .js since dataMain is now
1922
+ //like a module name.
1923
+ dataMain = dataMain.replace(jsSuffixRegExp, '');
1924
+
1925
+ //Put the data-main script in the files to load.
1926
+ cfg.deps = cfg.deps ? cfg.deps.concat(dataMain) : [dataMain];
1927
+
1928
+ return true;
1929
+ }
1930
+ });
1931
+ }
1932
+
1933
+ /**
1934
+ * The function that handles definitions of modules. Differs from
1935
+ * require() in that a string for the module should be the first argument,
1936
+ * and the function to execute after dependencies are loaded should
1937
+ * return a value to define the module corresponding to the first argument's
1938
+ * name.
1939
+ */
1940
+ define = function (name, deps, callback) {
1941
+ var node, context;
1942
+
1943
+ //Allow for anonymous modules
1944
+ if (typeof name !== 'string') {
1945
+ //Adjust args appropriately
1946
+ callback = deps;
1947
+ deps = name;
1948
+ name = null;
1949
+ }
1950
+
1951
+ //This module may not have dependencies
1952
+ if (!isArray(deps)) {
1953
+ callback = deps;
1954
+ deps = [];
1955
+ }
1956
+
1957
+ //If no name, and callback is a function, then figure out if it a
1958
+ //CommonJS thing with dependencies.
1959
+ if (!deps.length && isFunction(callback)) {
1960
+ //Remove comments from the callback string,
1961
+ //look for require calls, and pull them into the dependencies,
1962
+ //but only if there are function args.
1963
+ if (callback.length) {
1964
+ callback
1965
+ .toString()
1966
+ .replace(commentRegExp, '')
1967
+ .replace(cjsRequireRegExp, function (match, dep) {
1968
+ deps.push(dep);
1969
+ });
1970
+
1971
+ //May be a CommonJS thing even without require calls, but still
1972
+ //could use exports, and module. Avoid doing exports and module
1973
+ //work though if it just needs require.
1974
+ //REQUIRES the function to expect the CommonJS variables in the
1975
+ //order listed below.
1976
+ deps = (callback.length === 1 ? ['require'] : ['require', 'exports', 'module']).concat(deps);
1977
+ }
1978
+ }
1979
+
1980
+ //If in IE 6-8 and hit an anonymous define() call, do the interactive
1981
+ //work.
1982
+ if (useInteractive) {
1983
+ node = currentlyAddingScript || getInteractiveScript();
1984
+ if (node) {
1985
+ if (!name) {
1986
+ name = node.getAttribute('data-requiremodule');
1987
+ }
1988
+ context = contexts[node.getAttribute('data-requirecontext')];
1989
+ }
1990
+ }
1991
+
1992
+ //Always save off evaluating the def call until the script onload handler.
1993
+ //This allows multiple modules to be in a file without prematurely
1994
+ //tracing dependencies, and allows for anonymous module support,
1995
+ //where the module name is not known until the script onload event
1996
+ //occurs. If no context, use the global queue, and get it processed
1997
+ //in the onscript load callback.
1998
+ (context ? context.defQueue : globalDefQueue).push([name, deps, callback]);
1999
+ };
2000
+
2001
+ define.amd = {
2002
+ jQuery: true
2003
+ };
2004
+
2005
+
2006
+ /**
2007
+ * Executes the text. Normally just uses eval, but can be modified
2008
+ * to use a better, environment-specific call. Only used for transpiling
2009
+ * loader plugins, not for plain JS modules.
2010
+ * @param {String} text the text to execute/evaluate.
2011
+ */
2012
+ req.exec = function (text) {
2013
+ /*jslint evil: true */
2014
+ return eval(text);
2015
+ };
2016
+
2017
+ //Set up with config info.
2018
+ req(cfg);
2019
+ }(this));