[Emotion] Convert EuiProgress#5986
Conversation
674b539 to
a60bce3
Compare
|
jenkins test this |
|
Preview documentation changes for this PR: https://eui.elastic.co/pr_5986/ |
88177fc to
c0f6d7b
Compare
5390651 to
111f321
Compare
|
@cchaos and @miukimiu, I wasn't sure if just one or both of you would be interested in reviewing this PR so I tagged both of you, but please feel free to skip if it's just one. Just to follow up from my demo today on passing props/JS variables to our Emotion styles - for completeness, this approach works well for I also investigated the nested keys approach (example in prod) that @cchaos mentioned but ended up deciding against it for
which felt more repetitive than using JS logic. I'll definitely keep nested keys in mind for future cases however, I think for this specific component a flag just "felt" like it made the code cleaner. (Also we should def document nested keys in our Emotion wiki!) |
|
Preview documentation changes for this PR: https://eui.elastic.co/pr_5986/ |
1 similar comment
|
Preview documentation changes for this PR: https://eui.elastic.co/pr_5986/ |
+ move Amsterdam override CSS into Emotion + add prefers-reduced-motion accommodation
+ pass native/determinate JS var to Emotion styles to conditionally render native vs non native CSS + remove unnecessary `::moz-progress-bar` selector - that affects the value color, not the background color, and should not have been added
- create DRY helpers for repeating native vs indeterminate selectors - start valueText styles while here - remove unnecessary isNamedColor fn/typing in favor of single var - fix playground control
+ simplify CSS: apply text styling to parent __data wrapper as opposed to both children (truncation still needs to individually be on both children) - simplify CSS: remove need for nested `+` selector by: - converting `padding-left` to `gap` - always setting text alignment to right (removes need for margin-left: auto) - always setting flex grow/flex shrink CSS (same visual effect as before)
03f0b5a to
d725a28
Compare
|
Preview documentation changes for this PR: https://eui.elastic.co/pr_5986/ |
|
@constancecchen, now that we're using emotion, is it possible to calculate a high contrast color for the |
This comment was marked as outdated.
This comment was marked as outdated.
elizabetdev
left a comment
There was a problem hiding this comment.
LGTM! 🎉
Tested in Chrome, Safari, Edge, and Firefox. I also tested using the playground and looked at the code.
|
Preview documentation changes for this PR: https://eui.elastic.co/pr_5986/ |


Summary
Converts
EuiProgressto Emotion and removes all Sass variables (no instances of usage in Kibana) and modifier classes (no usages in Kibana). I opted not to remove childeuiProgress__data,euiProgress__label, andeuiProgress__valueTextclasses for ease of hooking in for non-Emotion users, but we could easily remove them if we prefer it.I strongly recommend following along by commit, as I did some clean-up along the way that are noted in commit messages.
Things to look out for when moving styles
-inlineand-block(Logical properties)gapproperty to add margin between items if using flexeuiCantAnimateinstead for simplicity)- [ ] Anything in the backlog that could be a quick fix for that component?Nothing I saw was a quick fix- [ ] Can any still existing.jsfiles be converted to TS?QA