HEX
Server: Apache
System: Linux b5.s-host.com.ua 4.18.0-305.10.2.el7.x86_64 #1 SMP Fri Jul 23 21:00:55 UTC 2021 x86_64
User: unelbhzm (1470)
PHP: 8.0.18
Disabled: NONE
Upload Files
File: /sites/nuofama.com/wp-content/themes/blocksy/static/js/options/options/ct-color-palettes-picker.js
import {
	createElement,
	createPortal,
	useRef,
	Fragment,
	useState,
} from '@wordpress/element'
import OptionsPanel from '../OptionsPanel'
import { __ } from 'ct-i18n'
import cls from 'classnames'
import PalettePreview from './color-palettes/PalettePreview'
import ColorPalettesModal from './color-palettes/ColorPalettesModal'

import usePopoverMaker from '../helpers/usePopoverMaker'
import OutsideClickHandler from './react-outside-click-handler'

import { Transition } from '@react-spring/web'
import bezierEasing from 'bezier-easing'

const ColorPalettes = ({ option, value, onChange }) => {
	const colorPalettesWrapper = useRef()

	const [{ isOpen, isTransitioning }, setModalState] = useState({
		isOpen: false,
		isTransitioning: false,
	})

	const { styles, popoverProps } = usePopoverMaker({
		ref: colorPalettesWrapper,
		defaultHeight: 430,
		shouldCalculate: isTransitioning || isOpen,
	})

	const setIsOpen = (isOpen) => {
		setModalState((state) => ({
			...state,
			isOpen,
			isTransitioning: true,
		}))
	}

	const stopTransitioning = () =>
		setModalState((state) => ({
			...state,
			isTransitioning: false,
		}))
	const properValue = {
		...option.value,
		...Object.keys(value).reduce(
			(all, currentKey) => ({
				...all,
				...(value[currentKey]
					? {
							[currentKey]: value[currentKey],
					  }
					: {}),
			}),
			{}
		),
		...(option.value.palettes
			? {
					palettes: option.value.palettes.map((p, index) => {
						let maybeCurrentlyInValue = value.palettes.find(
							({ id }) => p.id === id
						)

						let maybeCurrentValue = {}

						if (p.id === value.current_palette) {
							Object.keys(p).map((maybeColor) => {
								if (
									maybeColor.indexOf('color') === 0 &&
									value[maybeColor]
								) {
									maybeCurrentValue[maybeColor] =
										value[maybeColor]
								}
							})
						}

						const result = {
							...Object.keys(p).reduce(
								(all, currentKey) => ({
									...all,
									...(p[currentKey]
										? {
												[currentKey]: p[currentKey],
										  }
										: {}),
								}),
								{}
							),
							...Object.keys(maybeCurrentlyInValue || {}).reduce(
								(all, currentKey) => ({
									...all,
									...(maybeCurrentlyInValue[currentKey]
										? {
												[currentKey]:
													maybeCurrentlyInValue[
														currentKey
													],
										  }
										: {}),
								}),
								{}
							),
							...maybeCurrentValue,
						}

						return result
					}),
			  }
			: {}),
	}

	return (
		<div>
			<OutsideClickHandler
				disabled={!isOpen}
				useCapture={false}
				className="ct-palettes-preview"
				additionalRefs={[popoverProps.ref]}
				onOutsideClick={() => {
					setIsOpen(false)
				}}
				wrapperProps={{
					ref: colorPalettesWrapper,
					onClick: (e) => {
						e.preventDefault()

						if (
							e.target.closest('.ct-color-picker-modal') ||
							e.target.classList.contains('ct-color-picker-modal')
						) {
							return
						}

						if (!properValue.palettes) {
							return
						}

						setIsOpen(true)
					},
				}}>
				<PalettePreview
					onClick={() => {
						if (!properValue.palettes) {
							return
						}
						setIsOpen(true)
					}}
					value={properValue}
					onChange={(optionId, optionValue) => {
						onChange({
							...properValue,
							...optionValue,
							...(properValue.palettes
								? {
										palettes: properValue.palettes.map(
											(p) =>
												p.id ===
												properValue.current_palette
													? {
															...p,
															...optionValue,
													  }
													: p
										),
								  }
								: {}),
						})
					}}
				/>
			</OutsideClickHandler>

			{(isTransitioning || isOpen) &&
				createPortal(
					<Transition
						items={isOpen}
						onRest={(isOpen) => {
							stopTransitioning()
						}}
						config={{
							duration: 100,
							easing: bezierEasing(0.25, 0.1, 0.25, 1.0),
						}}
						from={
							isOpen
								? {
										transform: 'scale3d(0.95, 0.95, 1)',
										opacity: 0,
								  }
								: { opacity: 1 }
						}
						enter={
							isOpen
								? {
										transform: 'scale3d(1, 1, 1)',
										opacity: 1,
								  }
								: {
										opacity: 1,
								  }
						}
						leave={
							!isOpen
								? {
										transform: 'scale3d(0.95, 0.95, 1)',
										opacity: 0,
								  }
								: {
										opacity: 1,
								  }
						}>
						{(style, item) => {
							if (!item) {
								return null
							}

							return (
								<ColorPalettesModal
									wrapperProps={{
										style: {
											...style,
											...styles,
										},
										...popoverProps,
									}}
									onChange={(value) => {
										setIsOpen(false)
										onChange(value)
									}}
									value={properValue}
									option={option}
								/>
							)
						}}
					</Transition>,
					document.body
				)}
		</div>
	)
}

export default ColorPalettes