From bba8366af48bd2c80c96e7a0f58b3e16fd736125 Mon Sep 17 00:00:00 2001
From: Dave Methvin <dave.methvin@gmail.com>
Date: Tue, 17 Sep 2013 18:51:54 -0400
Subject: Fix #14180. Allow cross-frame use of focusin/out. Close gh-1369.
 (cherry picked from commit 6d5dfa0eda2c19e8838930fafff83b596654eca2) Manually
 edited for conflicts.

---
 src/event.js | 21 ++++++++++++++-------
 1 file changed, 14 insertions(+), 7 deletions(-)

(limited to 'src')

diff --git a/src/event.js b/src/event.js
index a6f69f49f..cc0fe1700 100644
--- a/src/event.js
+++ b/src/event.js
@@ -892,22 +892,29 @@ if ( !support.changeBubbles ) {
 if ( !support.focusinBubbles ) {
 	jQuery.each({ focus: "focusin", blur: "focusout" }, function( orig, fix ) {
 
-		// Attach a single capturing handler while someone wants focusin/focusout
-		var attaches = 0,
-			handler = function( event ) {
+		// Attach a single capturing handler on the document while someone wants focusin/focusout
+		var handler = function( event ) {
 				jQuery.event.simulate( fix, event.target, jQuery.event.fix( event ), true );
 			};
 
 		jQuery.event.special[ fix ] = {
 			setup: function() {
-				if ( attaches++ === 0 ) {
-					document.addEventListener( orig, handler, true );
+				var doc = this.ownerDocument,
+					attaches = jQuery._data( doc, "focusCount" );
+
+				if ( !attaches ) {
+					doc.addEventListener( orig, handler, true );
 				}
+				jQuery._data( doc, "focusCount", ( attaches || 0 ) + 1 );
 			},
 			teardown: function() {
-				if ( --attaches === 0 ) {
-					document.removeEventListener( orig, handler, true );
+				var doc = this.ownerDocument,
+					attaches = jQuery._data( doc, "focusCount" ) - 1;
+
+				if ( !attaches ) {
+					doc.removeEventListener( orig, handler, true );
 				}
+				jQuery._data( doc, "focusCount", attaches );
 			}
 		};
 	});
-- 
cgit v1.2.3