From a8b177aebfd480eecb0c30d8ea0f226e35558634 Mon Sep 17 00:00:00 2001 From: jquense Date: Sun, 28 Jun 2015 22:44:49 -0400 Subject: [PATCH] [fixed] Stack overflow with nested Modals fixes #893 in the same way tbs fixes it, only allow one listener at a time --- src/Modal.js | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/src/Modal.js b/src/Modal.js index 3a28a7ff62..41b0d51b6e 100644 --- a/src/Modal.js +++ b/src/Modal.js @@ -31,9 +31,16 @@ function getContainer(context){ domUtils.ownerDocument(context).body; } + + +let currentFocusListener; + /** * Firefox doesn't have a focusin event so using capture is easiest way to get bubbling * IE8 can't do addEventListener, but does have onfocusin, so we use that in ie8 + * + * We only allow one Listener at a time to avoid stack overflows + * * @param {ReactElement|HTMLElement} context * @param {Function} handler */ @@ -42,6 +49,9 @@ function onFocus(context, handler) { let useFocusin = !doc.addEventListener; let remove; + if ( currentFocusListener ) + currentFocusListener.remove(); + if (useFocusin) { document.attachEvent('onfocusin', handler); remove = () => document.detachEvent('onfocusin', handler); @@ -49,7 +59,10 @@ function onFocus(context, handler) { document.addEventListener('focus', handler, true); remove = () => document.removeEventListener('focus', handler, true); } - return { remove }; + + currentFocusListener = { remove } + + return currentFocusListener; } let scrollbarSize;