| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313 | 
							- <!DOCTYPE html>
 
- <html>
 
- <head>
 
-   <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 
-   <title>The source code</title>
 
-   <link href="../resources/prettify/prettify.css" type="text/css" rel="stylesheet" />
 
-   <script type="text/javascript" src="../resources/prettify/prettify.js"></script>
 
-   <style type="text/css">
 
-     .highlight { display: block; background-color: #ddd; }
 
-   </style>
 
-   <script type="text/javascript">
 
-     function highlight() {
 
-       document.getElementById(location.hash.replace(/#/, "")).className = "highlight";
 
-     }
 
-   </script>
 
- </head>
 
- <body onload="prettyPrint(); highlight();">
 
-   <pre class="prettyprint lang-js"><span id='Ext'>/**
 
- </span> * @class Ext
 
-  *
 
-  * The Ext namespace (global object) encapsulates all classes, singletons, and
 
-  * utility methods provided by Sencha's libraries.
 
-  *
 
-  * Most user interface Components are at a lower level of nesting in the namespace,
 
-  * but many common utility functions are provided as direct properties of the Ext namespace.
 
-  *
 
-  * Also many frequently used methods from other classes are provided as shortcuts
 
-  * within the Ext namespace. For example {@link Ext#getCmp Ext.getCmp} aliases
 
-  * {@link Ext.ComponentManager#get Ext.ComponentManager.get}.
 
-  *
 
-  * Many applications are initiated with {@link Ext#onReady Ext.onReady} which is
 
-  * called once the DOM is ready. This ensures all scripts have been loaded,
 
-  * preventing dependency issues. For example:
 
-  *
 
-  *     Ext.onReady(function(){
 
-  *         new Ext.Component({
 
-  *             renderTo: document.body,
 
-  *             html: 'DOM ready!'
 
-  *         });
 
-  *     });
 
-  *
 
-  * For more information about how to use the Ext classes, see:
 
-  *
 
-  * - <a href="http://www.sencha.com/learn/">The Learning Center</a>
 
-  * - <a href="http://www.sencha.com/learn/Ext_FAQ">The FAQ</a>
 
-  * - <a href="http://www.sencha.com/forum/">The forums</a>
 
-  *
 
-  * @singleton
 
-  */
 
- Ext.apply(Ext, {
 
-     userAgent: navigator.userAgent.toLowerCase(),
 
-     cache: {},
 
-     idSeed: 1000,
 
-     windowId: 'ext-window',
 
-     documentId: 'ext-document',
 
- <span id='Ext-property-isReady'>    /**
 
- </span>     * True when the document is fully initialized and ready for action
 
-      */
 
-     isReady: false,
 
- <span id='Ext-property-enableGarbageCollector'>    /**
 
- </span>     * True to automatically uncache orphaned Ext.Elements periodically
 
-      */
 
-     enableGarbageCollector: true,
 
- <span id='Ext-property-enableListenerCollection'>    /**
 
- </span>     * True to automatically purge event listeners during garbageCollection.
 
-      */
 
-     enableListenerCollection: true,
 
-     addCacheEntry: function(id, el, dom) {
 
-         dom = dom || el.dom;
 
-         //<debug>
 
-         if (!dom) {
 
-             // Without the DOM node we can't GC the entry
 
-             Ext.Error.raise('Cannot add an entry to the element cache without the DOM node');
 
-         }
 
-         //</debug>
 
-         var key = id || (el && el.id) || dom.id,
 
-             entry = Ext.cache[key] || (Ext.cache[key] = {
 
-                 data: {},
 
-                 events: {},
 
-                 dom: dom,
 
-                 // Skip garbage collection for special elements (window, document, iframes)
 
-                 skipGarbageCollection: !!(dom.getElementById || dom.navigator)
 
-             });
 
-         if (el) {
 
-             el.$cache = entry;
 
-             // Inject the back link from the cache in case the cache entry
 
-             // had already been created by Ext.fly. Ext.fly creates a cache entry with no el link.
 
-             entry.el = el;
 
-         }
 
-         return entry;
 
-     },
 
-     
 
-     updateCacheEntry: function(cacheItem, dom){
 
-         cacheItem.dom = dom;
 
-         if (cacheItem.el) {
 
-             cacheItem.el.dom = dom;
 
-         }
 
-         return cacheItem;
 
-     },
 
- <span id='Ext-method-id'>    /**
 
- </span>     * Generates unique ids. If the element already has an id, it is unchanged
 
-      * @param {HTMLElement/Ext.Element} [el] The element to generate an id for
 
-      * @param {String} prefix (optional) Id prefix (defaults "ext-gen")
 
-      * @return {String} The generated Id.
 
-      */
 
-     id: function(el, prefix) {
 
-         var me = this,
 
-             sandboxPrefix = '';
 
-         el = Ext.getDom(el, true) || {};
 
-         if (el === document) {
 
-             el.id = me.documentId;
 
-         }
 
-         else if (el === window) {
 
-             el.id = me.windowId;
 
-         }
 
-         if (!el.id) {
 
-             if (me.isSandboxed) {
 
-                 sandboxPrefix = Ext.sandboxName.toLowerCase() + '-';
 
-             }
 
-             el.id = sandboxPrefix + (prefix || "ext-gen") + (++Ext.idSeed);
 
-         }
 
-         return el.id;
 
-     },
 
-     escapeId: (function(){
 
-         var validIdRe = /^[a-zA-Z_][a-zA-Z0-9_\-]*$/i,
 
-             escapeRx = /([\W]{1})/g,
 
-             leadingNumRx = /^(\d)/g,
 
-             escapeFn = function(match, capture){
 
-                 return "\\" + capture;
 
-             },
 
-             numEscapeFn = function(match, capture){
 
-                 return '\\00' + capture.charCodeAt(0).toString(16) + ' ';
 
-             };
 
-         return function(id) {
 
-             return validIdRe.test(id)
 
-                 ? id
 
-                 // replace the number portion last to keep the trailing ' '
 
-                 // from being escaped
 
-                 : id.replace(escapeRx, escapeFn)
 
-                     .replace(leadingNumRx, numEscapeFn);
 
-         };
 
-     }()),
 
- <span id='Ext-method-getBody'>    /**
 
- </span>     * Returns the current document body as an {@link Ext.Element}.
 
-      * @return Ext.Element The document body
 
-      */
 
-     getBody: (function() {
 
-         var body;
 
-         return function() {
 
-             return body || (body = Ext.get(document.body));
 
-         };
 
-     }()),
 
- <span id='Ext-method-getHead'>    /**
 
- </span>     * Returns the current document head as an {@link Ext.Element}.
 
-      * @return Ext.Element The document head
 
-      * @method
 
-      */
 
-     getHead: (function() {
 
-         var head;
 
-         return function() {
 
-             return head || (head = Ext.get(document.getElementsByTagName("head")[0]));
 
-         };
 
-     }()),
 
- <span id='Ext-method-getDoc'>    /**
 
- </span>     * Returns the current HTML document object as an {@link Ext.Element}.
 
-      * @return Ext.Element The document
 
-      */
 
-     getDoc: (function() {
 
-         var doc;
 
-         return function() {
 
-             return doc || (doc = Ext.get(document));
 
-         };
 
-     }()),
 
- <span id='Ext-method-getCmp'>    /**
 
- </span>     * This is shorthand reference to {@link Ext.ComponentManager#get}.
 
-      * Looks up an existing {@link Ext.Component Component} by {@link Ext.Component#id id}
 
-      *
 
-      * @param {String} id The component {@link Ext.Component#id id}
 
-      * @return Ext.Component The Component, `undefined` if not found, or `null` if a
 
-      * Class was found.
 
-     */
 
-     getCmp: function(id) {
 
-         return Ext.ComponentManager.get(id);
 
-     },
 
- <span id='Ext-method-getOrientation'>    /**
 
- </span>     * Returns the current orientation of the mobile device
 
-      * @return {String} Either 'portrait' or 'landscape'
 
-      */
 
-     getOrientation: function() {
 
-         return window.innerHeight > window.innerWidth ? 'portrait' : 'landscape';
 
-     },
 
- <span id='Ext-method-destroy'>    /**
 
- </span>     * Attempts to destroy any objects passed to it by removing all event listeners, removing them from the
 
-      * DOM (if applicable) and calling their destroy functions (if available).  This method is primarily
 
-      * intended for arguments of type {@link Ext.Element} and {@link Ext.Component}, but any subclass of
 
-      * {@link Ext.util.Observable} can be passed in.  Any number of elements and/or components can be
 
-      * passed into this function in a single call as separate arguments.
 
-      *
 
-      * @param {Ext.Element/Ext.Component/Ext.Element[]/Ext.Component[]...} args
 
-      * An {@link Ext.Element}, {@link Ext.Component}, or an Array of either of these to destroy
 
-      */
 
-     destroy: function() {
 
-         var ln = arguments.length,
 
-         i, arg;
 
-         for (i = 0; i < ln; i++) {
 
-             arg = arguments[i];
 
-             if (arg) {
 
-                 if (Ext.isArray(arg)) {
 
-                     this.destroy.apply(this, arg);
 
-                 }
 
-                 else if (Ext.isFunction(arg.destroy)) {
 
-                     arg.destroy();
 
-                 }
 
-                 else if (arg.dom) {
 
-                     arg.remove();
 
-                 }
 
-             }
 
-         }
 
-     },
 
- <span id='Ext-method-callback'>    /**
 
- </span>     * Execute a callback function in a particular scope. If no function is passed the call is ignored.
 
-      *
 
-      * For example, these lines are equivalent:
 
-      *
 
-      *     Ext.callback(myFunc, this, [arg1, arg2]);
 
-      *     Ext.isFunction(myFunc) && myFunc.apply(this, [arg1, arg2]);
 
-      *
 
-      * @param {Function} callback The callback to execute
 
-      * @param {Object} [scope] The scope to execute in
 
-      * @param {Array} [args] The arguments to pass to the function
 
-      * @param {Number} [delay] Pass a number to delay the call by a number of milliseconds.
 
-      */
 
-     callback: function(callback, scope, args, delay){
 
-         if(Ext.isFunction(callback)){
 
-             args = args || [];
 
-             scope = scope || window;
 
-             if (delay) {
 
-                 Ext.defer(callback, delay, scope, args);
 
-             } else {
 
-                 callback.apply(scope, args);
 
-             }
 
-         }
 
-     },
 
- <span id='global-method-htmlEncode'>    /**
 
- </span>     * Alias for {@link Ext.String#htmlEncode}.
 
-      * @inheritdoc Ext.String#htmlEncode
 
-      * @ignore
 
-      */
 
-     htmlEncode : function(value) {
 
-         return Ext.String.htmlEncode(value);
 
-     },
 
- <span id='global-method-htmlDecode'>    /**
 
- </span>     * Alias for {@link Ext.String#htmlDecode}.
 
-      * @inheritdoc Ext.String#htmlDecode
 
-      * @ignore
 
-      */
 
-     htmlDecode : function(value) {
 
-          return Ext.String.htmlDecode(value);
 
-     },
 
- <span id='global-method-urlAppend'>    /**
 
- </span>     * Alias for {@link Ext.String#urlAppend}.
 
-      * @inheritdoc Ext.String#urlAppend
 
-      * @ignore
 
-      */
 
-     urlAppend : function(url, s) {
 
-         return Ext.String.urlAppend(url, s);
 
-     }
 
- });
 
- Ext.ns = Ext.namespace;
 
- // for old browsers
 
- window.undefined = window.undefined;
 
- <span id='Ext'>/**
 
- </span> * @class Ext
 
-  */
 
- (function(){
 
- /*
 
- FF 3.6      - Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.2.17) Gecko/20110420 Firefox/3.6.17
 
- FF 4.0.1    - Mozilla/5.0 (Windows NT 5.1; rv:2.0.1) Gecko/20100101 Firefox/4.0.1
 
- FF 5.0      - Mozilla/5.0 (Windows NT 6.1; WOW64; rv:5.0) Gecko/20100101 Firefox/5.0
 
- IE6         - Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1;)
 
- IE7         - Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; SV1;)
 
- IE8         - Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0)
 
- IE9         - Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0C; .NET4.0E)
 
- Chrome 11   - Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/534.24 (KHTML, like Gecko) Chrome/11.0.696.60 Safari/534.24
 
- Safari 5    - Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US) AppleWebKit/533.21.1 (KHTML, like Gecko) Version/5.0.5 Safari/533.21.1
 
- Opera 11.11 - Opera/9.80 (Windows NT 6.1; U; en) Presto/2.8.131 Version/11.11
 
- */
 
-     var check = function(regex){
 
-             return regex.test(Ext.userAgent);
 
-         },
 
-         isStrict = document.compatMode == "CSS1Compat",
 
-         version = function (is, regex) {
 
-             var m;
 
-             return (is && (m = regex.exec(Ext.userAgent))) ? parseFloat(m[1]) : 0;
 
-         },
 
-         docMode = document.documentMode,
 
-         isOpera = check(/opera/),
 
-         isOpera10_5 = isOpera && check(/version\/10\.5/),
 
-         isChrome = check(/\bchrome\b/),
 
-         isWebKit = check(/webkit/),
 
-         isSafari = !isChrome && check(/safari/),
 
-         isSafari2 = isSafari && check(/applewebkit\/4/), // unique to Safari 2
 
-         isSafari3 = isSafari && check(/version\/3/),
 
-         isSafari4 = isSafari && check(/version\/4/),
 
-         isSafari5_0 = isSafari && check(/version\/5\.0/),
 
-         isSafari5 = isSafari && check(/version\/5/),
 
-         isIE = !isOpera && check(/msie/),
 
-         isIE7 = isIE && ((check(/msie 7/) && docMode != 8 && docMode != 9) || docMode == 7),
 
-         isIE8 = isIE && ((check(/msie 8/) && docMode != 7 && docMode != 9) || docMode == 8),
 
-         isIE9 = isIE && ((check(/msie 9/) && docMode != 7 && docMode != 8) || docMode == 9),
 
-         isIE6 = isIE && check(/msie 6/),
 
-         isGecko = !isWebKit && check(/gecko/),
 
-         isGecko3 = isGecko && check(/rv:1\.9/),
 
-         isGecko4 = isGecko && check(/rv:2\.0/),
 
-         isGecko5 = isGecko && check(/rv:5\./),
 
-         isGecko10 = isGecko && check(/rv:10\./),
 
-         isFF3_0 = isGecko3 && check(/rv:1\.9\.0/),
 
-         isFF3_5 = isGecko3 && check(/rv:1\.9\.1/),
 
-         isFF3_6 = isGecko3 && check(/rv:1\.9\.2/),
 
-         isWindows = check(/windows|win32/),
 
-         isMac = check(/macintosh|mac os x/),
 
-         isLinux = check(/linux/),
 
-         scrollbarSize = null,
 
-         chromeVersion = version(true, /\bchrome\/(\d+\.\d+)/),
 
-         firefoxVersion = version(true, /\bfirefox\/(\d+\.\d+)/),
 
-         ieVersion = version(isIE, /msie (\d+\.\d+)/),
 
-         operaVersion = version(isOpera, /version\/(\d+\.\d+)/),
 
-         safariVersion = version(isSafari, /version\/(\d+\.\d+)/),
 
-         webKitVersion = version(isWebKit, /webkit\/(\d+\.\d+)/),
 
-         isSecure = /^https/i.test(window.location.protocol),
 
-         nullLog;
 
-     // remove css image flicker
 
-     try {
 
-         document.execCommand("BackgroundImageCache", false, true);
 
-     } catch(e) {}
 
-     //<debug>
 
-     var primitiveRe = /string|number|boolean/;
 
-     function dumpObject (object) {
 
-         var member, type, value, name,
 
-             members = [];
 
-         // Cannot use Ext.encode since it can recurse endlessly (if we're lucky)
 
-         // ...and the data could be prettier!
 
-         for (name in object) {
 
-             if (object.hasOwnProperty(name)) {
 
-                 value = object[name];
 
-                 type = typeof value;
 
-                 if (type == "function") {
 
-                     continue;
 
-                 }
 
-                 if (type == 'undefined') {
 
-                     member = type;
 
-                 } else if (value === null || primitiveRe.test(type) || Ext.isDate(value)) {
 
-                     member = Ext.encode(value);
 
-                 } else if (Ext.isArray(value)) {
 
-                     member = '[ ]';
 
-                 } else if (Ext.isObject(value)) {
 
-                     member = '{ }';
 
-                 } else {
 
-                     member = type;
 
-                 }
 
-                 members.push(Ext.encode(name) + ': ' + member);
 
-             }
 
-         }
 
-         if (members.length) {
 
-             return ' \nData: {\n  ' + members.join(',\n  ') + '\n}';
 
-         }
 
-         return '';
 
-     }
 
-     function log (message) {
 
-         var options, dump,
 
-             con = Ext.global.console,
 
-             level = 'log',
 
-             indent = log.indent || 0,
 
-             stack,
 
-             out,
 
-             max;
 
-         log.indent = indent;
 
-         if (typeof message != 'string') {
 
-             options = message;
 
-             message = options.msg || '';
 
-             level = options.level || level;
 
-             dump = options.dump;
 
-             stack = options.stack;
 
-             if (options.indent) {
 
-                 ++log.indent;
 
-             } else if (options.outdent) {
 
-                 log.indent = indent = Math.max(indent - 1, 0);
 
-             }
 
-             if (dump && !(con && con.dir)) {
 
-                 message += dumpObject(dump);
 
-                 dump = null;
 
-             }
 
-         }
 
-         if (arguments.length > 1) {
 
-             message += Array.prototype.slice.call(arguments, 1).join('');
 
-         }
 
-         message = indent ? Ext.String.repeat(' ', log.indentSize * indent) + message : message;
 
-         // w/o console, all messages are equal, so munge the level into the message:
 
-         if (level != 'log') {
 
-             message = '[' + level.charAt(0).toUpperCase() + '] ' + message;
 
-         }
 
-         // Not obvious, but 'console' comes and goes when Firebug is turned on/off, so
 
-         // an early test may fail either direction if Firebug is toggled.
 
-         //
 
-         if (con) { // if (Firebug-like console)
 
-             if (con[level]) {
 
-                 con[level](message);
 
-             } else {
 
-                 con.log(message);
 
-             }
 
-             if (dump) {
 
-                 con.dir(dump);
 
-             }
 
-             if (stack && con.trace) {
 
-                 // Firebug's console.error() includes a trace already...
 
-                 if (!con.firebug || level != 'error') {
 
-                     con.trace();
 
-                 }
 
-             }
 
-         } else {
 
-             if (Ext.isOpera) {
 
-                 opera.postError(message);
 
-             } else {
 
-                 out = log.out;
 
-                 max = log.max;
 
-                 if (out.length >= max) {
 
-                     // this formula allows out.max to change (via debugger), where the
 
-                     // more obvious "max/4" would not quite be the same
 
-                     Ext.Array.erase(out, 0, out.length - 3 * Math.floor(max / 4)); // keep newest 75%
 
-                 }
 
-                 out.push(message);
 
-             }
 
-         }
 
-         // Mostly informational, but the Ext.Error notifier uses them:
 
-         ++log.count;
 
-         ++log.counters[level];
 
-     }
 
-     function logx (level, args) {
 
-         if (typeof args[0] == 'string') {
 
-             args.unshift({});
 
-         }
 
-         args[0].level = level;
 
-         log.apply(this, args);
 
-     }
 
-     log.error = function () {
 
-         logx('error', Array.prototype.slice.call(arguments));
 
-     };
 
-     log.info = function () {
 
-         logx('info', Array.prototype.slice.call(arguments));
 
-     };
 
-     log.warn = function () {
 
-         logx('warn', Array.prototype.slice.call(arguments));
 
-     };
 
-     log.count = 0;
 
-     log.counters = { error: 0, warn: 0, info: 0, log: 0 };
 
-     log.indentSize = 2;
 
-     log.out = [];
 
-     log.max = 750;
 
-     log.show = function () {
 
-         window.open('','extlog').document.write([
 
-             '<html><head><script type="text/javascript">',
 
-                 'var lastCount = 0;',
 
-                 'function update () {',
 
-                     'var ext = window.opener.Ext,',
 
-                         'extlog = ext && ext.log;',
 
-                     'if (extlog && extlog.out && lastCount != extlog.count) {',
 
-                         'lastCount = extlog.count;',
 
-                         'var s = "<tt>" + extlog.out.join("~~~").replace(/[&]/g, "&amp;").replace(/[<]/g, "&lt;").replace(/[ ]/g, "&#160;").replace(/\\~\\~\\~/g, "<br/>") + "</tt>";',
 
-                         'document.body.innerHTML = s;',
 
-                     '}',
 
-                     'setTimeout(update, 1000);',
 
-                 '}',
 
-                 'setTimeout(update, 1000);',
 
-             '</script></head><body></body></html>'].join(''));
 
-     };
 
-     //</debug>
 
-     nullLog = function () {};
 
-     nullLog.info = nullLog.warn = nullLog.error = Ext.emptyFn;
 
-     Ext.setVersion('extjs', '4.1.1');
 
-     Ext.apply(Ext, {
 
- <span id='Ext-property-SSL_SECURE_URL'>        /**
 
- </span>         * @property {String} SSL_SECURE_URL
 
-          * URL to a blank file used by Ext when in secure mode for iframe src and onReady src
 
-          * to prevent the IE insecure content warning (`'about:blank'`, except for IE
 
-          * in secure mode, which is `'javascript:""'`).
 
-          */
 
-         SSL_SECURE_URL : isSecure && isIE ? 'javascript:\'\'' : 'about:blank',
 
- <span id='Ext-property-enableFx'>        /**
 
- </span>         * @property {Boolean} enableFx
 
-          * True if the {@link Ext.fx.Anim} Class is available.
 
-          */
 
- <span id='Ext-property-scopeResetCSS'>        /**
 
- </span>         * @property {Boolean} scopeResetCSS
 
-          * True to scope the reset CSS to be just applied to Ext components. Note that this
 
-          * wraps root containers with an additional element. Also remember that when you turn
 
-          * on this option, you have to use ext-all-scoped (unless you use the bootstrap.js to
 
-          * load your javascript, in which case it will be handled for you).
 
-          */
 
-         scopeResetCSS : Ext.buildSettings.scopeResetCSS,
 
-         
 
- <span id='Ext-property-resetCls'>        /**
 
- </span>         * @property {String} resetCls
 
-          * The css class used to wrap Ext components when the {@link #scopeResetCSS} option
 
-          * is used.
 
-          */
 
-         resetCls: Ext.buildSettings.baseCSSPrefix + 'reset',
 
- <span id='Ext-property-enableNestedListenerRemoval'>        /**
 
- </span>         * @property {Boolean} enableNestedListenerRemoval
 
-          * **Experimental.** True to cascade listener removal to child elements when an element
 
-          * is removed. Currently not optimized for performance.
 
-          */
 
-         enableNestedListenerRemoval : false,
 
- <span id='Ext-property-USE_NATIVE_JSON'>        /**
 
- </span>         * @property {Boolean} USE_NATIVE_JSON
 
-          * Indicates whether to use native browser parsing for JSON methods.
 
-          * This option is ignored if the browser does not support native JSON methods.
 
-          *
 
-          * **Note:** Native JSON methods will not work with objects that have functions.
 
-          * Also, property names must be quoted, otherwise the data will not parse.
 
-          */
 
-         USE_NATIVE_JSON : false,
 
- <span id='Ext-method-getDom'>        /**
 
- </span>         * Returns the dom node for the passed String (id), dom node, or Ext.Element.
 
-          * Optional 'strict' flag is needed for IE since it can return 'name' and
 
-          * 'id' elements by using getElementById.
 
-          *
 
-          * Here are some examples:
 
-          *
 
-          *     // gets dom node based on id
 
-          *     var elDom = Ext.getDom('elId');
 
-          *     // gets dom node based on the dom node
 
-          *     var elDom1 = Ext.getDom(elDom);
 
-          *
 
-          *     // If we don&#39;t know if we are working with an
 
-          *     // Ext.Element or a dom node use Ext.getDom
 
-          *     function(el){
 
-          *         var dom = Ext.getDom(el);
 
-          *         // do something with the dom node
 
-          *     }
 
-          *
 
-          * **Note:** the dom node to be found actually needs to exist (be rendered, etc)
 
-          * when this method is called to be successful.
 
-          *
 
-          * @param {String/HTMLElement/Ext.Element} el
 
-          * @return HTMLElement
 
-          */
 
-         getDom : function(el, strict) {
 
-             if (!el || !document) {
 
-                 return null;
 
-             }
 
-             if (el.dom) {
 
-                 return el.dom;
 
-             } else {
 
-                 if (typeof el == 'string') {
 
-                     var e = Ext.getElementById(el);
 
-                     // IE returns elements with the 'name' and 'id' attribute.
 
-                     // we do a strict check to return the element with only the id attribute
 
-                     if (e && isIE && strict) {
 
-                         if (el == e.getAttribute('id')) {
 
-                             return e;
 
-                         } else {
 
-                             return null;
 
-                         }
 
-                     }
 
-                     return e;
 
-                 } else {
 
-                     return el;
 
-                 }
 
-             }
 
-         },
 
- <span id='Ext-method-removeNode'>        /**
 
- </span>         * Removes a DOM node from the document.
 
-          *
 
-          * Removes this element from the document, removes all DOM event listeners, and
 
-          * deletes the cache reference. All DOM event listeners are removed from this element.
 
-          * If {@link Ext#enableNestedListenerRemoval Ext.enableNestedListenerRemoval} is
 
-          * `true`, then DOM event listeners are also removed from all child nodes.
 
-          * The body node will be ignored if passed in.
 
-          *
 
-          * @param {HTMLElement} node The node to remove
 
-          * @method
 
-          */
 
-         removeNode : isIE6 || isIE7 || isIE8
 
-             ? (function() {
 
-                 var d;
 
-                 return function(n){
 
-                     if(n && n.tagName.toUpperCase() != 'BODY'){
 
-                         (Ext.enableNestedListenerRemoval) ? Ext.EventManager.purgeElement(n) : Ext.EventManager.removeAll(n);
 
-                         var cache = Ext.cache,
 
-                             id = n.id;
 
-                         if (cache[id]) {
 
-                             delete cache[id].dom;
 
-                             delete cache[id];
 
-                         }
 
-                         if (isIE8 && n.parentNode) {
 
-                             n.parentNode.removeChild(n);
 
-                         }
 
-                         d = d || document.createElement('div');
 
-                         d.appendChild(n);
 
-                         d.innerHTML = '';
 
-                     }
 
-                 };
 
-             }())
 
-             : function(n) {
 
-                 if (n && n.parentNode && n.tagName.toUpperCase() != 'BODY') {
 
-                     (Ext.enableNestedListenerRemoval) ? Ext.EventManager.purgeElement(n) : Ext.EventManager.removeAll(n);
 
-                     var cache = Ext.cache,
 
-                         id = n.id;
 
-                     if (cache[id]) {
 
-                         delete cache[id].dom;
 
-                         delete cache[id];
 
-                     }
 
-                     n.parentNode.removeChild(n);
 
-                 }
 
-             },
 
-         isStrict: isStrict,
 
-         isIEQuirks: isIE && !isStrict,
 
- <span id='Ext-property-isOpera'>        /**
 
- </span>         * True if the detected browser is Opera.
 
-          * @type Boolean
 
-          */
 
-         isOpera : isOpera,
 
- <span id='Ext-property-isOpera10_5'>        /**
 
- </span>         * True if the detected browser is Opera 10.5x.
 
-          * @type Boolean
 
-          */
 
-         isOpera10_5 : isOpera10_5,
 
- <span id='Ext-property-isWebKit'>        /**
 
- </span>         * True if the detected browser uses WebKit.
 
-          * @type Boolean
 
-          */
 
-         isWebKit : isWebKit,
 
- <span id='Ext-property-isChrome'>        /**
 
- </span>         * True if the detected browser is Chrome.
 
-          * @type Boolean
 
-          */
 
-         isChrome : isChrome,
 
- <span id='Ext-property-isSafari'>        /**
 
- </span>         * True if the detected browser is Safari.
 
-          * @type Boolean
 
-          */
 
-         isSafari : isSafari,
 
- <span id='Ext-property-isSafari3'>        /**
 
- </span>         * True if the detected browser is Safari 3.x.
 
-          * @type Boolean
 
-          */
 
-         isSafari3 : isSafari3,
 
- <span id='Ext-property-isSafari4'>        /**
 
- </span>         * True if the detected browser is Safari 4.x.
 
-          * @type Boolean
 
-          */
 
-         isSafari4 : isSafari4,
 
- <span id='Ext-property-isSafari5'>        /**
 
- </span>         * True if the detected browser is Safari 5.x.
 
-          * @type Boolean
 
-          */
 
-         isSafari5 : isSafari5,
 
- <span id='Ext-property-isSafari5_0'>        /**
 
- </span>         * True if the detected browser is Safari 5.0.x.
 
-          * @type Boolean
 
-          */
 
-         isSafari5_0 : isSafari5_0,
 
- <span id='Ext-property-isSafari2'>        /**
 
- </span>         * True if the detected browser is Safari 2.x.
 
-          * @type Boolean
 
-          */
 
-         isSafari2 : isSafari2,
 
- <span id='Ext-property-isIE'>        /**
 
- </span>         * True if the detected browser is Internet Explorer.
 
-          * @type Boolean
 
-          */
 
-         isIE : isIE,
 
- <span id='Ext-property-isIE6'>        /**
 
- </span>         * True if the detected browser is Internet Explorer 6.x.
 
-          * @type Boolean
 
-          */
 
-         isIE6 : isIE6,
 
- <span id='Ext-property-isIE7'>        /**
 
- </span>         * True if the detected browser is Internet Explorer 7.x.
 
-          * @type Boolean
 
-          */
 
-         isIE7 : isIE7,
 
- <span id='Ext-property-isIE8'>        /**
 
- </span>         * True if the detected browser is Internet Explorer 8.x.
 
-          * @type Boolean
 
-          */
 
-         isIE8 : isIE8,
 
- <span id='Ext-property-isIE9'>        /**
 
- </span>         * True if the detected browser is Internet Explorer 9.x.
 
-          * @type Boolean
 
-          */
 
-         isIE9 : isIE9,
 
- <span id='Ext-property-isGecko'>        /**
 
- </span>         * True if the detected browser uses the Gecko layout engine (e.g. Mozilla, Firefox).
 
-          * @type Boolean
 
-          */
 
-         isGecko : isGecko,
 
- <span id='Ext-property-isGecko3'>        /**
 
- </span>         * True if the detected browser uses a Gecko 1.9+ layout engine (e.g. Firefox 3.x).
 
-          * @type Boolean
 
-          */
 
-         isGecko3 : isGecko3,
 
- <span id='Ext-property-isGecko4'>        /**
 
- </span>         * True if the detected browser uses a Gecko 2.0+ layout engine (e.g. Firefox 4.x).
 
-          * @type Boolean
 
-          */
 
-         isGecko4 : isGecko4,
 
- <span id='Ext-property-isGecko5'>        /**
 
- </span>         * True if the detected browser uses a Gecko 5.0+ layout engine (e.g. Firefox 5.x).
 
-          * @type Boolean
 
-          */
 
-         isGecko5 : isGecko5,
 
- <span id='Ext-property-isGecko10'>        /**
 
- </span>         * True if the detected browser uses a Gecko 5.0+ layout engine (e.g. Firefox 5.x).
 
-          * @type Boolean
 
-          */
 
-         isGecko10 : isGecko10,
 
- <span id='Ext-property-isFF3_0'>        /**
 
- </span>         * True if the detected browser uses FireFox 3.0
 
-          * @type Boolean
 
-          */
 
-         isFF3_0 : isFF3_0,
 
- <span id='Ext-property-isFF3_5'>        /**
 
- </span>         * True if the detected browser uses FireFox 3.5
 
-          * @type Boolean
 
-          */
 
-         isFF3_5 : isFF3_5,
 
- <span id='Ext-property-isFF3_6'>        /**
 
- </span>         * True if the detected browser uses FireFox 3.6
 
-          * @type Boolean
 
-          */
 
-         isFF3_6 : isFF3_6,
 
- <span id='Ext-property-isFF4'>        /**
 
- </span>         * True if the detected browser uses FireFox 4
 
-          * @type Boolean
 
-          */
 
-         isFF4 : 4 <= firefoxVersion && firefoxVersion < 5,
 
- <span id='Ext-property-isFF5'>        /**
 
- </span>         * True if the detected browser uses FireFox 5
 
-          * @type Boolean
 
-          */
 
-         isFF5 : 5 <= firefoxVersion && firefoxVersion < 6,
 
- <span id='Ext-property-isFF10'>        /**
 
- </span>         * True if the detected browser uses FireFox 10
 
-          * @type Boolean
 
-          */
 
-         isFF10 : 10 <= firefoxVersion && firefoxVersion < 11,
 
- <span id='Ext-property-isLinux'>        /**
 
- </span>         * True if the detected platform is Linux.
 
-          * @type Boolean
 
-          */
 
-         isLinux : isLinux,
 
- <span id='Ext-property-isWindows'>        /**
 
- </span>         * True if the detected platform is Windows.
 
-          * @type Boolean
 
-          */
 
-         isWindows : isWindows,
 
- <span id='Ext-property-isMac'>        /**
 
- </span>         * True if the detected platform is Mac OS.
 
-          * @type Boolean
 
-          */
 
-         isMac : isMac,
 
- <span id='Ext-property-chromeVersion'>        /**
 
- </span>         * The current version of Chrome (0 if the browser is not Chrome).
 
-          * @type Number
 
-          */
 
-         chromeVersion: chromeVersion,
 
- <span id='Ext-property-firefoxVersion'>        /**
 
- </span>         * The current version of Firefox (0 if the browser is not Firefox).
 
-          * @type Number
 
-          */
 
-         firefoxVersion: firefoxVersion,
 
- <span id='Ext-property-ieVersion'>        /**
 
- </span>         * The current version of IE (0 if the browser is not IE). This does not account
 
-          * for the documentMode of the current page, which is factored into {@link #isIE7},
 
-          * {@link #isIE8} and {@link #isIE9}. Thus this is not always true:
 
-          *
 
-          *     Ext.isIE8 == (Ext.ieVersion == 8)
 
-          *
 
-          * @type Number
 
-          */
 
-         ieVersion: ieVersion,
 
- <span id='Ext-property-operaVersion'>        /**
 
- </span>         * The current version of Opera (0 if the browser is not Opera).
 
-          * @type Number
 
-          */
 
-         operaVersion: operaVersion,
 
- <span id='Ext-property-safariVersion'>        /**
 
- </span>         * The current version of Safari (0 if the browser is not Safari).
 
-          * @type Number
 
-          */
 
-         safariVersion: safariVersion,
 
- <span id='Ext-property-webKitVersion'>        /**
 
- </span>         * The current version of WebKit (0 if the browser does not use WebKit).
 
-          * @type Number
 
-          */
 
-         webKitVersion: webKitVersion,
 
- <span id='Ext-property-isSecure'>        /**
 
- </span>         * True if the page is running over SSL
 
-          * @type Boolean
 
-          */
 
-         isSecure: isSecure,
 
-         
 
- <span id='Ext-property-BLANK_IMAGE_URL'>        /**
 
- </span>         * URL to a 1x1 transparent gif image used by Ext to create inline icons with
 
-          * CSS background images. In older versions of IE, this defaults to
 
-          * "http://sencha.com/s.gif" and you should change this to a URL on your server.
 
-          * For other browsers it uses an inline data URL.
 
-          * @type String
 
-          */
 
-         BLANK_IMAGE_URL : (isIE6 || isIE7) ? '/' + '/www.sencha.com/s.gif' : '',
 
- <span id='Ext-method-value'>        /**
 
- </span>         * Utility method for returning a default value if the passed value is empty.
 
-          *
 
-          * The value is deemed to be empty if it is:
 
-          *
 
-          * - null
 
-          * - undefined
 
-          * - an empty array
 
-          * - a zero length string (Unless the `allowBlank` parameter is `true`)
 
-          *
 
-          * @param {Object} value The value to test
 
-          * @param {Object} defaultValue The value to return if the original value is empty
 
-          * @param {Boolean} [allowBlank=false] true to allow zero length strings to qualify as non-empty.
 
-          * @return {Object} value, if non-empty, else defaultValue
 
-          * @deprecated 4.0.0 Use {@link Ext#valueFrom} instead
 
-          */
 
-         value : function(v, defaultValue, allowBlank){
 
-             return Ext.isEmpty(v, allowBlank) ? defaultValue : v;
 
-         },
 
- <span id='Ext-method-escapeRe'>        /**
 
- </span>         * Escapes the passed string for use in a regular expression.
 
-          * @param {String} str
 
-          * @return {String}
 
-          * @deprecated 4.0.0 Use {@link Ext.String#escapeRegex} instead
 
-          */
 
-         escapeRe : function(s) {
 
-             return s.replace(/([-.*+?\^${}()|\[\]\/\\])/g, "\\$1");
 
-         },
 
- <span id='Ext-method-addBehaviors'>        /**
 
- </span>         * Applies event listeners to elements by selectors when the document is ready.
 
-          * The event name is specified with an `@` suffix.
 
-          *
 
-          *     Ext.addBehaviors({
 
-          *         // add a listener for click on all anchors in element with id foo
 
-          *         '#foo a@click' : function(e, t){
 
-          *             // do something
 
-          *         },
 
-          *
 
-          *         // add the same listener to multiple selectors (separated by comma BEFORE the @)
 
-          *         '#foo a, #bar span.some-class@mouseover' : function(){
 
-          *             // do something
 
-          *         }
 
-          *     });
 
-          *
 
-          * @param {Object} obj The list of behaviors to apply
 
-          */
 
-         addBehaviors : function(o){
 
-             if(!Ext.isReady){
 
-                 Ext.onReady(function(){
 
-                     Ext.addBehaviors(o);
 
-                 });
 
-             } else {
 
-                 var cache = {}, // simple cache for applying multiple behaviors to same selector does query multiple times
 
-                     parts,
 
-                     b,
 
-                     s;
 
-                 for (b in o) {
 
-                     if ((parts = b.split('@'))[1]) { // for Object prototype breakers
 
-                         s = parts[0];
 
-                         if(!cache[s]){
 
-                             cache[s] = Ext.select(s);
 
-                         }
 
-                         cache[s].on(parts[1], o[b]);
 
-                     }
 
-                 }
 
-                 cache = null;
 
-             }
 
-         },
 
- <span id='Ext-method-getScrollbarSize'>        /**
 
- </span>         * Returns the size of the browser scrollbars. This can differ depending on
 
-          * operating system settings, such as the theme or font size.
 
-          * @param {Boolean} [force] true to force a recalculation of the value.
 
-          * @return {Object} An object containing scrollbar sizes.
 
-          * @return.width {Number} The width of the vertical scrollbar.
 
-          * @return.height {Number} The height of the horizontal scrollbar.
 
-          */
 
-         getScrollbarSize: function (force) {
 
-             if (!Ext.isReady) {
 
-                 return {};
 
-             }
 
-             if (force || !scrollbarSize) {
 
-                 var db = document.body,
 
-                     div = document.createElement('div');
 
-                 div.style.width = div.style.height = '100px';
 
-                 div.style.overflow = 'scroll';
 
-                 div.style.position = 'absolute';
 
-                 db.appendChild(div); // now we can measure the div...
 
-                 // at least in iE9 the div is not 100px - the scrollbar size is removed!
 
-                 scrollbarSize = {
 
-                     width: div.offsetWidth - div.clientWidth,
 
-                     height: div.offsetHeight - div.clientHeight
 
-                 };
 
-                 db.removeChild(div);
 
-             }
 
-             return scrollbarSize;
 
-         },
 
- <span id='Ext-method-getScrollBarWidth'>        /**
 
- </span>         * Utility method for getting the width of the browser's vertical scrollbar. This
 
-          * can differ depending on operating system settings, such as the theme or font size.
 
-          *
 
-          * This method is deprected in favor of {@link #getScrollbarSize}.
 
-          *
 
-          * @param {Boolean} [force] true to force a recalculation of the value.
 
-          * @return {Number} The width of a vertical scrollbar.
 
-          * @deprecated
 
-          */
 
-         getScrollBarWidth: function(force){
 
-             var size = Ext.getScrollbarSize(force);
 
-             return size.width + 2; // legacy fudge factor
 
-         },
 
- <span id='Ext-method-copyTo'>        /**
 
- </span>         * Copies a set of named properties fom the source object to the destination object.
 
-          *
 
-          * Example:
 
-          *
 
-          *     ImageComponent = Ext.extend(Ext.Component, {
 
-          *         initComponent: function() {
 
-          *             this.autoEl = { tag: 'img' };
 
-          *             MyComponent.superclass.initComponent.apply(this, arguments);
 
-          *             this.initialBox = Ext.copyTo({}, this.initialConfig, 'x,y,width,height');
 
-          *         }
 
-          *     });
 
-          *
 
-          * Important note: To borrow class prototype methods, use {@link Ext.Base#borrow} instead.
 
-          *
 
-          * @param {Object} dest The destination object.
 
-          * @param {Object} source The source object.
 
-          * @param {String/String[]} names Either an Array of property names, or a comma-delimited list
 
-          * of property names to copy.
 
-          * @param {Boolean} [usePrototypeKeys] Defaults to false. Pass true to copy keys off of the
 
-          * prototype as well as the instance.
 
-          * @return {Object} The modified object.
 
-          */
 
-         copyTo : function(dest, source, names, usePrototypeKeys){
 
-             if(typeof names == 'string'){
 
-                 names = names.split(/[,;\s]/);
 
-             }
 
-             var n,
 
-                 nLen = names.length,
 
-                 name;
 
-             for(n = 0; n < nLen; n++) {
 
-                 name = names[n];
 
-                 if(usePrototypeKeys || source.hasOwnProperty(name)){
 
-                     dest[name] = source[name];
 
-                 }
 
-             }
 
-             return dest;
 
-         },
 
- <span id='Ext-method-destroyMembers'>        /**
 
- </span>         * Attempts to destroy and then remove a set of named properties of the passed object.
 
-          * @param {Object} o The object (most likely a Component) who's properties you wish to destroy.
 
-          * @param {String...} args One or more names of the properties to destroy and remove from the object.
 
-          */
 
-         destroyMembers : function(o){
 
-             for (var i = 1, a = arguments, len = a.length; i < len; i++) {
 
-                 Ext.destroy(o[a[i]]);
 
-                 delete o[a[i]];
 
-             }
 
-         },
 
- <span id='Ext-method-log'>        /**
 
- </span>         * Logs a message. If a console is present it will be used. On Opera, the method
 
-          * "opera.postError" is called. In other cases, the message is logged to an array
 
-          * "Ext.log.out". An attached debugger can watch this array and view the log. The
 
-          * log buffer is limited to a maximum of "Ext.log.max" entries (defaults to 250).
 
-          * The `Ext.log.out` array can also be written to a popup window by entering the
 
-          * following in the URL bar (a "bookmarklet"):
 
-          *
 
-          *     javascript:void(Ext.log.show());
 
-          *
 
-          * If additional parameters are passed, they are joined and appended to the message.
 
-          * A technique for tracing entry and exit of a function is this:
 
-          *
 
-          *     function foo () {
 
-          *         Ext.log({ indent: 1 }, '>> foo');
 
-          *
 
-          *         // log statements in here or methods called from here will be indented
 
-          *         // by one step
 
-          *
 
-          *         Ext.log({ outdent: 1 }, '<< foo');
 
-          *     }
 
-          *
 
-          * This method does nothing in a release build.
 
-          *
 
-          * @param {String/Object} [options] The message to log or an options object with any
 
-          * of the following properties:
 
-          *
 
-          *  - `msg`: The message to log (required).
 
-          *  - `level`: One of: "error", "warn", "info" or "log" (the default is "log").
 
-          *  - `dump`: An object to dump to the log as part of the message.
 
-          *  - `stack`: True to include a stack trace in the log.
 
-          *  - `indent`: Cause subsequent log statements to be indented one step.
 
-          *  - `outdent`: Cause this and following statements to be one step less indented.
 
-          *
 
-          * @param {String...} [message] The message to log (required unless specified in
 
-          * options object).
 
-          *
 
-          * @method
 
-          */
 
-         log :
 
-             //<debug>
 
-             log ||
 
-             //</debug>
 
-             nullLog,
 
- <span id='Ext-method-partition'>        /**
 
- </span>         * Partitions the set into two sets: a true set and a false set.
 
-          *
 
-          * Example 1:
 
-          *
 
-          *     Ext.partition([true, false, true, true, false]);
 
-          *     // returns [[true, true, true], [false, false]]
 
-          *
 
-          * Example 2:
 
-          *
 
-          *     Ext.partition(
 
-          *         Ext.query("p"),
 
-          *         function(val){
 
-          *             return val.className == "class1"
 
-          *         }
 
-          *     );
 
-          *     // true are those paragraph elements with a className of "class1",
 
-          *     // false set are those that do not have that className.
 
-          *
 
-          * @param {Array/NodeList} arr The array to partition
 
-          * @param {Function} truth (optional) a function to determine truth.
 
-          * If this is omitted the element itself must be able to be evaluated for its truthfulness.
 
-          * @return {Array} [array of truish values, array of falsy values]
 
-          * @deprecated 4.0.0 Will be removed in the next major version
 
-          */
 
-         partition : function(arr, truth){
 
-             var ret = [[],[]],
 
-                 a, v,
 
-                 aLen = arr.length;
 
-             for (a = 0; a < aLen; a++) {
 
-                 v = arr[a];
 
-                 ret[ (truth && truth(v, a, arr)) || (!truth && v) ? 0 : 1].push(v);
 
-             }
 
-             return ret;
 
-         },
 
- <span id='Ext-method-invoke'>        /**
 
- </span>         * Invokes a method on each item in an Array.
 
-          *
 
-          * Example:
 
-          *
 
-          *     Ext.invoke(Ext.query("p"), "getAttribute", "id");
 
-          *     // [el1.getAttribute("id"), el2.getAttribute("id"), ..., elN.getAttribute("id")]
 
-          *
 
-          * @param {Array/NodeList} arr The Array of items to invoke the method on.
 
-          * @param {String} methodName The method name to invoke.
 
-          * @param {Object...} args Arguments to send into the method invocation.
 
-          * @return {Array} The results of invoking the method on each item in the array.
 
-          * @deprecated 4.0.0 Will be removed in the next major version
 
-          */
 
-         invoke : function(arr, methodName){
 
-             var ret  = [],
 
-                 args = Array.prototype.slice.call(arguments, 2),
 
-                 a, v,
 
-                 aLen = arr.length;
 
-             for (a = 0; a < aLen; a++) {
 
-                 v = arr[a];
 
-                 if (v && typeof v[methodName] == 'function') {
 
-                     ret.push(v[methodName].apply(v, args));
 
-                 } else {
 
-                     ret.push(undefined);
 
-                 }
 
-             }
 
-             return ret;
 
-         },
 
- <span id='Ext-method-zip'>        /**
 
- </span>         * Zips N sets together.
 
-          *
 
-          * Example 1:
 
-          *
 
-          *     Ext.zip([1,2,3],[4,5,6]); // [[1,4],[2,5],[3,6]]
 
-          *
 
-          * Example 2:
 
-          *
 
-          *     Ext.zip(
 
-          *         [ "+", "-", "+"],
 
-          *         [  12,  10,  22],
 
-          *         [  43,  15,  96],
 
-          *         function(a, b, c){
 
-          *             return "$" + a + "" + b + "." + c
 
-          *         }
 
-          *     ); // ["$+12.43", "$-10.15", "$+22.96"]
 
-          *
 
-          * @param {Array/NodeList...} arr This argument may be repeated. Array(s)
 
-          * to contribute values.
 
-          * @param {Function} zipper (optional) The last item in the argument list.
 
-          * This will drive how the items are zipped together.
 
-          * @return {Array} The zipped set.
 
-          * @deprecated 4.0.0 Will be removed in the next major version
 
-          */
 
-         zip : function(){
 
-             var parts = Ext.partition(arguments, function( val ){ return typeof val != 'function'; }),
 
-                 arrs = parts[0],
 
-                 fn = parts[1][0],
 
-                 len = Ext.max(Ext.pluck(arrs, "length")),
 
-                 ret = [],
 
-                 i,
 
-                 j,
 
-                 aLen;
 
-             for (i = 0; i < len; i++) {
 
-                 ret[i] = [];
 
-                 if(fn){
 
-                     ret[i] = fn.apply(fn, Ext.pluck(arrs, i));
 
-                 }else{
 
-                     for (j = 0, aLen = arrs.length; j < aLen; j++){
 
-                         ret[i].push( arrs[j][i] );
 
-                     }
 
-                 }
 
-             }
 
-             return ret;
 
-         },
 
- <span id='Ext-method-toSentence'>        /**
 
- </span>         * Turns an array into a sentence, joined by a specified connector - e.g.:
 
-          *
 
-          *     Ext.toSentence(['Adama', 'Tigh', 'Roslin']); //'Adama, Tigh and Roslin'
 
-          *     Ext.toSentence(['Adama', 'Tigh', 'Roslin'], 'or'); //'Adama, Tigh or Roslin'
 
-          *
 
-          * @param {String[]} items The array to create a sentence from
 
-          * @param {String} connector The string to use to connect the last two words.
 
-          * Usually 'and' or 'or' - defaults to 'and'.
 
-          * @return {String} The sentence string
 
-          * @deprecated 4.0.0 Will be removed in the next major version
 
-          */
 
-         toSentence: function(items, connector) {
 
-             var length = items.length,
 
-                 head,
 
-                 tail;
 
-             if (length <= 1) {
 
-                 return items[0];
 
-             } else {
 
-                 head = items.slice(0, length - 1);
 
-                 tail = items[length - 1];
 
-                 return Ext.util.Format.format("{0} {1} {2}", head.join(", "), connector || 'and', tail);
 
-             }
 
-         },
 
- <span id='Ext-property-useShims'>        /**
 
- </span>         * @property {Boolean} useShims
 
-          * By default, Ext intelligently decides whether floating elements should be shimmed.
 
-          * If you are using flash, you may want to set this to true.
 
-          */
 
-         useShims: isIE6
 
-     });
 
- }());
 
- <span id='Ext-method-application'>/**
 
- </span> * Loads Ext.app.Application class and starts it up with given configuration after the page is ready.
 
-  *
 
-  * See Ext.app.Application for details.
 
-  *
 
-  * @param {Object} config
 
-  */
 
- Ext.application = function(config) {
 
-     Ext.require('Ext.app.Application');
 
-     Ext.onReady(function() {
 
-         new Ext.app.Application(config);
 
-     });
 
- };
 
- </pre>
 
- </body>
 
- </html>
 
 
  |