-
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
Switch screen-reader-text to use VisuallyHidden #18167
Comments
@mkaz yes :) |
I've added this as a Good First Issue and switched the list to checkboxes. If you would like to contribute feel free to take any items above as separate PRs, everything doesn't have to be done in a single PR if that makes it easier to develop and test. |
I am working on this issue at Contributor Day. I am focused on the three files in packages/block-library/src/categories/edit.js |
@mkaz I was looking into this one, and encountered more than one situation like this: return (
<div className={classnames( {
'screen-reader-text': ! isSelected && RichText.isEmpty( caption ),
} )}>
{ caption }
</div>
); In which case we need some additional boilerplate code: const shouldHideCaption = ! isSelected && RichText.isEmpty( caption );
const CaptionComponent = shouldHideCaption ? VisuallyHidden : RichText;
const captionProps = shouldHideCaption ? { as: RichText } : {};
return (
<CaptionComponent { ...captionProps }>{ caption }</CaptionComponent>
); I feel like a better solution would be supporting an additional prop that we could use like this: <VisuallyHidden
as={ RichText }
hidden={ ! isSelected && RichText.isEmpty( caption ) }
>
{ caption }
</VisuallyHidden> What do you think? |
I think the logic would be better outside the wrapper. { ! isSelected && RichText.isEmpty( caption )
? <VisuallyHidden>{ caption } </VisuallyHidden>
: <div>{ caption }</div>
} Also, I don't quite follow that logic, if the caption is empty, then what is being shown in the tag? |
@mkaz I think I oversimplified my example. Let's take a look at the actual excerpt from gallery.js here: const captionClassNames = classnames( 'blocks-gallery-caption', {
'screen-reader-text': ! isSelected && RichText.isEmpty( caption ),
});
return (
// ...other stuff
<RichText
tagName="figcaption"
className={ captionClassNames }
placeholder={ __( 'Write gallery caption…' ) }
value={ caption }
unstableOnFocus={ onFocusGalleryCaption }
onChange={ ( value ) => setAttributes( { caption: value } ) }
inlineToolbar
/>
) So we're not talking about just an empty const richTextProps = {
tagName: "figcaption",
className: 'blocks-gallery-caption',
placeholder: __( 'Write gallery caption…' ),
value: caption,
unstableOnFocus: onFocusGalleryCaption,
onChange: ( value ) => setAttributes( { caption: value } ),
inlineToolbar: true
};
return (
// ... other stuff ...
! isSelected && RichText.isEmpty( caption )
? <VisuallyHidden as={ RichText } { ...richTextProps } />
: <RichText { ...richTextProps } />
) In which case we'd need to address one more issue: One more idea that wouldn't involve any changes to const richTextElem = (
<RichText
tagName="figcaption"
className={ captionClassNames }
placeholder={ __( 'Write gallery caption…' ) }
value={ caption }
unstableOnFocus={ onFocusGalleryCaption }
onChange={ ( value ) => setAttributes( { caption: value } ) }
inlineToolbar
/>
);
return (
// ...other stuff
! isSelected && RichText.isEmpty( caption )
? <VisuallyHidden> { richTextElem } </VisuallyHidden>
: { richTextElem }
) |
I think the final option will work, I'll take a look at the PR. My concern was around adding a prop called "hidden" to a component called
I remember considering this, attaching passed classnames, but I think it might conflict with what VisuallyHidden is trying to do. For example, if a passed class sets a |
Describe the Issue
This issue is to gather all the spots for changing spots using the
screen-reader-text
classname to using the VisuallyHidden component. Per comment in #18127A good reference implementation is PR #18165 that converts within the components package the spots that use
screen-reader-text
toVisuallyHidden
component.Why the switch?
See #18022 which introduced the
VisuallyHidden
component. The usage ofscreen-reader-text
assumes a WordPress context with the proper CSS already defined. This may not always be the case, especially when pieces of the Gutenberg project are used elsewhere.File list with
screen-reader-text
@youknowriad - just wanted to confirm that you do what this updated across all of the above?
The text was updated successfully, but these errors were encountered: