You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
{{ message }}
This repository has been archived by the owner on Dec 19, 2024. It is now read-only.
This isn't really a bug, but more of a general concern that I didn't see mentioned anywhere in the docs.
We built a theme editor inside our application that allows users to customize the colors of the application. These are applied through CSS variables. We currently have 29 variables that can be customized. The theme editor code looks something like this:
With the <paper-swatch-picker> removed from the theme editor code above, window.count was a modest 200. With the <paper-swatch-picker> line re-added, window.count was... 21428 ! With 29 color pickers, that means each color picker is adding 732 event listeners which is almost 4 times the rest of our application combined. This severely impacts the load time of our application.
This isn't exactly a bug or an issue with paper-swatch-picker, but I was surprised to not see a warning about this performance impact in the docs. I know that we can reduce the number of columns in the picker, but that sacrifices some functionality. We can also defer the loading of the theme editor until the user opens it, but then opening the theme editor will take a long time. What is the recommended way to include multiple swatch pickers on a page without killing load performance?
I think for now we will look into a way to have our variable color selectors share the same paper-swatch-picker which would presumably increase performance drastically.
I should add, we are using Polymer version 1.11.0.
The text was updated successfully, but these errors were encountered:
Sign up for freeto subscribe to this conversation on GitHub.
Already have an account?
Sign in.
Description
This isn't really a bug, but more of a general concern that I didn't see mentioned anywhere in the docs.
We built a theme editor inside our application that allows users to customize the colors of the application. These are applied through CSS variables. We currently have 29 variables that can be customized. The theme editor code looks something like this:
Sometime after making this we realized we had some serious performance issues. I made a small modification here to test a theory:
With the
<paper-swatch-picker>
removed from the theme editor code above,window.count
was a modest 200. With the<paper-swatch-picker>
line re-added,window.count
was... 21428 ! With 29 color pickers, that means each color picker is adding 732 event listeners which is almost 4 times the rest of our application combined. This severely impacts the load time of our application.This isn't exactly a bug or an issue with paper-swatch-picker, but I was surprised to not see a warning about this performance impact in the docs. I know that we can reduce the number of columns in the picker, but that sacrifices some functionality. We can also defer the loading of the theme editor until the user opens it, but then opening the theme editor will take a long time. What is the recommended way to include multiple swatch pickers on a page without killing load performance?
I think for now we will look into a way to have our variable color selectors share the same
paper-swatch-picker
which would presumably increase performance drastically.I should add, we are using Polymer version 1.11.0.
The text was updated successfully, but these errors were encountered: