diff --git a/.changeset/modern-cooks-decide.md b/.changeset/modern-cooks-decide.md new file mode 100644 index 00000000000..7233234208b --- /dev/null +++ b/.changeset/modern-cooks-decide.md @@ -0,0 +1,5 @@ +--- +'@primer/react': patch +--- + +Fixes conditional in `ActionList.Item` that was dependent on FF being active before applying forwarded ref. diff --git a/packages/react/src/ActionList/ActionList.test.tsx b/packages/react/src/ActionList/ActionList.test.tsx index 04cf1386f67..9c5c4afe14f 100644 --- a/packages/react/src/ActionList/ActionList.test.tsx +++ b/packages/react/src/ActionList/ActionList.test.tsx @@ -426,6 +426,34 @@ describe('ActionList', () => { expect(listItems.length).toBe(2) }) + it('should apply ref to ActionList.Item when feature flag is disabled', async () => { + const MockComponent = () => { + const ref = React.useRef(null) + + const focusRef = () => { + if (ref.current) ref.current.focus() + } + + return ( + + + + Item 1 + Item 2 + + + ) + } + + const {getByRole} = HTMLRender() + const triggerBtn = getByRole('button', {name: 'Prompt'}) + const focusTarget = getByRole('listitem', {name: 'Item 1'}) + + fireEvent.click(triggerBtn) + + expect(document.activeElement).toBe(focusTarget) + }) + it('should render ActionList.Item as li when feature flag is enabled and has proper aria role', async () => { const {container} = HTMLRender( diff --git a/packages/react/src/ActionList/Item.tsx b/packages/react/src/ActionList/Item.tsx index c003f94c140..0cf06a981c1 100644 --- a/packages/react/src/ActionList/Item.tsx +++ b/packages/react/src/ActionList/Item.tsx @@ -368,7 +368,7 @@ export const Item = React.forwardRef( value={{variant, disabled, inactive: Boolean(inactiveText), inlineDescriptionId, blockDescriptionId}} > (