Fixed event fixing (Opera provides event.srcElement, only create pageX if clientX...
[jquery.git] / src / jquery / jquery.js
index 8a0a115..330e05a 100644 (file)
@@ -1982,38 +1982,34 @@ jQuery.extend({
                },\r
 \r
                fix: function(event) {\r
-                       // fix target property, if available\r
-                       if(event.srcElement)\r
+                       // fix target property, if necessary\r
+                       if(!event.target && event.srcElement)\r
                                event.target = event.srcElement;\r
                \r
-                       // calculate pageX/Y if missing\r
-                       if(typeof event.pageX == "undefined") {\r
+                       // calculate pageX/Y if missing and clientX/Y available\r
+                       if(typeof event.pageX == "undefined" && typeof event.clientX != "undefined") {\r
                                var e = document.documentElement, b = document.body;\r
                                event.pageX = event.clientX + (e.scrollLeft || b.scrollLeft);\r
                                event.pageY = event.clientY + (e.scrollTop || b.scrollTop);\r
                        }\r
-                                       \r
-                       // check if target is a textnode (only for safari)\r
+                       // check safari and if target is a textnode\r
                        if(jQuery.browser.safari && event.target.nodeType == 3) {\r
                                // target is readonly, clone the event object\r
                                event = jQuery.extend({}, event);\r
                                // get parentnode from textnode\r
                                event.target = event.target.parentNode;\r
                        }\r
-                       \r
                        // fix preventDefault and stopPropagation\r
                        if (!event.preventDefault) {\r
                                event.preventDefault = function() {\r
                                        this.returnValue = false;\r
                                };\r
                        }\r
-                               \r
                        if (!event.stopPropagation) {\r
                                event.stopPropagation = function() {\r
                                        this.cancelBubble = true;\r
                                };\r
                        }\r
-                               \r
                        return event;\r
                }\r
        }\r