-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Sentiment poll and small feedback thread #1
Comments
It feels like an elegant solution, but I have a few concerns:
|
I think that people end up with the Shadow DOM (and thus the current problem case) because there's no way to write basic modular markup and style those modular structures. In my case, I often simply want a form of "namespacing" for plain, light DOM structures and selectors. (For which people invented class naming conventions like BEM, I guess.) I wrote about it here: How do you make components? <div>
<h2 id="foo">will be green</h2>
<div namespace>
<h3 id="foo">will be red</h3>
</div>
<style>
/* to all #foo */
#foo { color: red; }
/* to #foo in current (global) namespace */
#~foo { color: green; }
</style>
</div> It's part of a bigger story I developed as OOHTML and it goes with a JavaScript implementation that lets us play with the idea. |
My feedback:
|
Just want to reply to a few things in case there's confusion
A real proposal (probably) wouldn't use
This kind of feedback is why i created this sentiment poll. I understand that not everyone can actually use it. An emjoi isn't accurate, but feedback, but they're easy enough.
I haven't talked to anyone no, but it's not a proposal. The last thing wasn't a proposal either. They are us trying to figure out what we want, and what is going to work for developers. It might be one of these, or something else. If people have this problem, and they can use this, then it should help them and there is nothing to object to because it is literally how things already work. I can say that if we approach the problem with some data showing that this is actually a useful and necessary kind of thing to a lot of people, this is just an easier discussion than if we are speculating. |
In this thread: https://mastodon.social/@westbrook/111745107269022735 and this accidentally detached thread: https://mastodon.social/@westbrook/111745113717336060 I attempted to gather a handful of user stories that I think apply to this space. Is the lack of response a judgment of the problem space? Likely not. Is it a judgment of my "brand reach"? Likely so. There are a million things that could be done in this space, but I feel you'd have a hard time finding one that serves enough use cases for it to get traction here. As far as the user stories, I think that this takes a run at:
and
and
However, the more I think about them the more I'm struck by their being a theoretical extension of
Wherein in all likelihood the developer doesn't actually want a "component" with Shadow DOM. By the time you get to this space, it feels much more like the developer is grasping at the closest things to "templating" in the platform and then angry about the platform not actually having templating and then venting about that in the form of saying that Shadow DOM should have an expanded feature set. Simply stated: Do "component" consumers want "open-stylable shadow roots" or do they simply want packageable templating? Maybe there is a world wherein one is the other and both, but it seems like we're stretching for APIs because "this is all we have" rather than driving for the actual APIs we want here. I love Shadow DOM, love writing elements with Shadow DOM, and benefit greatly from the way it separates the concerns of my applications, and most of the reasons begin to fall apart when allowing a consumer to address styles and functionality against those DOM trees beyond my blessing. Would my work have more consumers were this sort of approach possible? Maybe. Would the added costs of maintaining a larger API surface balance that out? Likely not. I do not think it directly serves any of the above use cases, but as I hear the conversations and possible paths to addressing the space go back and forth, I am quite interested in the ability to share/transport
And, FINALLY have control over not just the same in third-party shadow roots, but also the ever-elusive:
Then app authors would have a path to cajoling the contents of shadow root to look a specific way, but the component author would still win when they apply DOM-tree local styles and no specific API (CSS Custom Properties or |
I tend to agree with @Westbrook's take. In general, I think that there are 2 use cases at odds here:
This proposal actively harms the first use case (by allowing consumers to override e.g. closed roots) and it doesn't help the second (since the stylesheet author needs to make changes). Maybe there is some other middle-ground use case that is served by it, but as Westbrook said, you probably just want templating or compile-time framework "slots" at that point. (At least then you would also get "scoped slots" [i.e. lists/virtual lists] to boot.) BTW I really appreciate you taking the time to gather all these use cases and solutions together and to provoke the conversation! This is a devilish problem, and I don't think the solutions are obvious. |
@nolanlawson your 2nd bullet was, I agree, a potential issue. You can do that with half-light now |
@Westbrook I can't make you able to replace UA sheets, but I did introduce layering! |
Please leave an emoji reaction to this comment to let me know how you feel about this repo's solution as a shape of solving some use cases for "open-stylable" Shadow Roots
Feel free to just drop comments small comments here as well if you need just a little bit more but don't feel like it's worth an issue of its own.
The text was updated successfully, but these errors were encountered: