File "info-modal.js"

Full Path: /home/warrior1/public_html/wp-content/plugins/elementor/app/modules/import-export/assets/js/shared/info-modal/info-modal.js
File size: 1.31 KB
MIME-type: text/x-java
Charset: utf-8

import ModalProvider from 'elementor-app/ui/modal/modal';
import InfoModalSection from './info-modal-section';
import InfoModalHeading from './info-modal-heading';
import InfoModalText from './info-modal-text';
import InfoModalTip from './info-modal-tip';

import './info-modal.scss';

export const infoButtonProps = {
	id: 'info-modal',
	className: 'e-app-export-kit-information__info-icon',
	icon: 'eicon-info-circle',
	text: __( 'Kit Info', 'elementor' ),
	color: 'secondary',
	hideText: true,
};

export default function InfoModal( props ) {
	const attrs = {
			className: 'e-app-import-export-info-modal',
			setShow: props.setShow,
			onOpen: props.onOpen,
			onClose: props.onClose,
			referrer: props.referrer,
		};

	if ( Object.prototype.hasOwnProperty.call( props, 'show' ) ) {
		attrs.show = props.show;
	} else {
		attrs.toggleButtonProps = infoButtonProps;
	}

	return (
		<ModalProvider { ...attrs } title={ props.title }>
			{ props.children }
		</ModalProvider>
	);
}

InfoModal.propTypes = {
	show: PropTypes.bool,
	setShow: PropTypes.func,
	title: PropTypes.string,
	children: PropTypes.any.isRequired,
	onOpen: PropTypes.func,
	onClose: PropTypes.func,
	referrer: PropTypes.string,
};

InfoModal.Section = InfoModalSection;
InfoModal.Heading = InfoModalHeading;
InfoModal.Text = InfoModalText;
InfoModal.Tip = InfoModalTip;