2023-04-19 20:56:15 +02:00
|
|
|
import { useState, useEffect } from 'react'
|
|
|
|
|
2023-04-16 10:45:36 +02:00
|
|
|
export const ModalWrapper = ({
|
|
|
|
app,
|
2023-04-19 20:56:15 +02:00
|
|
|
children = null,
|
2023-04-16 10:45:36 +02:00
|
|
|
flex = 'row',
|
|
|
|
justify = 'center',
|
|
|
|
items = 'center',
|
|
|
|
bg = 'base-100 lg:bg-base-300',
|
|
|
|
bgOpacity = '100 lg:bg-opacity-95',
|
|
|
|
bare = false,
|
|
|
|
keepOpenOnClick = false,
|
2023-04-19 20:56:15 +02:00
|
|
|
}) => {
|
|
|
|
const [animate, setAnimate] = useState(true)
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (animate) setAnimate(false)
|
|
|
|
}, [children, animate])
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div
|
|
|
|
className={`fixed top-0 left-0 m-0 p-0 shadow w-full h-screen
|
|
|
|
transform-all duration-100
|
|
|
|
${animate ? 'opacity-0 -translate-x-full lg:translate-x-0' : 'opacity-100 -translate-x-0'}
|
2023-04-16 10:45:36 +02:00
|
|
|
bg-${bg} bg-opacity-${bgOpacity} z-50 hover:cursor-pointer
|
|
|
|
flex flex-${flex} justify-${justify} overflow-auto items-${items}`}
|
2023-04-19 20:56:15 +02:00
|
|
|
onClick={keepOpenOnClick ? null : () => app.updateState('modal', false)}
|
|
|
|
>
|
|
|
|
{bare ? (
|
|
|
|
children
|
|
|
|
) : (
|
|
|
|
<div className="bg-base-100 p-4 lg:px-8 lg:rounded-lg lg:shadow-lg">{children}</div>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|