import {
createContext,
createElement,
useEffect,
useState,
} from '@wordpress/element'
import { __ } from 'ct-i18n'
import { Switch } from 'blocksy-options'
import ConditionsWithRelation from './ConditionsManager/ConditionsWithRelation'
export const ConditionsDataContext = createContext({
allLanguages: [],
remoteConditions: [],
})
let allLanguagesCache = []
let remoteConditionsCache = []
const ConditionsManager = ({
value,
onChange,
filter = 'all',
addConditionButtonLabel,
}) => {
const [allLanguages, setAllLanguages] = useState(allLanguagesCache)
const [remoteConditions, setRemoteConditions] = useState(
remoteConditionsCache
)
const [isAdvancedModeInternal, setIsAdvancedMode] = useState('__EMPTY__')
useEffect(() => {
fetch(
`${wp.ajax.settings.url}?action=blc_retrieve_conditions_data&filter=${filter}`,
{
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
},
method: 'POST',
}
)
.then((r) => r.json())
.then(({ data: { languages, conditions } }) => {
setAllLanguages(languages)
allLanguagesCache = languages
setRemoteConditions(conditions)
remoteConditionsCache = conditions
})
}, [])
const conditionsListDescriptor = Array.isArray(value)
? {
relation: 'OR',
conditions: value,
}
: value
let isAdvancedMode =
isAdvancedModeInternal === '__EMPTY__' ? false : isAdvancedModeInternal
if (
conditionsListDescriptor.conditions.find(
(condition) => condition.relation
)
) {
isAdvancedMode = true
}
/*
const conditionsListDescriptor = {
relation: 'OR',
conditions: [
{
type: 'include',
rule: rulesToUse[0].rules[0].id,
payload: {},
},
{
type: 'include',
rule: rulesToUse[0].rules[0].id,
payload: {},
},
{
type: 'include',
rule: rulesToUse[0].rules[0].id,
payload: {},
},
{
relation: 'AND',
conditions: [
{
type: 'include',
rule: rulesToUse[0].rules[0].id,
payload: {},
},
{
type: 'include',
rule: rulesToUse[0].rules[0].id,
payload: {},
},
{
type: 'include',
rule: rulesToUse[0].rules[0].id,
payload: {},
},
{
relation: 'OR',
conditions: [
{
type: 'include',
rule: rulesToUse[0].rules[0].id,
payload: {},
},
{
type: 'include',
rule: rulesToUse[0].rules[0].id,
payload: {},
},
],
},
{
type: 'include',
rule: rulesToUse[0].rules[0].id,
payload: {},
},
],
},
],
}
*/
// console.log(conditionsListDescriptor)
return (