/* @flow */ import React, { useState } from 'react' import classnames from 'classnames' import Modal from 'react-modal' import { buildAriaProps, buildCss, buildDataProps } from '../utilities/props' import { globalProps } from '../utilities/globalProps.js' import Button from '../pb_button/_button' import DialogHeader from './child_kits/_dialog_header' import DialogFooter from './child_kits/_dialog_footer' import DialogBody from './child_kits/_dialog_body' import { DialogContext } from './_dialog_context' type DialogProps = { aria?: object, cancelButton?: string, children: array | React.ReactNode | string, className?: string, closeable: boolean, confirmButton?: string, data?: object, id?: string, loading?: boolean, onCancel?: () => void, onChange?: () => void, onClose?: () => void, onConfirm?: () => void, opened: boolean, portalClassName?: string, shouldCloseOnOverlayClick: boolean, size?: "sm" | "md" | "lg" | "content", text?: string, title?: string, trigger?: string } const Dialog = (props: DialogProps) => { const { aria = {}, cancelButton, confirmButton, className, data = {}, id, size = 'md', children, loading = false, opened, onCancel = () => {}, onConfirm = () => {}, onClose = () => {}, portalClassName, shouldCloseOnOverlayClick = true, text, title, trigger, } = props const ariaProps = buildAriaProps(aria) const dataProps = buildDataProps(data) const dialogClassNames = { base: classnames('pb_dialog', buildCss('pb_dialog', size)), afterOpen: 'pb_dialog_after_open', beforeClose: 'pb_dialog_before_close', } const overlayClassNames = { base: 'pb_dialog_overlay', afterOpen: 'pb_dialog_overlay_after_open', beforeClose: 'pb_dialog_overlay_before_close', } const classes = classnames( buildCss('pb_dialog_wrapper'), globalProps(props), className ) const api = { onClose: trigger ? function(){ setTriggerOpened(false) } : onClose, } const [triggerOpened, setTriggerOpened] = useState(false), modalIsOpened = trigger ? triggerOpened : opened if (trigger) { const modalTrigger = document.querySelector(trigger) modalTrigger.addEventListener('click', () => { setTriggerOpened(true) document.querySelector('#cancel-button').addEventListener('click', () => { setTriggerOpened(false) }) }, { once: true }) } return (
{title} {text} {children}
) } Dialog.Header = DialogHeader Dialog.Body = DialogBody Dialog.Footer = DialogFooter export default Dialog