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/customizer/controls/options.js
import { createElement, useRef, useState } from '@wordpress/element'
import classnames from 'classnames'

import OptionsPanel from '../../options/OptionsPanel'
import { getValueFromInput } from '../../options/helpers/get-value-from-input'
import PanelLevel from '../../options/components/PanelLevel'
import { DeviceManagerProvider } from '../components/useDeviceManager'

const Options = ({ option, renderOptions = null }) => {
	const [values, setValues] = useState(null)

	const containerRef = useRef()

	return (
		<DeviceManagerProvider>
			<div className="ct-options-container" ref={containerRef}>
				<PanelLevel containerRef={containerRef}>
					<OptionsPanel
						renderOptions={renderOptions}
						purpose="customizer"
						onChange={(key, val) => {
							setValues((values) => {
								return {
									...(values ||
										getValueFromInput(
											option['inner-options'],
											{},
											(id) => ({
												[id]:
													wp.customize(id) &&
													wp.customize(id)(),
											})
										)),
									[key]: val,
								}
							})

							wp.customize(key) && wp.customize(key).set(val)
						}}
						options={option['inner-options']}
						value={
							values ||
							getValueFromInput(
								option['inner-options'],
								{},
								(id) => ({
									[id]:
										wp.customize(id) && wp.customize(id)(),
								})
							)
						}
					/>
				</PanelLevel>
			</div>
		</DeviceManagerProvider>
	)
}

export default Options