Upgrade to ExtJS 3.0.0 - Released 07/06/2009
[extjs.git] / docs / source / ext-air-adapter.html
diff --git a/docs/source/ext-air-adapter.html b/docs/source/ext-air-adapter.html
new file mode 100644 (file)
index 0000000..da24e46
--- /dev/null
@@ -0,0 +1,805 @@
+<html>\r
+<head>\r
+  <title>The source code</title>\r
+    <link href="../resources/prettify/prettify.css" type="text/css" rel="stylesheet" />\r
+    <script type="text/javascript" src="../resources/prettify/prettify.js"></script>\r
+</head>\r
+<body  onload="prettyPrint();">\r
+    <pre class="prettyprint lang-js">/*\r
+ * This file corrects air eval issues and other issues found in the AIR application sandbox \r
+ */\r
+Ext.namespace('Ext.air', 'Ext.sql');\r
+\r
+Ext.Template.prototype.compile = function() {\r
+       var fm = Ext.util.Format;\r
+       var useF = this.disableFormats !== true;\r
+       //\r
+       var prevOffset = 0;\r
+       var arr = [];\r
+       var tpl = this;\r
+       var fn = function(m, name, format, args, offset, s){\r
+               if (prevOffset != offset) {\r
+                       var action = {type: 1, value: s.substr(prevOffset, offset - prevOffset)};\r
+                       arr.push(action);\r
+               }\r
+               prevOffset = offset + m.length;\r
+               if(format && useF){\r
+                               if (args) {\r
+                                       var re = /^\s*['"](.*)["']\s*$/;\r
+                                       args = args.split(/,(?=(?:[^"]*"[^"]*")*(?![^"]*"))/);\r
+                                       for(var i = 0, len = args.length; i < len; i++){\r
+                                               args[i] = args[i].replace(re, "$1");\r
+                                       }\r
+                                       args = [''].concat(args);\r
+                               } else {\r
+                                               args = [''];\r
+                               }\r
+                       if(format.substr(0, 5) != "this."){\r
+                               var action = {type: 3, value:name, format: fm[format], args: args, scope: fm};\r
+                               arr.push(action);                                       \r
+                       }else{\r
+                               var action = {type: 3, value:name, format:tpl[format.substr(5)], args:args, scope: tpl};\r
+                               arr.push(action);                                       \r
+                       }\r
+               }else{\r
+                       var action  = {type: 2, value: name};\r
+                       arr.push(action);                               \r
+               }\r
+               return m;\r
+       };\r
+       \r
+       var s = this.html.replace(this.re, fn);\r
+       if (prevOffset != (s.length - 1)) {\r
+               var action = {type: 1, value: s.substr(prevOffset, s.length - prevOffset)};\r
+               arr.push(action);\r
+       }\r
+\r
+       this.compiled = function(values) {\r
+               function applyValues(el) {\r
+                       switch (el.type) {\r
+                                       case 1:\r
+                                                       return el.value;\r
+                                       case 2:\r
+                                                       return (values[el.value] ? values[el.value] : '');\r
+                                       default:\r
+                                                       el.args[0] = values[el.value];\r
+                                                       return el.format.apply(el.scope, el.args);\r
+                       }\r
+               }       \r
+               return arr.map(applyValues).join('');\r
+       }\r
+       return this;\r
+};\r
+\r
+Ext.Template.prototype.call = function(fnName, value, allValues){\r
+    return this[fnName](value, allValues);\r
+}\r
+\r
+\r
+Ext.DomQuery = function(){\r
+    var cache = {}, simpleCache = {}, valueCache = {};\r
+    var nonSpace = /\S/;\r
+    var trimRe = /^\s+|\s+$/g;\r
+    var tplRe = /\{(\d+)\}/g;\r
+    var modeRe = /^(\s?[\/>+~]\s?|\s|$)/;\r
+    var tagTokenRe = /^(#)?([\w-\*]+)/;\r
+    var nthRe = /(\d*)n\+?(\d*)/, nthRe2 = /\D/;\r
+\r
+    function child(p, index){\r
+        var i = 0;\r
+        var n = p.firstChild;\r
+        while(n){\r
+            if(n.nodeType == 1){\r
+               if(++i == index){\r
+                   return n;\r
+               }\r
+            }\r
+            n = n.nextSibling;\r
+        }\r
+        return null;\r
+    };\r
+\r
+    function next(n){\r
+        while((n = n.nextSibling) && n.nodeType != 1);\r
+        return n;\r
+    };\r
+\r
+    function prev(n){\r
+        while((n = n.previousSibling) && n.nodeType != 1);\r
+        return n;\r
+    };\r
+\r
+    function children(d){\r
+        var n = d.firstChild, ni = -1;\r
+           while(n){\r
+               var nx = n.nextSibling;\r
+               if(n.nodeType == 3 && !nonSpace.test(n.nodeValue)){\r
+                   d.removeChild(n);\r
+               }else{\r
+                   n.nodeIndex = ++ni;\r
+               }\r
+               n = nx;\r
+           }\r
+           return this;\r
+       };\r
+\r
+    function byClassName(c, a, v){\r
+        if(!v){\r
+            return c;\r
+        }\r
+        var r = [], ri = -1, cn;\r
+        for(var i = 0, ci; ci = c[i]; i++){\r
+            if((' '+ci.className+' ').indexOf(v) != -1){\r
+                r[++ri] = ci;\r
+            }\r
+        }\r
+        return r;\r
+    };\r
+\r
+    function attrValue(n, attr){\r
+        if(!n.tagName && typeof n.length != "undefined"){\r
+            n = n[0];\r
+        }\r
+        if(!n){\r
+            return null;\r
+        }\r
+        if(attr == "for"){\r
+            return n.htmlFor;\r
+        }\r
+        if(attr == "class" || attr == "className"){\r
+            return n.className;\r
+        }\r
+        return n.getAttribute(attr) || n[attr];\r
+\r
+    };\r
+\r
+    function getNodes(ns, mode, tagName){\r
+        var result = [], ri = -1, cs;\r
+        if(!ns){\r
+            return result;\r
+        }\r
+        tagName = tagName || "*";\r
+        if(typeof ns.getElementsByTagName != "undefined"){\r
+            ns = [ns];\r
+        }\r
+        if(!mode){\r
+            for(var i = 0, ni; ni = ns[i]; i++){\r
+                cs = ni.getElementsByTagName(tagName);\r
+                for(var j = 0, ci; ci = cs[j]; j++){\r
+                    result[++ri] = ci;\r
+                }\r
+            }\r
+        }else if(mode == "/" || mode == ">"){\r
+            var utag = tagName.toUpperCase();\r
+            for(var i = 0, ni, cn; ni = ns[i]; i++){\r
+                cn = ni.children || ni.childNodes;\r
+                for(var j = 0, cj; cj = cn[j]; j++){\r
+                    if(cj.nodeName == utag || cj.nodeName == tagName  || tagName == '*'){\r
+                        result[++ri] = cj;\r
+                    }\r
+                }\r
+            }\r
+        }else if(mode == "+"){\r
+            var utag = tagName.toUpperCase();\r
+            for(var i = 0, n; n = ns[i]; i++){\r
+                while((n = n.nextSibling) && n.nodeType != 1);\r
+                if(n && (n.nodeName == utag || n.nodeName == tagName || tagName == '*')){\r
+                    result[++ri] = n;\r
+                }\r
+            }\r
+        }else if(mode == "~"){\r
+            for(var i = 0, n; n = ns[i]; i++){\r
+                while((n = n.nextSibling) && (n.nodeType != 1 || (tagName == '*' || n.tagName.toLowerCase()!=tagName)));\r
+                if(n){\r
+                    result[++ri] = n;\r
+                }\r
+            }\r
+        }\r
+        return result;\r
+    };\r
+\r
+    function concat(a, b){\r
+        if(b.slice){\r
+            return a.concat(b);\r
+        }\r
+        for(var i = 0, l = b.length; i < l; i++){\r
+            a[a.length] = b[i];\r
+        }\r
+        return a;\r
+    }\r
+\r
+    function byTag(cs, tagName){\r
+        if(cs.tagName || cs == document){\r
+            cs = [cs];\r
+        }\r
+        if(!tagName){\r
+            return cs;\r
+        }\r
+        var r = [], ri = -1;\r
+        tagName = tagName.toLowerCase();\r
+        for(var i = 0, ci; ci = cs[i]; i++){\r
+            if(ci.nodeType == 1 && ci.tagName.toLowerCase()==tagName){\r
+                r[++ri] = ci;\r
+            }\r
+        }\r
+        return r;\r
+    };\r
+\r
+    function byId(cs, attr, id){\r
+        if(cs.tagName || cs == document){\r
+            cs = [cs];\r
+        }\r
+        if(!id){\r
+            return cs;\r
+        }\r
+        var r = [], ri = -1;\r
+        for(var i = 0,ci; ci = cs[i]; i++){\r
+            if(ci && ci.id == id){\r
+                r[++ri] = ci;\r
+                return r;\r
+            }\r
+        }\r
+        return r;\r
+    };\r
+\r
+    function byAttribute(cs, attr, value, op, custom){\r
+        var r = [], ri = -1, st = custom=="{";\r
+        var f = Ext.DomQuery.operators[op];\r
+        for(var i = 0, ci; ci = cs[i]; i++){\r
+            var a;\r
+            if(st){\r
+                a = Ext.DomQuery.getStyle(ci, attr);\r
+            }\r
+            else if(attr == "class" || attr == "className"){\r
+                a = ci.className;\r
+            }else if(attr == "for"){\r
+                a = ci.htmlFor;\r
+            }else if(attr == "href"){\r
+                a = ci.getAttribute("href", 2);\r
+            }else{\r
+                a = ci.getAttribute(attr);\r
+            }\r
+            if((f && f(a, value)) || (!f && a)){\r
+                r[++ri] = ci;\r
+            }\r
+        }\r
+        return r;\r
+    };\r
+\r
+    function byPseudo(cs, name, value){\r
+        return Ext.DomQuery.pseudos[name](cs, value);\r
+    };\r
+\r
\r
+    // this eval is stop the compressor from\r
+    // renaming the variable to something shorter\r
+    eval("var batch = 30803;");\r
+\r
+    var key = 30803;\r
+\r
+    function nodup(cs){\r
+        if(!cs){\r
+            return [];\r
+        }\r
+        var len = cs.length, c, i, r = cs, cj, ri = -1;\r
+        if(!len || typeof cs.nodeType != "undefined" || len == 1){\r
+            return cs;\r
+        }\r
+        var d = ++key;\r
+        cs[0]._nodup = d;\r
+        for(i = 1; c = cs[i]; i++){\r
+            if(c._nodup != d){\r
+                c._nodup = d;\r
+            }else{\r
+                r = [];\r
+                for(var j = 0; j < i; j++){\r
+                    r[++ri] = cs[j];\r
+                }\r
+                for(j = i+1; cj = cs[j]; j++){\r
+                    if(cj._nodup != d){\r
+                        cj._nodup = d;\r
+                        r[++ri] = cj;\r
+                    }\r
+                }\r
+                return r;\r
+            }\r
+        }\r
+        return r;\r
+    }\r
+\r
+    function quickDiff(c1, c2){\r
+        var len1 = c1.length;\r
+        if(!len1){\r
+            return c2;\r
+        }\r
+        var d = ++key;\r
+        for(var i = 0; i < len1; i++){\r
+            c1[i]._qdiff = d;\r
+        }\r
+        var r = [];\r
+        for(var i = 0, len = c2.length; i < len; i++){\r
+            if(c2[i]._qdiff != d){\r
+                r[r.length] = c2[i];\r
+            }\r
+        }\r
+        return r;\r
+    }\r
+\r
+    function quickId(ns, mode, root, id){\r
+        if(ns == root){\r
+           var d = root.ownerDocument || root;\r
+           return d.getElementById(id);\r
+        }\r
+        ns = getNodes(ns, mode, "*");\r
+           return byId(ns, null, id);\r
+    }\r
+\r
+       function search(path, root, type) {\r
+                   type = type || "select";\r
+            //\r
+            var n = root || document;\r
+            //\r
+            var q = path, mode, lq;\r
+            var tk = Ext.DomQuery.matchers;\r
+            var tklen = tk.length;\r
+            var mm;\r
+\r
+            var lmode = q.match(modeRe);\r
+            if(lmode && lmode[1]){\r
+                mode=lmode[1].replace(trimRe, "");\r
+                q = q.replace(lmode[1], "");\r
+            }\r
+            while(path.substr(0, 1)=="/"){\r
+                path = path.substr(1);\r
+            }\r
+            while(q && lq != q){\r
+                lq = q;\r
+                var tm = q.match(tagTokenRe);\r
+                if(type == "select"){\r
+                    if(tm){\r
+                        if(tm[1] == "#"){\r
+                            n = quickId(n, mode, root, tm[2]);\r
+                        }else{\r
+                            n = getNodes(n, mode, tm[2]);\r
+                        }\r
+                        q = q.replace(tm[0], "");\r
+                    }else if(q.substr(0, 1) != '@'){\r
+                        n = getNodes(n, mode, "*");\r
+                    }\r
+                }else{\r
+                    if(tm){\r
+                        if(tm[1] == "#"){\r
+                            n = byId(n, null, tm[2]);\r
+                        }else{\r
+                            n = byTag(n, tm[2]);\r
+                        }\r
+                        q = q.replace(tm[0], "");\r
+                    }\r
+                }\r
+                while(!(mm = q.match(modeRe))){\r
+                    var matched = false;\r
+                    for(var j = 0; j < tklen; j++){\r
+                        var t = tk[j];\r
+                        var m = q.match(t.re);\r
+                        if(m){\r
+                            switch(j) {\r
+                                case 0:\r
+                                    n = byClassName(n, null, " " + m[1] +" ");\r
+                                    break;\r
+                                case 1:\r
+                                    n = byPseudo(n, m[1], m[2]);\r
+                                    break;\r
+                                case 2:\r
+                                    n = byAttribute(n, m[2], m[4], m[3], m[1]);\r
+                                    break;\r
+                                case 3:\r
+                                    n = byId(n, null, m[1]);\r
+                                    break;\r
+                                case 4:\r
+                                    return {firstChild:{nodeValue:attrValue(n, m[1])}};\r
+                                    \r
+                            }\r
+                            q = q.replace(m[0], "");\r
+                            matched = true;\r
+                            break;\r
+                        }\r
+                    }\r
+\r
+                    if(!matched){\r
+                        throw 'Error parsing selector, parsing failed at "' + q + '"';\r
+                    }\r
+                }\r
+                if(mm[1]){\r
+                    mode=mm[1].replace(trimRe, "");\r
+                    q = q.replace(mm[1], "");\r
+                }\r
+            }\r
+            return nodup(n);\r
+        }              \r
+\r
+     return {\r
+        getStyle : function(el, name){\r
+             return Ext.fly(el).getStyle(name);\r
+        },\r
+               \r
+               compile: function(path, type) {\r
+                       return function(root) {\r
+                                       return search(path, root, type);\r
+                       }\r
+               },\r
+\r
+        <div id="method-Ext.air.DragType-select"></div>/**\r
+         * Selects a group of elements.\r
+         * @param {String} selector The selector/xpath query (can be a comma separated list of selectors)\r
+         * @param {Node} root (optional) The start of the query (defaults to document).\r
+         * @return {Array}\r
+         */\r
+        select : function(path, root, type){\r
+            if(!root || root == document){\r
+                root = document;\r
+            }\r
+            if(typeof root == "string"){\r
+                root = document.getElementById(root);\r
+            }\r
+            var paths = path.split(",");\r
+            var results = [];\r
+            for(var i = 0, len = paths.length; i < len; i++){\r
+                var p = paths[i].replace(trimRe, "");\r
+                if(!cache[p]){\r
+                    cache[p] = Ext.DomQuery.compile(p);\r
+                    if(!cache[p]){\r
+                        throw p + " is not a valid selector";\r
+                    }\r
+                }\r
+                var result = cache[p](root);\r
+                if(result && result != document){\r
+                    results = results.concat(result);\r
+                }\r
+            }\r
+            if(paths.length > 1){\r
+                return nodup(results);\r
+            }\r
+            return results;\r
+        },\r
+\r
+        <div id="method-Ext.air.DragType-selectNode"></div>/**\r
+         * Selects a single element.\r
+         * @param {String} selector The selector/xpath query\r
+         * @param {Node} root (optional) The start of the query (defaults to document).\r
+         * @return {Element}\r
+         */\r
+        selectNode : function(path, root){\r
+            return Ext.DomQuery.select(path, root)[0];\r
+        },\r
+\r
+        <div id="method-Ext.air.DragType-selectValue"></div>/**\r
+         * Selects the value of a node, optionally replacing null with the defaultValue.\r
+         * @param {String} selector The selector/xpath query\r
+         * @param {Node} root (optional) The start of the query (defaults to document).\r
+         * @param {String} defaultValue\r
+         */\r
+        selectValue : function(path, root, defaultValue){\r
+            path = path.replace(trimRe, "");\r
+            if(!valueCache[path]){\r
+                valueCache[path] = Ext.DomQuery.compile(path, "select");\r
+            }\r
+            var n = valueCache[path](root);\r
+            n = n[0] ? n[0] : n;\r
+            var v = (n && n.firstChild ? n.firstChild.nodeValue : null);\r
+            return ((v === null||v === undefined||v==='') ? defaultValue : v);\r
+        },\r
+\r
+        <div id="method-Ext.air.DragType-selectNumber"></div>/**\r
+         * Selects the value of a node, parsing integers and floats.\r
+         * @param {String} selector The selector/xpath query\r
+         * @param {Node} root (optional) The start of the query (defaults to document).\r
+         * @param {Number} defaultValue\r
+         * @return {Number}\r
+         */\r
+        selectNumber : function(path, root, defaultValue){\r
+            var v = Ext.DomQuery.selectValue(path, root, defaultValue || 0);\r
+            return parseFloat(v);\r
+        },\r
+\r
+        <div id="method-Ext.air.DragType-is"></div>/**\r
+         * Returns true if the passed element(s) match the passed simple selector (e.g. div.some-class or span:first-child)\r
+         * @param {String/HTMLElement/Array} el An element id, element or array of elements\r
+         * @param {String} selector The simple selector to test\r
+         * @return {Boolean}\r
+         */\r
+        is : function(el, ss){\r
+            if(typeof el == "string"){\r
+                el = document.getElementById(el);\r
+            }\r
+            var isArray = Ext.isArray(el);\r
+            var result = Ext.DomQuery.filter(isArray ? el : [el], ss);\r
+            return isArray ? (result.length == el.length) : (result.length > 0);\r
+        },\r
+\r
+        <div id="method-Ext.air.DragType-filter"></div>/**\r
+         * Filters an array of elements to only include matches of a simple selector (e.g. div.some-class or span:first-child)\r
+         * @param {Array} el An array of elements to filter\r
+         * @param {String} selector The simple selector to test\r
+         * @param {Boolean} nonMatches If true, it returns the elements that DON'T match\r
+         * the selector instead of the ones that match\r
+         * @return {Array}\r
+         */\r
+        filter : function(els, ss, nonMatches){\r
+            ss = ss.replace(trimRe, "");\r
+            if(!simpleCache[ss]){\r
+                simpleCache[ss] = Ext.DomQuery.compile(ss, "simple");\r
+            }\r
+            var result = simpleCache[ss](els);\r
+            return nonMatches ? quickDiff(result, els) : result;\r
+        },\r
+\r
+        <div id="prop-Ext.air.DragType-matchers"></div>/**\r
+         * Collection of matching regular expressions and code snippets.\r
+         */\r
+        matchers : [{\r
+                re: /^\.([\w-]+)/,\r
+                select: 'n = byClassName(n, null, " {1} ");'\r
+            }, {\r
+                re: /^\:([\w-]+)(?:\(((?:[^\s>\/]*|.*?))\))?/,\r
+                select: 'n = byPseudo(n, "{1}", "{2}");'\r
+            },{\r
+                re: /^(?:([\[\{])(?:@)?([\w-]+)\s?(?:(=|.=)\s?['"]?(.*?)["']?)?[\]\}])/,\r
+                select: 'n = byAttribute(n, "{2}", "{4}", "{3}", "{1}");'\r
+            }, {\r
+                re: /^#([\w-]+)/,\r
+                select: 'n = byId(n, null, "{1}");'\r
+            },{\r
+                re: /^@([\w-]+)/,\r
+                select: 'return {firstChild:{nodeValue:attrValue(n, "{1}")}};'\r
+            }\r
+        ],\r
+\r
+        <div id="method-Ext.air.DragType-operators"></div>/**\r
+         * Collection of operator comparison functions. The default operators are =, !=, ^=, $=, *=, %=, |= and ~=.\r
+         * New operators can be added as long as the match the format <i>c</i>= where <i>c</i> is any character other than space, &gt; &lt;.\r
+         */\r
+        operators : {\r
+            "=" : function(a, v){\r
+                return a == v;\r
+            },\r
+            "!=" : function(a, v){\r
+                return a != v;\r
+            },\r
+            "^=" : function(a, v){\r
+                return a && a.substr(0, v.length) == v;\r
+            },\r
+            "$=" : function(a, v){\r
+                return a && a.substr(a.length-v.length) == v;\r
+            },\r
+            "*=" : function(a, v){\r
+                return a && a.indexOf(v) !== -1;\r
+            },\r
+            "%=" : function(a, v){\r
+                return (a % v) == 0;\r
+            },\r
+            "|=" : function(a, v){\r
+                return a && (a == v || a.substr(0, v.length+1) == v+'-');\r
+            },\r
+            "~=" : function(a, v){\r
+                return a && (' '+a+' ').indexOf(' '+v+' ') != -1;\r
+            }\r
+        },\r
+\r
+        <div id="prop-Ext.air.DragType-pseudos"></div>/**\r
+         * Collection of "pseudo class" processors. Each processor is passed the current nodeset (array)\r
+         * and the argument (if any) supplied in the selector.\r
+         */\r
+        pseudos : {\r
+            "first-child" : function(c){\r
+                var r = [], ri = -1, n;\r
+                for(var i = 0, ci; ci = n = c[i]; i++){\r
+                    while((n = n.previousSibling) && n.nodeType != 1);\r
+                    if(!n){\r
+                        r[++ri] = ci;\r
+                    }\r
+                }\r
+                return r;\r
+            },\r
+\r
+            "last-child" : function(c){\r
+                var r = [], ri = -1, n;\r
+                for(var i = 0, ci; ci = n = c[i]; i++){\r
+                    while((n = n.nextSibling) && n.nodeType != 1);\r
+                    if(!n){\r
+                        r[++ri] = ci;\r
+                    }\r
+                }\r
+                return r;\r
+            },\r
+\r
+            "nth-child" : function(c, a) {\r
+                var r = [], ri = -1;\r
+                var m = nthRe.exec(a == "even" && "2n" || a == "odd" && "2n+1" || !nthRe2.test(a) && "n+" + a || a);\r
+                var f = (m[1] || 1) - 0, l = m[2] - 0;\r
+                for(var i = 0, n; n = c[i]; i++){\r
+                    var pn = n.parentNode;\r
+                    if (batch != pn._batch) {\r
+                        var j = 0;\r
+                        for(var cn = pn.firstChild; cn; cn = cn.nextSibling){\r
+                            if(cn.nodeType == 1){\r
+                               cn.nodeIndex = ++j;\r
+                            }\r
+                        }\r
+                        pn._batch = batch;\r
+                    }\r
+                    if (f == 1) {\r
+                        if (l == 0 || n.nodeIndex == l){\r
+                            r[++ri] = n;\r
+                        }\r
+                    } else if ((n.nodeIndex + l) % f == 0){\r
+                        r[++ri] = n;\r
+                    }\r
+                }\r
+\r
+                return r;\r
+            },\r
+\r
+            "only-child" : function(c){\r
+                var r = [], ri = -1;;\r
+                for(var i = 0, ci; ci = c[i]; i++){\r
+                    if(!prev(ci) && !next(ci)){\r
+                        r[++ri] = ci;\r
+                    }\r
+                }\r
+                return r;\r
+            },\r
+\r
+            "empty" : function(c){\r
+                var r = [], ri = -1;\r
+                for(var i = 0, ci; ci = c[i]; i++){\r
+                    var cns = ci.childNodes, j = 0, cn, empty = true;\r
+                    while(cn = cns[j]){\r
+                        ++j;\r
+                        if(cn.nodeType == 1 || cn.nodeType == 3){\r
+                            empty = false;\r
+                            break;\r
+                        }\r
+                    }\r
+                    if(empty){\r
+                        r[++ri] = ci;\r
+                    }\r
+                }\r
+                return r;\r
+            },\r
+\r
+            "contains" : function(c, v){\r
+                var r = [], ri = -1;\r
+                for(var i = 0, ci; ci = c[i]; i++){\r
+                    if((ci.textContent||ci.innerText||'').indexOf(v) != -1){\r
+                        r[++ri] = ci;\r
+                    }\r
+                }\r
+                return r;\r
+            },\r
+\r
+            "nodeValue" : function(c, v){\r
+                var r = [], ri = -1;\r
+                for(var i = 0, ci; ci = c[i]; i++){\r
+                    if(ci.firstChild && ci.firstChild.nodeValue == v){\r
+                        r[++ri] = ci;\r
+                    }\r
+                }\r
+                return r;\r
+            },\r
+\r
+            "checked" : function(c){\r
+                var r = [], ri = -1;\r
+                for(var i = 0, ci; ci = c[i]; i++){\r
+                    if(ci.checked == true){\r
+                        r[++ri] = ci;\r
+                    }\r
+                }\r
+                return r;\r
+            },\r
+\r
+            "not" : function(c, ss){\r
+                return Ext.DomQuery.filter(c, ss, true);\r
+            },\r
+\r
+            "any" : function(c, selectors){\r
+                var ss = selectors.split('|');\r
+                var r = [], ri = -1, s;\r
+                for(var i = 0, ci; ci = c[i]; i++){\r
+                    for(var j = 0; s = ss[j]; j++){\r
+                        if(Ext.DomQuery.is(ci, s)){\r
+                            r[++ri] = ci;\r
+                            break;\r
+                        }\r
+                    }\r
+                }\r
+                return r;\r
+            },\r
+\r
+            "odd" : function(c){\r
+                return this["nth-child"](c, "odd");\r
+            },\r
+\r
+            "even" : function(c){\r
+                return this["nth-child"](c, "even");\r
+            },\r
+\r
+            "nth" : function(c, a){\r
+                return c[a-1] || [];\r
+            },\r
+\r
+            "first" : function(c){\r
+                return c[0] || [];\r
+            },\r
+\r
+            "last" : function(c){\r
+                return c[c.length-1] || [];\r
+            },\r
+\r
+            "has" : function(c, ss){\r
+                var s = Ext.DomQuery.select;\r
+                var r = [], ri = -1;\r
+                for(var i = 0, ci; ci = c[i]; i++){\r
+                    if(s(ss, ci).length > 0){\r
+                        r[++ri] = ci;\r
+                    }\r
+                }\r
+                return r;\r
+            },\r
+\r
+            "next" : function(c, ss){\r
+                var is = Ext.DomQuery.is;\r
+                var r = [], ri = -1;\r
+                for(var i = 0, ci; ci = c[i]; i++){\r
+                    var n = next(ci);\r
+                    if(n && is(n, ss)){\r
+                        r[++ri] = ci;\r
+                    }\r
+                }\r
+                return r;\r
+            },\r
+\r
+            "prev" : function(c, ss){\r
+                var is = Ext.DomQuery.is;\r
+                var r = [], ri = -1;\r
+                for(var i = 0, ci; ci = c[i]; i++){\r
+                    var n = prev(ci);\r
+                    if(n && is(n, ss)){\r
+                        r[++ri] = ci;\r
+                    }\r
+                }\r
+                return r;\r
+            }\r
+        }\r
+    };\r
+}();\r
+\r
+Ext.query = Ext.DomQuery.select;\r
+\r
+Date.precompileFormats = function(s){\r
+       var formats = s.split('|');\r
+       for(var i = 0, len = formats.length;i < len;i++){\r
+               Date.createNewFormat(formats[i]);\r
+               Date.createParser(formats[i]);\r
+       }\r
+}\r
+\r
+Date.precompileFormats("D n/j/Y|n/j/Y|n/j/y|m/j/y|n/d/y|m/j/Y|n/d/Y|YmdHis|F d, Y|l, F d, Y|H:i:s|g:i A|g:ia|g:iA|g:i a|g:i A|h:i|g:i|H:i|ga|ha|gA|h a|g a|g A|gi|hi|gia|hia|g|H|m/d/y|m/d/Y|m-d-y|m-d-Y|m/d|m-d|md|mdy|mdY|d|Y-m-d|Y-m-d H:i:s|d/m/y|d/m/Y|d-m-y|d-m-Y|d/m|d-m|dm|dmy|dmY|Y-m-d|l|D m/d|D m/d/Y|m/d/Y");\r
+\r
+// precompile instead of lazy init\r
+Ext.ColorPalette.prototype.tpl = new Ext.XTemplate(\r
+    '<tpl for="."><a href="#" class="color-{.}" hidefocus="on"><em><span style="background:#{.}" unselectable="on">&#160;</span></em></a></tpl>'\r
+);\r
+\r
+Ext.grid.GroupingView.prototype.startTpl = new Ext.XTemplate(\r
+    '<div id="{groupId}" class="x-grid-group {cls}">',\r
+        '<div id="{groupId}-hd" class="x-grid-group-hd" style="{style}"><div>{text}</div></div>',\r
+        '<div id="{groupId}-bd" class="x-grid-group-body">'\r
+);\r
+\r
+\r
+\r
+\r
+\r
+</pre>    \r
+</body>\r
+</html>
\ No newline at end of file