-
Notifications
You must be signed in to change notification settings - Fork 195
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: e094501 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: 1.73 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
fc916f1
to
9d7f088
Compare
f9af38a
to
c6a5402
Compare
Alrighty!
@jawinn and I discussed the label visible in this component and (apparently) SWC doesn't have the label as part of the component and the consensus was that we didn't need to include it at this point.
I added a
I can reproduce this issue too, but haven't been able to sort out why it's happening yet. 🤔 |
c6a5402
to
afac5f7
Compare
afac5f7
to
d53abe8
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.
Looking great! I love the improvements to Storybook, and for whatever reason the keyboard focus issue has resolved itself! 🎉
One minor nitpick about the --spectrum-colorslider-fill-color-disabled
custom prop.
2a0e1c5
to
e094501
Compare
isDisabled, | ||
isFocused: { | ||
...isFocused, | ||
if: { arg: "isDisabled", truthy: false }, | ||
}, | ||
gradientStops: { | ||
name: "Gradient stops", | ||
color: { |
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.
This arg renaming also needs to be reflected in the colorslider.test.js
file.
And in the Alpha
story (not currently displaying correctly).
The Vertical
story gradient also looks like it's in the wrong direction, so that needs an adjustment.
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