WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
170762
Updating class name of a shadow host does not update the style applied by descendants of :host()
https://bugs.webkit.org/show_bug.cgi?id=170762
Summary
Updating class name of a shadow host does not update the style applied by des...
Ryosuke Niwa
Reported
2017-04-11 21:28:49 PDT
https://trac.webkit.org/changeset/202227
fixed the case where :host rule applies to itself, but not any rules that apply styles to its descendants.
Attachments
patch
(15.63 KB, patch)
2017-05-11 08:10 PDT
,
Antti Koivisto
rniwa
: review+
Details
Formatted Diff
Diff
patch
(15.96 KB, patch)
2017-05-12 05:03 PDT
,
Antti Koivisto
no flags
Details
Formatted Diff
Diff
Show Obsolete
(1)
View All
Add attachment
proposed patch, testcase, etc.
Ryosuke Niwa
Comment 1
2017-04-11 21:29:27 PDT
See
http://jsbin.com/masaxeq/edit?html,output
Radar WebKit Bug Importer
Comment 2
2017-04-11 21:29:53 PDT
<
rdar://problem/31572668
>
vpusher
Comment 3
2017-04-18 09:27:40 PDT
Experiencing the same issue with my custom element (game-card) but with an attribute selector: :host([unrevealed]) #flipper
> We can see the rule appear and match in the dev tools (transform: rotateY...), but the styles are not really applied to the #flipper element (the card should rotate on the Y axis, like it was flipped).
You can inspect it there:
https://www.webcomponents.org/element/vpusher/game-card
> Click on the card to toggle the 'unrevealed' attribute on the host, then check the #flipper styles.
The thing is, if you uncheck, then check the rule in the dev tools, it applies properly. Hope I helped.
Ryosuke Niwa
Comment 4
2017-05-08 18:35:24 PDT
***
Bug 169706
has been marked as a duplicate of this bug. ***
Antti Koivisto
Comment 5
2017-05-11 08:10:07 PDT
Created
attachment 309710
[details]
patch
Ryosuke Niwa
Comment 6
2017-05-11 14:17:19 PDT
Comment on
attachment 309710
[details]
patch View in context:
https://bugs.webkit.org/attachment.cgi?id=309710&action=review
> Source/WebCore/css/RuleSet.cpp:208 > + return leftmostSelector->match() == CSSSelector::PseudoClass && leftmostSelector->pseudoClassType() ==CSSSelector::PseudoClassHost;
Nit: Need a space after the second ==.
> Source/WebCore/css/RuleSet.h:218 > + bool m_hasHostPseudoClassRulesMatchingInShadowTree { false };
You might wanna put this next to another boolean for better packing not that it matters much.
> LayoutTests/fast/shadow-dom/css-scoping-host-class-and-attribute-mutation.html:108 > +test("#host4", "#shadow4", (host) => { > + host.setAttribute('id','green'); > +});
Could you also add a variant for modifying ID/class/attribute of a node inside the shadow tree?
Antti Koivisto
Comment 7
2017-05-12 05:03:53 PDT
Created
attachment 309889
[details]
patch
WebKit Commit Bot
Comment 8
2017-05-12 05:31:52 PDT
Comment on
attachment 309889
[details]
patch Clearing flags on attachment: 309889 Committed
r216761
: <
http://trac.webkit.org/changeset/216761
>
WebKit Commit Bot
Comment 9
2017-05-12 05:31:54 PDT
All reviewed patches have been landed. Closing bug.
ijaltllu
Comment 10
2021-05-03 22:12:23 PDT
Comment hidden (spam)
_legacyUndefinedCheck: true
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug