wp-productzilla/wp-content/plugins/blocksy-companion/static/js/options/ConditionsManager.js
rizal.productzilla e38e8b231d templating
2024-04-01 16:08:46 +07:00

238 lines
4.8 KiB
JavaScript

import {
createContext,
createElement,
useEffect,
useState,
} from '@wordpress/element'
import { __ } from 'ct-i18n'
import { Switch } from 'blocksy-options'
import ConditionsWithRelation from './ConditionsManager/ConditionsWithRelation'
import useConditionsData from './ConditionsManager/useConditionsData'
export const ConditionsDataContext = createContext({
filter: 'all',
allTaxonomies: [],
allLanguages: [],
allUsers: [],
})
let allTaxonomiesCache = []
let allLanguagesCache = []
let allUsersCache = []
const ConditionsManager = ({
value,
onChange,
filter = 'all',
addConditionButtonLabel,
}) => {
const { rulesToUse } = useConditionsData()
const [allTaxonomies, setAllTaxonomies] = useState(allTaxonomiesCache)
const [allLanguages, setAllLanguages] = useState(allLanguagesCache)
const [allUsers, setAllUsers] = useState(allUsersCache)
const [isAdvancedModeInternal, setIsAdvancedMode] = useState('__EMPTY__')
useEffect(() => {
fetch(
`${wp.ajax.settings.url}?action=blocksy_conditions_get_all_taxonomies`,
{
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
},
method: 'POST',
}
)
.then((r) => r.json())
.then(({ data: { taxonomies, languages, users } }) => {
setAllTaxonomies(taxonomies)
allTaxonomiesCache = taxonomies
setAllLanguages(languages)
allLanguagesCache = languages
setAllUsers(users)
allUsersCache = users
})
}, [])
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 (
<ConditionsDataContext.Provider
value={{
allTaxonomies,
allLanguages,
allUsers,
filter,
isAdvancedMode,
}}>
<div className="ct-display-conditions">
<ConditionsWithRelation
conditionsListDescriptor={conditionsListDescriptor}
onChange={(conditions) => {
onChange({
...conditionsListDescriptor,
conditions,
})
}}
/>
<div className="ct-conditions-actions">
<button
type="button"
className="button add-condition"
onClick={(e) => {
e.preventDefault()
onChange({
...conditionsListDescriptor,
conditions: [
...conditionsListDescriptor.conditions,
{
type: 'include',
rule: rulesToUse[0].rules[0].id,
payload: {},
},
],
})
}}>
{addConditionButtonLabel}
</button>
{(conditionsListDescriptor.conditions.length > 1 ||
conditionsListDescriptor.conditions.find(
(condition) => condition.relation
)) && (
<span>
{__('Advanced Mode', 'blocksy-companion')}
<Switch
value={isAdvancedMode}
onChange={(value) => {
if (
conditionsListDescriptor.conditions.find(
(condition) => condition.relation
)
) {
onChange({
...conditionsListDescriptor,
conditions:
conditionsListDescriptor.conditions.reduce(
(acc, condition) => {
return [
...acc,
...(condition.conditions
? condition.conditions
: [condition]),
]
},
[]
),
})
}
setIsAdvancedMode(value)
}}
option={{
behavior: 'boolean',
}}
/>
</span>
)}
</div>
</div>
</ConditionsDataContext.Provider>
)
}
export default ConditionsManager