mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-26 04:20:53 +01:00
47 lines
1.1 KiB
TypeScript
47 lines
1.1 KiB
TypeScript
import React, { useCallback } from 'react';
|
|
import ReactFocusLock from 'react-focus-lock';
|
|
import type { ModalFocusProps } from './modal-focus.types';
|
|
|
|
/**
|
|
* Based on the ModalFocusScope component from chakra-ui
|
|
* https://github.com/chakra-ui/chakra-ui/blob/main/packages/components/modal/src/modal-focus.tsx
|
|
*/
|
|
|
|
const FocusTrap: typeof ReactFocusLock =
|
|
(ReactFocusLock as any).default ?? ReactFocusLock;
|
|
|
|
export const ModalFocus: React.FC<ModalFocusProps> = ({
|
|
initialFocusRef,
|
|
finalFocusRef,
|
|
restoreFocus,
|
|
children,
|
|
autoFocus,
|
|
...props
|
|
}) => {
|
|
const onActivation = useCallback(() => {
|
|
if (initialFocusRef?.current) {
|
|
initialFocusRef.current.focus();
|
|
}
|
|
}, [initialFocusRef]);
|
|
|
|
const onDeactivation = useCallback(() => {
|
|
finalFocusRef?.current?.focus();
|
|
}, [finalFocusRef]);
|
|
|
|
const returnFocus = restoreFocus && !finalFocusRef;
|
|
|
|
return (
|
|
<FocusTrap
|
|
autoFocus={autoFocus}
|
|
onActivation={onActivation}
|
|
onDeactivation={onDeactivation}
|
|
returnFocus={returnFocus}
|
|
{...props}
|
|
>
|
|
{children}
|
|
</FocusTrap>
|
|
);
|
|
};
|
|
|
|
ModalFocus.displayName = 'ModalFocus';
|