From 17e25740f5bfda4546c53dd7de151ab51197c822 Mon Sep 17 00:00:00 2001 From: Ben Sussman Date: Thu, 12 Dec 2024 13:57:48 -0500 Subject: [PATCH] Set attributes to undefined (aka hide them) when false. Ultimately should be the same behavior, but cleaner html --- packages/mui-material/src/Select/Select.test.js | 13 +++++++++++++ packages/mui-material/src/Select/SelectInput.js | 4 ++-- 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/packages/mui-material/src/Select/Select.test.js b/packages/mui-material/src/Select/Select.test.js index a7f5dd963ba7c0..a2aebe345ce4db 100644 --- a/packages/mui-material/src/Select/Select.test.js +++ b/packages/mui-material/src/Select/Select.test.js @@ -474,6 +474,12 @@ describe('); + + expect(getByRole('combobox')).not.to.have.attribute('aria-required'); + }); + it('sets required attribute in input when component is required', () => { const { container } = render(', () => { expect(getByRole('combobox')).to.have.attribute('aria-invalid', 'true'); }); + it('aria-invalid is not present if component is not in an error state', () => { + const { getByRole } = render(); diff --git a/packages/mui-material/src/Select/SelectInput.js b/packages/mui-material/src/Select/SelectInput.js index 2f5ed36db4f675..fd48bd5d44b08d 100644 --- a/packages/mui-material/src/Select/SelectInput.js +++ b/packages/mui-material/src/Select/SelectInput.js @@ -504,8 +504,8 @@ const SelectInput = React.forwardRef(function SelectInput(props, ref) { aria-label={ariaLabel} aria-labelledby={[labelId, buttonId].filter(Boolean).join(' ') || undefined} aria-describedby={ariaDescribedby} - aria-required={required} - aria-invalid={error} + aria-required={required ? 'true' : undefined} + aria-invalid={error ? 'true' : undefined} onKeyDown={handleKeyDown} onMouseDown={disabled || readOnly ? null : handleMouseDown} onBlur={handleBlur}