import {
createElement,
Component,
Fragment,
createContext,
useRef,
useContext,
useState,
} from '@wordpress/element'
import SinglePicker from './color-picker/single-picker'
import { normalizeCondition, matchValuesWithCondition } from 'match-conditions'
const ColorPicker = ({
option,
values,
value: internalValue,
onChange: onInternalChange,
device,
}) => {
const value = internalValue
const onChange = onInternalChange
// const [value, onChange] = useState(internalValue)
const [{ isPicking, isTransitioning }, setState] = useState({
isPicking: null,
isTransitioning: null,
})
const containerRef = useRef()
const modalRef = useRef()
return (
{option.pickers
.filter(
(picker) =>
!picker.condition ||
matchValuesWithCondition(
normalizeCondition(picker.condition),
picker.condition_source === 'global'
? Object.keys(picker.condition).reduce(
(current, key) => ({
...current,
[key]: wp.customize(key)(),
}),
{}
)
: values
)
)
.map((picker) => (
{
setState(({ isPicking }) => ({
isPicking: null,
isTransitioning: isPicking,
}))
}}
onPickingChange={(isPicking) =>
setState({
isTransitioning: picker.id,
isPicking,
})
}
stopTransitioning={() =>
setState((state) => ({
...state,
isTransitioning: false,
}))
}
onChange={(newPicker) => {
onChange({
...value,
[picker.id]: newPicker,
})
}}
value={value[picker.id] || option.value[picker.id]}
/>
))}
)
}
export default ColorPicker