HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux WebLive 5.15.0-79-generic #86-Ubuntu SMP Mon Jul 10 16:07:21 UTC 2023 x86_64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/html/wpmuhibbah/wp-content/plugins/give/src/Views/Components/AdminUI/ModalDialog/index.tsx
import {MouseEventHandler, useCallback, useEffect} from 'react';
import {createPortal} from 'react-dom';
import {__} from '@wordpress/i18n';
import {ExitIcon} from '@givewp/components/AdminUI/Icons';
import './style.scss';

export interface ModalProps {
    children: JSX.Element | JSX.Element[];
    title: string;
    isOpen?: boolean;
    icon?: JSX.Element | JSX.Element[];
    insertInto?: string;
    handleClose?: MouseEventHandler;
    showHeader?: boolean;
    showCloseIcon?: boolean;
    wrapperClassName?: string;
}

export default function Modal({
    title,
    icon,
    children,
    insertInto,
    handleClose,
    isOpen = true,
    showHeader = true,
    showCloseIcon = true,
    wrapperClassName = '',
}: ModalProps) {
    // ESC key closes modal
    const closeModal = useCallback((e) => {
        if (e.keyCode === 27 && typeof handleClose === 'function') {
            handleClose(e);
        }
    }, []);

    useEffect(() => {
        document.addEventListener('keydown', closeModal, false);

        return () => {
            document.removeEventListener('keydown', closeModal, false);
        };
    }, []);

    useEffect(() => {
        if (isOpen) {
            document.body.classList.add('modalDialog-open');
        } else {
            document.body.classList.remove('modalDialog-open');
        }

        return () => {
            document.body.classList.remove('modalDialog-open');
        };
    }, [isOpen]);

    if (!isOpen) return null;

    return createPortal(
        <div className={`givewp-modal-wrapper ${wrapperClassName}`}>
            <div role="dialog" aria-label={title} className="givewp-modal-dialog">
                <div className={`givewp-modal-dialog-content`}>
                    {showHeader ? (
                        <div className="givewp-modal-header">
                            {icon && <div className="givewp-modal-icon-header">{icon}</div>}
                            {title}
                            {showCloseIcon && handleClose && (
                                <button
                                    aria-label={__('Close dialog', 'give')}
                                    className="givewp-modal-close"
                                    onClick={handleClose}
                                >
                                    <ExitIcon aria-label={__('Close dialog icon', 'give')} />
                                </button>
                            )}
                        </div>
                    ) : (
                        <>
                            {showCloseIcon && handleClose && (
                                <button
                                    aria-label={__('Close dialog', 'give')}
                                    className="givewp-modal-close-headless"
                                    onClick={handleClose}
                                >
                                    <ExitIcon aria-label={__('Close dialog icon', 'give')} />
                                </button>
                            )}
                            {icon && <div className="givewp-modal-icon-center">{icon}</div>}
                        </>
                    )}

                    <div className="givewp-modal-content">{children}</div>
                </div>
            </div>
        </div>,
        insertInto ? document.querySelector(insertInto) : document.body
    );
}