From 7f9bbdaa8644fe659860bbe28709b2e1fef32f6d Mon Sep 17 00:00:00 2001 From: Andrew Duthie Date: Tue, 26 Feb 2019 16:07:11 -0500 Subject: [PATCH] DOM: Avoid consolidating unnamed radio inputs --- packages/dom/src/tabbable.js | 2 +- packages/dom/src/test/tabbable.js | 24 ++++++++++++++++++++++++ 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/packages/dom/src/tabbable.js b/packages/dom/src/tabbable.js index 7a5cbd51aa923..315a98b8b2a8e 100644 --- a/packages/dom/src/tabbable.js +++ b/packages/dom/src/tabbable.js @@ -51,7 +51,7 @@ function createStatefulCollapseRadioGroup() { const { nodeName, type, checked, name } = element; // For all non-radio tabbables, construct to array by concatenating. - if ( nodeName !== 'INPUT' || type !== 'radio' ) { + if ( nodeName !== 'INPUT' || type !== 'radio' || ! name ) { return result.concat( element ); } diff --git a/packages/dom/src/test/tabbable.js b/packages/dom/src/test/tabbable.js index 4f0955777be24..e262fccd86d65 100644 --- a/packages/dom/src/test/tabbable.js +++ b/packages/dom/src/test/tabbable.js @@ -104,5 +104,29 @@ describe( 'tabbable', () => { thirdRadio, ] ); } ); + + it( 'not consolidate unnamed radio inputs', () => { + const node = createElement( 'div' ); + const firstRadio = createElement( 'input' ); + firstRadio.type = 'radio'; + firstRadio.value = 'firstRadio'; + const text = createElement( 'input' ); + text.type = 'text'; + text.name = 'b'; + const secondRadio = createElement( 'input' ); + secondRadio.type = 'radio'; + secondRadio.value = 'secondRadio'; + node.appendChild( firstRadio ); + node.appendChild( text ); + node.appendChild( secondRadio ); + + const tabbables = find( node ); + + expect( tabbables ).toEqual( [ + firstRadio, + text, + secondRadio, + ] ); + } ); } ); } );