-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
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
Replace Sass variables with CSS custom properties #21656
Comments
Yes, this would make themes a lot less painful, I think. Though we might need to clean up the themes before we get to this as currently, we have a bunch of unnecessary colour variables that we would need to deal with. I am sort of in the progress of reducing the number of colour variables we use but I am stuck on design review/input... See #19254 |
Hi @SimonBrandner, I am an outreachy applicant. Can you guide me on how to work on this issue? I have been working on an issue that is related to the UI theme switching see #19514. I think that working on this issue would enable me to fix the UI theme switching issue. |
Hi @SimonBrandner @robintown. Can you elaborate more on the issue? |
@goelesha I would not particularly recommend someone new to Element to work on this as there are a lot of undocumented things around themes and how Element is built that one will face when working on this |
I get it. I will look for some other issues to work on. Can you guide me on how can I get acquainted with the functioning of themes so that I am able to take up such issues in future? |
This comment was marked as resolved.
This comment was marked as resolved.
Another reason why this would be nice: sometimes design wants select parts of the UI to always use the dark theme colors, so with CSS variables we could keep both themes loaded with minimal overhead, and then just apply a |
@robintown only if we make themes all include both a light & dark variant but right now custom themes are not such and neither is the high contrast theme. |
The future of this, will be generated by the vector-im/compound-design-tokens repo. It outputs some CSS custom properties, and addresses most of the comment made in this conversation. |
When will that Compound stuff available approximately? In the Q2 of this year, Q3 or Q4? A hint would be appreciated, whether it is official or not. |
It already exists, https://github.com/vector-im/compound-design-tokens We will started using them in the Compound components https://github.com/vector-im/compound-web and then start replacing UI parts in Element with the components and organically grow their usage. |
I am wondering if the design decision making process or its result would be publicly available as documentation or something, if it does not happen on I am asking this because I am afraid that a community member's PR would be rejected because it did not follow the design spec, though the existence of the spec was not well shared due to information asymmetry. |
If replacing Sass variables will not happen, let's just close the issue to clarify the situation. |
The tokens themselves are the results of design decisions. While we're bootstrapping this project community contributions can happen but we want to also get confidence in our approach so we can promote consistent way of achieving things.
Don't get me wrong, it will happen. I just don't advocate for community contributors to go ahead and start replacing values at this stage. We don't think we're quite ready for that yet. |
Right, I did not notice the line below on #21656 (comment):
It would be appreciated if you or someone who is an employee would announce to the community some way when it gets ready. Updating documentation would be fine too. Thanks in advance. |
Your use case
What would you like to do?
Replace all Sass variables with CSS custom properties.
Why would you like to do it?
How would you like to achieve it?
Separate our theme files from the rest of the CSS so that they can be swapped out easily.
Have you considered any alternatives?
Not doing this if we have a good reason to continue using preprocessor variables.
Additional context
https://caniuse.com/css-variables
The text was updated successfully, but these errors were encountered: