Skip to content
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

fix(list-box): ensure size variants are in effect #4928

Merged

Conversation

asudoh
Copy link
Contributor

@asudoh asudoh commented Dec 20, 2019

This change ensures the style rule in .bx--list-box--xl for dropdown size wins over one in .bx--dropdown or any ones in application styles (for default size), by expressing that they are for non-default styles and should win order the one for the default size.

Fixes #4916.

Changelog

Changed

  • Adding .bx--list-box to the selector of size variant style rule, so it wins over the style rule for the default height.

Testing / Reviewing

Testing should make sure combo box, dropdown, multi select are not broken.

This change ensures the style rule in `.bx--list-box--xl` for dropdown
size wins over one in `.bx--dropdown` or any ones in applicatoin styles
(for default size), by expressing that they are for non-default styles
and should win order the one for the default size.

Fixes carbon-design-system#4916.
@asudoh asudoh requested a review from emyarod December 20, 2019 01:12
@asudoh asudoh requested a review from a team as a code owner December 20, 2019 01:12
@ghost ghost requested a review from dakahn December 20, 2019 01:12
@netlify
Copy link

netlify bot commented Dec 20, 2019

Deploy preview for the-carbon-components ready!

Built with commit fdf545d

https://deploy-preview-4928--the-carbon-components.netlify.com

@netlify
Copy link

netlify bot commented Dec 20, 2019

Deploy preview for carbon-components-react ready!

Built with commit fdf545d

https://deploy-preview-4928--carbon-components-react.netlify.com

@netlify
Copy link

netlify bot commented Dec 20, 2019

Deploy preview for carbon-elements failed.

Built with commit fdf545d

https://app.netlify.com/sites/carbon-elements/deploys/5e1e664d1bcd2e00087e8145

@dakahn dakahn requested review from vpicone and removed request for dakahn December 20, 2019 16:35
@vpicone vpicone self-requested a review December 31, 2019 05:22
Copy link
Contributor

@vpicone vpicone left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@asudoh I don't believe this is the correct approach. We don't want double the specificity for all listbox components it makes it very difficult to override and theme. Say for instance someone wanted to make the 'large' button larger in their theme. This would be unexpected specificity and require important or double/triple classNames.

This is also different than how we do variants in the codebase. Take Button for example: the variants (size and kind) don't use double class names to style.

@vpicone
Copy link
Contributor

vpicone commented Jan 3, 2020

Also wondering if the dropdown options should be the same size as the field. @carbon-design-system/design

Screen Shot 2020-01-03 at 3 52 07 PM

@mjabbink
Copy link

mjabbink commented Jan 3, 2020

yes. The dropdown and fields below should be same. so for 32px dd then 32px for content, and for 40 and 48px options the same I think. @jeanservaas?

@asudoh
Copy link
Contributor Author

asudoh commented Jan 4, 2020

Wrt visual design it makes sense. Given it does not seem to be in the scope of #4916, created #4951 to track that.

Wrt the CSS rule, I see the point of difference from buttons, while I think it's a sensible difference given where we are at. Just in case - Would you want to suggest an alternate approach @vpicone?

@vpicone
Copy link
Contributor

vpicone commented Jan 6, 2020

@asudoh yes, creating an exception for non-listbox implementations (vanilla) as I did in my original PR would both prevent excess specificity and allow us to use the strategy found in other variant implementations (such as button).

@asudoh
Copy link
Contributor Author

asudoh commented Jan 6, 2020

Refs: #4917 (comment)

@vpicone
Copy link
Contributor

vpicone commented Jan 7, 2020

@asudoh removing the height from dropdown and instead using the listbox styles solves the problem.

We need an exception for vanilla which does not use listbox:

  .#{$prefix}--dropdown:not(.#{$prefix}--list-box) {
    height: rem(40px);
  }

This approach means only vanilla (and even then only the dropdown) is impacted by extra specificity.

I believe this is a better approach compared to doubling the specificity for all frameworks and for all three list box components. At this point, we shouldn't be sacrificing style quality for Vanilla. Since this is a new feature, we could have made the Vanilla implementation require listbox classes to function (or even better, not introduce these variants for vanilla at all)

@asudoh
Copy link
Contributor Author

asudoh commented Jan 7, 2020

Just in case it clarifies, the list box classes cannot be applies to the legacy markup due to the nature of difference in markup.

Copy link
Member

@emyarod emyarod left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it looks like .bx--dropdown--xl is already in the stylesheet, it is just not being added to the React component. since multiselect and combobox are not present in the vanilla library and dropdown does not use listbox classes in vanilla, should we just apply the .bx--dropdown--xl class to the React component for now?

@asudoh
Copy link
Contributor Author

asudoh commented Jan 9, 2020

@emyarod Sounds 💯, now I wonder why I didn't come up with such idea... Updated.

@asudoh asudoh dismissed vpicone’s stale review January 9, 2020 23:29

Got a different technical approach.

Copy link
Member

@emyarod emyarod left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

was the selector change intentional?

@asudoh
Copy link
Contributor Author

asudoh commented Jan 13, 2020

Oops good catch @emyarod! Not sure why the wrong selectors got into the commit...

Copy link
Member

@emyarod emyarod left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

thanks for making the change, looks good to me

@asudoh asudoh merged commit 0e4d6a8 into carbon-design-system:master Jan 15, 2020
@asudoh asudoh deleted the list-box-size-variants-priority branch January 15, 2020 01:25
@vpicone
Copy link
Contributor

vpicone commented Jan 15, 2020

@joshblack @emyarod those drop down selectors were added with @asudoh’s original PR last month. They went unused in that PR (#4731)

The size functionality in react got randomly lumped in with this unrelated PR: #4999. Now this PR just wires it up?

Isn’t weird the other listbox components don’t need their own size variant classes? Or that we're still passing the size into the Listbox of dropdown?

Also the arrow is misaligned for the size variants in iOS:
DFC93455-0F75-40D0-A1E4-05338CA0CC11

@joshblack
Copy link
Contributor

@vpicone oh wow, did not realize this. How can we address this? Do we need to revert this PR?

@vpicone
Copy link
Contributor

vpicone commented Jan 15, 2020

@joshblack this was my recommendation and has context/explanation in the comments #4917

The reality is our vanilla implementation of dropdown differs from react (it doesn’t use listbox). So we have to choose the “least wrong” way to style these variants. That PR has a bunch of info on why I thought that approach was the lesser of two evils. Optimizing for parity with other listbox components and minimizing specificity.

The issue with reverting this PR is that the actual substance of the implementation (wiring the selectors to the react component) is in an unrelated PR: #4999 . That PR likely has changes we don’t want to revert.

@asudoh
Copy link
Contributor Author

asudoh commented Jan 15, 2020

.bx--dropdown--xl is actually something for use - It was introduced so that size variants can be used in legacy markup.

@vpicone
Copy link
Contributor

vpicone commented Jan 15, 2020

@asudoh So we're okay with including classes/styles for particular frameworks now?

You've now made it the implementation for React as well as legacy markup. Now React Dropdown get's size variant from both Listbox and this new Dropdown class you've added.

@asudoh
Copy link
Contributor Author

asudoh commented Jan 15, 2020

The legacy markup is not for particular frameworks, just a left-over from earlier release. That said, usage of .bx--dropdown--xl class is an interim solution until we can make a breaking change.

@vpicone
Copy link
Contributor

vpicone commented Jan 16, 2020

@asudoh legacy markup is vanilla no? The Dropdown is now styled by both these new classes you added for the “legacy system” and listbox classes.

@asudoh
Copy link
Contributor Author

asudoh commented Jan 16, 2020

As stated earlier, cleaning up legacy code can happen only when we can make a breaking change.

@vpicone
Copy link
Contributor

vpicone commented Jan 17, 2020

@asudoh but this isn’t legacy it’s a new feature. You just added these selectors: asudoh@0723836#diff-d69d1c6c9ae9007ad44b45f8f333fa3f

Were they only meant for vanilla?

@asudoh
Copy link
Contributor Author

asudoh commented Jan 18, 2020

New feature, while given it's in v10 codebase, compatibility with existing codebase in v10 needs to be taken into account.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Dropdown] xl size doesn't work
6 participants