2022-12-10 10:14:48 +01:00
|
|
|
import './modal.css';
|
|
|
|
|
|
|
|
import { createPortal } from 'preact/compat';
|
2022-12-30 13:37:57 +01:00
|
|
|
import { useEffect, useRef } from 'preact/hooks';
|
2022-12-10 10:14:48 +01:00
|
|
|
|
|
|
|
const $modalContainer = document.getElementById('modal-container');
|
|
|
|
|
2022-12-16 06:27:04 +01:00
|
|
|
function Modal({ children, onClick, class: className }) {
|
2022-12-10 10:14:48 +01:00
|
|
|
if (!children) return null;
|
|
|
|
|
2022-12-30 13:37:57 +01:00
|
|
|
const modalRef = useRef();
|
|
|
|
useEffect(() => {
|
|
|
|
let timer = setTimeout(() => {
|
|
|
|
const focusElement = modalRef.current?.querySelector('[tabindex="-1"]');
|
|
|
|
if (focusElement) {
|
|
|
|
focusElement.focus();
|
|
|
|
}
|
|
|
|
}, 100);
|
|
|
|
return () => clearTimeout(timer);
|
|
|
|
}, []);
|
|
|
|
|
2022-12-10 10:14:48 +01:00
|
|
|
const Modal = (
|
2022-12-30 13:37:57 +01:00
|
|
|
<div ref={modalRef} className={className} onClick={onClick}>
|
2022-12-10 10:14:48 +01:00
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
|
|
|
|
return createPortal(Modal, $modalContainer);
|
|
|
|
|
|
|
|
// return createPortal(children, $modalContainer);
|
2022-12-16 06:27:04 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
export default Modal;
|