Upgrade to ExtJS 3.0.0 - Released 07/06/2009
[extjs.git] / source / adapter / prototype-bridge.js
diff --git a/source/adapter/prototype-bridge.js b/source/adapter/prototype-bridge.js
deleted file mode 100644 (file)
index 7a7484a..0000000
+++ /dev/null
@@ -1,548 +0,0 @@
-/*\r
- * Ext JS Library 2.2.1\r
- * Copyright(c) 2006-2009, Ext JS, LLC.\r
- * licensing@extjs.com\r
- * \r
- * http://extjs.com/license\r
- */\r
-\r
-(function(){\r
-\r
-var libFlyweight;\r
-\r
-Ext.lib.Dom = {\r
-    getViewWidth : function(full){\r
-        return full ? this.getDocumentWidth() : this.getViewportWidth();\r
-    },\r
-\r
-    getViewHeight : function(full){\r
-        return full ? this.getDocumentHeight() : this.getViewportHeight();\r
-    },\r
-\r
-    getDocumentHeight: function() { // missing from prototype?\r
-        var scrollHeight = (document.compatMode != "CSS1Compat") ? document.body.scrollHeight : document.documentElement.scrollHeight;\r
-        return Math.max(scrollHeight, this.getViewportHeight());\r
-    },\r
-\r
-    getDocumentWidth: function() { // missing from prototype?\r
-        var scrollWidth = (document.compatMode != "CSS1Compat") ? document.body.scrollWidth : document.documentElement.scrollWidth;\r
-        return Math.max(scrollWidth, this.getViewportWidth());\r
-    },\r
-\r
-    getViewportHeight: function() { // missing from prototype?\r
-        var height = self.innerHeight;\r
-        var mode = document.compatMode;\r
-\r
-        if ( (mode || Ext.isIE) && !Ext.isOpera ) {\r
-            height = (mode == "CSS1Compat") ?\r
-                    document.documentElement.clientHeight : // Standards\r
-                    document.body.clientHeight; // Quirks\r
-        }\r
-\r
-        return height;\r
-    },\r
-\r
-    getViewportWidth: function() { // missing from prototype?\r
-        var width = self.innerWidth;  // Safari\r
-        var mode = document.compatMode;\r
-\r
-        if (mode || Ext.isIE) { // IE, Gecko, Opera\r
-            width = (mode == "CSS1Compat") ?\r
-                    document.documentElement.clientWidth : // Standards\r
-                    document.body.clientWidth; // Quirks\r
-        }\r
-        return width;\r
-    },\r
-\r
-    isAncestor : function(p, c){ // missing from prototype?\r
-        p = Ext.getDom(p);\r
-        c = Ext.getDom(c);\r
-        if (!p || !c) {return false;}\r
-\r
-        if(p.contains && !Ext.isSafari) {\r
-            return p.contains(c);\r
-        }else if(p.compareDocumentPosition) {\r
-            return !!(p.compareDocumentPosition(c) & 16);\r
-        }else{\r
-            var parent = c.parentNode;\r
-            while (parent) {\r
-                if (parent == p) {\r
-                    return true;\r
-                }\r
-                else if (!parent.tagName || parent.tagName.toUpperCase() == "HTML") {\r
-                    return false;\r
-                }\r
-                parent = parent.parentNode;\r
-            }\r
-            return false;\r
-        }\r
-    },\r
-\r
-    getRegion : function(el){\r
-        return Ext.lib.Region.getRegion(el);\r
-    },\r
-\r
-    getY : function(el){\r
-        return this.getXY(el)[1];\r
-    },\r
-\r
-    getX : function(el){\r
-        return this.getXY(el)[0];\r
-    },\r
-\r
-    getXY : function(el){ // this initially used Position.cumulativeOffset but it is not accurate enough\r
-        var p, pe, b, scroll, bd = (document.body || document.documentElement);\r
-        el = Ext.getDom(el);\r
-\r
-        if(el == bd){\r
-            return [0, 0];\r
-        }\r
-\r
-        if (el.getBoundingClientRect) {\r
-            b = el.getBoundingClientRect();\r
-            scroll = fly(document).getScroll();\r
-            return [b.left + scroll.left, b.top + scroll.top];\r
-        }\r
-        var x = 0, y = 0;\r
-\r
-        p = el;\r
-\r
-        var hasAbsolute = fly(el).getStyle("position") == "absolute";\r
-\r
-        while (p) {\r
-\r
-            x += p.offsetLeft;\r
-            y += p.offsetTop;\r
-\r
-            if (!hasAbsolute && fly(p).getStyle("position") == "absolute") {\r
-                hasAbsolute = true;\r
-            }\r
-\r
-            if (Ext.isGecko) {\r
-                pe = fly(p);\r
-\r
-                var bt = parseInt(pe.getStyle("borderTopWidth"), 10) || 0;\r
-                var bl = parseInt(pe.getStyle("borderLeftWidth"), 10) || 0;\r
-\r
-\r
-                x += bl;\r
-                y += bt;\r
-\r
-\r
-                if (p != el && pe.getStyle('overflow') != 'visible') {\r
-                    x += bl;\r
-                    y += bt;\r
-                }\r
-            }\r
-            p = p.offsetParent;\r
-        }\r
-\r
-        if (Ext.isSafari && hasAbsolute) {\r
-            x -= bd.offsetLeft;\r
-            y -= bd.offsetTop;\r
-        }\r
-\r
-        if (Ext.isGecko && !hasAbsolute) {\r
-            var dbd = fly(bd);\r
-            x += parseInt(dbd.getStyle("borderLeftWidth"), 10) || 0;\r
-            y += parseInt(dbd.getStyle("borderTopWidth"), 10) || 0;\r
-        }\r
-\r
-        p = el.parentNode;\r
-        while (p && p != bd) {\r
-            if (!Ext.isOpera || (p.tagName != 'TR' && fly(p).getStyle("display") != "inline")) {\r
-                x -= p.scrollLeft;\r
-                y -= p.scrollTop;\r
-            }\r
-            p = p.parentNode;\r
-        }\r
-        return [x, y];\r
-    },\r
-\r
-    setXY : function(el, xy){ // this initially used Position.cumulativeOffset but it is not accurate enough\r
-        el = Ext.fly(el, '_setXY');\r
-        el.position();\r
-        var pts = el.translatePoints(xy);\r
-        if(xy[0] !== false){\r
-            el.dom.style.left = pts.left + "px";\r
-        }\r
-        if(xy[1] !== false){\r
-            el.dom.style.top = pts.top + "px";\r
-        }\r
-    },\r
-\r
-    setX : function(el, x){\r
-        this.setXY(el, [x, false]);\r
-    },\r
-\r
-    setY : function(el, y){\r
-        this.setXY(el, [false, y]);\r
-    }\r
-};\r
-\r
-Ext.lib.Event = {\r
-    getPageX : function(e){\r
-        return Event.pointerX(e.browserEvent || e);\r
-    },\r
-\r
-    getPageY : function(e){\r
-        return Event.pointerY(e.browserEvent || e);\r
-    },\r
-\r
-    getXY : function(e){\r
-        e = e.browserEvent || e;\r
-        return [Event.pointerX(e), Event.pointerY(e)];\r
-    },\r
-\r
-    getTarget : function(e){\r
-        return Event.element(e.browserEvent || e);\r
-    },\r
-\r
-    resolveTextNode: function(node) {\r
-        if (node && 3 == node.nodeType) {\r
-            return node.parentNode;\r
-        } else {\r
-            return node;\r
-        }\r
-    },\r
-\r
-    getRelatedTarget: function(ev) { // missing from prototype?\r
-        ev = ev.browserEvent || ev;\r
-        var t = ev.relatedTarget;\r
-        if (!t) {\r
-            if (ev.type == "mouseout") {\r
-                t = ev.toElement;\r
-            } else if (ev.type == "mouseover") {\r
-                t = ev.fromElement;\r
-            }\r
-        }\r
-\r
-        return this.resolveTextNode(t);\r
-    },\r
-\r
-    on : function(el, eventName, fn){\r
-        Event.observe(el, eventName, fn, false);\r
-    },\r
-\r
-    un : function(el, eventName, fn){\r
-        Event.stopObserving(el, eventName, fn, false);\r
-    },\r
-\r
-    purgeElement : function(el){\r
-        // no equiv?\r
-    },\r
-\r
-    preventDefault : function(e){   // missing from prototype?\r
-        e = e.browserEvent || e;\r
-        if(e.preventDefault) {\r
-            e.preventDefault();\r
-        } else {\r
-            e.returnValue = false;\r
-        }\r
-    },\r
-\r
-    stopPropagation : function(e){   // missing from prototype?\r
-        e = e.browserEvent || e;\r
-        if(e.stopPropagation) {\r
-            e.stopPropagation();\r
-        } else {\r
-            e.cancelBubble = true;\r
-        }\r
-    },\r
-\r
-    stopEvent : function(e){\r
-        Event.stop(e.browserEvent || e);\r
-    },\r
-\r
-    onAvailable : function(id, fn, scope){  // no equiv\r
-        var start = new Date(), iid;\r
-        var f = function(){\r
-            if(start.getElapsed() > 10000){\r
-                clearInterval(iid);\r
-            }\r
-            var el = document.getElementById(id);\r
-            if(el){\r
-                clearInterval(iid);\r
-                fn.call(scope||window, el);\r
-            }\r
-        };\r
-        iid = setInterval(f, 50);\r
-    }\r
-};\r
-\r
-Ext.lib.Ajax = function(){\r
-    var createSuccess = function(cb){\r
-         return cb.success ? function(xhr){\r
-            cb.success.call(cb.scope||window, {\r
-                responseText: xhr.responseText,\r
-                responseXML : xhr.responseXML,\r
-                argument: cb.argument\r
-            });\r
-         } : Ext.emptyFn;\r
-    };\r
-    var createFailure = function(cb){\r
-         return cb.failure ? function(xhr){\r
-            cb.failure.call(cb.scope||window, {\r
-                responseText: xhr.responseText,\r
-                responseXML : xhr.responseXML,\r
-                argument: cb.argument\r
-            });\r
-         } : Ext.emptyFn;\r
-    };\r
-    return {\r
-        request : function(method, uri, cb, data, options){\r
-            var o = {\r
-                method: method,\r
-                parameters: data || '',\r
-                timeout: cb.timeout,\r
-                onSuccess: createSuccess(cb),\r
-                onFailure: createFailure(cb)\r
-            };\r
-            if(options){\r
-                var hs = options.headers;\r
-                if(hs){\r
-                    o.requestHeaders = hs;\r
-                }\r
-                if(options.xmlData){\r
-                    method = (method ? method : (options.method ? options.method : 'POST'));\r
-                    if (!hs || !hs['Content-Type']){\r
-                        o.contentType = 'text/xml';\r
-                    }\r
-                    o.postBody = options.xmlData;\r
-                    delete o.parameters;\r
-                }\r
-                if(options.jsonData){\r
-                    method = (method ? method : (options.method ? options.method : 'POST'));\r
-                    if (!hs || !hs['Content-Type']){\r
-                        o.contentType = 'application/json';\r
-                    }\r
-                    o.postBody = typeof options.jsonData == 'object' ? Ext.encode(options.jsonData) : options.jsonData;\r
-                    delete o.parameters;\r
-                }\r
-            }\r
-            new Ajax.Request(uri, o);\r
-        },\r
-\r
-        formRequest : function(form, uri, cb, data, isUpload, sslUri){\r
-            new Ajax.Request(uri, {\r
-                method: Ext.getDom(form).method ||'POST',\r
-                parameters: Form.serialize(form)+(data?'&'+data:''),\r
-                timeout: cb.timeout,\r
-                onSuccess: createSuccess(cb),\r
-                onFailure: createFailure(cb)\r
-            });\r
-        },\r
-\r
-        isCallInProgress : function(trans){\r
-            return false;\r
-        },\r
-\r
-        abort : function(trans){\r
-            return false;\r
-        },\r
-        \r
-        serializeForm : function(form){\r
-            return Form.serialize(form.dom||form);\r
-        }\r
-    };\r
-}();\r
-\r
-\r
-Ext.lib.Anim = function(){\r
-    \r
-    var easings = {\r
-        easeOut: function(pos) {\r
-            return 1-Math.pow(1-pos,2);\r
-        },\r
-        easeIn: function(pos) {\r
-            return 1-Math.pow(1-pos,2);\r
-        }\r
-    };\r
-    var createAnim = function(cb, scope){\r
-        return {\r
-            stop : function(skipToLast){\r
-                this.effect.cancel();\r
-            },\r
-\r
-            isAnimated : function(){\r
-                return this.effect.state == 'running';\r
-            },\r
-\r
-            proxyCallback : function(){\r
-                Ext.callback(cb, scope);\r
-            }\r
-        };\r
-    };\r
-    return {\r
-        scroll : function(el, args, duration, easing, cb, scope){\r
-            // not supported so scroll immediately?\r
-            var anim = createAnim(cb, scope);\r
-            el = Ext.getDom(el);\r
-            if(typeof args.scroll.to[0] == 'number'){\r
-                el.scrollLeft = args.scroll.to[0];\r
-            }\r
-            if(typeof args.scroll.to[1] == 'number'){\r
-                el.scrollTop = args.scroll.to[1];\r
-            }\r
-            anim.proxyCallback();\r
-            return anim;\r
-        },\r
-\r
-        motion : function(el, args, duration, easing, cb, scope){\r
-            return this.run(el, args, duration, easing, cb, scope);\r
-        },\r
-\r
-        color : function(el, args, duration, easing, cb, scope){\r
-            return this.run(el, args, duration, easing, cb, scope);\r
-        },\r
-\r
-        run : function(el, args, duration, easing, cb, scope, type){\r
-            var o = {};\r
-            for(var k in args){\r
-                switch(k){   // scriptaculous doesn't support, so convert these\r
-                    case 'points':\r
-                        var by, pts, e = Ext.fly(el, '_animrun');\r
-                        e.position();\r
-                        if(by = args.points.by){\r
-                            var xy = e.getXY();\r
-                            pts = e.translatePoints([xy[0]+by[0], xy[1]+by[1]]);\r
-                        }else{\r
-                            pts = e.translatePoints(args.points.to);\r
-                        }\r
-                        o.left = pts.left+'px';\r
-                        o.top = pts.top+'px';\r
-                    break;\r
-                    case 'width':\r
-                        o.width = args.width.to+'px';\r
-                    break;\r
-                    case 'height':\r
-                        o.height = args.height.to+'px';\r
-                    break;\r
-                    case 'opacity':\r
-                        o.opacity = String(args.opacity.to);\r
-                    break;\r
-                    default:\r
-                        o[k] = String(args[k].to);\r
-                    break;\r
-                }\r
-            }\r
-            var anim = createAnim(cb, scope);\r
-            anim.effect = new Effect.Morph(Ext.id(el), {\r
-                duration: duration,\r
-                afterFinish: anim.proxyCallback,\r
-                transition: easings[easing] || Effect.Transitions.linear,\r
-                style: o\r
-            });\r
-            return anim;\r
-        }\r
-    };\r
-}();\r
-\r
-\r
-// all lib flyweight calls use their own flyweight to prevent collisions with developer flyweights\r
-function fly(el){\r
-    if(!libFlyweight){\r
-        libFlyweight = new Ext.Element.Flyweight();\r
-    }\r
-    libFlyweight.dom = el;\r
-    return libFlyweight;\r
-}\r
-    \r
-Ext.lib.Region = function(t, r, b, l) {\r
-    this.top = t;\r
-    this[1] = t;\r
-    this.right = r;\r
-    this.bottom = b;\r
-    this.left = l;\r
-    this[0] = l;\r
-};\r
-\r
-Ext.lib.Region.prototype = {\r
-    contains : function(region) {\r
-        return ( region.left   >= this.left   &&\r
-                 region.right  <= this.right  &&\r
-                 region.top    >= this.top    &&\r
-                 region.bottom <= this.bottom    );\r
-\r
-    },\r
-\r
-    getArea : function() {\r
-        return ( (this.bottom - this.top) * (this.right - this.left) );\r
-    },\r
-\r
-    intersect : function(region) {\r
-        var t = Math.max( this.top,    region.top    );\r
-        var r = Math.min( this.right,  region.right  );\r
-        var b = Math.min( this.bottom, region.bottom );\r
-        var l = Math.max( this.left,   region.left   );\r
-\r
-        if (b >= t && r >= l) {\r
-            return new Ext.lib.Region(t, r, b, l);\r
-        } else {\r
-            return null;\r
-        }\r
-    },\r
-    union : function(region) {\r
-        var t = Math.min( this.top,    region.top    );\r
-        var r = Math.max( this.right,  region.right  );\r
-        var b = Math.max( this.bottom, region.bottom );\r
-        var l = Math.min( this.left,   region.left   );\r
-\r
-        return new Ext.lib.Region(t, r, b, l);\r
-    },\r
-\r
-    constrainTo : function(r) {\r
-            this.top = this.top.constrain(r.top, r.bottom);\r
-            this.bottom = this.bottom.constrain(r.top, r.bottom);\r
-            this.left = this.left.constrain(r.left, r.right);\r
-            this.right = this.right.constrain(r.left, r.right);\r
-            return this;\r
-    },\r
-\r
-    adjust : function(t, l, b, r){\r
-        this.top += t;\r
-        this.left += l;\r
-        this.right += r;\r
-        this.bottom += b;\r
-        return this;\r
-    }\r
-};\r
-\r
-Ext.lib.Region.getRegion = function(el) {\r
-    var p = Ext.lib.Dom.getXY(el);\r
-\r
-    var t = p[1];\r
-    var r = p[0] + el.offsetWidth;\r
-    var b = p[1] + el.offsetHeight;\r
-    var l = p[0];\r
-\r
-    return new Ext.lib.Region(t, r, b, l);\r
-};\r
-\r
-Ext.lib.Point = function(x, y) {\r
-   if (Ext.isArray(x)) {\r
-      y = x[1];\r
-      x = x[0];\r
-   }\r
-    this.x = this.right = this.left = this[0] = x;\r
-    this.y = this.top = this.bottom = this[1] = y;\r
-};\r
-\r
-Ext.lib.Point.prototype = new Ext.lib.Region();\r
-\r
-\r
-// prevent IE leaks\r
-if(Ext.isIE) {\r
-    function fnCleanUp() {\r
-        var p = Function.prototype;\r
-        delete p.createSequence;\r
-        delete p.defer;\r
-        delete p.createDelegate;\r
-        delete p.createCallback;\r
-        delete p.createInterceptor;\r
-\r
-        window.detachEvent("onunload", fnCleanUp);\r
-    }\r
-    window.attachEvent("onunload", fnCleanUp);\r
-}\r
-})();
\ No newline at end of file