-
Notifications
You must be signed in to change notification settings - Fork 198
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
feat(colorslider): S2 migration #3424
base: spectrum-two
Are you sure you want to change the base?
Conversation
🦋 Changeset detectedLatest commit: 4fd06b6 The changes in this PR will be included in the next version bump. This PR includes changesets to release 1 package
Not sure what this means? Click here to learn what changesets are. Click here if you're a maintainer who wants to add another changeset to this PR |
🚀 Deployed on https://pr-3424--spectrum-css.netlify.app |
File metricsSummaryTotal size: 2.23 MB* Table reports on changes to a package's main file. Other changes can be found in the collapsed Details section below.
Detailscolorslider
* Results are not gzipped or minified. * An ASCII character in UTF-8 is 8 bits or 1 byte. |
b516928
to
97aad9d
Compare
cdb180d
to
27d01df
Compare
ea0cb43
to
295161b
Compare
295161b
to
ff4309f
Compare
Per design we can ignore the spacing tokens as they're not required for the implementation (alignment of the handle within the color slide is handled by this rule: .spectrum-ColorSlider-handle {
inset-inline-start: 0;
inset-block-start: 50%;
} |
ff4309f
to
37a6f2c
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Migration-wise, this looks fine, since not a lot needed to change here! I have a few other recommendations though:
CSS
I have a few recommendations for the CSS that would make this file more consistent with some of the other migration work that's been done:
- Generally, we've been moving forced-colors media query blocks to the bottom in recent migrations (see feat(colorarea): S2 migration #3388, feat(tooltip): S2 migration #2743, or feat(statuslight): s2 migration #2818 for instance), and I see that Color Slider's is still further up in the CSS file, that could probably be moved down.
- We have this line:
I'm really not sure why that
block-size: var(--mod-color-slider-control-track-width, var(--spectrum-color-control-track-width));
color-control-track-width
token has that name, but it seems like a good idea to create an alias custom property for this, especially given that its token name doesn't match its mod name, something like this, we can even take the word "control" out and change the mod name completely, up to you:/* Up at the topmost .spectrum-ColorSlider block */ --spectrum-color-slider-control-track-width: var(--spectrum-color-control-track-width); /* further down in the code, same place it is now */ block-size: var(--mod-color-slider-control-track-width, var(--spectrum-color-slider-control-track-width));
- In that same vein, we could also alias the global token for the disabled background color that we have here, similar to how it's done in Color Wheel, Picker, or Search, for instance:
--spectrum-color-slider-border-color-local: var(--highcontrast-color-slider-border-color-disabled, var(--mod-color-slider-border-color-disabled, var(--spectrum-disabled-background-color))); background: var(--highcontrast-color-slider-background-color-disabled, var(--mod-color-slider-background-color-disabled, var(--spectrum-disabled-background-color)));
- There's also an unused token for the spacing between the field label and the color slider, but this isn't new. I don't know if there's some specific reason we're not adding the label to this implementation (Slider has a label that we display), but it feels like something we ought to be doing. Feel free to get more opinions on this one.
Storybook
Otherwise, this component could probably benefit from a few Storybook enhancements similar to what we added for several of our other components back when we were doing docs to storybook migrations (this component got migrated early on, before we decided that we would be doing that kind of thing):
- Being able to change the colors in the slider from the Storybook controls or add an image (Swatch on main added this with the docs to storybook migration docs(swatch,swatchgroup,table,tabs): docs migrations to storybook #2925, so we might be able to copy that over)
- A control to be able to view the vertical variant from the default story in Storybook. In this branch, all the variants are showing, but on
main
, on the default variant is visible and the others are used just for display purposes on the Docs page, that's probably where we'd like to end up one day whenspectrum-two
has some of those docs changes from main.
Last thing! I can't use the keyboard to focus on the slider handle (I can in main
, but not on this branch or spectrum-two
), this may not be a big deal, but I'm curious about why it's happening.
b68e2a2
to
d101918
Compare
e6d16bd
to
fc916f1
Compare
2a0e1c5
to
e094501
Compare
2f16d17
to
cdaf090
Compare
cdaf090
to
c1480ba
Compare
b438a55
to
46ae687
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm still seeing a few issues with the Alpha and Vertical stories being displayed on the Docs.
This'll also need some rebasing after the rebase in spectrum-two
that recently happened, which is causing the large number of changed files to be shown. It may be easier to cherry-pick your commits than to handle the conflicts (at least that's what I found in my other branch).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Alpha
It looks like the Alpha story is still using the gradientStops
arg that renamed, so it's not displaying correctly:
Prod:
Vertical
The Vertical story also still needs an update for its story in our docs, and the VRT tests file config. The gradient should be in the to bottom
direction for these instances where we set the arg value, though we talked about not needing any complicated logic if someone is manually flipping the vertical control on the Default story:
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Got it! I renamed and updated that arg and updated the gradient direction in the tests you highlighted. ✨
c1480ba
to
5a0f5d3
Compare
46ae687
to
8d65de0
Compare
a295f06
to
e2867d6
Compare
7e783b6
to
e3585cd
Compare
6f03ace
to
9e51467
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A couple of other details on the docs page that look like they still need some attention:
- This Alpha story doesn't look the same as in Foundations or main, it looks like the gradient in the args is using the same rainbow gradient rather than the previous one that included rgba values.
- The Vertical variant is improved! But it looks like it needs its handle adjusted, the color doesn't match the color next to it in the gradient and it's off-center. Previous versions showed the handle at the top which probably isn't strictly necessary, but it seems like maybe that's where the red color is coming from. Feels like a bit of a silly ask since it's not a working implementation, but would help it look the part anyway!
8796fce
to
4fd06b6
Compare
Description
CSS-1028
S2 colorslider migration
This migrates the
colorslider
component to S2. Custom properties have been remapped per the design spec.--spectrum-gray-900-rgb
--spectrum-gray-1000-rgb
Validation steps
colorslider
component and verify no regressions have occurred.Regression testing
Validate:
Screenshots
To-do list