From d3025968f349c37a8ca41bfc63ee1b37d9d7354f Mon Sep 17 00:00:00 2001 From: Scott González Date: Fri, 25 Sep 2015 10:33:58 -0400 Subject: Focusable: Fix handling of `visibility: inherit` Ref #14596 Ref gh-1583 Closes gh-1605 --- ui/focusable.js | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) (limited to 'ui') diff --git a/ui/focusable.js b/ui/focusable.js index 942f0fed3..6b7a0b1f1 100644 --- a/ui/focusable.js +++ b/ui/focusable.js @@ -42,9 +42,20 @@ $.ui.focusable = function( element, hasTabindex ) { "a" === nodeName ? element.href || hasTabindex : hasTabindex ) && - $( element ).is( ":visible" ) && $( element ).css( "visibility" ) === "visible"; + $( element ).is( ":visible" ) && visible( $( element ) ); }; +// Support: IE 8 only +// IE 8 doesn't resolve inherit to visible/hidden for computed values +function visible( element ) { + var visibility = element.css( "visibility" ); + while ( visibility === "inherit" ) { + element = element.parent(); + visibility = element.css( "visibility" ); + } + return visibility !== "hidden"; +} + $.extend( $.expr[ ":" ], { focusable: function( element ) { return $.ui.focusable( element, $.attr( element, "tabindex" ) != null ); -- cgit v1.2.3