{"version":3,"sources":["webpack:///./node_modules/core-js/modules/es.array.find-index.js","webpack:///../../../src/js/util/util.js","webpack:///../../../src/js/core/eventable.js","webpack:///../../../src/js/slide/placeholder.js","webpack:///../../../src/js/slide/content.js","webpack:///../../../src/js/util/viewport-size.js","webpack:///../../../src/js/slide/zoom-level.js","webpack:///../../../src/js/slide/loader.js","webpack:///../../../src/js/core/base.js","webpack:///../../../src/js/lightbox/lightbox.js","webpack:///./node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","webpack:///./node_modules/core-js/modules/es.reflect.construct.js","webpack:///./node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js","webpack:///./node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js","webpack:///./node_modules/core-js/modules/es.array.fill.js","webpack:///./node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","webpack:///./node_modules/@babel/runtime/helpers/esm/inherits.js","webpack:///./node_modules/core-js/internals/function-bind.js"],"names":["$","$findIndex","findIndex","addToUnscopables","FIND_INDEX","SKIPS_HOLES","Array","target","proto","forced","callbackfn","this","arguments","length","undefined","createElement","className","tagName","appendToEl","el","document","appendChild","setWidthHeight","w","h","style","width","concat","height","LOAD_STATE","getElementsFromOption","option","legacySelector","parent","elements","Element","NodeList","isArray","from","selector","querySelectorAll","isSafari","navigator","vendor","match","PhotoSwipeEvent","type","details","_classCallCheck","defaultPrevented","Object","assign","_createClass","key","value","Eventable","_listeners","_filters","pswp","options","name","fn","_this$_filters$name","_this$_filters$name2","_this$pswp","priority","push","sort","f1","f2","addFilter","filter","removeFilter","_this$_filters$name3","_this","_len","args","_key","forEach","apply","_this$_listeners$name","_this$pswp2","on","_this$pswp3","listener","off","_this$_listeners$name2","_this2","dispatch","event","call","Placeholder","imageSrc","container","element","imgEl","decoding","alt","src","setAttribute","y","scale","propValue","transformOrigin","transform","_this$element","parentNode","remove","Content","itemData","instance","index","data","placeholder","slide","displayedImageWidth","displayedImageHeight","Number","isAttached","hasSlide","isDecoding","state","content","_this3","keepPlaceholder","setTimeout","destroy","isLazy","reload","usePlaceholder","placeholderEl","parentElement","prepend","placeholderSrc","applyFilters","msrc","isFirstSlide","isImageContent","loadImage","innerHTML","html","updateContentSize","_this$data$src","_this$data$alt","_this4","imageElement","updateSrcsetSizes","srcset","complete","onLoaded","onload","onerror","onError","isActive","heavyAppended","append","removePlaceholder","displayError","isError","setDisplayedSize","isInitialSizeUpdate","image","sizesWidth","dataset","largestUsedSize","parseInt","sizes","String","load","isLoading","_this$instance$option","_this$instance$option2","errorMsgEl","innerText","errorMsg","_this5","supportsDecode","decode","catch","finally","appendImage","holderElement","parsePaddingOption","prop","viewportSize","paddingValue","paddingFn","padding","legacyPropName","toUpperCase","slice","ZoomLevel","panAreaSize","elementSize","fit","fill","vFill","initial","secondary","max","min","maxWidth","maxHeight","x","hRatio","vRatio","Math","_getInitial","_getSecondary","_getMax","zoomLevels","slideData","optionPrefix","optionName","optionValue","currZoomLevel","_parseZoomLevelOption","lazyLoadData","zoomLevel","createContentFromData","getViewportSizeFn","newViewportSize","documentElement","clientWidth","window","innerHeight","getViewportSize","getPanAreaSize","update","lazyLoad","ceil","PhotoSwipeBase","_Eventable","_inherits","_super","_createSuper","_this$options","numItems","dataSource","items","_getGalleryDOMElements","gallery","_this$options2","dataSourceItem","_domElementToItemData","galleryElement","_this$options3","_this$options4","children","childSelector","linkEl","querySelector","pswpSrc","href","pswpSrcset","pswpWidth","pswpHeight","pswpType","_thumbnailEl$getAttri","thumbnailEl","currentSrc","getAttribute","pswpCropped","cropped","thumbCropped","PhotoSwipeLightbox","_PhotoSwipeBase","_super2","_this6","_uid","shouldOpen","_preloadedContent","onThumbnailsClick","bind","_assertThisInitialized","_this7","gallerySelector","addEventListener","e","button","ctrlKey","metaKey","altKey","shiftKey","specialKeyUsed","initialPoint","clientX","clientY","clickedIndex","getClickedIndex","currentTarget","preventDefault","loadAndOpen","getClickedIndexFn","clickedTarget","clickedChildIndex","child","contains","initialPointerPos","preload","_this8","promiseArray","pswpModuleType","_typeof","pswpModule","prototype","goTo","Promise","resolve","Error","openPromise","preloadFirstSlide","getItemData","lazyLoadSlide","uid","all","then","iterableModules","mainModule","_openPhotoswipe","module","_this9","default","keys","_this9$_listeners$nam","_this9$_filters$name","contentLoader","addToCache","init","_this$pswp4","_this10","removeEventListener","self","ReferenceError","getBuiltIn","aConstructor","anObject","isObject","create","fails","nativeConstruct","ObjectPrototype","NEW_TARGET_BUG","F","ARGS_BUG","FORCED","stat","sham","construct","Target","newTarget","$args","result","_possibleConstructorReturn","TypeError","_getPrototypeOf","o","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","p","subClass","superClass","constructor","writable","configurable","defineProperty","uncurryThis","aCallable","hasOwn","arraySlice","NATIVE_BIND","$Function","Function","join","factories","exports","that","Prototype","partArgs","boundFunction","C","argsLength","list","i"],"mappings":"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","file":"322bc54.js","sourcesContent":["'use strict';\nvar $ = require('../internals/export');\nvar $findIndex = require('../internals/array-iteration').findIndex;\nvar addToUnscopables = require('../internals/add-to-unscopables');\n\nvar FIND_INDEX = 'findIndex';\nvar SKIPS_HOLES = true;\n\n// Shouldn't skip holes\n// eslint-disable-next-line es/no-array-prototype-findindex -- testing\nif (FIND_INDEX in []) Array(1)[FIND_INDEX](function () { SKIPS_HOLES = false; });\n\n// `Array.prototype.findIndex` method\n// https://tc39.es/ecma262/#sec-array.prototype.findindex\n$({ target: 'Array', proto: true, forced: SKIPS_HOLES }, {\n findIndex: function findIndex(callbackfn /* , that = undefined */) {\n return $findIndex(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\naddToUnscopables(FIND_INDEX);\n","/** @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 thubmnail 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 thubmnail 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 */\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) {\r\n return false;\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","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}","var $ = require('../internals/export');\nvar getBuiltIn = require('../internals/get-built-in');\nvar apply = require('../internals/function-apply');\nvar bind = require('../internals/function-bind');\nvar aConstructor = require('../internals/a-constructor');\nvar anObject = require('../internals/an-object');\nvar isObject = require('../internals/is-object');\nvar create = require('../internals/object-create');\nvar fails = require('../internals/fails');\n\nvar nativeConstruct = getBuiltIn('Reflect', 'construct');\nvar ObjectPrototype = Object.prototype;\nvar push = [].push;\n\n// `Reflect.construct` method\n// https://tc39.es/ecma262/#sec-reflect.construct\n// MS Edge supports only 2 arguments and argumentsList argument is optional\n// FF Nightly sets third argument as `new.target`, but does not create `this` from it\nvar NEW_TARGET_BUG = fails(function () {\n function F() { /* empty */ }\n return !(nativeConstruct(function () { /* empty */ }, [], F) instanceof F);\n});\n\nvar ARGS_BUG = !fails(function () {\n nativeConstruct(function () { /* empty */ });\n});\n\nvar FORCED = NEW_TARGET_BUG || ARGS_BUG;\n\n$({ target: 'Reflect', stat: true, forced: FORCED, sham: FORCED }, {\n construct: function construct(Target, args /* , newTarget */) {\n aConstructor(Target);\n anObject(args);\n var newTarget = arguments.length < 3 ? Target : aConstructor(arguments[2]);\n if (ARGS_BUG && !NEW_TARGET_BUG) return nativeConstruct(Target, args, newTarget);\n if (Target == newTarget) {\n // w/o altered newTarget, optimization for 0-4 arguments\n switch (args.length) {\n case 0: return new Target();\n case 1: return new Target(args[0]);\n case 2: return new Target(args[0], args[1]);\n case 3: return new Target(args[0], args[1], args[2]);\n case 4: return new Target(args[0], args[1], args[2], args[3]);\n }\n // w/o altered newTarget, lot of arguments case\n var $args = [null];\n apply(push, $args, args);\n return new (apply(bind, Target, $args))();\n }\n // with altered newTarget, not support built-in constructors\n var proto = newTarget.prototype;\n var instance = create(isObject(proto) ? proto : ObjectPrototype);\n var result = apply(Target, instance, args);\n return isObject(result) ? result : instance;\n }\n});\n","import _typeof from \"./typeof.js\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return assertThisInitialized(self);\n}","export default function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}","var $ = require('../internals/export');\nvar fill = require('../internals/array-fill');\nvar addToUnscopables = require('../internals/add-to-unscopables');\n\n// `Array.prototype.fill` method\n// https://tc39.es/ecma262/#sec-array.prototype.fill\n$({ target: 'Array', proto: true }, {\n fill: fill\n});\n\n// https://tc39.es/ecma262/#sec-array.prototype-@@unscopables\naddToUnscopables('fill');\n","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}","'use strict';\nvar uncurryThis = require('../internals/function-uncurry-this');\nvar aCallable = require('../internals/a-callable');\nvar isObject = require('../internals/is-object');\nvar hasOwn = require('../internals/has-own-property');\nvar arraySlice = require('../internals/array-slice');\nvar NATIVE_BIND = require('../internals/function-bind-native');\n\nvar $Function = Function;\nvar concat = uncurryThis([].concat);\nvar join = uncurryThis([].join);\nvar factories = {};\n\nvar construct = function (C, argsLength, args) {\n if (!hasOwn(factories, argsLength)) {\n for (var list = [], i = 0; i < argsLength; i++) list[i] = 'a[' + i + ']';\n factories[argsLength] = $Function('C,a', 'return new C(' + join(list, ',') + ')');\n } return factories[argsLength](C, args);\n};\n\n// `Function.prototype.bind` method implementation\n// https://tc39.es/ecma262/#sec-function.prototype.bind\n// eslint-disable-next-line es/no-function-prototype-bind -- detection\nmodule.exports = NATIVE_BIND ? $Function.bind : function bind(that /* , ...args */) {\n var F = aCallable(this);\n var Prototype = F.prototype;\n var partArgs = arraySlice(arguments, 1);\n var boundFunction = function bound(/* args... */) {\n var args = concat(partArgs, arraySlice(arguments));\n return this instanceof boundFunction ? construct(F, args.length, args) : F.apply(that, args);\n };\n if (isObject(Prototype)) boundFunction.prototype = Prototype;\n return boundFunction;\n};\n"],"sourceRoot":""}