-
Notifications
You must be signed in to change notification settings - Fork 682
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
[css-cascade-5] Add a R/W CSSStyleSheet.layer
attribute for the layer name
#7002
Comments
Sounds good to me; this is an obvious hole currently both on the reading side (can't tell from inspection if a stylesheet was imported or linked with a layer) and on the writing side (can't have constructed sheets with the equivalent functionality of importing/linking into a particular layer). |
How should anonymous layers work? Maybe represent them with the empty string? |
Yes. This is also consistent with how |
Ah, we should match that name, too, and use |
(Or switch them both to |
The CSS Working Group just discussed
The full IRC log of that discussion<TabAtkins> Topic: Add a .layer attribute to CSSSTyleSheet<TabAtkins> github: https://github.com//issues/7002 <TabAtkins> fantasai: So it just seemed reasonable to add, and discussion suggests it should be called .layerName to match the CSSLayerRule <TabAtkins> astearns: And using .layerName is preferable to switching both to .layer? <TabAtkins> fantasai: I'm open to both. <smfr> prefer layerName <TabAtkins> astearns: I think .layerName does suggest a string rather than an object, so it seems slightly more clear <emilio> q+ <astearns> ack emilio <TabAtkins> emilio: does @import allow us to set this on import, so we can make it immutable? <fantasai_> TabAtkins: If this stylesheet is reflecting from a <link>, that's changeable in HTML <fantasai_> TabAtkins: maybe we could make it immutable in the API? <TabAtkins> emilio: Link mutations already have steps to recreate the stylesheet object <TabAtkins> emilio: So that would trigger the same as changing media='' <TabAtkins> emilio: Which creates a new stylesheet <TabAtkins> TabAtkins: What about constructed stylesheets? <TabAtkins> emilio: Hopefully we can set it in the constructor - it already has an option bag for things like baseURI, which also is immutable. Hopefully we can follow the same pattern. <TabAtkins> TabAtkins: I'm fine with that. <TabAtkins> emilio: The original issue uses @import syntax, which requires using an extra argument object somewhere to preserve the mime type... <TabAtkins> TabAtkins: Don't understand <TabAtkins> emilio: When you use importSheet() <TabAtkins> scratch last line <TabAtkins> emilio: When you use `import sheet from style.css`, can you set the layer there? <TabAtkins> emilio: I think in JS you have a trailing object that lets you set the mimetype? <TabAtkins> TabAtkins: Yes, but I'm unsure whether that's meant to be just assertions or can have extra data <TabAtkins> astearns: Sounds like we can resolve on .layerName? <TabAtkins> TabAtkins: And on makign it readonly unless that's killer for the JS ipmort syntax <TabAtkins> emilio: Agreed <TabAtkins> astearns: objections? <TabAtkins> RESOLVED: Add .layerName to CSSStyleSheet as a readonly attribute. <emeyer> scribenick emeyer |
If it's a readonly attribute, how do we support the JS import syntax (which is the major use case I'd like to support)? We don't explicitly call its constructor so we can't pass the layer name in that way.
@tabatkins When you said "yes", were you talking about setting the layer or the mimetype? |
"yes" to trailing object; I just wasn't sure if it's meant to be able to carry additional data beyond the mime type. |
Then the resolution is inadequate. We still need a way to make it work on the JS-imported style modules. The easiest way that I can see is still to make it writable on constructed stylesheets. |
@xiaochengh can't the trailing object carry the layer name? If not, why not? |
Sorry I misunderstood. Didn't realize you were talking about import assertion. Yeah, we can pass a layer name there. There's also one thing that I think we missed in the previous discussion. The same sheet can be imported for multiple times into different layers (e.g., when used by different modules), which means we need to make sure that each import creates a different |
Agenda+ to get @xiaochengh's question answered:
@fantasai and I are not clear on the answer. |
If CSSStyleSheet instances are not unique to their usage, and one can be imported in multiple places, then we can't have a layerName attribute. Instead, the importing mechanism needs to accept/track the layer name. |
The CSS Working Group just discussed
The full IRC log of that discussion<emilio> Topic: CSSStyleSheet.layer<emilio> github:https://github.com//issues/7002 <emilio> miriam: we resolved on the main question, a CSStyleSheet.layer <emilio> ... another question came up that fantasai and me weren't sure how to answer <emilio> ... can the same sheet be imported in different layers <emilio> ... is it guaranteed that different imports end up with different sheets or do we need to track all the different names? <Rossen_> q? <emilio> q+ <Rossen_> ack emilio <heycam> emilio: the CSSOM guarantees each @import rule should be a different style sheet <fantasai> emilio: The CSSOM guarantees that each @import rule should be a different style sheet <heycam> ... so I think we're good <emilio> RESOLVED: No change to the previous resolution <heycam> emilio: Xiaocheng is talking about CSS Imports, not @import <heycam> ... I don't know how CSS Modules behave, if they always create the same style sheet object, or multiple <heycam> ... I was talking about @import rules <heycam> ... presumably if Xiaocheng is asking, they must only create a single object <dbaron> not sure if https://github.com/WICG/webcomponents/blob/gh-pages/proposals/css-modules-v1-explainer.md is still accurate <heycam> chrishtr: we should continue to research then get back to the issue <heycam> dbaron: I have some memory of a discussion in a TAG review about whethehr they create separate objects, can't remember the conclusion <dbaron> https://github.com/w3ctag/design-reviews/issues/405 <emilio> Rossen_: let's re-discuss when Xiaocheng is back |
@dandclark do you know the answer to @xiaochengh's question? |
CSS module scripts are defined here https://html.spec.whatwg.org/multipage/webappapis.html#creating-a-css-module-script which is called from https://html.spec.whatwg.org/multipage/webappapis.html#fetch-a-single-module-script |
Based on my memory from the CSS Modules TAG review (and a quick re-read to refresh my memory) in w3ctag/design-reviews#405, part of the idea of CSS modules is definitely that they are a new mechanism that allows the same stylesheet object to be referenced from multiple places, and then be used by adding to However, there was an issue related to |
Separate imports of a CSSStyleSheet from a given URL will share the same stylesheet instance. This is analogous to how multiple imports of a given JS module reuse the same module. That seems to be problematic for |
There's been discussion in the past about extending the import stylesA from "./style1.css" assert { type: "css"} with {layerName: "foo"}; // Creates stylesheet instance
import stylesB from "./style1.css" assert { type: "css"} with {layerName: "foo"}; // Same instance as stylesA
import stylesC from "./style1.css" assert { type: "css"} with {layerName: "bar"}; // New instance because value in `with` clause is different But this would require a syntax change going through TC39. |
(Edit: fixed some details on settings)
I'm proposing extending the
CSSStyleSheet
interface with a new attribute,layer
.On getting, it should return the layer name if the sheet is entirely in some cascade layer. In particular:
@import
-ed stylesheet, return thelayerName
attribute value of theCSSImportRule
<link>
element (depending on Allow authors to apply new css features (like cascade layers) while linking stylesheets whatwg/html#7540), then return the name of that layernull
On setting:
The primary use case is to allow adding layered constructed stylesheets, especially if the stylesheet is a 3rd party CSS module, and we want to use that to set up a web component (which we currently don't have a good way to make it layered):
The text was updated successfully, but these errors were encountered: