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

Try tabs instead of segmented control for switching between solid/gradient in color panels #41937

Merged
merged 12 commits into from
Jul 11, 2022

Conversation

jameskoster
Copy link
Contributor

When picking a color, where both solid colors and gradients are available, their visibility is toggled through a component that resembles a segmented control:

Screenshot 2022-06-23 at 10 28 17

One drawback I find with this approach is that it is not a consistent implementation of the segmented control pattern when compared with other instances in our UI. When choosing a font size (for example) a selection equates with an actual value, whereas with colors the value isn't set until a color swatch is clicked.

To promote consistency we might instead use tabs for switching between the solid / gradient palettes:

tabs.mp4

This feels like an appropriate use case for the TabPanel component:

TabPanels organize and allow navigation between groups of content that are related and at the same level of hierarchy.
Block Editor Handbook


A somewhat related consideration is the tab labels. Since they toggle the visibility of different palettes, and palettes typically contain more than one color, I wonder if the labels should be plural?

Screenshot 2022-06-24 at 10 38 44

This is probably something we could adjust here as well, if it is deemed appropriate.

@jameskoster jameskoster added [Type] Enhancement A suggestion for improvement. Needs Design Feedback Needs general design feedback. [Feature] Design Tools Tools that impact the appearance of blocks both to expand the number of tools and improve the experi [Feature] Colors Color management labels Jun 24, 2022
@jameskoster jameskoster requested a review from a team June 24, 2022 09:44
@github-actions
Copy link

github-actions bot commented Jun 24, 2022

Size Change: -246 B (0%)

Total Size: 1.25 MB

Filename Size Change
build/block-editor/index.min.js 152 kB +17 B (0%)
build/block-editor/style.css 14.5 kB +4 B (0%)
build/block-library/blocks/query/editor-rtl.css 365 B -4 B (-1%)
build/block-library/blocks/query/editor.css 364 B -5 B (-1%)
build/block-library/editor-rtl.css 10.2 kB +4 B (0%)
build/block-library/editor.css 10.2 kB +5 B (0%)
build/block-library/index.min.js 183 kB -281 B (0%)
build/blocks/index.min.js 47.2 kB +130 B (0%)
build/components/index.min.js 230 kB +88 B (0%)
build/components/style-rtl.css 14 kB +38 B (0%)
build/components/style.css 14 kB +39 B (0%)
build/dom/index.min.js 4.66 kB +1 B (0%)
build/edit-navigation/index.min.js 16 kB -9 B (0%)
build/edit-navigation/style-rtl.css 4.02 kB -9 B (0%)
build/edit-navigation/style.css 4.03 kB -9 B (0%)
build/edit-post/index.min.js 30.4 kB -1 B (0%)
build/edit-post/style-rtl.css 6.97 kB -73 B (-1%)
build/edit-post/style.css 6.97 kB -73 B (-1%)
build/edit-site/index.min.js 52 kB -14 B (0%)
build/edit-site/style-rtl.css 8.19 kB -86 B (-1%)
build/edit-site/style.css 8.18 kB -83 B (-1%)
build/edit-widgets/index.min.js 16.5 kB -4 B (0%)
build/edit-widgets/style-rtl.css 4.35 kB -11 B (0%)
build/edit-widgets/style.css 4.35 kB -11 B (0%)
build/editor/index.min.js 39.4 kB +118 B (0%)
build/editor/style-rtl.css 3.65 kB -21 B (-1%)
build/editor/style.css 3.65 kB -17 B (0%)
build/media-utils/index.min.js 2.93 kB +21 B (+1%)
ℹ️ View Unchanged
Filename Size
build/a11y/index.min.js 982 B
build/annotations/index.min.js 2.76 kB
build/api-fetch/index.min.js 2.26 kB
build/autop/index.min.js 2.14 kB
build/blob/index.min.js 475 B
build/block-directory/index.min.js 6.58 kB
build/block-directory/style-rtl.css 990 B
build/block-directory/style.css 991 B
build/block-editor/default-editor-styles-rtl.css 378 B
build/block-editor/default-editor-styles.css 378 B
build/block-editor/style-rtl.css 14.5 kB
build/block-library/blocks/archives/editor-rtl.css 61 B
build/block-library/blocks/archives/editor.css 60 B
build/block-library/blocks/archives/style-rtl.css 65 B
build/block-library/blocks/archives/style.css 65 B
build/block-library/blocks/audio/editor-rtl.css 150 B
build/block-library/blocks/audio/editor.css 150 B
build/block-library/blocks/audio/style-rtl.css 103 B
build/block-library/blocks/audio/style.css 103 B
build/block-library/blocks/audio/theme-rtl.css 110 B
build/block-library/blocks/audio/theme.css 110 B
build/block-library/blocks/avatar/editor-rtl.css 116 B
build/block-library/blocks/avatar/editor.css 116 B
build/block-library/blocks/avatar/style-rtl.css 59 B
build/block-library/blocks/avatar/style.css 59 B
build/block-library/blocks/block/editor-rtl.css 161 B
build/block-library/blocks/block/editor.css 161 B
build/block-library/blocks/button/editor-rtl.css 441 B
build/block-library/blocks/button/editor.css 441 B
build/block-library/blocks/button/style-rtl.css 543 B
build/block-library/blocks/button/style.css 543 B
build/block-library/blocks/buttons/editor-rtl.css 292 B
build/block-library/blocks/buttons/editor.css 292 B
build/block-library/blocks/buttons/style-rtl.css 275 B
build/block-library/blocks/buttons/style.css 275 B
build/block-library/blocks/calendar/style-rtl.css 207 B
build/block-library/blocks/calendar/style.css 207 B
build/block-library/blocks/categories/editor-rtl.css 84 B
build/block-library/blocks/categories/editor.css 83 B
build/block-library/blocks/categories/style-rtl.css 79 B
build/block-library/blocks/categories/style.css 79 B
build/block-library/blocks/code/style-rtl.css 103 B
build/block-library/blocks/code/style.css 103 B
build/block-library/blocks/code/theme-rtl.css 124 B
build/block-library/blocks/code/theme.css 124 B
build/block-library/blocks/columns/editor-rtl.css 108 B
build/block-library/blocks/columns/editor.css 108 B
build/block-library/blocks/columns/style-rtl.css 406 B
build/block-library/blocks/columns/style.css 406 B
build/block-library/blocks/comment-author-avatar/editor-rtl.css 125 B
build/block-library/blocks/comment-author-avatar/editor.css 125 B
build/block-library/blocks/comment-content/style-rtl.css 92 B
build/block-library/blocks/comment-content/style.css 92 B
build/block-library/blocks/comment-template/style-rtl.css 187 B
build/block-library/blocks/comment-template/style.css 185 B
build/block-library/blocks/comments-pagination-numbers/editor-rtl.css 123 B
build/block-library/blocks/comments-pagination-numbers/editor.css 121 B
build/block-library/blocks/comments-pagination/editor-rtl.css 222 B
build/block-library/blocks/comments-pagination/editor.css 209 B
build/block-library/blocks/comments-pagination/style-rtl.css 235 B
build/block-library/blocks/comments-pagination/style.css 231 B
build/block-library/blocks/comments-title/editor-rtl.css 75 B
build/block-library/blocks/comments-title/editor.css 75 B
build/block-library/blocks/comments/editor-rtl.css 95 B
build/block-library/blocks/comments/editor.css 95 B
build/block-library/blocks/cover/editor-rtl.css 615 B
build/block-library/blocks/cover/editor.css 616 B
build/block-library/blocks/cover/style-rtl.css 1.55 kB
build/block-library/blocks/cover/style.css 1.55 kB
build/block-library/blocks/embed/editor-rtl.css 293 B
build/block-library/blocks/embed/editor.css 293 B
build/block-library/blocks/embed/style-rtl.css 410 B
build/block-library/blocks/embed/style.css 410 B
build/block-library/blocks/embed/theme-rtl.css 110 B
build/block-library/blocks/embed/theme.css 110 B
build/block-library/blocks/file/editor-rtl.css 300 B
build/block-library/blocks/file/editor.css 300 B
build/block-library/blocks/file/style-rtl.css 253 B
build/block-library/blocks/file/style.css 254 B
build/block-library/blocks/file/view.min.js 346 B
build/block-library/blocks/freeform/editor-rtl.css 2.44 kB
build/block-library/blocks/freeform/editor.css 2.44 kB
build/block-library/blocks/gallery/editor-rtl.css 948 B
build/block-library/blocks/gallery/editor.css 950 B
build/block-library/blocks/gallery/style-rtl.css 1.5 kB
build/block-library/blocks/gallery/style.css 1.49 kB
build/block-library/blocks/gallery/theme-rtl.css 108 B
build/block-library/blocks/gallery/theme.css 108 B
build/block-library/blocks/group/editor-rtl.css 333 B
build/block-library/blocks/group/editor.css 333 B
build/block-library/blocks/group/style-rtl.css 57 B
build/block-library/blocks/group/style.css 57 B
build/block-library/blocks/group/theme-rtl.css 78 B
build/block-library/blocks/group/theme.css 78 B
build/block-library/blocks/heading/style-rtl.css 76 B
build/block-library/blocks/heading/style.css 76 B
build/block-library/blocks/html/editor-rtl.css 327 B
build/block-library/blocks/html/editor.css 329 B
build/block-library/blocks/image/editor-rtl.css 738 B
build/block-library/blocks/image/editor.css 737 B
build/block-library/blocks/image/style-rtl.css 524 B
build/block-library/blocks/image/style.css 530 B
build/block-library/blocks/image/theme-rtl.css 110 B
build/block-library/blocks/image/theme.css 110 B
build/block-library/blocks/latest-comments/style-rtl.css 284 B
build/block-library/blocks/latest-comments/style.css 284 B
build/block-library/blocks/latest-posts/editor-rtl.css 199 B
build/block-library/blocks/latest-posts/editor.css 198 B
build/block-library/blocks/latest-posts/style-rtl.css 463 B
build/block-library/blocks/latest-posts/style.css 462 B
build/block-library/blocks/list/style-rtl.css 88 B
build/block-library/blocks/list/style.css 88 B
build/block-library/blocks/media-text/editor-rtl.css 266 B
build/block-library/blocks/media-text/editor.css 263 B
build/block-library/blocks/media-text/style-rtl.css 493 B
build/block-library/blocks/media-text/style.css 490 B
build/block-library/blocks/more/editor-rtl.css 431 B
build/block-library/blocks/more/editor.css 431 B
build/block-library/blocks/navigation-link/editor-rtl.css 705 B
build/block-library/blocks/navigation-link/editor.css 703 B
build/block-library/blocks/navigation-link/style-rtl.css 115 B
build/block-library/blocks/navigation-link/style.css 115 B
build/block-library/blocks/navigation-submenu/editor-rtl.css 296 B
build/block-library/blocks/navigation-submenu/editor.css 295 B
build/block-library/blocks/navigation-submenu/view.min.js 402 B
build/block-library/blocks/navigation/editor-rtl.css 2.03 kB
build/block-library/blocks/navigation/editor.css 2.04 kB
build/block-library/blocks/navigation/style-rtl.css 1.96 kB
build/block-library/blocks/navigation/style.css 1.95 kB
build/block-library/blocks/navigation/view-modal.min.js 2.78 kB
build/block-library/blocks/navigation/view.min.js 423 B
build/block-library/blocks/nextpage/editor-rtl.css 395 B
build/block-library/blocks/nextpage/editor.css 395 B
build/block-library/blocks/page-list/editor-rtl.css 363 B
build/block-library/blocks/page-list/editor.css 363 B
build/block-library/blocks/page-list/style-rtl.css 175 B
build/block-library/blocks/page-list/style.css 175 B
build/block-library/blocks/paragraph/editor-rtl.css 157 B
build/block-library/blocks/paragraph/editor.css 157 B
build/block-library/blocks/paragraph/style-rtl.css 260 B
build/block-library/blocks/paragraph/style.css 260 B
build/block-library/blocks/post-author/style-rtl.css 175 B
build/block-library/blocks/post-author/style.css 176 B
build/block-library/blocks/post-comments-form/editor-rtl.css 96 B
build/block-library/blocks/post-comments-form/editor.css 96 B
build/block-library/blocks/post-comments-form/style-rtl.css 495 B
build/block-library/blocks/post-comments-form/style.css 495 B
build/block-library/blocks/post-comments/editor-rtl.css 77 B
build/block-library/blocks/post-comments/editor.css 77 B
build/block-library/blocks/post-comments/style-rtl.css 632 B
build/block-library/blocks/post-comments/style.css 630 B
build/block-library/blocks/post-excerpt/editor-rtl.css 73 B
build/block-library/blocks/post-excerpt/editor.css 73 B
build/block-library/blocks/post-excerpt/style-rtl.css 69 B
build/block-library/blocks/post-excerpt/style.css 69 B
build/block-library/blocks/post-featured-image/editor-rtl.css 605 B
build/block-library/blocks/post-featured-image/editor.css 605 B
build/block-library/blocks/post-featured-image/style-rtl.css 153 B
build/block-library/blocks/post-featured-image/style.css 153 B
build/block-library/blocks/post-template/editor-rtl.css 99 B
build/block-library/blocks/post-template/editor.css 98 B
build/block-library/blocks/post-template/style-rtl.css 282 B
build/block-library/blocks/post-template/style.css 282 B
build/block-library/blocks/post-terms/style-rtl.css 73 B
build/block-library/blocks/post-terms/style.css 73 B
build/block-library/blocks/post-title/style-rtl.css 80 B
build/block-library/blocks/post-title/style.css 80 B
build/block-library/blocks/preformatted/style-rtl.css 103 B
build/block-library/blocks/preformatted/style.css 103 B
build/block-library/blocks/pullquote/editor-rtl.css 198 B
build/block-library/blocks/pullquote/editor.css 198 B
build/block-library/blocks/pullquote/style-rtl.css 370 B
build/block-library/blocks/pullquote/style.css 370 B
build/block-library/blocks/pullquote/theme-rtl.css 167 B
build/block-library/blocks/pullquote/theme.css 167 B
build/block-library/blocks/query-pagination-numbers/editor-rtl.css 122 B
build/block-library/blocks/query-pagination-numbers/editor.css 121 B
build/block-library/blocks/query-pagination/editor-rtl.css 221 B
build/block-library/blocks/query-pagination/editor.css 211 B
build/block-library/blocks/query-pagination/style-rtl.css 234 B
build/block-library/blocks/query-pagination/style.css 231 B
build/block-library/blocks/quote/style-rtl.css 213 B
build/block-library/blocks/quote/style.css 213 B
build/block-library/blocks/quote/theme-rtl.css 223 B
build/block-library/blocks/quote/theme.css 226 B
build/block-library/blocks/read-more/style-rtl.css 132 B
build/block-library/blocks/read-more/style.css 132 B
build/block-library/blocks/rss/editor-rtl.css 202 B
build/block-library/blocks/rss/editor.css 204 B
build/block-library/blocks/rss/style-rtl.css 289 B
build/block-library/blocks/rss/style.css 288 B
build/block-library/blocks/search/editor-rtl.css 165 B
build/block-library/blocks/search/editor.css 165 B
build/block-library/blocks/search/style-rtl.css 385 B
build/block-library/blocks/search/style.css 386 B
build/block-library/blocks/search/theme-rtl.css 114 B
build/block-library/blocks/search/theme.css 114 B
build/block-library/blocks/separator/editor-rtl.css 146 B
build/block-library/blocks/separator/editor.css 146 B
build/block-library/blocks/separator/style-rtl.css 233 B
build/block-library/blocks/separator/style.css 233 B
build/block-library/blocks/separator/theme-rtl.css 194 B
build/block-library/blocks/separator/theme.css 194 B
build/block-library/blocks/shortcode/editor-rtl.css 464 B
build/block-library/blocks/shortcode/editor.css 464 B
build/block-library/blocks/site-logo/editor-rtl.css 708 B
build/block-library/blocks/site-logo/editor.css 708 B
build/block-library/blocks/site-logo/style-rtl.css 192 B
build/block-library/blocks/site-logo/style.css 192 B
build/block-library/blocks/site-tagline/editor-rtl.css 86 B
build/block-library/blocks/site-tagline/editor.css 86 B
build/block-library/blocks/site-title/editor-rtl.css 84 B
build/block-library/blocks/site-title/editor.css 84 B
build/block-library/blocks/social-link/editor-rtl.css 177 B
build/block-library/blocks/social-link/editor.css 177 B
build/block-library/blocks/social-links/editor-rtl.css 674 B
build/block-library/blocks/social-links/editor.css 673 B
build/block-library/blocks/social-links/style-rtl.css 1.37 kB
build/block-library/blocks/social-links/style.css 1.36 kB
build/block-library/blocks/spacer/editor-rtl.css 322 B
build/block-library/blocks/spacer/editor.css 322 B
build/block-library/blocks/spacer/style-rtl.css 48 B
build/block-library/blocks/spacer/style.css 48 B
build/block-library/blocks/table/editor-rtl.css 494 B
build/block-library/blocks/table/editor.css 494 B
build/block-library/blocks/table/style-rtl.css 611 B
build/block-library/blocks/table/style.css 609 B
build/block-library/blocks/table/theme-rtl.css 175 B
build/block-library/blocks/table/theme.css 175 B
build/block-library/blocks/tag-cloud/style-rtl.css 226 B
build/block-library/blocks/tag-cloud/style.css 227 B
build/block-library/blocks/template-part/editor-rtl.css 149 B
build/block-library/blocks/template-part/editor.css 149 B
build/block-library/blocks/template-part/theme-rtl.css 101 B
build/block-library/blocks/template-part/theme.css 101 B
build/block-library/blocks/text-columns/editor-rtl.css 95 B
build/block-library/blocks/text-columns/editor.css 95 B
build/block-library/blocks/text-columns/style-rtl.css 166 B
build/block-library/blocks/text-columns/style.css 166 B
build/block-library/blocks/verse/style-rtl.css 87 B
build/block-library/blocks/verse/style.css 87 B
build/block-library/blocks/video/editor-rtl.css 561 B
build/block-library/blocks/video/editor.css 563 B
build/block-library/blocks/video/style-rtl.css 159 B
build/block-library/blocks/video/style.css 159 B
build/block-library/blocks/video/theme-rtl.css 110 B
build/block-library/blocks/video/theme.css 110 B
build/block-library/common-rtl.css 987 B
build/block-library/common.css 984 B
build/block-library/elements-rtl.css 54 B
build/block-library/elements.css 54 B
build/block-library/reset-rtl.css 478 B
build/block-library/reset.css 478 B
build/block-library/style-rtl.css 11.5 kB
build/block-library/style.css 11.5 kB
build/block-library/theme-rtl.css 695 B
build/block-library/theme.css 700 B
build/block-serialization-default-parser/index.min.js 1.11 kB
build/block-serialization-spec-parser/index.min.js 2.83 kB
build/compose/index.min.js 11.7 kB
build/core-data/index.min.js 14.7 kB
build/customize-widgets/index.min.js 11.2 kB
build/customize-widgets/style-rtl.css 1.4 kB
build/customize-widgets/style.css 1.4 kB
build/data-controls/index.min.js 653 B
build/data/index.min.js 7.95 kB
build/date/index.min.js 32 kB
build/deprecated/index.min.js 507 B
build/dom-ready/index.min.js 324 B
build/edit-post/classic-rtl.css 546 B
build/edit-post/classic.css 547 B
build/element/index.min.js 4.27 kB
build/escape-html/index.min.js 537 B
build/format-library/index.min.js 6.75 kB
build/format-library/style-rtl.css 571 B
build/format-library/style.css 571 B
build/hooks/index.min.js 1.64 kB
build/html-entities/index.min.js 448 B
build/i18n/index.min.js 3.77 kB
build/is-shallow-equal/index.min.js 527 B
build/keyboard-shortcuts/index.min.js 1.78 kB
build/keycodes/index.min.js 1.38 kB
build/list-reusable-blocks/index.min.js 1.74 kB
build/list-reusable-blocks/style-rtl.css 835 B
build/list-reusable-blocks/style.css 835 B
build/notices/index.min.js 953 B
build/nux/index.min.js 2.05 kB
build/nux/style-rtl.css 732 B
build/nux/style.css 728 B
build/plugins/index.min.js 1.94 kB
build/preferences-persistence/index.min.js 2.22 kB
build/preferences/index.min.js 1.3 kB
build/primitives/index.min.js 933 B
build/priority-queue/index.min.js 612 B
build/react-i18n/index.min.js 696 B
build/react-refresh-entry/index.min.js 8.44 kB
build/react-refresh-runtime/index.min.js 7.31 kB
build/redux-routine/index.min.js 2.69 kB
build/reusable-blocks/index.min.js 2.22 kB
build/reusable-blocks/style-rtl.css 256 B
build/reusable-blocks/style.css 256 B
build/rich-text/index.min.js 11.1 kB
build/server-side-render/index.min.js 1.61 kB
build/shortcode/index.min.js 1.53 kB
build/token-list/index.min.js 644 B
build/url/index.min.js 3.61 kB
build/vendors/react-dom.min.js 38.5 kB
build/vendors/react.min.js 4.34 kB
build/viewport/index.min.js 1.08 kB
build/warning/index.min.js 268 B
build/widgets/index.min.js 7.19 kB
build/widgets/style-rtl.css 1.16 kB
build/widgets/style.css 1.16 kB
build/wordcount/index.min.js 1.06 kB

compressed-size-action

Comment on lines 45 to 50

.block-editor-color-gradient-control__tabs {
margin-top: - $grid-unit-10;
margin-left: - $grid-unit-10;
margin-right: - $grid-unit-10;
}
Copy link
Contributor

Choose a reason for hiding this comment

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

I wonder if there's a better way to make sure that the Tabs fill the whole width of the sidebar — what about removing the padding from .edit-site-screen-background-color__control and adding it back only to the tab panel's contents?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I suppose avoiding negative values has some merit, but both implementations would still be exposed to the same risk, no? Just trying to fully understand the implications :)

Copy link
Contributor

@ciampo ciampo Jul 5, 2022

Choose a reason for hiding this comment

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

In general, there isn't anything wrong with negative margins. In this case, it's more about introducing custom style overrides of the TabPanel component (that implicitly relies on the fact that the popover's content has a padding of $grid-unit-10 px).

Specifically to this case, please ignore my initial suggestion re. removing the padding from — I mixed up this instance (which is rendered in a popover) with the one below (rendered in the sidebar).

It looks like the popover's contents have an 8px margin added directly by the Dropdown component (see the code here) (which I'm definitely not a fan of!)

Screenshot 2022-07-05 at 21 13 55

In this specific situation, I'm not sure if there's a clean way to avoid the style override 🤔

@mirka , any ideas?

Copy link
Member

@mirka mirka Jul 6, 2022

Choose a reason for hiding this comment

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

One solution that comes to mind is how the Card component does it. It has a designated <CardMedia> component that you put inside <Card> when you want to break out of the padding. We could provide a similar subcomponent for Dropdown. ("Media" is not a very discoverable name for this, so ideally we'll give it a more literal name like <DropdownContentFullWidth> or something.)

I'm fine with the hacky style override as a temporary thing for this PR to land, and we can make a DropdownContentFullWidth in a separate PR.

Copy link
Member

Choose a reason for hiding this comment

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

Looking at the mockups in #38277 (cf. some of the implementations in Global Styles ▸ Colors), I'm wondering whether we've thought through the decision to make the tablist break out of the parent padding or not. There seems to be a lot of hierarchical contexts where it would be better not to be full-width. I wanted to check on this point because it does add a good amount of complexity and fragmentation risk if we don't have a clear style guide.

It's totally fine if some top-level tablists are full-width (e.g. Blocks/Patterns, Template/Block, Post/Block). But for things that aren't really top-level, or for components that are reused in multiple contexts such as this ColorGradientControl, things will be a lot simpler if we don't go full-width. Again, your call, but just a consideration from the maintenance/consistency standpoint 🙂 (cc @javierarce)

Comment on lines 110 to 113
.block-editor-color-gradient-control__tabs {
border-bottom: 1px solid $gray-300;
margin-bottom: $grid-unit-10;
}
Copy link
Contributor

Choose a reason for hiding this comment

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

Overriding styles this way introduces fragmentation in the way a component looks across the app, and makes this code less resilient to future design changes.

It would be great if we could use the component as it comes out of the box (or alternatively, we could look at updating the component to fit the new design requirements).

Copy link
Contributor Author

Choose a reason for hiding this comment

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

As far as I know all implementations of TabPanel in core append a bottom border, so we should explore adding it to the component, and removing these styles holistically.

Copy link
Contributor

Choose a reason for hiding this comment

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

That sounds like a good plan, at least in principle!

Copy link
Contributor Author

Choose a reason for hiding this comment

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

From a purely design perspective I find the tabs to look a little awkward with no stroke beneath them. But thinking about backwards compatibility I suppose we could add a prop to the component that creates a 'borderless' appearance?

Copy link
Contributor

@ciampo ciampo Jul 6, 2022

Choose a reason for hiding this comment

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

On one hand, we could add an isBorderless prop (with a default value of true, so that it doesn't introduce a visual change to the component) and replace all "border style overrides" by setting isBorderless to false

But I wonder if this is the right approach:

  • I'm not a massive fan of props that are very visually descriptive, as they expose an implementation detail of the design (in this case, showing a border or not) which may not make sense in future iterations
  • this pattern of adding props and introduce variants to our components is often a way to mask consistency issues

I'd prefer a scenario in which:

  • we investigate how the component is used across Gutenberg (and potentially plugins)
  • we assess if the component's design needs updating. In this case, relatively to the bottom border, we should assess if there can be only one version of the component (with or without border) — which would be our preferred option — or if it's absolutely necessary to expose both variants.
  • we update the component accordingly and remove style overrides across Gutenberg.

@javierarce javierarce added the Needs Figma Update Needs an update to Figma for design purposes label Jul 6, 2022
Copy link
Member

@mirka mirka left a comment

Choose a reason for hiding this comment

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

Very happy that we're going in this direction! 😊

Once we fix up the usage of the TabPanel component here, I think we can merge and then take note of the follow-up tasks to remove the CSS hacks.

label={ __( 'Gradient' ) }
/>
</ToggleGroupControl>
{ ( tab ) => <p className="screen-reader-text">Selected tab: { tab.title }</p> }
Copy link
Member

Choose a reason for hiding this comment

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

I believe what needs to happen here is to provide a function that receives the currently selected tab as an argument and render the tab panel for it. Basically the TabPanel is going to manage our currentTab state from now on. That is how it handles the a11y concerns for us.

Since it looks like we're going to use the tab panel content outside of a TabPanel context as well, perhaps we could do some light refactoring along these lines:

const tabPanels = {
  [TAB_COLOR.value]: <ColorPalette foo={bar} />;
  [TAB_GRADIENT.value]: <GradientPicker foo={bar} />;
};
					{ canChooseAColor && canChooseAGradient && (
						/* Note that we don't need the `onSelect` anymore */
						<TabPanel
							className="block-editor-color-gradient-control__tabs"
							tabs={ TABS_SETTINGS }
						>
						  { ( tab ) => tabPanels[ tab ]; }
						</TabPanel>
					) }
					{ ! canChooseAGradient && tabPanels[ TAB_COLOR.value ] }
					{ ! canChooseAColor && tabPanels[ TAB_GRADIENT.value ] }

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Oh yeah, that makes sense :)

I tried to implement this as you suggested but my designer brain has obviously messed something up because the panels aren't rendering for me 🤔 I don't suppose you could take a look?

Copy link
Member

Choose a reason for hiding this comment

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

Ah yes, of course! I wrote that code snippet without running it so something is likely wrong 😂 I'll rework the code and push it directly to this PR branch then 👍

Copy link
Member

Choose a reason for hiding this comment

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

Ok, done ✅ Passing the torch back to you!

@@ -75,7 +75,7 @@ function ScreenLinkColor( { name } ) {
) }
/>

<TabPanel className="my-tab-panel" tabs={ tabs }>
Copy link
Member

Choose a reason for hiding this comment

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

🧹 Removed some copypasta here

Comment on lines 114 to 116
.block-editor-color-gradient-control__tab-panel {
border-top: 1px solid $gray-300;
}
Copy link
Member

@mirka mirka Jul 8, 2022

Choose a reason for hiding this comment

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

FWIW, after working on this PR, I'm now a little apprehensive about adding in this ad hoc border. The Global Styles ▸ Colors menu already contains several tabbed color panels that have different implementations, easily leading to style fragmentation. See also #41976 which seems to have landed recently. Your call, but it might be better to leave the border off for now and address the border issue in a separate PR.

Comment on lines 45 to 50

.block-editor-color-gradient-control__tabs {
margin-top: - $grid-unit-10;
margin-left: - $grid-unit-10;
margin-right: - $grid-unit-10;
}
Copy link
Member

Choose a reason for hiding this comment

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

Looking at the mockups in #38277 (cf. some of the implementations in Global Styles ▸ Colors), I'm wondering whether we've thought through the decision to make the tablist break out of the parent padding or not. There seems to be a lot of hierarchical contexts where it would be better not to be full-width. I wanted to check on this point because it does add a good amount of complexity and fragmentation risk if we don't have a clear style guide.

It's totally fine if some top-level tablists are full-width (e.g. Blocks/Patterns, Template/Block, Post/Block). But for things that aren't really top-level, or for components that are reused in multiple contexts such as this ColorGradientControl, things will be a lot simpler if we don't go full-width. Again, your call, but just a consideration from the maintenance/consistency standpoint 🙂 (cc @javierarce)

@jameskoster
Copy link
Contributor Author

I've removed the ad hoc border, and the negative margins in the popover. I agree it would be best to address this at the component level first.

Copy link
Member

@mirka mirka left a comment

Choose a reason for hiding this comment

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

Thanks! I think this is a solid accessibility and consistency improvement 💛 I'll see what we can do about the dropdown paddings. And for the tablist bottom border, let us know which way you want to go and we can help implement it 👍

@jameskoster
Copy link
Contributor Author

Thanks for the review :) I'll merge once another designer has signed off.

And for the tablist bottom border, let us know which way you want to go and we can help implement it

I'll open an issue for us to discuss this in more detail.

@javierarce
Copy link
Contributor

This looks good to me, nice job!

@jameskoster jameskoster merged commit b371a93 into trunk Jul 11, 2022
@jameskoster jameskoster deleted the try/tabs-in-color-panels branch July 11, 2022 10:13
@github-actions github-actions bot added this to the Gutenberg 13.7 milestone Jul 11, 2022
@ciampo ciampo mentioned this pull request Jul 19, 2022
1 task
@jasmussen
Copy link
Contributor

Apologies for coming back here after almost a month 😅 — but I much preferred the segmented control, and would want us to have that also for inline text colors:

Screenshot 2022-08-03 at 11 11 54

I don't dislike the tabs especially in global styles, though I still think the segmented control worked better there. The tab by virtue of going edge to edge acts as a separator or a new sub-section, when in fact it is contextual to the controls above and below both.

While I'd personally prefer us going back to the segmented control, I also don't mind trying this out for a bit. But we should at least change "Solid color" to just read "Solid". I'll spin up a PR.

@jasmussen jasmussen mentioned this pull request Aug 3, 2022
@jasmussen
Copy link
Contributor

I created #42918 as a followup to renaming, but learned that there are some awkward padding issues. I do see those raised in this thread, I wonder if that regressed? Would going back to the segmented control simplify some of this?

@mirka
Copy link
Member

mirka commented Aug 3, 2022

Would going back to the segmented control simplify some of this?

Especially if we want the full-width color button to also happen, I'd say it would take more work to achieve everything correctly with the ToggleGroupControl.

The main hurdle with using the ToggleGroupControl as a tabpanel tab selector (i.e. tablist) is that ToggleGroupControl is semantically a radio right now. So the HTML would be very wrong. We would resolve this either by making a new TabPanel component, or add a design variant to the existing TabPanel component. (This is the "more work" part.)

I'm not entirely convinced that a radio control and a tab panel should look the same (e.g. what happens if you need to put a radio control inside the tab panel?), but if that's the direction we're going, it is technically possible.

@jasmussen
Copy link
Contributor

The main hurdle with using the ToggleGroupControl as a tabpanel tab selector (i.e. tablist) is that ToggleGroupControl is semantically a radio right now. So the HTML would be very wrong. We would resolve this either by making a new TabPanel component, or add a design variant to the existing TabPanel component. (This is the "more work" part.)

Just to be sure, that means when we had the ToggleGroupControl for solid/gradient instead of the new tab-group, the HTML was incorrect?

@mirka
Copy link
Member

mirka commented Aug 4, 2022

Just to be sure, that means when we had the ToggleGroupControl for solid/gradient instead of the new tab-group, the HTML was incorrect?

Exactly. HTML-wise, that was just a radio control preceding the rest of the color controls. No hierarchy or indication that it was a tab panel switcher.

@jasmussen
Copy link
Contributor

Exactly. HTML-wise, that was just a radio control preceding the rest of the color controls. No hierarchy or indication that it was a tab panel switcher.

Thank you for explaining. In various forms isn't it reasonable enough to have a radio group contextually affect subsequent options? I don't think of the segmented control (ToggleGroupControl) as being conceptually related to a tab panel switcher, so unless there's some semantic reason not to use it, I'm unsure it's a problem. But I'm happy to learn here if I'm wrong.

@jameskoster
Copy link
Contributor Author

jameskoster commented Aug 4, 2022

Radios don't make sense in some flows, the inline text color options your shared in this thread are a good example:

You don't select text or background, you can select both.

@jasmussen
Copy link
Contributor

In that case tabs are more appropriate, indeed, but I feel the original point for customizing a single color still stands. It's not a very very strong opinion — things look okay. It's just not clear to me that the tabs are better for the color panel.

@jameskoster
Copy link
Contributor Author

jameskoster commented Aug 4, 2022

There may be an argument to support both, dependent on situation. In the example above, and when editing palettes in global styles, I think tabs make more sense. When applying a background color (solid vs gradient) to a specific block, radios / segmented control may be preferable.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Colors Color management [Feature] Design Tools Tools that impact the appearance of blocks both to expand the number of tools and improve the experi Needs Design Feedback Needs general design feedback. Needs Figma Update Needs an update to Figma for design purposes Needs User Documentation Needs new user documentation [Type] Enhancement A suggestion for improvement.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants