import { createElement, Component, createRef, useRef, useCallback, useEffect, useState, } from '@wordpress/element' import OptionsPanel from './OptionsPanel' import $ from 'jquery' import ctEvents from 'ct-events' const INITIAL_VALUE = '__INITIAL__' const OptionsRoot = ({ value, options, input_name, input_id, hasRevertButton, }) => { const [internalValue, setInternalValue] = useState(value) const input = useRef() const handleChange = useCallback(({ id, value, input: inputRef }) => { if (inputRef === input.current) { setInternalValue((internalValue) => ({ ...internalValue, [id]: value, })) } }, []) useEffect(() => { ctEvents.on('ct:options:trigger-change', handleChange) return () => { ctEvents.off('ct:options:trigger-change', handleChange) } }, []) return (
{}} name={input_name} id={input_id} type="hidden" ref={input} /> { setInternalValue((internalValue) => ({ ...internalValue, [key]: newValue, })) $(input.current).change() }} value={internalValue} options={options} />
) } export default OptionsRoot