Files
mtdb_movie/common/resources/client/ui/focus/use-auto-focus.ts
maher 703f50a09d
Some checks failed
Build / run (push) Has been cancelled
first commit
2025-10-29 11:42:25 +01:00

28 lines
804 B
TypeScript
Executable File

import {RefObject, useEffect, useRef} from 'react';
export interface AutoFocusProps {
autoFocus?: boolean;
autoSelectText?: boolean;
disabled?: boolean;
}
export function useAutoFocus(
{autoFocus, autoSelectText}: AutoFocusProps,
ref: RefObject<HTMLElement>
) {
const autoFocusRef = useRef(autoFocus);
useEffect(() => {
if (autoFocusRef.current && ref.current) {
// run inside animation frame to prevent issues when opening
// dialog with via keyboard shortcut and focusing input
requestAnimationFrame(() => {
ref.current?.focus();
if (autoSelectText && ref.current?.nodeName.toLowerCase() === 'input') {
(ref.current as HTMLInputElement).select();
}
});
}
autoFocusRef.current = false;
}, [ref, autoSelectText]);
}