PluginProbe ʕ •ᴥ•ʔ
GiveWP – Donation Plugin and Fundraising Platform / trunk
GiveWP – Donation Plugin and Fundraising Platform vtrunk
4.16.2 4.16.1 4.16.0 4.15.5 4.15.4 4.15.3 4.15.2 4.15.1 4.15.0 2.3.0 2.3.1 2.3.2 2.30.0 2.31.0 2.31.1 2.32.0 2.33.0 2.33.1 2.33.2 2.33.3 2.33.4 2.33.5 2.4.0 2.4.1 2.4.2 2.4.3 2.4.4 2.4.5 2.4.6 2.4.7 2.5.0 2.5.1 2.5.10 2.5.11 2.5.12 2.5.13 2.5.2 2.5.3 2.5.4 2.5.5 2.5.6 2.5.7 2.5.8 2.5.9 2.6.0 2.6.1 2.6.2 2.6.3 2.7.0 2.7.1 2.7.2 2.7.3 2.7.4 2.7.5 2.8.0 2.8.1 2.9.0 2.9.1 2.9.2 2.9.3 2.9.4 2.9.5 2.9.6 2.9.7 3.0.0 3.0.1 3.0.2 3.0.3 3.0.4 3.1.0 3.1.1 3.1.2 3.10.0 3.11.0 3.12.0 3.12.1 3.12.2 3.12.3 3.13.0 3.14.0 3.14.1 3.14.2 3.15.0 3.15.1 3.16.0 3.16.1 3.16.2 3.16.3 3.16.4 3.16.5 3.17.0 3.17.1 3.17.2 3.18.0 3.19.0 3.19.1 3.19.2 3.19.3 3.19.4 3.2.0 3.2.1 3.2.2 3.20.0 3.21.0 3.21.1 3.22.0 3.22.1 3.22.2 3.3.0 3.3.1 3.4.0 3.4.1 3.4.2 3.5.0 3.5.1 3.6.0 3.6.1 3.6.2 3.7.0 3.8.0 3.9.0 4.0.0 4.1.0 4.1.1 4.10.0 4.10.1 4.11.0 4.12.0 4.13.0 4.13.1 4.13.2 4.14.0 4.14.1 4.14.2 4.14.3 4.14.4 4.14.5 4.14.6 4.2.0 4.2.1 4.3.0 4.3.1 4.3.2 4.4.0 4.5.0 4.6.1 4.7.0 4.7.1 4.8.0 4.8.1 4.9.0 trunk 1.9.0 2.0.0 2.0.1 2.0.2 2.0.3 2.0.4 2.0.5 2.0.6 2.0.7 2.1.0 2.1.1 2.1.2 2.1.3 2.1.4 2.1.5 2.1.6 2.1.7 2.1.8 2.10.0 2.10.1 2.10.2 2.10.3 2.10.4 2.11.0 2.11.1 2.11.2 2.11.3 2.12.0 2.12.1 2.12.2 2.12.3 2.13.0 2.13.1 2.13.2 2.13.3 2.13.4 2.14.0 2.15.0 2.16.0 2.16.1 2.17.0 2.17.1 2.17.3 2.18.0 2.18.1 2.19.1 2.19.2 2.19.3 2.19.4 2.19.5 2.19.6 2.19.7 2.19.8 2.2.0 2.2.1 2.2.2 2.2.3 2.2.4 2.2.5 2.2.6 2.20.0 2.20.1 2.20.2 2.21.0 2.21.1 2.21.2 2.21.3 2.21.4 2.22.0 2.22.1 2.22.2 2.22.3 2.23.0 2.23.1 2.23.2 2.24.0 2.24.1 2.24.2 2.25.0 2.25.1 2.25.2 2.25.3 2.26.0 2.27.0 2.27.1 2.27.2 2.27.3 2.28.0 2.29.0 2.29.1 2.29.2
give / src / Views / Components / AdminUI / ModalDialog / index.tsx
give / src / Views / Components / AdminUI / ModalDialog Last commit date
index.tsx 1 year ago style.scss 1 year ago
index.tsx
100 lines
1 import {MouseEventHandler, useCallback, useEffect} from 'react';
2 import {createPortal} from 'react-dom';
3 import {__} from '@wordpress/i18n';
4 import {ExitIcon} from '@givewp/components/AdminUI/Icons';
5 import './style.scss';
6
7 export interface ModalProps {
8 children: JSX.Element | JSX.Element[];
9 title: string;
10 isOpen?: boolean;
11 icon?: JSX.Element | JSX.Element[];
12 insertInto?: string;
13 handleClose?: MouseEventHandler;
14 showHeader?: boolean;
15 showCloseIcon?: boolean;
16 wrapperClassName?: string;
17 }
18
19 export default function Modal({
20 title,
21 icon,
22 children,
23 insertInto,
24 handleClose,
25 isOpen = true,
26 showHeader = true,
27 showCloseIcon = true,
28 wrapperClassName = '',
29 }: ModalProps) {
30 // ESC key closes modal
31 const closeModal = useCallback((e) => {
32 if (e.keyCode === 27 && typeof handleClose === 'function') {
33 handleClose(e);
34 }
35 }, []);
36
37 useEffect(() => {
38 document.addEventListener('keydown', closeModal, false);
39
40 return () => {
41 document.removeEventListener('keydown', closeModal, false);
42 };
43 }, []);
44
45 useEffect(() => {
46 if (isOpen) {
47 document.body.classList.add('modalDialog-open');
48 } else {
49 document.body.classList.remove('modalDialog-open');
50 }
51
52 return () => {
53 document.body.classList.remove('modalDialog-open');
54 };
55 }, [isOpen]);
56
57 if (!isOpen) return null;
58
59 return createPortal(
60 <div className={`givewp-modal-wrapper ${wrapperClassName}`}>
61 <div role="dialog" aria-label={title} className="givewp-modal-dialog">
62 <div className={`givewp-modal-dialog-content`}>
63 {showHeader ? (
64 <div className="givewp-modal-header">
65 {icon && <div className="givewp-modal-icon-header">{icon}</div>}
66 {title}
67 {showCloseIcon && handleClose && (
68 <button
69 aria-label={__('Close dialog', 'give')}
70 className="givewp-modal-close"
71 onClick={handleClose}
72 >
73 <ExitIcon aria-label={__('Close dialog icon', 'give')} />
74 </button>
75 )}
76 </div>
77 ) : (
78 <>
79 {showCloseIcon && handleClose && (
80 <button
81 aria-label={__('Close dialog', 'give')}
82 className="givewp-modal-close-headless"
83 onClick={handleClose}
84 >
85 <ExitIcon aria-label={__('Close dialog icon', 'give')} />
86 </button>
87 )}
88 {icon && <div className="givewp-modal-icon-center">{icon}</div>}
89 </>
90 )}
91
92 <div className="givewp-modal-content">{children}</div>
93 </div>
94 </div>
95 </div>,
96 insertInto ? document.querySelector(insertInto) : document.body
97 );
98 }
99
100