{ "version": 3, "sources": ["../../../node_modules/.pnpm/photoswipe@5.4.4/src/js/util/util.js", "../../../node_modules/.pnpm/photoswipe@5.4.4/src/js/core/eventable.js", "../../../node_modules/.pnpm/photoswipe@5.4.4/src/js/slide/placeholder.js", "../../../node_modules/.pnpm/photoswipe@5.4.4/src/js/slide/content.js", "../../../node_modules/.pnpm/photoswipe@5.4.4/src/js/util/viewport-size.js", "../../../node_modules/.pnpm/photoswipe@5.4.4/src/js/slide/zoom-level.js", "../../../node_modules/.pnpm/photoswipe@5.4.4/src/js/slide/loader.js", "../../../node_modules/.pnpm/photoswipe@5.4.4/src/js/core/base.js", "../../../node_modules/.pnpm/photoswipe@5.4.4/src/js/lightbox/lightbox.js"], "sourcesContent": ["/** @typedef {import('../photoswipe.js').Point} Point */\r\n\r\n/**\r\n * @template {keyof HTMLElementTagNameMap} T\r\n * @param {string} className\r\n * @param {T} tagName\r\n * @param {Node} [appendToEl]\r\n * @returns {HTMLElementTagNameMap[T]}\r\n */\r\nexport function createElement(className, tagName, appendToEl) {\r\n const el = document.createElement(tagName);\r\n if (className) {\r\n el.className = className;\r\n }\r\n if (appendToEl) {\r\n appendToEl.appendChild(el);\r\n }\r\n return el;\r\n}\r\n\r\n/**\r\n * @param {Point} p1\r\n * @param {Point} p2\r\n * @returns {Point}\r\n */\r\nexport function equalizePoints(p1, p2) {\r\n p1.x = p2.x;\r\n p1.y = p2.y;\r\n if (p2.id !== undefined) {\r\n p1.id = p2.id;\r\n }\r\n return p1;\r\n}\r\n\r\n/**\r\n * @param {Point} p\r\n */\r\nexport function roundPoint(p) {\r\n p.x = Math.round(p.x);\r\n p.y = Math.round(p.y);\r\n}\r\n\r\n/**\r\n * Returns distance between two points.\r\n *\r\n * @param {Point} p1\r\n * @param {Point} p2\r\n * @returns {number}\r\n */\r\nexport function getDistanceBetween(p1, p2) {\r\n const x = Math.abs(p1.x - p2.x);\r\n const y = Math.abs(p1.y - p2.y);\r\n return Math.sqrt((x * x) + (y * y));\r\n}\r\n\r\n/**\r\n * Whether X and Y positions of points are equal\r\n *\r\n * @param {Point} p1\r\n * @param {Point} p2\r\n * @returns {boolean}\r\n */\r\nexport function pointsEqual(p1, p2) {\r\n return p1.x === p2.x && p1.y === p2.y;\r\n}\r\n\r\n/**\r\n * The float result between the min and max values.\r\n *\r\n * @param {number} val\r\n * @param {number} min\r\n * @param {number} max\r\n * @returns {number}\r\n */\r\nexport function clamp(val, min, max) {\r\n return Math.min(Math.max(val, min), max);\r\n}\r\n\r\n/**\r\n * Get transform string\r\n *\r\n * @param {number} x\r\n * @param {number} [y]\r\n * @param {number} [scale]\r\n * @returns {string}\r\n */\r\nexport function toTransformString(x, y, scale) {\r\n let propValue = `translate3d(${x}px,${y || 0}px,0)`;\r\n\r\n if (scale !== undefined) {\r\n propValue += ` scale3d(${scale},${scale},1)`;\r\n }\r\n\r\n return propValue;\r\n}\r\n\r\n/**\r\n * Apply transform:translate(x, y) scale(scale) to element\r\n *\r\n * @param {HTMLElement} el\r\n * @param {number} x\r\n * @param {number} [y]\r\n * @param {number} [scale]\r\n */\r\nexport function setTransform(el, x, y, scale) {\r\n el.style.transform = toTransformString(x, y, scale);\r\n}\r\n\r\nconst defaultCSSEasing = 'cubic-bezier(.4,0,.22,1)';\r\n\r\n/**\r\n * Apply CSS transition to element\r\n *\r\n * @param {HTMLElement} el\r\n * @param {string} [prop] CSS property to animate\r\n * @param {number} [duration] in ms\r\n * @param {string} [ease] CSS easing function\r\n */\r\nexport function setTransitionStyle(el, prop, duration, ease) {\r\n // inOut: 'cubic-bezier(.4, 0, .22, 1)', // for \"toggle state\" transitions\r\n // out: 'cubic-bezier(0, 0, .22, 1)', // for \"show\" transitions\r\n // in: 'cubic-bezier(.4, 0, 1, 1)'// for \"hide\" transitions\r\n el.style.transition = prop\r\n ? `${prop} ${duration}ms ${ease || defaultCSSEasing}`\r\n : 'none';\r\n}\r\n\r\n/**\r\n * Apply width and height CSS properties to element\r\n *\r\n * @param {HTMLElement} el\r\n * @param {string | number} w\r\n * @param {string | number} h\r\n */\r\nexport function setWidthHeight(el, w, h) {\r\n el.style.width = (typeof w === 'number') ? `${w}px` : w;\r\n el.style.height = (typeof h === 'number') ? `${h}px` : h;\r\n}\r\n\r\n/**\r\n * @param {HTMLElement} el\r\n */\r\nexport function removeTransitionStyle(el) {\r\n setTransitionStyle(el);\r\n}\r\n\r\n/**\r\n * @param {HTMLImageElement} img\r\n * @returns {Promise}\r\n */\r\nexport function decodeImage(img) {\r\n if ('decode' in img) {\r\n return img.decode().catch(() => {});\r\n }\r\n\r\n if (img.complete) {\r\n return Promise.resolve(img);\r\n }\r\n\r\n return new Promise((resolve, reject) => {\r\n img.onload = () => resolve(img);\r\n img.onerror = reject;\r\n });\r\n}\r\n\r\n/** @typedef {LOAD_STATE[keyof LOAD_STATE]} LoadState */\r\n/** @type {{ IDLE: 'idle'; LOADING: 'loading'; LOADED: 'loaded'; ERROR: 'error' }} */\r\nexport const LOAD_STATE = {\r\n IDLE: 'idle',\r\n LOADING: 'loading',\r\n LOADED: 'loaded',\r\n ERROR: 'error',\r\n};\r\n\r\n\r\n/**\r\n * Check if click or keydown event was dispatched\r\n * with a special key or via mouse wheel.\r\n *\r\n * @param {MouseEvent | KeyboardEvent} e\r\n * @returns {boolean}\r\n */\r\nexport function specialKeyUsed(e) {\r\n return ('button' in e && e.button === 1) || e.ctrlKey || e.metaKey || e.altKey || e.shiftKey;\r\n}\r\n\r\n/**\r\n * Parse `gallery` or `children` options.\r\n *\r\n * @param {import('../photoswipe.js').ElementProvider} [option]\r\n * @param {string} [legacySelector]\r\n * @param {HTMLElement | Document} [parent]\r\n * @returns HTMLElement[]\r\n */\r\nexport function getElementsFromOption(option, legacySelector, parent = document) {\r\n /** @type {HTMLElement[]} */\r\n let elements = [];\r\n\r\n if (option instanceof Element) {\r\n elements = [option];\r\n } else if (option instanceof NodeList || Array.isArray(option)) {\r\n elements = Array.from(option);\r\n } else {\r\n const selector = typeof option === 'string' ? option : legacySelector;\r\n if (selector) {\r\n elements = Array.from(parent.querySelectorAll(selector));\r\n }\r\n }\r\n\r\n return elements;\r\n}\r\n\r\n/**\r\n * Check if variable is PhotoSwipe class\r\n *\r\n * @param {any} fn\r\n * @returns {boolean}\r\n */\r\nexport function isPswpClass(fn) {\r\n return typeof fn === 'function'\r\n && fn.prototype\r\n && fn.prototype.goTo;\r\n}\r\n\r\n/**\r\n * Check if browser is Safari\r\n *\r\n * @returns {boolean}\r\n */\r\nexport function isSafari() {\r\n return !!(navigator.vendor && navigator.vendor.match(/apple/i));\r\n}\r\n\r\n", "/** @typedef {import('../lightbox/lightbox.js').default} PhotoSwipeLightbox */\r\n/** @typedef {import('../photoswipe.js').default} PhotoSwipe */\r\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\r\n/** @typedef {import('../photoswipe.js').DataSource} DataSource */\r\n/** @typedef {import('../ui/ui-element.js').UIElementData} UIElementData */\r\n/** @typedef {import('../slide/content.js').default} ContentDefault */\r\n/** @typedef {import('../slide/slide.js').default} Slide */\r\n/** @typedef {import('../slide/slide.js').SlideData} SlideData */\r\n/** @typedef {import('../slide/zoom-level.js').default} ZoomLevel */\r\n/** @typedef {import('../slide/get-thumb-bounds.js').Bounds} Bounds */\r\n\r\n/**\r\n * Allow adding an arbitrary props to the Content\r\n * https://photoswipe.com/custom-content/#using-webp-image-format\r\n * @typedef {ContentDefault & Record} Content\r\n */\r\n/** @typedef {{ x?: number; y?: number }} Point */\r\n\r\n/**\r\n * @typedef {Object} PhotoSwipeEventsMap https://photoswipe.com/events/\r\n *\r\n *\r\n * https://photoswipe.com/adding-ui-elements/\r\n *\r\n * @prop {undefined} uiRegister\r\n * @prop {{ data: UIElementData }} uiElementCreate\r\n *\r\n *\r\n * https://photoswipe.com/events/#initialization-events\r\n *\r\n * @prop {undefined} beforeOpen\r\n * @prop {undefined} firstUpdate\r\n * @prop {undefined} initialLayout\r\n * @prop {undefined} change\r\n * @prop {undefined} afterInit\r\n * @prop {undefined} bindEvents\r\n *\r\n *\r\n * https://photoswipe.com/events/#opening-or-closing-transition-events\r\n *\r\n * @prop {undefined} openingAnimationStart\r\n * @prop {undefined} openingAnimationEnd\r\n * @prop {undefined} closingAnimationStart\r\n * @prop {undefined} closingAnimationEnd\r\n *\r\n *\r\n * https://photoswipe.com/events/#closing-events\r\n *\r\n * @prop {undefined} close\r\n * @prop {undefined} destroy\r\n *\r\n *\r\n * https://photoswipe.com/events/#pointer-and-gesture-events\r\n *\r\n * @prop {{ originalEvent: PointerEvent }} pointerDown\r\n * @prop {{ originalEvent: PointerEvent }} pointerMove\r\n * @prop {{ originalEvent: PointerEvent }} pointerUp\r\n * @prop {{ bgOpacity: number }} pinchClose can be default prevented\r\n * @prop {{ panY: number }} verticalDrag can be default prevented\r\n *\r\n *\r\n * https://photoswipe.com/events/#slide-content-events\r\n *\r\n * @prop {{ content: Content }} contentInit\r\n * @prop {{ content: Content; isLazy: boolean }} contentLoad can be default prevented\r\n * @prop {{ content: Content; isLazy: boolean }} contentLoadImage can be default prevented\r\n * @prop {{ content: Content; slide: Slide; isError?: boolean }} loadComplete\r\n * @prop {{ content: Content; slide: Slide }} loadError\r\n * @prop {{ content: Content; width: number; height: number }} contentResize can be default prevented\r\n * @prop {{ content: Content; width: number; height: number; slide: Slide }} imageSizeChange\r\n * @prop {{ content: Content }} contentLazyLoad can be default prevented\r\n * @prop {{ content: Content }} contentAppend can be default prevented\r\n * @prop {{ content: Content }} contentActivate can be default prevented\r\n * @prop {{ content: Content }} contentDeactivate can be default prevented\r\n * @prop {{ content: Content }} contentRemove can be default prevented\r\n * @prop {{ content: Content }} contentDestroy can be default prevented\r\n *\r\n *\r\n * undocumented\r\n *\r\n * @prop {{ point: Point; originalEvent: PointerEvent }} imageClickAction can be default prevented\r\n * @prop {{ point: Point; originalEvent: PointerEvent }} bgClickAction can be default prevented\r\n * @prop {{ point: Point; originalEvent: PointerEvent }} tapAction can be default prevented\r\n * @prop {{ point: Point; originalEvent: PointerEvent }} doubleTapAction can be default prevented\r\n *\r\n * @prop {{ originalEvent: KeyboardEvent }} keydown can be default prevented\r\n * @prop {{ x: number; dragging: boolean }} moveMainScroll\r\n * @prop {{ slide: Slide }} firstZoomPan\r\n * @prop {{ slide: Slide | undefined, data: SlideData, index: number }} gettingData\r\n * @prop {undefined} beforeResize\r\n * @prop {undefined} resize\r\n * @prop {undefined} viewportSize\r\n * @prop {undefined} updateScrollOffset\r\n * @prop {{ slide: Slide }} slideInit\r\n * @prop {{ slide: Slide }} afterSetContent\r\n * @prop {{ slide: Slide }} slideLoad\r\n * @prop {{ slide: Slide }} appendHeavy can be default prevented\r\n * @prop {{ slide: Slide }} appendHeavyContent\r\n * @prop {{ slide: Slide }} slideActivate\r\n * @prop {{ slide: Slide }} slideDeactivate\r\n * @prop {{ slide: Slide }} slideDestroy\r\n * @prop {{ destZoomLevel: number, centerPoint: Point | undefined, transitionDuration: number | false | undefined }} beforeZoomTo\r\n * @prop {{ slide: Slide }} zoomPanUpdate\r\n * @prop {{ slide: Slide }} initialZoomPan\r\n * @prop {{ slide: Slide }} calcSlideSize\r\n * @prop {undefined} resolutionChanged\r\n * @prop {{ originalEvent: WheelEvent }} wheel can be default prevented\r\n * @prop {{ content: Content }} contentAppendImage can be default prevented\r\n * @prop {{ index: number; itemData: SlideData }} lazyLoadSlide can be default prevented\r\n * @prop {undefined} lazyLoad\r\n * @prop {{ slide: Slide }} calcBounds\r\n * @prop {{ zoomLevels: ZoomLevel, slideData: SlideData }} zoomLevelsUpdate\r\n *\r\n *\r\n * legacy\r\n *\r\n * @prop {undefined} init\r\n * @prop {undefined} initialZoomIn\r\n * @prop {undefined} initialZoomOut\r\n * @prop {undefined} initialZoomInEnd\r\n * @prop {undefined} initialZoomOutEnd\r\n * @prop {{ dataSource: DataSource | undefined, numItems: number }} numItems\r\n * @prop {{ itemData: SlideData; index: number }} itemData\r\n * @prop {{ index: number, itemData: SlideData, instance: PhotoSwipe }} thumbBounds\r\n */\r\n\r\n/**\r\n * @typedef {Object} PhotoSwipeFiltersMap https://photoswipe.com/filters/\r\n *\r\n * @prop {(numItems: number, dataSource: DataSource | undefined) => number} numItems\r\n * Modify the total amount of slides. Example on Data sources page.\r\n * https://photoswipe.com/filters/#numitems\r\n *\r\n * @prop {(itemData: SlideData, index: number) => SlideData} itemData\r\n * Modify slide item data. Example on Data sources page.\r\n * https://photoswipe.com/filters/#itemdata\r\n *\r\n * @prop {(itemData: SlideData, element: HTMLElement, linkEl: HTMLAnchorElement) => SlideData} domItemData\r\n * Modify item data when it's parsed from DOM element. Example on Data sources page.\r\n * https://photoswipe.com/filters/#domitemdata\r\n *\r\n * @prop {(clickedIndex: number, e: MouseEvent, instance: PhotoSwipeLightbox) => number} clickedIndex\r\n * Modify clicked gallery item index.\r\n * https://photoswipe.com/filters/#clickedindex\r\n *\r\n * @prop {(placeholderSrc: string | false, content: Content) => string | false} placeholderSrc\r\n * Modify placeholder image source.\r\n * https://photoswipe.com/filters/#placeholdersrc\r\n *\r\n * @prop {(isContentLoading: boolean, content: Content) => boolean} isContentLoading\r\n * Modify if the content is currently loading.\r\n * https://photoswipe.com/filters/#iscontentloading\r\n *\r\n * @prop {(isContentZoomable: boolean, content: Content) => boolean} isContentZoomable\r\n * Modify if the content can be zoomed.\r\n * https://photoswipe.com/filters/#iscontentzoomable\r\n *\r\n * @prop {(useContentPlaceholder: boolean, content: Content) => boolean} useContentPlaceholder\r\n * Modify if the placeholder should be used for the content.\r\n * https://photoswipe.com/filters/#usecontentplaceholder\r\n *\r\n * @prop {(isKeepingPlaceholder: boolean, content: Content) => boolean} isKeepingPlaceholder\r\n * Modify if the placeholder should be kept after the content is loaded.\r\n * https://photoswipe.com/filters/#iskeepingplaceholder\r\n *\r\n *\r\n * @prop {(contentErrorElement: HTMLElement, content: Content) => HTMLElement} contentErrorElement\r\n * Modify an element when the content has error state (for example, if image cannot be loaded).\r\n * https://photoswipe.com/filters/#contenterrorelement\r\n *\r\n * @prop {(element: HTMLElement, data: UIElementData) => HTMLElement} uiElement\r\n * Modify a UI element that's being created.\r\n * https://photoswipe.com/filters/#uielement\r\n *\r\n * @prop {(thumbnail: HTMLElement | null | undefined, itemData: SlideData, index: number) => HTMLElement} thumbEl\r\n * Modify the thumbnail element from which opening zoom animation starts or ends.\r\n * https://photoswipe.com/filters/#thumbel\r\n *\r\n * @prop {(thumbBounds: Bounds | undefined, itemData: SlideData, index: number) => Bounds} thumbBounds\r\n * Modify the thumbnail bounds from which opening zoom animation starts or ends.\r\n * https://photoswipe.com/filters/#thumbbounds\r\n *\r\n * @prop {(srcsetSizesWidth: number, content: Content) => number} srcsetSizesWidth\r\n *\r\n * @prop {(preventPointerEvent: boolean, event: PointerEvent, pointerType: string) => boolean} preventPointerEvent\r\n *\r\n */\r\n\r\n/**\r\n * @template {keyof PhotoSwipeFiltersMap} T\r\n * @typedef {{ fn: PhotoSwipeFiltersMap[T], priority: number }} Filter\r\n */\r\n\r\n/**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @typedef {PhotoSwipeEventsMap[T] extends undefined ? PhotoSwipeEvent : PhotoSwipeEvent & PhotoSwipeEventsMap[T]} AugmentedEvent\r\n */\r\n\r\n/**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @typedef {(event: AugmentedEvent) => void} EventCallback\r\n */\r\n\r\n/**\r\n * Base PhotoSwipe event object\r\n *\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n */\r\nclass PhotoSwipeEvent {\r\n /**\r\n * @param {T} type\r\n * @param {PhotoSwipeEventsMap[T]} [details]\r\n */\r\n constructor(type, details) {\r\n this.type = type;\r\n this.defaultPrevented = false;\r\n if (details) {\r\n Object.assign(this, details);\r\n }\r\n }\r\n\r\n preventDefault() {\r\n this.defaultPrevented = true;\r\n }\r\n}\r\n\r\n/**\r\n * PhotoSwipe base class that can listen and dispatch for events.\r\n * Shared by PhotoSwipe Core and PhotoSwipe Lightbox, extended by base.js\r\n */\r\nclass Eventable {\r\n constructor() {\r\n /**\r\n * @type {{ [T in keyof PhotoSwipeEventsMap]?: ((event: AugmentedEvent) => void)[] }}\r\n */\r\n this._listeners = {};\r\n\r\n /**\r\n * @type {{ [T in keyof PhotoSwipeFiltersMap]?: Filter[] }}\r\n */\r\n this._filters = {};\r\n\r\n /** @type {PhotoSwipe | undefined} */\r\n this.pswp = undefined;\r\n\r\n /** @type {PhotoSwipeOptions | undefined} */\r\n this.options = undefined;\r\n }\r\n\r\n /**\r\n * @template {keyof PhotoSwipeFiltersMap} T\r\n * @param {T} name\r\n * @param {PhotoSwipeFiltersMap[T]} fn\r\n * @param {number} priority\r\n */\r\n addFilter(name, fn, priority = 100) {\r\n if (!this._filters[name]) {\r\n this._filters[name] = [];\r\n }\r\n\r\n this._filters[name]?.push({ fn, priority });\r\n this._filters[name]?.sort((f1, f2) => f1.priority - f2.priority);\r\n\r\n this.pswp?.addFilter(name, fn, priority);\r\n }\r\n\r\n /**\r\n * @template {keyof PhotoSwipeFiltersMap} T\r\n * @param {T} name\r\n * @param {PhotoSwipeFiltersMap[T]} fn\r\n */\r\n removeFilter(name, fn) {\r\n if (this._filters[name]) {\r\n // @ts-expect-error\r\n this._filters[name] = this._filters[name].filter(filter => (filter.fn !== fn));\r\n }\r\n\r\n if (this.pswp) {\r\n this.pswp.removeFilter(name, fn);\r\n }\r\n }\r\n\r\n /**\r\n * @template {keyof PhotoSwipeFiltersMap} T\r\n * @param {T} name\r\n * @param {Parameters} args\r\n * @returns {Parameters[0]}\r\n */\r\n applyFilters(name, ...args) {\r\n this._filters[name]?.forEach((filter) => {\r\n // @ts-expect-error\r\n args[0] = filter.fn.apply(this, args);\r\n });\r\n return args[0];\r\n }\r\n\r\n /**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @param {T} name\r\n * @param {EventCallback} fn\r\n */\r\n on(name, fn) {\r\n if (!this._listeners[name]) {\r\n this._listeners[name] = [];\r\n }\r\n this._listeners[name]?.push(fn);\r\n\r\n // When binding events to lightbox,\r\n // also bind events to PhotoSwipe Core,\r\n // if it's open.\r\n this.pswp?.on(name, fn);\r\n }\r\n\r\n /**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @param {T} name\r\n * @param {EventCallback} fn\r\n */\r\n off(name, fn) {\r\n if (this._listeners[name]) {\r\n // @ts-expect-error\r\n this._listeners[name] = this._listeners[name].filter(listener => (fn !== listener));\r\n }\r\n\r\n this.pswp?.off(name, fn);\r\n }\r\n\r\n /**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @param {T} name\r\n * @param {PhotoSwipeEventsMap[T]} [details]\r\n * @returns {AugmentedEvent}\r\n */\r\n dispatch(name, details) {\r\n if (this.pswp) {\r\n return this.pswp.dispatch(name, details);\r\n }\r\n\r\n const event = /** @type {AugmentedEvent} */ (new PhotoSwipeEvent(name, details));\r\n\r\n this._listeners[name]?.forEach((listener) => {\r\n listener.call(this, event);\r\n });\r\n\r\n return event;\r\n }\r\n}\r\n\r\nexport default Eventable;\r\n", "import { createElement, setWidthHeight, toTransformString } from '../util/util.js';\r\n\r\nclass Placeholder {\r\n /**\r\n * @param {string | false} imageSrc\r\n * @param {HTMLElement} container\r\n */\r\n constructor(imageSrc, container) {\r\n // Create placeholder\r\n // (stretched thumbnail or simple div behind the main image)\r\n /** @type {HTMLImageElement | HTMLDivElement | null} */\r\n this.element = createElement(\r\n 'pswp__img pswp__img--placeholder',\r\n imageSrc ? 'img' : 'div',\r\n container\r\n );\r\n\r\n if (imageSrc) {\r\n const imgEl = /** @type {HTMLImageElement} */ (this.element);\r\n imgEl.decoding = 'async';\r\n imgEl.alt = '';\r\n imgEl.src = imageSrc;\r\n imgEl.setAttribute('role', 'presentation');\r\n }\r\n\r\n this.element.setAttribute('aria-hidden', 'true');\r\n }\r\n\r\n /**\r\n * @param {number} width\r\n * @param {number} height\r\n */\r\n setDisplayedSize(width, height) {\r\n if (!this.element) {\r\n return;\r\n }\r\n\r\n if (this.element.tagName === 'IMG') {\r\n // Use transform scale() to modify img placeholder size\r\n // (instead of changing width/height directly).\r\n // This helps with performance, specifically in iOS15 Safari.\r\n setWidthHeight(this.element, 250, 'auto');\r\n this.element.style.transformOrigin = '0 0';\r\n this.element.style.transform = toTransformString(0, 0, width / 250);\r\n } else {\r\n setWidthHeight(this.element, width, height);\r\n }\r\n }\r\n\r\n destroy() {\r\n if (this.element?.parentNode) {\r\n this.element.remove();\r\n }\r\n this.element = null;\r\n }\r\n}\r\n\r\nexport default Placeholder;\r\n", "import { createElement, isSafari, LOAD_STATE, setWidthHeight } from '../util/util.js';\r\nimport Placeholder from './placeholder.js';\r\n\r\n/** @typedef {import('./slide.js').default} Slide */\r\n/** @typedef {import('./slide.js').SlideData} SlideData */\r\n/** @typedef {import('../core/base.js').default} PhotoSwipeBase */\r\n/** @typedef {import('../util/util.js').LoadState} LoadState */\r\n\r\nclass Content {\r\n /**\r\n * @param {SlideData} itemData Slide data\r\n * @param {PhotoSwipeBase} instance PhotoSwipe or PhotoSwipeLightbox instance\r\n * @param {number} index\r\n */\r\n constructor(itemData, instance, index) {\r\n this.instance = instance;\r\n this.data = itemData;\r\n this.index = index;\r\n\r\n /** @type {HTMLImageElement | HTMLDivElement | undefined} */\r\n this.element = undefined;\r\n /** @type {Placeholder | undefined} */\r\n this.placeholder = undefined;\r\n /** @type {Slide | undefined} */\r\n this.slide = undefined;\r\n\r\n this.displayedImageWidth = 0;\r\n this.displayedImageHeight = 0;\r\n\r\n this.width = Number(this.data.w) || Number(this.data.width) || 0;\r\n this.height = Number(this.data.h) || Number(this.data.height) || 0;\r\n\r\n this.isAttached = false;\r\n this.hasSlide = false;\r\n this.isDecoding = false;\r\n /** @type {LoadState} */\r\n this.state = LOAD_STATE.IDLE;\r\n\r\n if (this.data.type) {\r\n this.type = this.data.type;\r\n } else if (this.data.src) {\r\n this.type = 'image';\r\n } else {\r\n this.type = 'html';\r\n }\r\n\r\n this.instance.dispatch('contentInit', { content: this });\r\n }\r\n\r\n removePlaceholder() {\r\n if (this.placeholder && !this.keepPlaceholder()) {\r\n // With delay, as image might be loaded, but not rendered\r\n setTimeout(() => {\r\n if (this.placeholder) {\r\n this.placeholder.destroy();\r\n this.placeholder = undefined;\r\n }\r\n }, 1000);\r\n }\r\n }\r\n\r\n /**\r\n * Preload content\r\n *\r\n * @param {boolean} isLazy\r\n * @param {boolean} [reload]\r\n */\r\n load(isLazy, reload) {\r\n if (this.slide && this.usePlaceholder()) {\r\n if (!this.placeholder) {\r\n const placeholderSrc = this.instance.applyFilters(\r\n 'placeholderSrc',\r\n // use image-based placeholder only for the first slide,\r\n // as rendering (even small stretched thumbnail) is an expensive operation\r\n (this.data.msrc && this.slide.isFirstSlide) ? this.data.msrc : false,\r\n this\r\n );\r\n this.placeholder = new Placeholder(\r\n placeholderSrc,\r\n this.slide.container\r\n );\r\n } else {\r\n const placeholderEl = this.placeholder.element;\r\n // Add placeholder to DOM if it was already created\r\n if (placeholderEl && !placeholderEl.parentElement) {\r\n this.slide.container.prepend(placeholderEl);\r\n }\r\n }\r\n }\r\n\r\n if (this.element && !reload) {\r\n return;\r\n }\r\n\r\n if (this.instance.dispatch('contentLoad', { content: this, isLazy }).defaultPrevented) {\r\n return;\r\n }\r\n\r\n if (this.isImageContent()) {\r\n this.element = createElement('pswp__img', 'img');\r\n // Start loading only after width is defined, as sizes might depend on it.\r\n // Due to Safari feature, we must define sizes before srcset.\r\n if (this.displayedImageWidth) {\r\n this.loadImage(isLazy);\r\n }\r\n } else {\r\n this.element = createElement('pswp__content', 'div');\r\n this.element.innerHTML = this.data.html || '';\r\n }\r\n\r\n if (reload && this.slide) {\r\n this.slide.updateContentSize(true);\r\n }\r\n }\r\n\r\n /**\r\n * Preload image\r\n *\r\n * @param {boolean} isLazy\r\n */\r\n loadImage(isLazy) {\r\n if (!this.isImageContent()\r\n || !this.element\r\n || this.instance.dispatch('contentLoadImage', { content: this, isLazy }).defaultPrevented) {\r\n return;\r\n }\r\n\r\n const imageElement = /** @type HTMLImageElement */ (this.element);\r\n\r\n this.updateSrcsetSizes();\r\n\r\n if (this.data.srcset) {\r\n imageElement.srcset = this.data.srcset;\r\n }\r\n\r\n imageElement.src = this.data.src ?? '';\r\n imageElement.alt = this.data.alt ?? '';\r\n\r\n this.state = LOAD_STATE.LOADING;\r\n\r\n if (imageElement.complete) {\r\n this.onLoaded();\r\n } else {\r\n imageElement.onload = () => {\r\n this.onLoaded();\r\n };\r\n\r\n imageElement.onerror = () => {\r\n this.onError();\r\n };\r\n }\r\n }\r\n\r\n /**\r\n * Assign slide to content\r\n *\r\n * @param {Slide} slide\r\n */\r\n setSlide(slide) {\r\n this.slide = slide;\r\n this.hasSlide = true;\r\n this.instance = slide.pswp;\r\n\r\n // todo: do we need to unset slide?\r\n }\r\n\r\n /**\r\n * Content load success handler\r\n */\r\n onLoaded() {\r\n this.state = LOAD_STATE.LOADED;\r\n\r\n if (this.slide && this.element) {\r\n this.instance.dispatch('loadComplete', { slide: this.slide, content: this });\r\n\r\n // if content is reloaded\r\n if (this.slide.isActive\r\n && this.slide.heavyAppended\r\n && !this.element.parentNode) {\r\n this.append();\r\n this.slide.updateContentSize(true);\r\n }\r\n\r\n if (this.state === LOAD_STATE.LOADED || this.state === LOAD_STATE.ERROR) {\r\n this.removePlaceholder();\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Content load error handler\r\n */\r\n onError() {\r\n this.state = LOAD_STATE.ERROR;\r\n\r\n if (this.slide) {\r\n this.displayError();\r\n this.instance.dispatch('loadComplete', { slide: this.slide, isError: true, content: this });\r\n this.instance.dispatch('loadError', { slide: this.slide, content: this });\r\n }\r\n }\r\n\r\n /**\r\n * @returns {Boolean} If the content is currently loading\r\n */\r\n isLoading() {\r\n return this.instance.applyFilters(\r\n 'isContentLoading',\r\n this.state === LOAD_STATE.LOADING,\r\n this\r\n );\r\n }\r\n\r\n /**\r\n * @returns {Boolean} If the content is in error state\r\n */\r\n isError() {\r\n return this.state === LOAD_STATE.ERROR;\r\n }\r\n\r\n /**\r\n * @returns {boolean} If the content is image\r\n */\r\n isImageContent() {\r\n return this.type === 'image';\r\n }\r\n\r\n /**\r\n * Update content size\r\n *\r\n * @param {Number} width\r\n * @param {Number} height\r\n */\r\n setDisplayedSize(width, height) {\r\n if (!this.element) {\r\n return;\r\n }\r\n\r\n if (this.placeholder) {\r\n this.placeholder.setDisplayedSize(width, height);\r\n }\r\n\r\n if (this.instance.dispatch(\r\n 'contentResize',\r\n { content: this, width, height }).defaultPrevented\r\n ) {\r\n return;\r\n }\r\n\r\n setWidthHeight(this.element, width, height);\r\n\r\n if (this.isImageContent() && !this.isError()) {\r\n const isInitialSizeUpdate = (!this.displayedImageWidth && width);\r\n\r\n this.displayedImageWidth = width;\r\n this.displayedImageHeight = height;\r\n\r\n if (isInitialSizeUpdate) {\r\n this.loadImage(false);\r\n } else {\r\n this.updateSrcsetSizes();\r\n }\r\n\r\n if (this.slide) {\r\n this.instance.dispatch(\r\n 'imageSizeChange',\r\n { slide: this.slide, width, height, content: this }\r\n );\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * @returns {boolean} If the content can be zoomed\r\n */\r\n isZoomable() {\r\n return this.instance.applyFilters(\r\n 'isContentZoomable',\r\n this.isImageContent() && (this.state !== LOAD_STATE.ERROR),\r\n this\r\n );\r\n }\r\n\r\n /**\r\n * Update image srcset sizes attribute based on width and height\r\n */\r\n updateSrcsetSizes() {\r\n // Handle srcset sizes attribute.\r\n //\r\n // Never lower quality, if it was increased previously.\r\n // Chrome does this automatically, Firefox and Safari do not,\r\n // so we store largest used size in dataset.\r\n if (!this.isImageContent() || !this.element || !this.data.srcset) {\r\n return;\r\n }\r\n\r\n const image = /** @type HTMLImageElement */ (this.element);\r\n const sizesWidth = this.instance.applyFilters(\r\n 'srcsetSizesWidth',\r\n this.displayedImageWidth,\r\n this\r\n );\r\n\r\n if (\r\n !image.dataset.largestUsedSize\r\n || sizesWidth > parseInt(image.dataset.largestUsedSize, 10)\r\n ) {\r\n image.sizes = sizesWidth + 'px';\r\n image.dataset.largestUsedSize = String(sizesWidth);\r\n }\r\n }\r\n\r\n /**\r\n * @returns {boolean} If content should use a placeholder (from msrc by default)\r\n */\r\n usePlaceholder() {\r\n return this.instance.applyFilters(\r\n 'useContentPlaceholder',\r\n this.isImageContent(),\r\n this\r\n );\r\n }\r\n\r\n /**\r\n * Preload content with lazy-loading param\r\n */\r\n lazyLoad() {\r\n if (this.instance.dispatch('contentLazyLoad', { content: this }).defaultPrevented) {\r\n return;\r\n }\r\n\r\n this.load(true);\r\n }\r\n\r\n /**\r\n * @returns {boolean} If placeholder should be kept after content is loaded\r\n */\r\n keepPlaceholder() {\r\n return this.instance.applyFilters(\r\n 'isKeepingPlaceholder',\r\n this.isLoading(),\r\n this\r\n );\r\n }\r\n\r\n /**\r\n * Destroy the content\r\n */\r\n destroy() {\r\n this.hasSlide = false;\r\n this.slide = undefined;\r\n\r\n if (this.instance.dispatch('contentDestroy', { content: this }).defaultPrevented) {\r\n return;\r\n }\r\n\r\n this.remove();\r\n\r\n if (this.placeholder) {\r\n this.placeholder.destroy();\r\n this.placeholder = undefined;\r\n }\r\n\r\n if (this.isImageContent() && this.element) {\r\n this.element.onload = null;\r\n this.element.onerror = null;\r\n this.element = undefined;\r\n }\r\n }\r\n\r\n /**\r\n * Display error message\r\n */\r\n displayError() {\r\n if (this.slide) {\r\n let errorMsgEl = createElement('pswp__error-msg', 'div');\r\n errorMsgEl.innerText = this.instance.options?.errorMsg ?? '';\r\n errorMsgEl = /** @type {HTMLDivElement} */ (this.instance.applyFilters(\r\n 'contentErrorElement',\r\n errorMsgEl,\r\n this\r\n ));\r\n this.element = createElement('pswp__content pswp__error-msg-container', 'div');\r\n this.element.appendChild(errorMsgEl);\r\n this.slide.container.innerText = '';\r\n this.slide.container.appendChild(this.element);\r\n this.slide.updateContentSize(true);\r\n this.removePlaceholder();\r\n }\r\n }\r\n\r\n /**\r\n * Append the content\r\n */\r\n append() {\r\n if (this.isAttached || !this.element) {\r\n return;\r\n }\r\n\r\n this.isAttached = true;\r\n\r\n if (this.state === LOAD_STATE.ERROR) {\r\n this.displayError();\r\n return;\r\n }\r\n\r\n if (this.instance.dispatch('contentAppend', { content: this }).defaultPrevented) {\r\n return;\r\n }\r\n\r\n const supportsDecode = ('decode' in this.element);\r\n\r\n if (this.isImageContent()) {\r\n // Use decode() on nearby slides\r\n //\r\n // Nearby slide images are in DOM and not hidden via display:none.\r\n // However, they are placed offscreen (to the left and right side).\r\n //\r\n // Some browsers do not composite the image until it's actually visible,\r\n // using decode() helps.\r\n //\r\n // You might ask \"why dont you just decode() and then append all images\",\r\n // that's because I want to show image before it's fully loaded,\r\n // as browser can render parts of image while it is loading.\r\n // We do not do this in Safari due to partial loading bug.\r\n if (supportsDecode && this.slide && (!this.slide.isActive || isSafari())) {\r\n this.isDecoding = true;\r\n // purposefully using finally instead of then,\r\n // as if srcset sizes changes dynamically - it may cause decode error\r\n /** @type {HTMLImageElement} */\r\n (this.element).decode().catch(() => {}).finally(() => {\r\n this.isDecoding = false;\r\n this.appendImage();\r\n });\r\n } else {\r\n this.appendImage();\r\n }\r\n } else if (this.slide && !this.element.parentNode) {\r\n this.slide.container.appendChild(this.element);\r\n }\r\n }\r\n\r\n /**\r\n * Activate the slide,\r\n * active slide is generally the current one,\r\n * meaning the user can see it.\r\n */\r\n activate() {\r\n if (this.instance.dispatch('contentActivate', { content: this }).defaultPrevented\r\n || !this.slide) {\r\n return;\r\n }\r\n\r\n if (this.isImageContent() && this.isDecoding && !isSafari()) {\r\n // add image to slide when it becomes active,\r\n // even if it's not finished decoding\r\n this.appendImage();\r\n } else if (this.isError()) {\r\n this.load(false, true); // try to reload\r\n }\r\n\r\n if (this.slide.holderElement) {\r\n this.slide.holderElement.setAttribute('aria-hidden', 'false');\r\n }\r\n }\r\n\r\n /**\r\n * Deactivate the content\r\n */\r\n deactivate() {\r\n this.instance.dispatch('contentDeactivate', { content: this });\r\n if (this.slide && this.slide.holderElement) {\r\n this.slide.holderElement.setAttribute('aria-hidden', 'true');\r\n }\r\n }\r\n\r\n\r\n /**\r\n * Remove the content from DOM\r\n */\r\n remove() {\r\n this.isAttached = false;\r\n\r\n if (this.instance.dispatch('contentRemove', { content: this }).defaultPrevented) {\r\n return;\r\n }\r\n\r\n if (this.element && this.element.parentNode) {\r\n this.element.remove();\r\n }\r\n\r\n if (this.placeholder && this.placeholder.element) {\r\n this.placeholder.element.remove();\r\n }\r\n }\r\n\r\n /**\r\n * Append the image content to slide container\r\n */\r\n appendImage() {\r\n if (!this.isAttached) {\r\n return;\r\n }\r\n\r\n if (this.instance.dispatch('contentAppendImage', { content: this }).defaultPrevented) {\r\n return;\r\n }\r\n\r\n // ensure that element exists and is not already appended\r\n if (this.slide && this.element && !this.element.parentNode) {\r\n this.slide.container.appendChild(this.element);\r\n }\r\n\r\n if (this.state === LOAD_STATE.LOADED || this.state === LOAD_STATE.ERROR) {\r\n this.removePlaceholder();\r\n }\r\n }\r\n}\r\n\r\nexport default Content;\r\n", "/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\r\n/** @typedef {import('../core/base.js').default} PhotoSwipeBase */\r\n/** @typedef {import('../photoswipe.js').Point} Point */\r\n/** @typedef {import('../slide/slide.js').SlideData} SlideData */\r\n\r\n/**\r\n * @param {PhotoSwipeOptions} options\r\n * @param {PhotoSwipeBase} pswp\r\n * @returns {Point}\r\n */\r\nexport function getViewportSize(options, pswp) {\r\n if (options.getViewportSizeFn) {\r\n const newViewportSize = options.getViewportSizeFn(options, pswp);\r\n if (newViewportSize) {\r\n return newViewportSize;\r\n }\r\n }\r\n\r\n return {\r\n x: document.documentElement.clientWidth,\r\n\r\n // TODO: height on mobile is very incosistent due to toolbar\r\n // find a way to improve this\r\n //\r\n // document.documentElement.clientHeight - doesn't seem to work well\r\n y: window.innerHeight\r\n };\r\n}\r\n\r\n/**\r\n * Parses padding option.\r\n * Supported formats:\r\n *\r\n * // Object\r\n * padding: {\r\n * top: 0,\r\n * bottom: 0,\r\n * left: 0,\r\n * right: 0\r\n * }\r\n *\r\n * // A function that returns the object\r\n * paddingFn: (viewportSize, itemData, index) => {\r\n * return {\r\n * top: 0,\r\n * bottom: 0,\r\n * left: 0,\r\n * right: 0\r\n * };\r\n * }\r\n *\r\n * // Legacy variant\r\n * paddingLeft: 0,\r\n * paddingRight: 0,\r\n * paddingTop: 0,\r\n * paddingBottom: 0,\r\n *\r\n * @param {'left' | 'top' | 'bottom' | 'right'} prop\r\n * @param {PhotoSwipeOptions} options PhotoSwipe options\r\n * @param {Point} viewportSize PhotoSwipe viewport size, for example: { x:800, y:600 }\r\n * @param {SlideData} itemData Data about the slide\r\n * @param {number} index Slide index\r\n * @returns {number}\r\n */\r\nexport function parsePaddingOption(prop, options, viewportSize, itemData, index) {\r\n let paddingValue = 0;\r\n\r\n if (options.paddingFn) {\r\n paddingValue = options.paddingFn(viewportSize, itemData, index)[prop];\r\n } else if (options.padding) {\r\n paddingValue = options.padding[prop];\r\n } else {\r\n const legacyPropName = 'padding' + prop[0].toUpperCase() + prop.slice(1);\r\n // @ts-expect-error\r\n if (options[legacyPropName]) {\r\n // @ts-expect-error\r\n paddingValue = options[legacyPropName];\r\n }\r\n }\r\n\r\n return Number(paddingValue) || 0;\r\n}\r\n\r\n/**\r\n * @param {PhotoSwipeOptions} options\r\n * @param {Point} viewportSize\r\n * @param {SlideData} itemData\r\n * @param {number} index\r\n * @returns {Point}\r\n */\r\nexport function getPanAreaSize(options, viewportSize, itemData, index) {\r\n return {\r\n x: viewportSize.x\r\n - parsePaddingOption('left', options, viewportSize, itemData, index)\r\n - parsePaddingOption('right', options, viewportSize, itemData, index),\r\n y: viewportSize.y\r\n - parsePaddingOption('top', options, viewportSize, itemData, index)\r\n - parsePaddingOption('bottom', options, viewportSize, itemData, index)\r\n };\r\n}\r\n", "const MAX_IMAGE_WIDTH = 4000;\r\n\r\n/** @typedef {import('../photoswipe.js').default} PhotoSwipe */\r\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\r\n/** @typedef {import('../photoswipe.js').Point} Point */\r\n/** @typedef {import('../slide/slide.js').SlideData} SlideData */\r\n\r\n/** @typedef {'fit' | 'fill' | number | ((zoomLevelObject: ZoomLevel) => number)} ZoomLevelOption */\r\n\r\n/**\r\n * Calculates zoom levels for specific slide.\r\n * Depends on viewport size and image size.\r\n */\r\nclass ZoomLevel {\r\n /**\r\n * @param {PhotoSwipeOptions} options PhotoSwipe options\r\n * @param {SlideData} itemData Slide data\r\n * @param {number} index Slide index\r\n * @param {PhotoSwipe} [pswp] PhotoSwipe instance, can be undefined if not initialized yet\r\n */\r\n constructor(options, itemData, index, pswp) {\r\n this.pswp = pswp;\r\n this.options = options;\r\n this.itemData = itemData;\r\n this.index = index;\r\n /** @type { Point | null } */\r\n this.panAreaSize = null;\r\n /** @type { Point | null } */\r\n this.elementSize = null;\r\n this.fit = 1;\r\n this.fill = 1;\r\n this.vFill = 1;\r\n this.initial = 1;\r\n this.secondary = 1;\r\n this.max = 1;\r\n this.min = 1;\r\n }\r\n\r\n /**\r\n * Calculate initial, secondary and maximum zoom level for the specified slide.\r\n *\r\n * It should be called when either image or viewport size changes.\r\n *\r\n * @param {number} maxWidth\r\n * @param {number} maxHeight\r\n * @param {Point} panAreaSize\r\n */\r\n update(maxWidth, maxHeight, panAreaSize) {\r\n /** @type {Point} */\r\n const elementSize = { x: maxWidth, y: maxHeight };\r\n this.elementSize = elementSize;\r\n this.panAreaSize = panAreaSize;\r\n\r\n const hRatio = panAreaSize.x / elementSize.x;\r\n const vRatio = panAreaSize.y / elementSize.y;\r\n\r\n this.fit = Math.min(1, hRatio < vRatio ? hRatio : vRatio);\r\n this.fill = Math.min(1, hRatio > vRatio ? hRatio : vRatio);\r\n\r\n // zoom.vFill defines zoom level of the image\r\n // when it has 100% of viewport vertical space (height)\r\n this.vFill = Math.min(1, vRatio);\r\n\r\n this.initial = this._getInitial();\r\n this.secondary = this._getSecondary();\r\n this.max = Math.max(\r\n this.initial,\r\n this.secondary,\r\n this._getMax()\r\n );\r\n\r\n this.min = Math.min(\r\n this.fit,\r\n this.initial,\r\n this.secondary\r\n );\r\n\r\n if (this.pswp) {\r\n this.pswp.dispatch('zoomLevelsUpdate', { zoomLevels: this, slideData: this.itemData });\r\n }\r\n }\r\n\r\n /**\r\n * Parses user-defined zoom option.\r\n *\r\n * @private\r\n * @param {'initial' | 'secondary' | 'max'} optionPrefix Zoom level option prefix (initial, secondary, max)\r\n * @returns { number | undefined }\r\n */\r\n _parseZoomLevelOption(optionPrefix) {\r\n const optionName = /** @type {'initialZoomLevel' | 'secondaryZoomLevel' | 'maxZoomLevel'} */ (\r\n optionPrefix + 'ZoomLevel'\r\n );\r\n const optionValue = this.options[optionName];\r\n\r\n if (!optionValue) {\r\n return;\r\n }\r\n\r\n if (typeof optionValue === 'function') {\r\n return optionValue(this);\r\n }\r\n\r\n if (optionValue === 'fill') {\r\n return this.fill;\r\n }\r\n\r\n if (optionValue === 'fit') {\r\n return this.fit;\r\n }\r\n\r\n return Number(optionValue);\r\n }\r\n\r\n /**\r\n * Get zoom level to which image will be zoomed after double-tap gesture,\r\n * or when user clicks on zoom icon,\r\n * or mouse-click on image itself.\r\n * If you return 1 image will be zoomed to its original size.\r\n *\r\n * @private\r\n * @return {number}\r\n */\r\n _getSecondary() {\r\n let currZoomLevel = this._parseZoomLevelOption('secondary');\r\n\r\n if (currZoomLevel) {\r\n return currZoomLevel;\r\n }\r\n\r\n // 3x of \"fit\" state, but not larger than original\r\n currZoomLevel = Math.min(1, this.fit * 3);\r\n\r\n if (this.elementSize && currZoomLevel * this.elementSize.x > MAX_IMAGE_WIDTH) {\r\n currZoomLevel = MAX_IMAGE_WIDTH / this.elementSize.x;\r\n }\r\n\r\n return currZoomLevel;\r\n }\r\n\r\n /**\r\n * Get initial image zoom level.\r\n *\r\n * @private\r\n * @return {number}\r\n */\r\n _getInitial() {\r\n return this._parseZoomLevelOption('initial') || this.fit;\r\n }\r\n\r\n /**\r\n * Maximum zoom level when user zooms\r\n * via zoom/pinch gesture,\r\n * via cmd/ctrl-wheel or via trackpad.\r\n *\r\n * @private\r\n * @return {number}\r\n */\r\n _getMax() {\r\n // max zoom level is x4 from \"fit state\",\r\n // used for zoom gesture and ctrl/trackpad zoom\r\n return this._parseZoomLevelOption('max') || Math.max(1, this.fit * 4);\r\n }\r\n}\r\n\r\nexport default ZoomLevel;\r\n", "import { getViewportSize, getPanAreaSize } from '../util/viewport-size.js';\r\nimport ZoomLevel from './zoom-level.js';\r\n\r\n/** @typedef {import('./content.js').default} Content */\r\n/** @typedef {import('./slide.js').default} Slide */\r\n/** @typedef {import('./slide.js').SlideData} SlideData */\r\n/** @typedef {import('../core/base.js').default} PhotoSwipeBase */\r\n/** @typedef {import('../photoswipe.js').default} PhotoSwipe */\r\n\r\nconst MIN_SLIDES_TO_CACHE = 5;\r\n\r\n/**\r\n * Lazy-load an image\r\n * This function is used both by Lightbox and PhotoSwipe core,\r\n * thus it can be called before dialog is opened.\r\n *\r\n * @param {SlideData} itemData Data about the slide\r\n * @param {PhotoSwipeBase} instance PhotoSwipe or PhotoSwipeLightbox instance\r\n * @param {number} index\r\n * @returns {Content} Image that is being decoded or false.\r\n */\r\nexport function lazyLoadData(itemData, instance, index) {\r\n const content = instance.createContentFromData(itemData, index);\r\n /** @type {ZoomLevel | undefined} */\r\n let zoomLevel;\r\n\r\n const { options } = instance;\r\n\r\n // We need to know dimensions of the image to preload it,\r\n // as it might use srcset, and we need to define sizes\r\n if (options) {\r\n zoomLevel = new ZoomLevel(options, itemData, -1);\r\n\r\n let viewportSize;\r\n if (instance.pswp) {\r\n viewportSize = instance.pswp.viewportSize;\r\n } else {\r\n viewportSize = getViewportSize(options, instance);\r\n }\r\n\r\n const panAreaSize = getPanAreaSize(options, viewportSize, itemData, index);\r\n zoomLevel.update(content.width, content.height, panAreaSize);\r\n }\r\n\r\n content.lazyLoad();\r\n\r\n if (zoomLevel) {\r\n content.setDisplayedSize(\r\n Math.ceil(content.width * zoomLevel.initial),\r\n Math.ceil(content.height * zoomLevel.initial)\r\n );\r\n }\r\n\r\n return content;\r\n}\r\n\r\n\r\n/**\r\n * Lazy-loads specific slide.\r\n * This function is used both by Lightbox and PhotoSwipe core,\r\n * thus it can be called before dialog is opened.\r\n *\r\n * By default, it loads image based on viewport size and initial zoom level.\r\n *\r\n * @param {number} index Slide index\r\n * @param {PhotoSwipeBase} instance PhotoSwipe or PhotoSwipeLightbox eventable instance\r\n * @returns {Content | undefined}\r\n */\r\nexport function lazyLoadSlide(index, instance) {\r\n const itemData = instance.getItemData(index);\r\n\r\n if (instance.dispatch('lazyLoadSlide', { index, itemData }).defaultPrevented) {\r\n return;\r\n }\r\n\r\n return lazyLoadData(itemData, instance, index);\r\n}\r\n\r\nclass ContentLoader {\r\n /**\r\n * @param {PhotoSwipe} pswp\r\n */\r\n constructor(pswp) {\r\n this.pswp = pswp;\r\n // Total amount of cached images\r\n this.limit = Math.max(\r\n pswp.options.preload[0] + pswp.options.preload[1] + 1,\r\n MIN_SLIDES_TO_CACHE\r\n );\r\n /** @type {Content[]} */\r\n this._cachedItems = [];\r\n }\r\n\r\n /**\r\n * Lazy load nearby slides based on `preload` option.\r\n *\r\n * @param {number} [diff] Difference between slide indexes that was changed recently, or 0.\r\n */\r\n updateLazy(diff) {\r\n const { pswp } = this;\r\n\r\n if (pswp.dispatch('lazyLoad').defaultPrevented) {\r\n return;\r\n }\r\n\r\n const { preload } = pswp.options;\r\n const isForward = diff === undefined ? true : (diff >= 0);\r\n let i;\r\n\r\n // preload[1] - num items to preload in forward direction\r\n for (i = 0; i <= preload[1]; i++) {\r\n this.loadSlideByIndex(pswp.currIndex + (isForward ? i : (-i)));\r\n }\r\n\r\n // preload[0] - num items to preload in backward direction\r\n for (i = 1; i <= preload[0]; i++) {\r\n this.loadSlideByIndex(pswp.currIndex + (isForward ? (-i) : i));\r\n }\r\n }\r\n\r\n /**\r\n * @param {number} initialIndex\r\n */\r\n loadSlideByIndex(initialIndex) {\r\n const index = this.pswp.getLoopedIndex(initialIndex);\r\n // try to get cached content\r\n let content = this.getContentByIndex(index);\r\n if (!content) {\r\n // no cached content, so try to load from scratch:\r\n content = lazyLoadSlide(index, this.pswp);\r\n // if content can be loaded, add it to cache:\r\n if (content) {\r\n this.addToCache(content);\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * @param {Slide} slide\r\n * @returns {Content}\r\n */\r\n getContentBySlide(slide) {\r\n let content = this.getContentByIndex(slide.index);\r\n if (!content) {\r\n // create content if not found in cache\r\n content = this.pswp.createContentFromData(slide.data, slide.index);\r\n this.addToCache(content);\r\n }\r\n\r\n // assign slide to content\r\n content.setSlide(slide);\r\n\r\n return content;\r\n }\r\n\r\n /**\r\n * @param {Content} content\r\n */\r\n addToCache(content) {\r\n // move to the end of array\r\n this.removeByIndex(content.index);\r\n this._cachedItems.push(content);\r\n\r\n if (this._cachedItems.length > this.limit) {\r\n // Destroy the first content that's not attached\r\n const indexToRemove = this._cachedItems.findIndex((item) => {\r\n return !item.isAttached && !item.hasSlide;\r\n });\r\n if (indexToRemove !== -1) {\r\n const removedItem = this._cachedItems.splice(indexToRemove, 1)[0];\r\n removedItem.destroy();\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Removes an image from cache, does not destroy() it, just removes.\r\n *\r\n * @param {number} index\r\n */\r\n removeByIndex(index) {\r\n const indexToRemove = this._cachedItems.findIndex(item => item.index === index);\r\n if (indexToRemove !== -1) {\r\n this._cachedItems.splice(indexToRemove, 1);\r\n }\r\n }\r\n\r\n /**\r\n * @param {number} index\r\n * @returns {Content | undefined}\r\n */\r\n getContentByIndex(index) {\r\n return this._cachedItems.find(content => content.index === index);\r\n }\r\n\r\n destroy() {\r\n this._cachedItems.forEach(content => content.destroy());\r\n this._cachedItems = [];\r\n }\r\n}\r\n\r\nexport default ContentLoader;\r\n", "import Eventable from './eventable.js';\r\nimport { getElementsFromOption } from '../util/util.js';\r\nimport Content from '../slide/content.js';\r\nimport { lazyLoadData } from '../slide/loader.js';\r\n\r\n/** @typedef {import(\"../photoswipe.js\").default} PhotoSwipe */\r\n/** @typedef {import(\"../slide/slide.js\").SlideData} SlideData */\r\n\r\n/**\r\n * PhotoSwipe base class that can retrieve data about every slide.\r\n * Shared by PhotoSwipe Core and PhotoSwipe Lightbox\r\n */\r\nclass PhotoSwipeBase extends Eventable {\r\n /**\r\n * Get total number of slides\r\n *\r\n * @returns {number}\r\n */\r\n getNumItems() {\r\n let numItems = 0;\r\n const dataSource = this.options?.dataSource;\r\n\r\n if (dataSource && 'length' in dataSource) {\r\n // may be an array or just object with length property\r\n numItems = dataSource.length;\r\n } else if (dataSource && 'gallery' in dataSource) {\r\n // query DOM elements\r\n if (!dataSource.items) {\r\n dataSource.items = this._getGalleryDOMElements(dataSource.gallery);\r\n }\r\n\r\n if (dataSource.items) {\r\n numItems = dataSource.items.length;\r\n }\r\n }\r\n\r\n // legacy event, before filters were introduced\r\n const event = this.dispatch('numItems', {\r\n dataSource,\r\n numItems\r\n });\r\n return this.applyFilters('numItems', event.numItems, dataSource);\r\n }\r\n\r\n /**\r\n * @param {SlideData} slideData\r\n * @param {number} index\r\n * @returns {Content}\r\n */\r\n createContentFromData(slideData, index) {\r\n return new Content(slideData, this, index);\r\n }\r\n\r\n /**\r\n * Get item data by index.\r\n *\r\n * \"item data\" should contain normalized information that PhotoSwipe needs to generate a slide.\r\n * For example, it may contain properties like\r\n * `src`, `srcset`, `w`, `h`, which will be used to generate a slide with image.\r\n *\r\n * @param {number} index\r\n * @returns {SlideData}\r\n */\r\n getItemData(index) {\r\n const dataSource = this.options?.dataSource;\r\n /** @type {SlideData | HTMLElement} */\r\n let dataSourceItem = {};\r\n if (Array.isArray(dataSource)) {\r\n // Datasource is an array of elements\r\n dataSourceItem = dataSource[index];\r\n } else if (dataSource && 'gallery' in dataSource) {\r\n // dataSource has gallery property,\r\n // thus it was created by Lightbox, based on\r\n // gallery and children options\r\n\r\n // query DOM elements\r\n if (!dataSource.items) {\r\n dataSource.items = this._getGalleryDOMElements(dataSource.gallery);\r\n }\r\n\r\n dataSourceItem = dataSource.items[index];\r\n }\r\n\r\n let itemData = dataSourceItem;\r\n\r\n if (itemData instanceof Element) {\r\n itemData = this._domElementToItemData(itemData);\r\n }\r\n\r\n // Dispatching the itemData event,\r\n // it's a legacy verion before filters were introduced\r\n const event = this.dispatch('itemData', {\r\n itemData: itemData || {},\r\n index\r\n });\r\n\r\n return this.applyFilters('itemData', event.itemData, index);\r\n }\r\n\r\n /**\r\n * Get array of gallery DOM elements,\r\n * based on childSelector and gallery element.\r\n *\r\n * @param {HTMLElement} galleryElement\r\n * @returns {HTMLElement[]}\r\n */\r\n _getGalleryDOMElements(galleryElement) {\r\n if (this.options?.children || this.options?.childSelector) {\r\n return getElementsFromOption(\r\n this.options.children,\r\n this.options.childSelector,\r\n galleryElement\r\n ) || [];\r\n }\r\n\r\n return [galleryElement];\r\n }\r\n\r\n /**\r\n * Converts DOM element to item data object.\r\n *\r\n * @param {HTMLElement} element DOM element\r\n * @returns {SlideData}\r\n */\r\n _domElementToItemData(element) {\r\n /** @type {SlideData} */\r\n const itemData = {\r\n element\r\n };\r\n\r\n const linkEl = /** @type {HTMLAnchorElement} */ (\r\n element.tagName === 'A'\r\n ? element\r\n : element.querySelector('a')\r\n );\r\n\r\n if (linkEl) {\r\n // src comes from data-pswp-src attribute,\r\n // if it's empty link href is used\r\n itemData.src = linkEl.dataset.pswpSrc || linkEl.href;\r\n\r\n if (linkEl.dataset.pswpSrcset) {\r\n itemData.srcset = linkEl.dataset.pswpSrcset;\r\n }\r\n\r\n itemData.width = linkEl.dataset.pswpWidth ? parseInt(linkEl.dataset.pswpWidth, 10) : 0;\r\n itemData.height = linkEl.dataset.pswpHeight ? parseInt(linkEl.dataset.pswpHeight, 10) : 0;\r\n\r\n // support legacy w & h properties\r\n itemData.w = itemData.width;\r\n itemData.h = itemData.height;\r\n\r\n if (linkEl.dataset.pswpType) {\r\n itemData.type = linkEl.dataset.pswpType;\r\n }\r\n\r\n const thumbnailEl = element.querySelector('img');\r\n\r\n if (thumbnailEl) {\r\n // msrc is URL to placeholder image that's displayed before large image is loaded\r\n // by default it's displayed only for the first slide\r\n itemData.msrc = thumbnailEl.currentSrc || thumbnailEl.src;\r\n itemData.alt = thumbnailEl.getAttribute('alt') ?? '';\r\n }\r\n\r\n if (linkEl.dataset.pswpCropped || linkEl.dataset.cropped) {\r\n itemData.thumbCropped = true;\r\n }\r\n }\r\n\r\n return this.applyFilters('domItemData', itemData, element, linkEl);\r\n }\r\n\r\n /**\r\n * Lazy-load by slide data\r\n *\r\n * @param {SlideData} itemData Data about the slide\r\n * @param {number} index\r\n * @returns {Content} Image that is being decoded or false.\r\n */\r\n lazyLoadData(itemData, index) {\r\n return lazyLoadData(itemData, this, index);\r\n }\r\n}\r\n\r\nexport default PhotoSwipeBase;\r\n", "import {\r\n specialKeyUsed,\r\n getElementsFromOption,\r\n isPswpClass\r\n} from '../util/util.js';\r\n\r\nimport PhotoSwipeBase from '../core/base.js';\r\nimport { lazyLoadSlide } from '../slide/loader.js';\r\n\r\n/**\r\n * @template T\r\n * @typedef {import('../types.js').Type} Type\r\n */\r\n\r\n/** @typedef {import('../photoswipe.js').default} PhotoSwipe */\r\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\r\n/** @typedef {import('../photoswipe.js').DataSource} DataSource */\r\n/** @typedef {import('../photoswipe.js').Point} Point */\r\n/** @typedef {import('../slide/content.js').default} Content */\r\n/** @typedef {import('../core/eventable.js').PhotoSwipeEventsMap} PhotoSwipeEventsMap */\r\n/** @typedef {import('../core/eventable.js').PhotoSwipeFiltersMap} PhotoSwipeFiltersMap */\r\n\r\n/**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @typedef {import('../core/eventable.js').EventCallback} EventCallback\r\n */\r\n\r\n/**\r\n * PhotoSwipe Lightbox\r\n *\r\n * - If user has unsupported browser it falls back to default browser action (just opens URL)\r\n * - Binds click event to links that should open PhotoSwipe\r\n * - parses DOM strcture for PhotoSwipe (retrieves large image URLs and sizes)\r\n * - Initializes PhotoSwipe\r\n *\r\n *\r\n * Loader options use the same object as PhotoSwipe, and supports such options:\r\n *\r\n * gallery - Element | Element[] | NodeList | string selector for the gallery element\r\n * children - Element | Element[] | NodeList | string selector for the gallery children\r\n *\r\n */\r\nclass PhotoSwipeLightbox extends PhotoSwipeBase {\r\n /**\r\n * @param {PhotoSwipeOptions} [options]\r\n */\r\n constructor(options) {\r\n super();\r\n /** @type {PhotoSwipeOptions} */\r\n this.options = options || {};\r\n this._uid = 0;\r\n this.shouldOpen = false;\r\n /**\r\n * @private\r\n * @type {Content | undefined}\r\n */\r\n this._preloadedContent = undefined;\r\n\r\n this.onThumbnailsClick = this.onThumbnailsClick.bind(this);\r\n }\r\n\r\n /**\r\n * Initialize lightbox, should be called only once.\r\n * It's not included in the main constructor, so you may bind events before it.\r\n */\r\n init() {\r\n // Bind click events to each gallery\r\n getElementsFromOption(this.options.gallery, this.options.gallerySelector)\r\n .forEach((galleryElement) => {\r\n galleryElement.addEventListener('click', this.onThumbnailsClick, false);\r\n });\r\n }\r\n\r\n /**\r\n * @param {MouseEvent} e\r\n */\r\n onThumbnailsClick(e) {\r\n // Exit and allow default browser action if:\r\n if (specialKeyUsed(e) // ... if clicked with a special key (ctrl/cmd...)\r\n || window.pswp) { // ... if PhotoSwipe is already open\r\n return;\r\n }\r\n\r\n // If both clientX and clientY are 0 or not defined,\r\n // the event is likely triggered by keyboard,\r\n // so we do not pass the initialPoint\r\n //\r\n // Note that some screen readers emulate the mouse position,\r\n // so it's not the ideal way to detect them.\r\n //\r\n /** @type {Point | null} */\r\n let initialPoint = { x: e.clientX, y: e.clientY };\r\n\r\n if (!initialPoint.x && !initialPoint.y) {\r\n initialPoint = null;\r\n }\r\n\r\n let clickedIndex = this.getClickedIndex(e);\r\n clickedIndex = this.applyFilters('clickedIndex', clickedIndex, e, this);\r\n /** @type {DataSource} */\r\n const dataSource = {\r\n gallery: /** @type {HTMLElement} */ (e.currentTarget)\r\n };\r\n\r\n if (clickedIndex >= 0) {\r\n e.preventDefault();\r\n this.loadAndOpen(clickedIndex, dataSource, initialPoint);\r\n }\r\n }\r\n\r\n /**\r\n * Get index of gallery item that was clicked.\r\n *\r\n * @param {MouseEvent} e click event\r\n * @returns {number}\r\n */\r\n getClickedIndex(e) {\r\n // legacy option\r\n if (this.options.getClickedIndexFn) {\r\n return this.options.getClickedIndexFn.call(this, e);\r\n }\r\n\r\n const clickedTarget = /** @type {HTMLElement} */ (e.target);\r\n const childElements = getElementsFromOption(\r\n this.options.children,\r\n this.options.childSelector,\r\n /** @type {HTMLElement} */ (e.currentTarget)\r\n );\r\n const clickedChildIndex = childElements.findIndex(\r\n child => child === clickedTarget || child.contains(clickedTarget)\r\n );\r\n\r\n if (clickedChildIndex !== -1) {\r\n return clickedChildIndex;\r\n } else if (this.options.children || this.options.childSelector) {\r\n // click wasn't on a child element\r\n return -1;\r\n }\r\n\r\n // There is only one item (which is the gallery)\r\n return 0;\r\n }\r\n\r\n /**\r\n * Load and open PhotoSwipe\r\n *\r\n * @param {number} index\r\n * @param {DataSource} [dataSource]\r\n * @param {Point | null} [initialPoint]\r\n * @returns {boolean}\r\n */\r\n loadAndOpen(index, dataSource, initialPoint) {\r\n // Check if the gallery is already open\r\n if (window.pswp || !this.options) {\r\n return false;\r\n }\r\n\r\n // Use the first gallery element if dataSource is not provided\r\n if (!dataSource && this.options.gallery && this.options.children) {\r\n const galleryElements = getElementsFromOption(this.options.gallery);\r\n if (galleryElements[0]) {\r\n dataSource = {\r\n gallery: galleryElements[0]\r\n };\r\n }\r\n }\r\n\r\n // set initial index\r\n this.options.index = index;\r\n\r\n // define options for PhotoSwipe constructor\r\n this.options.initialPointerPos = initialPoint;\r\n\r\n this.shouldOpen = true;\r\n this.preload(index, dataSource);\r\n return true;\r\n }\r\n\r\n /**\r\n * Load the main module and the slide content by index\r\n *\r\n * @param {number} index\r\n * @param {DataSource} [dataSource]\r\n */\r\n preload(index, dataSource) {\r\n const { options } = this;\r\n\r\n if (dataSource) {\r\n options.dataSource = dataSource;\r\n }\r\n\r\n // Add the main module\r\n /** @type {Promise>[]} */\r\n const promiseArray = [];\r\n\r\n const pswpModuleType = typeof options.pswpModule;\r\n if (isPswpClass(options.pswpModule)) {\r\n promiseArray.push(Promise.resolve(/** @type {Type} */ (options.pswpModule)));\r\n } else if (pswpModuleType === 'string') {\r\n throw new Error('pswpModule as string is no longer supported');\r\n } else if (pswpModuleType === 'function') {\r\n promiseArray.push(/** @type {() => Promise>} */ (options.pswpModule)());\r\n } else {\r\n throw new Error('pswpModule is not valid');\r\n }\r\n\r\n // Add custom-defined promise, if any\r\n if (typeof options.openPromise === 'function') {\r\n // allow developers to perform some task before opening\r\n promiseArray.push(options.openPromise());\r\n }\r\n\r\n if (options.preloadFirstSlide !== false && index >= 0) {\r\n this._preloadedContent = lazyLoadSlide(index, this);\r\n }\r\n\r\n // Wait till all promises resolve and open PhotoSwipe\r\n const uid = ++this._uid;\r\n Promise.all(promiseArray).then((iterableModules) => {\r\n if (this.shouldOpen) {\r\n const mainModule = iterableModules[0];\r\n this._openPhotoswipe(mainModule, uid);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * @private\r\n * @param {Type | { default: Type }} module\r\n * @param {number} uid\r\n */\r\n _openPhotoswipe(module, uid) {\r\n // Cancel opening if UID doesn't match the current one\r\n // (if user clicked on another gallery item before current was loaded).\r\n //\r\n // Or if shouldOpen flag is set to false\r\n // (developer may modify it via public API)\r\n if (uid !== this._uid && this.shouldOpen) {\r\n return;\r\n }\r\n\r\n this.shouldOpen = false;\r\n\r\n // PhotoSwipe is already open\r\n if (window.pswp) {\r\n return;\r\n }\r\n\r\n /**\r\n * Pass data to PhotoSwipe and open init\r\n *\r\n * @type {PhotoSwipe}\r\n */\r\n const pswp = typeof module === 'object'\r\n ? new module.default(this.options) // eslint-disable-line\r\n : new module(this.options); // eslint-disable-line\r\n\r\n this.pswp = pswp;\r\n window.pswp = pswp;\r\n\r\n // map listeners from Lightbox to PhotoSwipe Core\r\n /** @type {(keyof PhotoSwipeEventsMap)[]} */\r\n (Object.keys(this._listeners)).forEach((name) => {\r\n this._listeners[name]?.forEach((fn) => {\r\n pswp.on(name, /** @type {EventCallback} */(fn));\r\n });\r\n });\r\n\r\n // same with filters\r\n /** @type {(keyof PhotoSwipeFiltersMap)[]} */\r\n (Object.keys(this._filters)).forEach((name) => {\r\n this._filters[name]?.forEach((filter) => {\r\n pswp.addFilter(name, filter.fn, filter.priority);\r\n });\r\n });\r\n\r\n if (this._preloadedContent) {\r\n pswp.contentLoader.addToCache(this._preloadedContent);\r\n this._preloadedContent = undefined;\r\n }\r\n\r\n pswp.on('destroy', () => {\r\n // clean up public variables\r\n this.pswp = undefined;\r\n delete window.pswp;\r\n });\r\n\r\n pswp.init();\r\n }\r\n\r\n /**\r\n * Unbinds all events, closes PhotoSwipe if it's open.\r\n */\r\n destroy() {\r\n this.pswp?.destroy();\r\n\r\n this.shouldOpen = false;\r\n this._listeners = {};\r\n\r\n getElementsFromOption(this.options.gallery, this.options.gallerySelector)\r\n .forEach((galleryElement) => {\r\n galleryElement.removeEventListener('click', this.onThumbnailsClick, false);\r\n });\r\n }\r\n}\r\n\r\nexport default PhotoSwipeLightbox;\r\n"], "mappings": "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", "names": ["createElement", "className", "tagName", "appendToEl", "el", "document", "appendChild", "toTransformString", "x", "y", "scale", "propValue", "undefined", "setWidthHeight", "w", "h", "style", "width", "height", "LOAD_STATE", "IDLE", "LOADING", "LOADED", "ERROR", "specialKeyUsed", "e", "button", "ctrlKey", "metaKey", "altKey", "shiftKey", "getElementsFromOption", "option", "legacySelector", "parent", "elements", "Element", "NodeList", "Array", "isArray", "from", "selector", "querySelectorAll", "isPswpClass", "fn", "prototype", "goTo", "isSafari", "navigator", "vendor", "match", "PhotoSwipeEvent", "constructor", "type", "details", "defaultPrevented", "Object", "assign", "preventDefault", "Eventable", "_listeners", "_filters", "pswp", "options", "addFilter", "name", "priority", "_this$_filters$name", "_this$_filters$name2", "_this$pswp", "push", "sort", "f1", "f2", "removeFilter", "filter", "applyFilters", "args", "_this$_filters$name3", "forEach", "apply", "on", "_this$_listeners$name", "_this$pswp2", "off", "_this$pswp3", "listener", "dispatch", "_this$_listeners$name2", "event", "call", "Placeholder", "imageSrc", "container", "element", "imgEl", "decoding", "alt", "src", "setAttribute", "setDisplayedSize", "transformOrigin", "transform", "destroy", "_this$element", "parentNode", "remove", "Content", "itemData", "instance", "index", "data", "placeholder", "slide", "displayedImageWidth", "displayedImageHeight", "Number", "isAttached", "hasSlide", "isDecoding", "state", "content", "removePlaceholder", "keepPlaceholder", "setTimeout", "load", "isLazy", "reload", "usePlaceholder", "placeholderEl", "parentElement", "prepend", "placeholderSrc", "msrc", "isFirstSlide", "isImageContent", "loadImage", "innerHTML", "html", "updateContentSize", "_this$data$src", "_this$data$alt", "imageElement", "updateSrcsetSizes", "srcset", "complete", "onLoaded", "onload", "onerror", "onError", "setSlide", "isActive", "heavyAppended", "append", "displayError", "isError", "isLoading", "isInitialSizeUpdate", "isZoomable", "image", "sizesWidth", "dataset", "largestUsedSize", "parseInt", "sizes", "String", "lazyLoad", "_this$instance$option", "_this$instance$option2", "errorMsgEl", "innerText", "errorMsg", "supportsDecode", "decode", "catch", "finally", "appendImage", "activate", "holderElement", "deactivate", "getViewportSize", "getViewportSizeFn", "newViewportSize", "documentElement", "clientWidth", "window", "innerHeight", "parsePaddingOption", "prop", "viewportSize", "paddingValue", "paddingFn", "padding", "legacyPropName", "toUpperCase", "slice", "getPanAreaSize", "MAX_IMAGE_WIDTH", "ZoomLevel", "panAreaSize", "elementSize", "fit", "fill", "vFill", "initial", "secondary", "max", "min", "update", "maxWidth", "maxHeight", "hRatio", "vRatio", "Math", "_getInitial", "_getSecondary", "_getMax", "zoomLevels", "slideData", "_parseZoomLevelOption", "optionPrefix", "optionName", "optionValue", "currZoomLevel", "lazyLoadData", "createContentFromData", "zoomLevel", "ceil", "lazyLoadSlide", "getItemData", "PhotoSwipeBase", "getNumItems", "_this$options", "numItems", "dataSource", "length", "items", "_getGalleryDOMElements", "gallery", "_this$options2", "dataSourceItem", "_domElementToItemData", "galleryElement", "_this$options3", "_this$options4", "children", "childSelector", "linkEl", "querySelector", "pswpSrc", "href", "pswpSrcset", "pswpWidth", "pswpHeight", "pswpType", "thumbnailEl", "_thumbnailEl$getAttri", "currentSrc", "getAttribute", "pswpCropped", "cropped", "thumbCropped", "PhotoSwipeLightbox", "_uid", "shouldOpen", "_preloadedContent", "onThumbnailsClick", "bind", "init", "gallerySelector", "addEventListener", "initialPoint", "clientX", "clientY", "clickedIndex", "getClickedIndex", "currentTarget", "loadAndOpen", "getClickedIndexFn", "clickedTarget", "target", "clickedChildIndex", "findIndex", "child", "contains", "galleryElements", "initialPointerPos", "preload", "promiseArray", "pswpModuleType", "pswpModule", "Promise", "resolve", "Error", "openPromise", "preloadFirstSlide", "uid", "all", "then", "iterableModules", "mainModule", "_openPhotoswipe", "module", "default", "keys", "contentLoader", "addToCache", "removeEventListener"] }