HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux vm8 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: afleverb (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //var/www/drakkar_site/wp-content/themes/blocksy/static/js/options/helpers/useSpringModal.js
import { useState } from '@wordpress/element'

import { useSpring } from 'react-spring'
import bezierEasing from 'bezier-easing'

export const useSpringModal = (args = {}) => {
	args = {
		onClosed: () => {},

		...args,
	}

	const [modalOpen, setModalOpen] = useState(false)

	const [modalSprings, modalAnimationApi] = useSpring(() => ({
		from: {
			transform: 'scale3d(0.95, 0.95, 1)',
			opacity: 0,
		},

		config: {
			duration: 100,
			easing: bezierEasing(0.25, 0.1, 0.25, 1.0),
		},
	}))

	// First render modal and make it hidden.
	//
	// Then, after one frame, animate the modal to be visible.
	const openModal = () => {
		if (modalOpen) {
			return
		}

		setModalOpen(true)

		requestAnimationFrame(() => {
			modalAnimationApi.start({
				transform: 'scale3d(1, 1, 1)',
				opacity: 1,
			})
		})
	}

	// Animate the modal to be hidden first. Then fully remove it from the DOM.
	const closeModal = () => {
		if (!modalOpen) {
			return
		}

		modalAnimationApi.start({
			transform: 'scale3d(0.95, 0.95, 1)',
			opacity: 0,

			onRest: () => {
				setModalOpen(false)
				args.onClosed()
			},
		})
	}

	return {
		modalOpen,
		modalStyles: modalSprings,

		openModal,
		closeModal,
	}
}