236 lines
5.5 KiB
JavaScript
236 lines
5.5 KiB
JavaScript
import { handleBackgroundOptionFor } from '../../../static/js/customizer/sync/variables/background'
|
|
import { maybePromoteScalarValueIntoResponsive } from 'customizer-sync-helpers/dist/promote-into-responsive'
|
|
import {
|
|
withKeys,
|
|
handleResponsiveSwitch,
|
|
} from '../../../static/js/customizer/sync/helpers'
|
|
import ctEvents from 'ct-events'
|
|
|
|
import {
|
|
getRootSelectorFor,
|
|
assembleSelector,
|
|
mutateSelector,
|
|
} from '../../../static/js/customizer/sync/helpers'
|
|
|
|
ctEvents.on(
|
|
'ct:footer:sync:collect-variable-descriptors',
|
|
(variableDescriptors) => {
|
|
variableDescriptors['global'] = () => ({
|
|
...handleBackgroundOptionFor({
|
|
id: 'footerBackground',
|
|
selector: assembleSelector(
|
|
mutateSelector({
|
|
selector: getRootSelectorFor({ panelType: 'footer' }),
|
|
operation: 'suffix',
|
|
to_add: '.ct-footer',
|
|
})
|
|
),
|
|
responsive: true,
|
|
}),
|
|
|
|
footer_spacing: {
|
|
selector: assembleSelector(
|
|
mutateSelector({
|
|
selector: getRootSelectorFor({ panelType: 'footer' }),
|
|
operation: 'suffix',
|
|
to_add: '.ct-footer',
|
|
})
|
|
),
|
|
type: 'spacing',
|
|
variable: 'footer-container-padding',
|
|
responsive: true,
|
|
},
|
|
|
|
footer_boxed_offset: {
|
|
selector: assembleSelector(
|
|
mutateSelector({
|
|
selector: getRootSelectorFor({ panelType: 'footer' }),
|
|
operation: 'suffix',
|
|
to_add: 'footer.ct-container',
|
|
})
|
|
),
|
|
variable: 'footer-container-bottom-offset',
|
|
responsive: true,
|
|
unit: 'px',
|
|
},
|
|
|
|
footer_boxed_spacing: {
|
|
selector: assembleSelector(
|
|
mutateSelector({
|
|
selector: getRootSelectorFor({ panelType: 'footer' }),
|
|
operation: 'suffix',
|
|
to_add: 'footer.ct-container',
|
|
})
|
|
),
|
|
type: 'spacing',
|
|
variable: 'footer-container-padding',
|
|
responsive: true,
|
|
},
|
|
|
|
footer_container_border_radius: {
|
|
selector: assembleSelector(
|
|
mutateSelector({
|
|
selector: getRootSelectorFor({ panelType: 'footer' }),
|
|
operation: 'suffix',
|
|
to_add: '.ct-container',
|
|
})
|
|
),
|
|
type: 'spacing',
|
|
variable: 'footer-container-border-radius',
|
|
responsive: true,
|
|
},
|
|
|
|
...withKeys(
|
|
['has_reveal_effect', 'footerShadow'],
|
|
[
|
|
handleResponsiveSwitch({
|
|
selector: assembleSelector(
|
|
mutateSelector({
|
|
selector: mutateSelector({
|
|
selector: getRootSelectorFor({
|
|
panelType: 'footer',
|
|
}),
|
|
operation: 'suffix',
|
|
to_add: '.ct-footer',
|
|
}),
|
|
operation: 'container-suffix',
|
|
to_add: '[data-footer*="reveal"]',
|
|
})
|
|
),
|
|
variable: 'position',
|
|
on: 'sticky',
|
|
off: 'static',
|
|
fullValue: true,
|
|
extractValue: ({
|
|
has_reveal_effect = {
|
|
desktop: false,
|
|
tablet: false,
|
|
mobile: false,
|
|
},
|
|
}) => has_reveal_effect,
|
|
}),
|
|
|
|
{
|
|
selector: assembleSelector(
|
|
mutateSelector({
|
|
selector: mutateSelector({
|
|
selector: getRootSelectorFor({
|
|
panelType: 'footer',
|
|
}),
|
|
operation: 'suffix',
|
|
to_add: '.site-main',
|
|
}),
|
|
operation: 'container-suffix',
|
|
to_add: '[data-footer*="reveal"]',
|
|
})
|
|
),
|
|
type: 'box-shadow',
|
|
variable: 'footer-box-shadow',
|
|
responsive: true,
|
|
fullValue: true,
|
|
forcedOutput: true,
|
|
extractValue: ({
|
|
has_reveal_effect = {
|
|
desktop: false,
|
|
tablet: false,
|
|
mobile: false,
|
|
},
|
|
|
|
footerShadow = {
|
|
enable: true,
|
|
h_offset: 0,
|
|
v_offset: 30,
|
|
blur: 50,
|
|
spread: 0,
|
|
inset: false,
|
|
color: { color: 'rgba(0, 0, 0, 0.1)' },
|
|
},
|
|
}) => {
|
|
let value =
|
|
maybePromoteScalarValueIntoResponsive(
|
|
footerShadow
|
|
)
|
|
|
|
if (
|
|
!has_reveal_effect.desktop &&
|
|
!has_reveal_effect.tablet &&
|
|
!has_reveal_effect.mobile
|
|
) {
|
|
return 'CT_CSS_SKIP_RULE'
|
|
}
|
|
|
|
if (!has_reveal_effect.desktop) {
|
|
value.desktop = 'none'
|
|
}
|
|
|
|
if (!has_reveal_effect.tablet) {
|
|
value.tablet = 'none'
|
|
}
|
|
|
|
if (!has_reveal_effect.mobile) {
|
|
value.mobile = 'none'
|
|
}
|
|
|
|
return value
|
|
},
|
|
},
|
|
]
|
|
),
|
|
})
|
|
}
|
|
)
|
|
|
|
ctEvents.on('ct:footer:sync:item:global', (changeDescriptor) => {
|
|
const footer = document.querySelector('.ct-footer')
|
|
|
|
if (changeDescriptor.optionId === 'has_reveal_effect') {
|
|
let revealComponents = []
|
|
|
|
if (changeDescriptor.optionValue.desktop) {
|
|
revealComponents.push('desktop')
|
|
}
|
|
|
|
if (changeDescriptor.optionValue.tablet) {
|
|
revealComponents.push('tablet')
|
|
}
|
|
|
|
if (changeDescriptor.optionValue.mobile) {
|
|
revealComponents.push('mobile')
|
|
}
|
|
|
|
document.body.dataset.footer.replace(':reveal', '')
|
|
|
|
if (revealComponents.length > 0) {
|
|
document.body.dataset.footer += ':reveal'
|
|
}
|
|
}
|
|
|
|
if (changeDescriptor.optionId === 'footer_container_structure') {
|
|
const rows = footer.querySelectorAll('[data-row] > div')
|
|
|
|
rows.forEach((row) => {
|
|
row.classList.remove('ct-container-auto')
|
|
row.classList.remove('ct-container-fluid')
|
|
row.classList.add('ct-container')
|
|
})
|
|
|
|
if (changeDescriptor.optionValue === 'boxed') {
|
|
footer.classList.add('ct-container')
|
|
|
|
rows.forEach((row) => {
|
|
row.classList.remove('ct-container')
|
|
row.classList.add('ct-container-auto')
|
|
})
|
|
} else {
|
|
footer.classList.remove('ct-container')
|
|
}
|
|
|
|
if (changeDescriptor.optionValue === 'fluid') {
|
|
rows.forEach((row) => {
|
|
row.classList.remove('ct-container')
|
|
row.classList.add('ct-container-fluid')
|
|
})
|
|
}
|
|
}
|
|
})
|