Skip to content
This repository has been archived by the owner on Sep 30, 2024. It is now read-only.

Commit

Permalink
Revert "[SG-36350] Accessibility: Global Menu: Focus isn't correctl…
Browse files Browse the repository at this point in the history
…y captured when menus are opened (#36915)"

This reverts commit d30b22a.
  • Loading branch information
umpox authored Jul 6, 2022
1 parent d279638 commit 4e125eb
Show file tree
Hide file tree
Showing 8 changed files with 16 additions and 28 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -165,14 +165,15 @@ const renderDashboardsContent = (

const triggerDashboardMenuItem = async (screen: RenderWithBrandedContextResult & { user: UserEvent }, name: RegExp) => {
const { user } = screen
const dashboardMenu = await waitFor(() => screen.getByRole('button', { name: /dashboard context menu/ }))
user.click(dashboardMenu)

const dashboardMenu = await screen.findByRole('button', { name: /dashboard context menu/ })
userEvent.click(dashboardMenu)
const dashboardMenuItem = screen.getByRole('menuitem', { name })

// We're simulating keyboard navigation here to circumvent a bug in ReachUI
// does not respond to programmatic click events on menu items
screen.getByText(name).closest<HTMLButtonElement>('[role="menuitem"]')?.focus()
user.keyboard('{enter}')
dashboardMenuItem.focus()
user.keyboard(' ')
}

beforeEach(() => {
Expand Down Expand Up @@ -217,7 +218,7 @@ describe('DashboardsContent', () => {

const { history } = screen

await triggerDashboardMenuItem(screen, /configure dashboard/i)
await triggerDashboardMenuItem(screen, /configure dashboard/)

expect(history.location.pathname).toEqual('/insights/dashboards/foo/edit')
})
Expand All @@ -237,17 +238,18 @@ describe('DashboardsContent', () => {
it('opens delete dashboard modal', async () => {
const screen = renderDashboardsContent()

await triggerDashboardMenuItem(screen, /delete/i)
await triggerDashboardMenuItem(screen, /Delete/)

await waitFor(() => expect(screen.getByRole('heading', { name: /Delete/ })).toBeInTheDocument())
const addInsightHeader = await waitFor(() => screen.getByRole('heading', { name: /Delete/ }))
expect(addInsightHeader).toBeInTheDocument()
})

// copies dashboard url
it('copies dashboard url', async () => {
const screen = renderDashboardsContent()

await triggerDashboardMenuItem(screen, /copy link/i)
await triggerDashboardMenuItem(screen, /Copy link/)

await waitFor(() => sinon.assert.calledOnce(mockCopyURL))
sinon.assert.calledOnce(mockCopyURL)
})
})
4 changes: 2 additions & 2 deletions client/web/src/nav/NavBar/NavDropdown.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -184,8 +184,8 @@ export const NavDropdown: React.FunctionComponent<React.PropsWithChildren<NavDro
>
{mobileHomeItem.content}
</MenuLink>
{items.map((item, index) => (
<MenuLink as={Link} key={item.path} to={item.path} index={index}>
{items.map(item => (
<MenuLink as={Link} key={item.path} to={item.path}>
{item.content}
</MenuLink>
))}
Expand Down
1 change: 0 additions & 1 deletion client/wildcard/src/components/Menu/MenuList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,5 @@ const Popover = React.forwardRef(({ popoverPosition, ...props }, reference) => (
position={popoverPosition}
focusLocked={false}
className={classNames('py-1', props.className)}
keepInDOM={true}
/>
)) as ForwardReferenceComponent<'div', PopoverProps>
2 changes: 0 additions & 2 deletions client/wildcard/src/components/Popover/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -226,5 +226,3 @@ enum Strategy {
```

- **_targetPadding_** (optional) - Adds space/padding between target and popover elements

- **_keepInDOM_** (optional) - By default `PopoverContent` element is removed from DOM when tooltip is hidden. If it's `true`, `PopoverContent` element will be kept in DOM but is hidden with CSS rule `visibility=hidden`. This prop is useful when `PopoverContent` children need this behavior to work. Ex: `@sourcegraph/wildcard` `MenuList` component need this to fix [focus state issue](https://github.com/sourcegraph/sourcegraph/issues/36350).
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,6 @@ export interface FloatingPanelProps extends Omit<Tether, 'target' | 'element'>,
* outside the dom tree.
*/
rootRender?: HTMLElement | null

forceHidden?: boolean
}

/**
Expand All @@ -47,7 +45,6 @@ export const FloatingPanel = forwardRef((props, reference) => {
targetPadding,
constraint,
rootRender,
forceHidden,
...otherProps
} = props

Expand Down Expand Up @@ -75,7 +72,6 @@ export const FloatingPanel = forwardRef((props, reference) => {
constrainToScrollParents,
overflowToScrollParents,
flipping,
forceHidden,
})

return unsubscribe
Expand All @@ -94,7 +90,6 @@ export const FloatingPanel = forwardRef((props, reference) => {
constrainToScrollParents,
overflowToScrollParents,
flipping,
forceHidden,
])

if (strategy === Strategy.Absolute) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ export interface PopoverContentProps extends Omit<FloatingPanelProps, 'target' |
isOpen?: boolean
focusLocked?: boolean
autoFocus?: boolean
keepInDOM?: boolean
}

export const PopoverContent = forwardRef((props, reference) => {
Expand All @@ -29,11 +28,9 @@ export const PopoverContent = forwardRef((props, reference) => {
as: Component = 'div',
role = 'dialog',
'aria-modal': ariaModel = true,
keepInDOM = false,
// we should let FloatingPanel to control its `hidden` attribute
hidden,
...otherProps
} = props

const { isOpen: isOpenContext, targetElement, tailElement, anchor, setOpen } = useContext(PopoverContext)
const { renderRoot } = useContext(PopoverRoot)

Expand Down Expand Up @@ -71,7 +68,7 @@ export const PopoverContent = forwardRef((props, reference) => {
return () => setFocusLock(false)
}, [autoFocus, focusLocked, tooltipElement])

if (!keepInDOM && !isOpenContext && !isOpen) {
if (!isOpenContext && !isOpen) {
return null
}

Expand All @@ -86,7 +83,6 @@ export const PopoverContent = forwardRef((props, reference) => {
aria-modal={ariaModel}
rootRender={renderRoot}
className={classNames(styles.popover, otherProps.className)}
forceHidden={keepInDOM && !isOpenContext && !isOpen}
>
{focusLocked ? (
<FocusLock disabled={!focusLock} returnFocus={true}>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ export function render(tether: Tether, eventTarget: HTMLElement | null, preserve
const layout = getLayout(tether)
const state = getState(layout)

if (state === null || !isVisible(tether.target) || tether.forceHidden) {
if (state === null || !isVisible(tether.target)) {
setVisibility(tether.element, false)
setVisibility((tether.marker as HTMLElement) ?? null, false)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,8 +55,6 @@ export interface Tether {

overflowToScrollParents?: boolean
constrainToScrollParents?: boolean

forceHidden?: boolean
}

export type MarkerElement = HTMLElement | SVGElement
Expand Down

0 comments on commit 4e125eb

Please sign in to comment.