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/options/ct-box-shadow.js
import { createElement, useState, useRef } from '@wordpress/element'
import OutsideClickHandler from './react-outside-click-handler'
import classnames from 'classnames'
import SingleColorPicker from './color-picker/single-picker'
import { __ } from 'ct-i18n'
import BoxShadowModal from './box-shadow/modal'

import { useSpringModal } from '../helpers/useSpringModal'

const BoxShadow = ({ value, option, onChange }) => {
	// null | color | opts
	const [currentView, setCurrentView] = useState(null)

	const [colorPickerEl, setColorPickerEl] = useState(null)

	const { modalOpen, modalStyles, openModal, closeModal } = useSpringModal({
		onClosed: () => {
			setCurrentView(null)
			setColorPickerEl(null)
		},
	})

	const el = useRef()
	const colorPicker = useRef()

	const hOffsetRef = useRef()
	const vOffsetRef = useRef()
	const blurRef = useRef()
	const spreadRef = useRef()

	const containerRef = useRef()
	const modalRef = useRef()

	return (
		<div ref={el} className={classnames('ct-box-shadow')}>
			<OutsideClickHandler
				useCapture={false}
				disabled={!modalOpen}
				className="ct-box-shadow-values"
				additionalRefs={[colorPicker, modalRef]}
				onOutsideClick={(e) => {
					closeModal()
				}}
				wrapperProps={{
					ref: containerRef,
					onClick: (e) => {
						e.preventDefault()

						if (modalOpen) {
							closeModal()
							return
						}

						setCurrentView('opts')

						openModal()
					},
				}}>
				<span>
					{value.inherit
						? __('Inherit', 'blocksy')
						: value.enable
						? __('Adjust', 'blocksy')
						: __('None', 'blocksy')}
				</span>
			</OutsideClickHandler>

			{value.enable && !value.inherit && (
				<SingleColorPicker
					innerRef={colorPicker}
					picker={{
						id: 'default',
						title: 'Initial',
					}}
					option={{
						pickers: [
							{
								id: 'default',
								title: 'Initial',
							},
						],
					}}
					modalRef={modalRef}
					containerRef={containerRef}
					onPickingChange={(el) => {
						if (!value.enable) {
							return
						}

						if (modalOpen) {
							closeModal()
							return
						}

						setCurrentView('color')
						setColorPickerEl(el)

						openModal()
					}}
					onChange={(colorValue) =>
						onChange({
							...value,
							color: colorValue,
						})
					}
					value={value.color}
				/>
			)}

			{modalOpen && (
				<BoxShadowModal
					currentView={currentView}
					modalStyles={modalStyles}
					option={option}
					value={value}
					onChange={onChange}
					modalRef={modalRef}
					el={el}
					colorPickerEl={colorPickerEl}
					colorPicker={{
						id: 'default',
						title: 'Initial',
					}}
				/>
			)}
		</div>
	)
}

export default BoxShadow