STRATO-apps/wordpress_03/app/wp-content/themes/blocksy/static/js/customizer/components/Overlay.js

SHA-256: 97220df3535dcb3d41498e29b5bcaa2f85e554ee546a8ae670066d2f57bfecb5
import {
	createElement,
	Component,
	useEffect,
	useState,
	useContext,
	createContext,
	Fragment,
} from '@wordpress/element'
import { Dialog, DialogOverlay, DialogContent } from './reach/dialog'
import { Transition, animated } from 'react-spring'
import { __ } from 'ct-i18n'
import classnames from 'classnames'

const AnimatedDialogOverlay = animated(DialogOverlay)
const AnimatedDialogContent = animated(DialogContent)

const defaultIsVisible = (i) => !!i

const Overlay = ({
	items,
	isVisible = defaultIsVisible,
	render,
	className,
	initialFocusRef,
	onDismiss,
	onDismissed,
	onCloseButtonClick,
}) => {
	return (
		<Transition
			items={items}
			onStart={() =>
				document.body.classList[isVisible(items) ? 'add' : 'remove'](
					'ct-dashboard-overlay-open'
				)
			}
			onRest={(result, spring, item) => {
				if (onDismissed && !isVisible(item)) {
					onDismissed()
				}
			}}
			config={{ duration: 200 }}
			from={{ opacity: 0, y: -10 }}
			enter={{ opacity: 1, y: 0 }}
			leave={{ opacity: 0, y: 10 }}>
			{(props, items) => {
				return (
					isVisible(items) && (
						<AnimatedDialogOverlay
							style={{ opacity: props.opacity }}
							container={document.body}
							onDismiss={() => onDismiss()}
							initialFocusRef={initialFocusRef}>
							<AnimatedDialogContent
								className={classnames(
									'ct-admin-modal',
									className
								)}
								style={{
									transform: props.y.to(
										(y) => `translate3d(0px, ${y}px, 0px)`
									),
								}}>
								<button
									className="close-button"
									onClick={() =>
										onCloseButtonClick
											? onCloseButtonClick()
											: onDismiss()
									}>
									×
								</button>

								{render(items, props)}
							</AnimatedDialogContent>
						</AnimatedDialogOverlay>
					)
				)
			}}
		</Transition>
	)
}

export default Overlay