From d3b53f515d71321a127f0bf8c4660a8bbac791c1 Mon Sep 17 00:00:00 2001 From: James Talton Date: Tue, 12 Mar 2024 15:22:03 -0400 Subject: [PATCH] fix(Menu): Fix crash in menu referencing invalid array index (#10153) * Fix crash in menu * Update code best on review feedback * fix linting --- packages/react-core/src/components/Menu/Menu.tsx | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/packages/react-core/src/components/Menu/Menu.tsx b/packages/react-core/src/components/Menu/Menu.tsx index 18c084449bf..8aa8eda6087 100644 --- a/packages/react-core/src/components/Menu/Menu.tsx +++ b/packages/react-core/src/components/Menu/Menu.tsx @@ -156,8 +156,11 @@ class MenuBase extends React.Component { this.setState({ transitionMoveTarget: null }); } else { const nextMenu = current.querySelector('#' + this.props.activeMenu) || current || null; - const nextMenuChildren = Array.from(nextMenu.getElementsByTagName('UL')[0].children); - + const nextMenuLists = nextMenu.getElementsByTagName('UL'); + if (nextMenuLists.length === 0) { + return; + } + const nextMenuChildren = Array.from(nextMenuLists[0].children); if (!this.state.currentDrilldownMenuId || nextMenu.id !== this.state.currentDrilldownMenuId) { this.setState({ currentDrilldownMenuId: nextMenu.id }); } else { @@ -167,7 +170,6 @@ class MenuBase extends React.Component { const nextTarget = nextMenuChildren.filter( (el) => !(el.classList.contains('pf-m-disabled') || el.classList.contains(styles.divider)) )[0].firstChild; - (nextTarget as HTMLElement).focus(); (nextTarget as HTMLElement).tabIndex = 0; }