|
import * as __WEBPACK_EXTERNAL_MODULE__wordpress_interactivity_8e89b257__ from "@wordpress/interactivity"; |
|
|
|
var __webpack_require__ = {}; |
|
|
|
|
|
|
|
(() => { |
|
|
|
__webpack_require__.d = (exports, definition) => { |
|
for(var key in definition) { |
|
if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { |
|
Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); |
|
} |
|
} |
|
}; |
|
})(); |
|
|
|
|
|
(() => { |
|
__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) |
|
})(); |
|
|
|
|
|
var __webpack_exports__ = {}; |
|
|
|
; |
|
var x = (y) => { |
|
var x = {}; __webpack_require__.d(x, y); return x |
|
} |
|
var y = (x) => (() => (x)) |
|
const interactivity_namespaceObject = x({ ["getContext"]: () => (__WEBPACK_EXTERNAL_MODULE__wordpress_interactivity_8e89b257__.getContext), ["getElement"]: () => (__WEBPACK_EXTERNAL_MODULE__wordpress_interactivity_8e89b257__.getElement), ["store"]: () => (__WEBPACK_EXTERNAL_MODULE__wordpress_interactivity_8e89b257__.store) }); |
|
; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let isTouching = false; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let lastTouchTime = 0; |
|
|
|
|
|
|
|
|
|
|
|
|
|
let imageRef; |
|
|
|
|
|
|
|
|
|
|
|
|
|
let buttonRef; |
|
const { |
|
state, |
|
actions, |
|
callbacks |
|
} = (0,interactivity_namespaceObject.store)('core/image', { |
|
state: { |
|
currentImage: {}, |
|
get overlayOpened() { |
|
return state.currentImage.currentSrc; |
|
}, |
|
get roleAttribute() { |
|
return state.overlayOpened ? 'dialog' : null; |
|
}, |
|
get ariaModal() { |
|
return state.overlayOpened ? 'true' : null; |
|
}, |
|
get enlargedSrc() { |
|
return state.currentImage.uploadedSrc || ''; |
|
}, |
|
get imgStyles() { |
|
return state.overlayOpened && `${state.currentImage.imgStyles?.replace(/;$/, '')}; object-fit:cover;`; |
|
} |
|
}, |
|
actions: { |
|
showLightbox() { |
|
const ctx = (0,interactivity_namespaceObject.getContext)(); |
|
|
|
|
|
if (!ctx.imageRef?.complete) { |
|
return; |
|
} |
|
|
|
|
|
|
|
state.scrollTopReset = document.documentElement.scrollTop; |
|
state.scrollLeftReset = document.documentElement.scrollLeft; |
|
|
|
|
|
ctx.currentSrc = ctx.imageRef.currentSrc; |
|
imageRef = ctx.imageRef; |
|
buttonRef = ctx.buttonRef; |
|
state.currentImage = ctx; |
|
state.overlayEnabled = true; |
|
|
|
|
|
callbacks.setOverlayStyles(); |
|
}, |
|
hideLightbox() { |
|
if (state.overlayEnabled) { |
|
|
|
|
|
|
|
|
|
|
|
setTimeout(function () { |
|
|
|
|
|
|
|
buttonRef.focus({ |
|
preventScroll: true |
|
}); |
|
|
|
|
|
state.currentImage = {}; |
|
imageRef = null; |
|
buttonRef = null; |
|
}, 450); |
|
|
|
|
|
|
|
state.showClosingAnimation = true; |
|
state.overlayEnabled = false; |
|
} |
|
}, |
|
handleKeydown(event) { |
|
if (state.overlayEnabled) { |
|
|
|
if (event.key === 'Tab') { |
|
event.preventDefault(); |
|
const { |
|
ref |
|
} = (0,interactivity_namespaceObject.getElement)(); |
|
ref.querySelector('button').focus(); |
|
} |
|
|
|
if (event.key === 'Escape') { |
|
actions.hideLightbox(); |
|
} |
|
} |
|
}, |
|
handleTouchMove(event) { |
|
|
|
|
|
|
|
|
|
|
|
|
|
if (state.overlayEnabled) { |
|
event.preventDefault(); |
|
} |
|
}, |
|
handleTouchStart() { |
|
isTouching = true; |
|
}, |
|
handleTouchEnd() { |
|
|
|
|
|
lastTouchTime = Date.now(); |
|
isTouching = false; |
|
}, |
|
handleScroll() { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (state.overlayOpened) { |
|
|
|
|
|
|
|
if (!isTouching && Date.now() - lastTouchTime > 450) { |
|
|
|
|
|
|
|
window.scrollTo(state.scrollLeftReset, state.scrollTopReset); |
|
} |
|
} |
|
} |
|
}, |
|
callbacks: { |
|
setOverlayStyles() { |
|
if (!imageRef) { |
|
return; |
|
} |
|
let { |
|
naturalWidth, |
|
naturalHeight, |
|
offsetWidth: originalWidth, |
|
offsetHeight: originalHeight |
|
} = imageRef; |
|
let { |
|
x: screenPosX, |
|
y: screenPosY |
|
} = imageRef.getBoundingClientRect(); |
|
|
|
|
|
const naturalRatio = naturalWidth / naturalHeight; |
|
|
|
let originalRatio = originalWidth / originalHeight; |
|
|
|
|
|
|
|
if (state.currentImage.scaleAttr === 'contain') { |
|
if (naturalRatio > originalRatio) { |
|
const heightWithoutSpace = originalWidth / naturalRatio; |
|
|
|
screenPosY += (originalHeight - heightWithoutSpace) / 2; |
|
originalHeight = heightWithoutSpace; |
|
} else { |
|
const widthWithoutSpace = originalHeight * naturalRatio; |
|
|
|
screenPosX += (originalWidth - widthWithoutSpace) / 2; |
|
originalWidth = widthWithoutSpace; |
|
} |
|
} |
|
originalRatio = originalWidth / originalHeight; |
|
|
|
|
|
|
|
|
|
|
|
let imgMaxWidth = parseFloat(state.currentImage.targetWidth !== 'none' ? state.currentImage.targetWidth : naturalWidth); |
|
let imgMaxHeight = parseFloat(state.currentImage.targetHeight !== 'none' ? state.currentImage.targetHeight : naturalHeight); |
|
|
|
|
|
let imgRatio = imgMaxWidth / imgMaxHeight; |
|
let containerMaxWidth = imgMaxWidth; |
|
let containerMaxHeight = imgMaxHeight; |
|
let containerWidth = imgMaxWidth; |
|
let containerHeight = imgMaxHeight; |
|
|
|
|
|
if (naturalRatio.toFixed(2) !== imgRatio.toFixed(2)) { |
|
if (naturalRatio > imgRatio) { |
|
|
|
|
|
|
|
|
|
const reducedHeight = imgMaxWidth / naturalRatio; |
|
if (imgMaxHeight - reducedHeight > imgMaxWidth) { |
|
imgMaxHeight = reducedHeight; |
|
imgMaxWidth = reducedHeight * naturalRatio; |
|
} else { |
|
imgMaxHeight = imgMaxWidth / naturalRatio; |
|
} |
|
} else { |
|
|
|
|
|
|
|
|
|
const reducedWidth = imgMaxHeight * naturalRatio; |
|
if (imgMaxWidth - reducedWidth > imgMaxHeight) { |
|
imgMaxWidth = reducedWidth; |
|
imgMaxHeight = reducedWidth / naturalRatio; |
|
} else { |
|
imgMaxWidth = imgMaxHeight * naturalRatio; |
|
} |
|
} |
|
containerWidth = imgMaxWidth; |
|
containerHeight = imgMaxHeight; |
|
imgRatio = imgMaxWidth / imgMaxHeight; |
|
|
|
|
|
if (originalRatio > imgRatio) { |
|
containerMaxWidth = imgMaxWidth; |
|
containerMaxHeight = containerMaxWidth / originalRatio; |
|
} else { |
|
containerMaxHeight = imgMaxHeight; |
|
containerMaxWidth = containerMaxHeight * originalRatio; |
|
} |
|
} |
|
|
|
|
|
if (originalWidth > containerWidth || originalHeight > containerHeight) { |
|
containerWidth = originalWidth; |
|
containerHeight = originalHeight; |
|
} |
|
|
|
|
|
|
|
|
|
let horizontalPadding = 0; |
|
if (window.innerWidth > 480) { |
|
horizontalPadding = 80; |
|
} else if (window.innerWidth > 1920) { |
|
horizontalPadding = 160; |
|
} |
|
const verticalPadding = 80; |
|
const targetMaxWidth = Math.min(window.innerWidth - horizontalPadding, containerWidth); |
|
const targetMaxHeight = Math.min(window.innerHeight - verticalPadding, containerHeight); |
|
const targetContainerRatio = targetMaxWidth / targetMaxHeight; |
|
if (originalRatio > targetContainerRatio) { |
|
|
|
containerWidth = targetMaxWidth; |
|
containerHeight = containerWidth / originalRatio; |
|
} else { |
|
|
|
containerHeight = targetMaxHeight; |
|
containerWidth = containerHeight * originalRatio; |
|
} |
|
const containerScale = originalWidth / containerWidth; |
|
const lightboxImgWidth = imgMaxWidth * (containerWidth / containerMaxWidth); |
|
const lightboxImgHeight = imgMaxHeight * (containerHeight / containerMaxHeight); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
state.overlayStyles = ` |
|
:root { |
|
--wp--lightbox-initial-top-position: ${screenPosY}px; |
|
--wp--lightbox-initial-left-position: ${screenPosX}px; |
|
--wp--lightbox-container-width: ${containerWidth + 1}px; |
|
--wp--lightbox-container-height: ${containerHeight + 1}px; |
|
--wp--lightbox-image-width: ${lightboxImgWidth}px; |
|
--wp--lightbox-image-height: ${lightboxImgHeight}px; |
|
--wp--lightbox-scale: ${containerScale}; |
|
--wp--lightbox-scrollbar-width: ${window.innerWidth - document.documentElement.clientWidth}px; |
|
} |
|
`; |
|
}, |
|
setButtonStyles() { |
|
const ctx = (0,interactivity_namespaceObject.getContext)(); |
|
const { |
|
ref |
|
} = (0,interactivity_namespaceObject.getElement)(); |
|
ctx.imageRef = ref; |
|
const { |
|
naturalWidth, |
|
naturalHeight, |
|
offsetWidth, |
|
offsetHeight |
|
} = ref; |
|
|
|
|
|
|
|
if (naturalWidth === 0 || naturalHeight === 0) { |
|
return; |
|
} |
|
const figure = ref.parentElement; |
|
const figureWidth = ref.parentElement.clientWidth; |
|
|
|
|
|
|
|
|
|
|
|
let figureHeight = ref.parentElement.clientHeight; |
|
const caption = figure.querySelector('figcaption'); |
|
if (caption) { |
|
const captionComputedStyle = window.getComputedStyle(caption); |
|
if (!['absolute', 'fixed'].includes(captionComputedStyle.position)) { |
|
figureHeight = figureHeight - caption.offsetHeight - parseFloat(captionComputedStyle.marginTop) - parseFloat(captionComputedStyle.marginBottom); |
|
} |
|
} |
|
const buttonOffsetTop = figureHeight - offsetHeight; |
|
const buttonOffsetRight = figureWidth - offsetWidth; |
|
|
|
|
|
|
|
|
|
if (ctx.scaleAttr === 'contain') { |
|
|
|
const naturalRatio = naturalWidth / naturalHeight; |
|
|
|
const offsetRatio = offsetWidth / offsetHeight; |
|
if (naturalRatio >= offsetRatio) { |
|
|
|
|
|
const referenceHeight = offsetWidth / naturalRatio; |
|
ctx.imageButtonTop = (offsetHeight - referenceHeight) / 2 + buttonOffsetTop + 16; |
|
ctx.imageButtonRight = buttonOffsetRight + 16; |
|
} else { |
|
|
|
|
|
const referenceWidth = offsetHeight * naturalRatio; |
|
ctx.imageButtonTop = buttonOffsetTop + 16; |
|
ctx.imageButtonRight = (offsetWidth - referenceWidth) / 2 + buttonOffsetRight + 16; |
|
} |
|
} else { |
|
ctx.imageButtonTop = buttonOffsetTop + 16; |
|
ctx.imageButtonRight = buttonOffsetRight + 16; |
|
} |
|
}, |
|
setOverlayFocus() { |
|
if (state.overlayEnabled) { |
|
|
|
const { |
|
ref |
|
} = (0,interactivity_namespaceObject.getElement)(); |
|
ref.focus(); |
|
} |
|
}, |
|
initTriggerButton() { |
|
const ctx = (0,interactivity_namespaceObject.getContext)(); |
|
const { |
|
ref |
|
} = (0,interactivity_namespaceObject.getElement)(); |
|
ctx.buttonRef = ref; |
|
} |
|
} |
|
}, { |
|
lock: true |
|
}); |
|
|
|
|