Bug 205531

Summary: :focus pseudo class fails to repaint on a shadow host when focus moves from outside the page inside a shadow tree
Product: WebKit Reporter: Russell Bicknell <bicknellr>
Component: CSSAssignee: Ryosuke Niwa <rniwa>
Status: RESOLVED FIXED    
Severity: Normal CC: rniwa, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: Safari Technology Preview   
Hardware: Mac   
OS: macOS 10.14   
Bug Depends on:    
Bug Blocks: 148695    
Attachments:
Description Flags
A page with a focusable input inside a shadow root that delegates focus.
none
screen recording of repro none

Russell Bicknell
Reported 2019-12-20 16:50:07 PST
Created attachment 386276 [details] A page with a focusable input inside a shadow root that delegates focus. Safari Technology Preview, Release 96 (Safari 13.1, WebKit 14609.1.9.7) When some part of the Safari UI outside of the web content area is focused and then focus is moved directly to an element that is a descendant of a shadow root that delegates focus, CSS rules using `:focus` to select the shadow root's host don't apply. Steps to reproduce: 1. Open the attached file "WebKit-delegatesFocus-focusSelector.html". The input inside the div should become focused and the div should have a magenta border. 2. Click somewhere on the page outside of the box to cause it to lose focus, the border should become black. 3. Click the URL bar to focus it. 4. Press the tab key (once). Or, click inside the black box (either inside or outside the contained input). The input inside the shadow root should now have focus. The input inside the div with the shadow root becomes focused but the CSS rule with the `:host(:focus)` selector does not apply. (The border of the host div should become magenta, but doesn't.) If you change System Preferences > Keyboard > Shortcuts > Full Keyboard Access to "All controls", you'll be able to tab through the other buttons in the toolbar. Using the tab key to move focus from something other than the URL bar to the input or clicking on the box still reproduces this behavior (i.e. this isn't specific to the URL bar). Also, if you add an input before the div in that page, then tab from the URL bar to that new input and then to the input inside the shadow root, the `:host(:focus)` rule *does* apply correctly, while moving focus directly from the URL bar to the input in the shadow root by clicking still does not. Another way to reproduce this is: 1. Open the attached file "WebKit-delegatesFocus-focusSelector.html". 2. Open the inspector and focus something in it (for example, the console input). 3. Close the inspector using the keyboard shortcut. 4. Refresh the page. The input will be focused by the script but the `:host(:focus)` rule still doesn't apply.
Attachments
A page with a focusable input inside a shadow root that delegates focus. (315 bytes, text/html)
2019-12-20 16:50 PST, Russell Bicknell
no flags
screen recording of repro (767.52 KB, video/quicktime)
2019-12-20 16:56 PST, Russell Bicknell
no flags
Russell Bicknell
Comment 1 2019-12-20 16:56:26 PST
Created attachment 386278 [details] screen recording of repro
Russell Bicknell
Comment 2 2019-12-20 17:41:18 PST
Chrome has the same problem but only when using the keyboard to move focus: https://bugs.chromium.org/p/chromium/issues/detail?id=1014091#c3
Radar WebKit Bug Importer
Comment 3 2019-12-21 13:43:03 PST
Ryosuke Niwa
Comment 4 2022-07-03 18:49:01 PDT
I have a fix for this bug but I'm having a difficulty writing a test.
Ryosuke Niwa
Comment 5 2022-07-03 19:13:24 PDT
EWS
Comment 6 2022-07-07 22:16:27 PDT
Committed 252261@main (e92078a985a7): <https://commits.webkit.org/252261@main> Reviewed commits have been landed. Closing PR #2047 and removing active labels.
Note You need to log in before you can comment on or make changes to this bug.