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 (