Skip to content

Commit

Permalink
feat(Popover): add ariaLabel, ariaLabelledby props and focus state
Browse files Browse the repository at this point in the history
This commit adds ariaLabel and ariaLabelledby props to
enhance the component's accessibility. It also updates the tabIndex
value to make the Popover element focusable and readable by screen
readers.
  • Loading branch information
sarkaaa committed Dec 18, 2024
1 parent 934d5d5 commit e815138
Show file tree
Hide file tree
Showing 4 changed files with 23 additions and 3 deletions.
10 changes: 10 additions & 0 deletions packages/orbit-components/src/Popover/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,8 @@ The table below contains all types of props available in the Popover component.
| labelClose | `React.Node` | `Close` | The label for close button. |
| renderTimeout | `number` | `0` | The timeout for rendering the Popover. |
| zIndex | `number` | `710` | The zIndex value of the Popover component. |
| ariaLabel | `string` | | Optional prop for `aria-label` value. |
| ariaLabelledby | `string` | | Optional prop for `aria-labelledby` value. |

## enum

Expand Down Expand Up @@ -110,3 +112,11 @@ The table below contains all types of props available in the Popover component.
<Button>Open Popover</Button>
</Popover>
```

## Accessibility

- The `Button` component inside the `Popover` component is the most common trigger component for the opening and closing of the popover. The Popover component includes the `role="button"` attribute. Ensure that the `Button` is set as a non-interactive component (for example, using the `asComponent` prop) to avoid the accessibility violation of nesting interactive controls (`Interactive controls must not be nested`).

- The `ariaLabelledby` prop allows you to specify an `aria-labelledby` attribute for the popover content component. This attribute provides a reference to one or more elements that label the popover content. By using `ariaLabelledby`, the accessibility of popover component is improved and easier for users with assistive technologies to understand the context and purpose of the content.

- The `ariaLabel` prop allows you to specify an `aria-label` attribute for the popover content component. This attribute provides additional information to screen readers, enhancing the accessibility of the component. By using `ariaLabel`, you can ensure that users who rely on assistive technologies receive the necessary context and information about the component's purpose and functionality.
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,8 @@ export interface Props extends Common.Globals {
actions?: React.ReactNode;
offset?: Offset;
onClose: (ev?: MouseEvent | React.SyntheticEvent<HTMLElement>) => void;
ariaLabel?: string;
ariaLabelledby?: string;
}

const PopoverContentWrapper = ({
Expand All @@ -67,6 +69,8 @@ const PopoverContentWrapper = ({
allowOverflow,
lockScrolling = true,
actions,
ariaLabelledby,
ariaLabel,
}: Props) => {
const [actionsHeight, setActionsHeight] = React.useState<number | null>(null);
const { isInsideModal } = React.useContext(ModalContext);
Expand Down Expand Up @@ -198,6 +202,8 @@ const PopoverContentWrapper = ({
shown ? "lm:opacity-100" : "lm:opacity-0",
)}
style={cssVars}
aria-label={ariaLabel}
aria-labelledby={ariaLabelledby}
>
<div
ref={content}
Expand Down
8 changes: 5 additions & 3 deletions packages/orbit-components/src/Popover/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,8 @@ const Popover = ({
actions,
overlapped,
dataTest,
ariaLabel,
ariaLabelledby,
}: Props) => {
const ref = React.useRef<HTMLDivElement | null>(null);
const popoverId = useRandomId();
Expand Down Expand Up @@ -142,6 +144,8 @@ const Popover = ({
referenceElement={ref.current}
onClose={handleOut}
placement={placement}
ariaLabel={ariaLabel}
ariaLabelledby={ariaLabelledby}
>
{content}
</PopoverContent>
Expand All @@ -157,9 +161,7 @@ const Popover = ({
// @ts-expect-error expected
// eslint-disable-next-line react/no-unknown-property
popovertarget={id || popoverId}
// according to our docs button should be used for opening popover inside children (uncontrolled behavior),
// that's why this div shouldn't be focusable in order to avoid double focus
tabIndex={-1}
tabIndex={0}
onClick={handleClick}
onKeyDown={handleKeyDown<HTMLDivElement>(handleClick)}
>
Expand Down
2 changes: 2 additions & 0 deletions packages/orbit-components/src/Popover/types.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,4 +32,6 @@ export interface Props extends Common.Globals {
readonly renderInPortal?: boolean;
readonly onClose?: Common.Callback;
readonly zIndex?: number;
readonly ariaLabel?: string;
readonly ariaLabelledby?: string;
}

0 comments on commit e815138

Please sign in to comment.