-
Notifications
You must be signed in to change notification settings - Fork 93
paper-styles destroy custom theme settings when used with importHref #93
Comments
Just to double check I understand what's happening, the tldr is that in an The much simpler analogy (I think) is that in your
And then later on (maybe in that same file even), you have another style:
I would expect the last write to win, so I'm going to cc our styling expert @sorvell because I don't have a good idea about a workaround here :( |
I think that this behaviour might be a problem as this means that I need to know all dependencies of all elements which might change a variable and then import them all in my main document before my custom theme. I think this breaks encapsulation. What I'm missing is an option to define a variable as constant. This would then allow to include my custom theme first and no random element would be able to mess with the value of |
@notwaldorf and @sorvell. If you look at the analysis I've been doing today of the problem in Polymer/polymer #3348 you will see that is pot luck which import of a theme happens first. Can you put these theme variables into share-styles ? |
@IntranetFactory. I found a compromise workaround for the issue. Do not load your theme directly in your html, instead in you app.js script add the following:
Its working great for me (other than 4 days ago the --text-primary-color is now the --primary-text-color variable, so I have just spent 4 hours figuring out why just one element had still not updated from my theme) |
@akc42 importHref already creates an link element dynamically. So you still need to ensure that the import of a custom theme is the absolute last element changing theme relevant vars. |
@IntranetFactory That is why I wait for the dom-change event to create the element and inject it. By that time all the top level items in your index.html page are all attached. At that point I still get a brief flash of old theme before the new one kicks in. The problem I was having was that with http/2's multiplexing some imports were arriving before others, with absolutely no control over which and when. Even though I put my theme as the very last thing to be loaded, it was so much shorter than the toolbar element that it was arriving first. Polymer processes the CSS as the element arrives and calls Polymer() with its prototype. If course lazy loading could still screw things up, but then I only see the above solution as a temporary work around. I don't know what a longer term solution would be. I suspect it would be something along the lines of |
@IntranetFactory Okay. I after talking a bit with @shans, we think an easy workaround for this might be for your custom-theme to use something that's higher specificity than So, in your |
So when I change
to
the color is not applied at all. So I think that this doesn't work. |
See my comment over here: Polymer/polymer#3348 (comment) I think you can only define a custom property in a rule that matches a custom element (which includes the |
@arthurevans do you have any alternate idea how to protect variables from a custom theme without the need to know the internals of all elements and their dependencies? |
My point is that these shouldn't be treated as internals. If you're going to expose a set of theme-able properties and mixins, you need to:
The person who's overriding these theme properties then knows exactly which files to import and which properties to override. The method @akc42 described above also works, but it has two drawbacks:
On the other hand, if you use |
From my understanding that still means that the developer who creates the main page/the theme needs to know all components which might be used and the whole dependency tree of all elements, to ensure, that all their files which define default values, are loaded before the custom theme. Whenever a component later changes its structure and e.g. moves the default definitions into a different file my applications theming might be broken. So when an internal change in the file structure of any element can break my application, I think that some reliable solution should be searched to address that or it will be hard to rely on any 3rd party components if you want to build applications which can be themed. |
@IntranetFactory I tried @arthurevans solution and is it working great! I think what @arthurevans is saying is that if you use any third party library, then by default you must import their default-style file (if they have one) in your theme module. So using paper-toolbar must mean loading paper-default styles But I agree its a pain in the backside. The problem is one of when these things get instanciated. because we already have "scopes" defined with the main app getting :root and any custom element gets own scope with (as far as I can work out) :host meaning a prototype scope and outside of host, but in the <style> element inside its getting a per instance scope. It should be possible for default styles to only go into the (prototype) scopes of the elements they are importing into. It seems to me that is where custom-styles come in, and the ability to include them in elements. If default styles were as provided as a custom style for including in your element if you needed them we wouldn't get this leakage that is causing the problem |
Actually I think I am wrong on the detail as I am still struggling with the concepts. I am currently in a styling phase of what I am doing and getting the correct margins round paper card elements is an interesting excercise. I am not sure I have :host correct. It seems to apply to just the outside view of the element where as the rest of the css applies internally. - but I not even sure about that at the moment. Nevertheless, the main thrust of what I am saying is still correct |
When an element which imports paper-styles.html is loaded with importHref then custom theme settings get destroyed.
For example:
I have a basic custom theme defining just the value for one variable
In static.html this variable changes the color of a paper-checkbox as expected to red:
In failing.html I use importHref to import the paper-checkbox
and now my-theme is overridden by paper-styles and reverts the checkbox color back to indigo
I understand why this currently happens.
I think paper-styles should not be able to just revert my custom theme settings.
The text was updated successfully, but these errors were encountered: