1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-01 21:57:06 +01:00
metamask-extension/ui/components/component-library/modal-focus/modal-focus.tsx

47 lines
1.1 KiB
TypeScript
Raw Normal View History

2023-05-09 23:33:29 +02:00
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';