-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
Button: add support for iconPosition top and showDescription #62373
Comments
Note: the screenshots above are only very rough examples made by quickly altering some code and using the browser dev tools inspector. Please do not take these screenshots as a 'strict' reference. The main point is to be able to:
|
The Button props are bloated as it is, and I don't think it's sustainable to add any more internal layout options on top of it. The matrix of possible prop combinations is huge, and many of those combinations don't make sense at all. Even for a simple One way I think we can approach this is to make Button more composable in terms of layout. Currently, the Ideally we'd have a more customizable button component (perhaps a facade component of Button with non-compatible props omitted), where it can support completely arbitrary internal layouts while maintaining the standard focus styles, accessible disabled behavior, etc. Then it would be a matter of resusably encapsulating whatever internal layout patterns you want, at whichever layer is appropriate ( |
Of course, the 'size' scheme doesn't make sense with a button that shows icon on top and label below the icon. That's inherent to a stacked layout where the actual height is determined by the content. Extending your reasoning, then I would argue that if the 'sustainability' is a problem, many other props should be removed and any layout (size, icon position) removed entirely. I'm not sure that would be the best approach in terms of what the editor actually needs. While I do understand arguments about the 'pureness' of the components package, I'm more on the pragmatic side. The editor needs components that are flexible. Otherwise, any 'local implementation' would be just redundant code prone to maintenance problems, maintenance cost, inconsistencies, and bugs. |
Is it worse to add additional props to the Button component, or to add more custom code in each variant usage of the component where we want an alternate design? If we want consistency across the application and maintainable code, I think that the Button component needs to support the properties that we frequently use. This change is a pretty minimal increase in complexity for the component that can make usages more consistent across the application. It seems very reasonable to me. I don't think our base components need to be simple; they need to have simple, sensible defaults, so that they can be used with minimal required props, but they should be richly featured so that we can use them in a wide variety of contexts without requiring extra code. |
I totally agree with @joedolson. To me, the main purpose of a library of reusable base component is having components to serve the needs of WordPress in terms of functionality, usability, accessibility, and design. These are the WordPress components, they are made for WordPress. People can use them in other projects, if they like. Still, the base components should be crafted to align with the WordPress needs. |
Looking back into this issue and the proposed PR #62412 what I'd really like to see is the Button component to be flexible enough to avoid custom implementation, code bloat and maintenance cost in the editor. I can think at three different examples, at least, where the editor uses custom implementations or overrides just because the Button component can't be used to implement the provided design. In all these three examples there are relevant accessibility problems: Block placeholder buttons
Style variations These style variations should be buttons. Instead, for design purposes, they have been implemented with a focusable diw element with a Menu items with description The descriptions of the menu items in the Options panel should be separated from the button accessible name. Instead, the description is just appended to the button text, thus polluting the button name. All these custom implementations introduce semantics and accessibility problems that could be avoided by using the Button base component. On the other hand, I do understand the concerns about the props bloat in the Button component and its current complexity. Thinking at an alternative solution, at least for the iconPosition prop, how about providing a Would a Regarding the new |
An attempt to solve this issue was tried in #62412 I understand the concerns about introducing too many props and variations to the Button component. However, there are many cases in the editor where the provided design needs a button that displays:
Currently, to achieve the provided design, a series of ad-hoc implementations and style overrides have been implemented. These implementations are sometimes not accessible, to varying degrees. As such:
I'm not opposed to any alternative solution but the current ad-hoc implementations are far from ideal and I'd appreciate this issue to get more focus. Thanks. Cc @WordPress/gutenberg-core @WordPress/gutenberg-components @WordPress/gutenberg-design |
Yes, in fact we have been discussing the need for some kind of unstyled variant, or a way to compose Button styles more modularly (e.g. so a consumer could opt into focus indicators, size, padding styles etc. separately). I think providing modular styles could be very flexible. Maybe through a |
Thanks for the clarification and also thanks @ciampo for your feedback at #62412 (comment) Can you please point other contributors (including myself) to where that discussion has taken place? Thanks. |
To some extent, I'd agree. |
Nothing concrete or more detailed than that one sentence summary, yet. But I think we've all been feeling the need for something like it, so let's discuss specifics in an issue when we're ready to take it on.
I'm not immediately sure if we can cover all styling needs with a single focus style, but yes, it would make things a lot simpler if that's possible. |
Thanks for clarifying.
The problem when using the pronoun 'we' is that it's not clear who 'we' is in that context. In these cases, it should be always clarified who 'we' is and when and where any discussion occurred. In a collaborative open source project, discussions should be open and public, thanks. |
Issue for unstyled Button usage created at #67320 |
Thanks for creating the new issue @mirka that would address the styling part (icon on top). IMO, the button still needs a way to make the description visible. At the moment, the component assumes the description must always be visually hidden while there are legitimate cases where we need to have a visible description. gutenberg/packages/components/src/button/index.tsx Lines 282 to 284 in 0b81255
Making it visible to better illustrate: |
I would like to echo @joedolson 's question:
I think we need to be aware of some semantics, sorry if it will sound pedantic: simple does not mean not complex. Simple means not complicated. There is inherent complexity with providing foundational tooling: one needs sensible defaults but also flexibility, configurability and maintainability too. The focus is to avoid complication. Bloated APIs are complicated, in that they inevitably bear the possibility of incompatible combinations and unforeseen behaviours. Avoiding complication is possible, but avoidiing complexity is not. Hence the directions suggested by @mirka and @ciampo seem to me to be a good approach in extending what we can do, but in a manageable future proof way. Neither is about "let's have less props", it's about let's make sure we keep things simple depite them being complex to solve. At the same time I too fully support buttons with vertical icons, the separation of label and description, design API that removes the need to make divs with button roles and sensible ways to always enable text (labels instead of icons, and visible descriptions). Except that it takes time to solve properly if we want to solve it at the most basic level.
I think it's worse to have custom code long term, but not short term. Just like the engineering/design ICs had to do with what they've got and made the style selection buttons divs with role button because buttons can't temporarily support that kind of design. But we can't not evolve the product because we don't support stuff at component level. It's the exact opposite, the design pushes the system to see the limitations. I think @afercia 's work here to collect all these problesm is awesome. It connected in my head to @youknowriad 's work to keep track of things that engineering had to go around - for instance we still hardcode WP specific stuff in non WP specific packages, because the foundation is not ready, but we learn (see #61622) and improve accordingly in steps. So it's not only design. It's the fact that the product will always, always be farther into the future compared to the fromework, there is always some catch up to do. |
I totally agree but I would argue the base components should move fast to support what the product needs. |
What problem does this address?
I've been exploring potential solutions for #60206 and realized there's many cases where the editor uses custom components or ad-hoc CSS to modify or replace the
Button
base component.One notable example of this is for the Group, Columns, and Query block placeholders. These placeholders design and accessibility would benefit from two new features of the Button component:
iconPosition?: 'left' | 'right';
describedBy
prop, a visually hidden element is rendered after the button and properly referenced with aria-describedby/id attributes. The description is visually hidden but in some scenarios it would be beneficial to make it visible.Cc @mirka
After a quick look at the Button component, seems to me that:
iconPosition="top"
would be pretty trivial. The DOM order would be the same asleft
. It would likely need only a CSS class and some styling.showDescription
seems pretty trivial as well. When true, it should make the button description use a paragraph insteaed of theVisuallyHidden
component.I'd appreciate any feedback and thoughts.
Use cases examples:
For better accessibility in the block placeholders that show variations, I'd like to change the design to make the variation title and description visible. Example screenshot:
To evaluate:
Other editor components e.g. PreferenceToggleMenuItem > MenuItem already show both a label and a description. They do it wrongly, by putting both the label and description as content of the button. As such, the accessible name of the button is a very long string that is a barrier for speech recognition software users ang generally not a good practice. The description should be separated from teh label and likely the visible description should be supported by the base Button component instead of reimplementing ad-hoc solutions. Screenshot:
Finally, in the future the editor may just have the need to have buttons that show icon and label vertically stacked. Example screenshot:
What is your proposed solution?
The text was updated successfully, but these errors were encountered: