@fancyapps/ui
Version:
Robust JavaScript UI Component Library
3 lines (2 loc) • 22.2 kB
JavaScript
/*! License details at fancyapps.com/license */
import{isPlainObject as e}from"../utils/isPlainObject.js";import{isString as t}from"../utils/isString.js";import{isNode as n}from"../utils/isNode.js";import{stringToHtml as o}from"../utils/strToHtml.js";import{getScrollableParent as i}from"../utils/getScrollableParent.js";import{scrollLock as r}from"../utils/scrollLock.js";import{extend as s}from"../utils/extend.js";import{canUseDOM as l}from"../utils/canUseDOM.js";import{map as a}from"../utils/map.js";import{addClass as c}from"../utils/addClass.js";import{PANZOOM_DEFAULT_POS as u}from"../panzoom/panzoom.js";export{Panzoom,PanzoomAction,PanzoomZoomLevel}from"../panzoom/panzoom.js";import{Carousel as d}from"../carousel/carousel.js";import{Zoomable as f}from"../carousel/carousel.zoomable.js";import{Sync as m}from"../carousel/carousel.sync.js";import{Lazyload as p}from"../carousel/carousel.lazyload.js";import{Arrows as g}from"../carousel/carousel.arrows.js";import{Toolbar as v}from"../carousel/carousel.toolbar.js";export{ToolbarColumn}from"../carousel/carousel.toolbar.js";import{Autoplay as y}from"../carousel/carousel.autoplay.js";import{Thumbs as h}from"../carousel/carousel.thumbs.js";import{Html as b}from"../carousel/carousel.html.js";import{Video as E}from"../carousel/carousel.video.js";import{Fullscreen as x}from"../carousel/carousel.fullscreen.js";import{Hash as w}from"./fancybox.hash.js";import{Tween as L}from"../libs/tween.js";import{en_EN as j}from"./l10n/en_EN.js";import{Gestures as S}from"../libs/gestures.js";import{removeClass as P}from"../utils/removeClass.js";const C='<button class="f-button" title="{{CLOSE}}" data-fancybox-close><svg><path d="M19.286 4.714 4.714 19.286M4.714 4.714l14.572 14.572" /></svg></button>';v().add("close",{tpl:C});const T=e=>{e&&e.dispatchEvent(new CustomEvent("animationend",{bubbles:!1,cancelable:!0,currentTarget:e}))},A=(e=null,t="",n)=>{if(!e||!e.parentElement||!t)return void(n&&n());T(e);const o=i=>{i.target===e&&e.dataset.animationName&&(e.removeEventListener("animationend",o),delete e.dataset.animationName,n&&n(),e.classList.remove(t))};e.dataset.animationName=t,e.addEventListener("animationend",o),c(e,t)};var k;!function(e){e[e.Init=0]="Init",e[e.Ready=1]="Ready",e[e.Closing=2]="Closing",e[e.Destroyed=3]="Destroyed"}(k||(k={}));const O={ajax:null,backdropClick:"close",Carousel:{},closeButton:"auto",closeExisting:!1,delegateEl:void 0,dragToClose:!0,fadeEffect:!0,groupAll:!1,groupAttr:"data-fancybox",hideClass:"f-fadeOut",hideScrollbar:!0,id:void 0,idle:!1,keyboard:{Escape:"close",Delete:"close",Backspace:"close",PageUp:"next",PageDown:"prev",ArrowUp:"prev",ArrowDown:"next",ArrowRight:"next",ArrowLeft:"prev"},l10n:j,mainClass:"",mainStyle:{},mainTpl:'<dialog class="fancybox__dialog">\n <div class="fancybox__container" tabindex="0" aria-label="{{MODAL}}">\n <div class="fancybox__backdrop"></div>\n <div class="fancybox__carousel"></div>\n </div>\n </dialog>',on:{},parentEl:void 0,placeFocusBack:!0,showClass:"f-zoomInUp",startIndex:0,sync:void 0,theme:"dark",triggerEl:void 0,triggerEvent:void 0,zoomEffect:!0},M=new Map;let _=0;const R="with-fancybox",D=()=>{let l,w,j,D,z,H=k.Init,B=Object.assign({},O),N=-1,q={},V=[],F=!1,W=!0;function $(e,...t){let n=B[e];return n&&"function"==typeof n?n(Le,...t):n}function K(e,t=[]){const n=$("l10n")||{};e=String(e).replace(/\{\{(\w+)\}\}/g,((e,t)=>n[t]||e));for(let n=0;n<t.length;n++)e=e.split(t[n][0]).join(t[n][1]);return e=e.replace(/\{\{(.*?)\}\}/g,((e,t)=>t))}const U=new Map;function G(e,...t){const n=U.get(e)||[];for(const[t,o]of Object.entries(B.on||{}))(t===e||t.split(" ").indexOf(e)>-1)&&n.push(o);for(const e of n)e&&"function"==typeof e&&e(Le,...t);"*"!==e&&G("*",e,...t)}function X(t=[],n={}){H!==k.Init&&(Le.destroy(),H=k.Init),B=s({},O,n),N=$("id")||"fancybox-"+ ++_;const i=M.get(N);if(i&&i.destroy(),M.set(N,Le),G("init"),function(){for(const[e,t]of Object.entries(Object.assign(Object.assign({},I.Plugins),B.plugins||{})))if(e&&!q[e]&&t instanceof Function){const n=t();n.init(Le),q[e]=n}G("initPlugins")}(),function(e=[]){G("initSlides",e),V=[...e]}(t),function(){const t=$("parentEl")||document.body;if(!(t&&t instanceof HTMLElement))return;const n=K($("mainTpl")||"");if(l=o(n)||void 0,!(l&&l instanceof HTMLDialogElement))return;if(w=l.querySelector(".fancybox__container"),!(w&&w instanceof HTMLElement))return;const i=$("mainClass");i&&c(w,i);const s=$("mainStyle");if(s&&e(s))for(const[e,t]of Object.entries(s))w.style.setProperty(e,t);const a=$("theme"),u="auto"===a?window.matchMedia("(prefers-color-scheme:light)").matches:"light"===a;w.setAttribute("theme",u?"light":"dark"),l.setAttribute("id",`${N}`),l.addEventListener("keydown",(e=>{"Escape"===e.key&&e.preventDefault()})),l.addEventListener("cancel",(e=>{Ee(e)})),t.append(l),1===M.size&&($("hideScrollbar")&&r(!0),document.documentElement.classList.add(R));l.showModal(),G("initLayout")}(),function(){if(j=(null==l?void 0:l.querySelector(".fancybox__carousel"))||void 0,!j)return;const e=s({Autoplay:{autoStart:!1,pauseOnHover:!1,progressbarParentEl:e=>{const t=e.getContainer();return(null==t?void 0:t.querySelector(".f-carousel__toolbar [data-autoplay-action]"))||t}},Fullscreen:{el:w},Toolbar:{absolute:!0,display:{left:["counter"],right:["toggleFull","autoplay","fullscreen","thumbs","close"]}},Video:{autoplay:!0},Zoomable:{Panzoom:{event:$("triggerEvent")}},classes:{container:"fancybox__carousel",viewport:"fancybox__viewport",slide:"fancybox__slide"},spinnerTpl:'<div class="f-spinner" data-fancybox-close></div>',dragFree:!1,slidesPerPage:1,plugins:{Sync:m,Arrows:g,Lazyload:p,Zoomable:f,Html:b,Video:E,Autoplay:y,Fullscreen:x,Thumbs:h,Toolbar:v}},$("Carousel")||{},{slides:V,enabled:!0,initialPage:$("startIndex")||0,l10n:$("l10n")});D=d(j,e),G("initCarousel",D),D.on("*",((e,t,...n)=>{G(`Carousel.${t}`,e,...n)})),null==D||D.on("addSlide",ee),D.on("attachSlideEl",te),D.on("detachSlideEl",ne),D.on("contentReady",ae),D.on("ready",re),D.on("change",ie),D.on("settle",se),D.init()}(),l&&w){if($("closeExisting"))for(const[e,t]of M.entries())e!==N&&t.close();$("fadeEffect")?(setTimeout((()=>{Y()}),500),c(w,"is-revealing")):Y(),w.classList.add("is-ready"),H=k.Ready,G("ready")}}function Y(){P(w,"is-revealing");try{if(document.activeElement===l){((null==w?void 0:w.querySelector("[autofocus]"))||w).focus()}}catch(e){}}function Z(e){if(!de())return;if(H!==k.Ready)return e.preventDefault(),void e.stopPropagation();if(e.defaultPrevented)return;if(!S.isClickAllowed())return;const t=e.composedPath()[0];t.closest(".fancybox__carousel")&&t.classList.contains("fancybox__slide")&&J(e)}function J(e){if(!!e.composedPath()[0].closest("[data-fancybox-close]"))return void Ee(e);if(G("backdropClick",e),e.defaultPrevented)return;$("backdropClick")&&Ee(e)}function Q(e){if(!de())return;if(H!==k.Ready)return;if(he(),e.defaultPrevented)return;const t=e.composedPath()[0],n=!!t.closest("[data-fancybox-close]"),o=t.classList.contains("fancybox__backdrop");(n||o)&&J(e)}function ee(e,t){var n;null===(n=t.el)||void 0===n||n.addEventListener("click",Z)}function te(e,n){oe(n),"inline"!==n.type&&"clone"!==n.type||function(e){if(!D||!e||!e.el)return;let n=null;if(t(e.src)){const t=e.src.split("#",2).pop();n=t?document.getElementById(t):null}if(n){if(c(n,"f-html"),"clone"===e.type||n.closest(".fancybox__carousel")){n=n.cloneNode(!0);const t=n.dataset.animationName;t&&(n.classList.remove(t),delete n.dataset.animationName);let o=n.getAttribute("id");o=o?`${o}--clone`:`clone-${N}-${e.index}`,n.setAttribute("id",o)}else if(n.parentNode){const t=document.createElement("div");t.inert=!0,n.parentNode.insertBefore(t,n),e.placeholderEl=t}e.htmlEl=n,c(e.el,"has-html"),e.el.prepend(n),n.classList.remove("hidden"),"none"===n.style.display&&(n.style.display=""),"none"===getComputedStyle(n).getPropertyValue("display")&&(n.style.display=n.dataset.display||"flex"),null==D||D.emit("contentReady",e)}else null==D||D.showError(e,"{{ELEMENT_NOT_FOUND}}")}(n),"ajax"===n.type&&function(e){const t=e.el;if(!t)return;if(e.htmlEl||e.xhr)return;null==D||D.showLoading(e),e.state=0;const n=new XMLHttpRequest;n.onreadystatechange=function(){if(n.readyState===XMLHttpRequest.DONE&&H===k.Ready)if(null==D||D.hideLoading(e),e.state=1,200===n.status){let o=n.responseText+"",i=null,r=null;if(e.filter){const t=document.createElement("div");t.innerHTML=o,r=t.querySelector(e.filter+"")}r&&r instanceof HTMLElement?i=r:(i=document.createElement("div"),i.innerHTML=o),i.classList.add("f-html"),e.htmlEl=i,t.classList.add("has-html"),t.classList.add("has-ajax"),t.prepend(i),null==D||D.emit("contentReady",e)}else null==D||D.showError(e)};const o=$("ajax")||null;n.open(o?"POST":"GET",e.src+""),n.setRequestHeader("Content-Type","application/x-www-form-urlencoded"),n.setRequestHeader("X-Requested-With","XMLHttpRequest"),n.send(o),e.xhr=n}(n)}function ne(e,t){!function(e){e.closeButtonEl&&(e.closeButtonEl.remove(),e.closeButtonEl=void 0)}(t),"inline"!==t.type&&"clone"!==t.type||function(e){const t=e.htmlEl,n=e.placeholderEl;t&&("none"!==getComputedStyle(t).getPropertyValue("display")&&(t.style.display="none"),t.offsetHeight);n&&(t&&n.parentNode&&n.parentNode.insertBefore(t,n),n.remove());e.htmlEl=void 0,e.placeholderEl=void 0}(t),t.xhr&&(t.xhr.abort(),t.xhr=void 0)}function oe(e){var t;const{el:n,htmlEl:i,closeButtonEl:r}=e;if(!n||!i||r)return;let s=$("closeButton");if("auto"===s&&(s=!0!==(null===(t=null==D?void 0:D.getPlugins().Toolbar)||void 0===t?void 0:t.isEnabled())),s){const t=o(K(C));t&&(e.closeButtonEl=i.insertAdjacentElement("afterbegin",t),n.classList.add("has-close-btn"))}}function ie(){W=!1,w&&D&&w.classList.remove("is-revealing");const e=$("sync");if(D&&e){const t=e.getPageIndex(D.getPageIndex())||0;e.goTo(t,{transition:!1})}}function re(){var e;if(H!==k.Ready)return;le(fe()),function(){if(!$("dragToClose"))return;if(!D)return;if(!D.getViewport())return;const e=D.getGestures();if(!e)return;let t=0,n=0,o=L().on("step",(e=>{t=e.y;const n=null==D?void 0:D.getViewport();if(w&&n){const e=a(Math.abs(t),0,.5*n.getBoundingClientRect().height,1,.5);w.style.setProperty("--f-drag-opacity",e+""),w.style.setProperty("--f-drag-offset",t+"px")}})).on("end",(()=>{if(!t){w&&w.style.removeProperty("--f-opacity");const e=null==D?void 0:D.getViewport();e&&(e.style.transform="")}}));e.on("start",(function(){o.pause()})).on("panstart",(e=>{var t;const n=e.srcEvent.target;n&&!i(n)&&(null===(t=null==D?void 0:D.getViewport())||void 0===t||t.classList.add("is-dragging"))})).on("pan",(function(e){const r=e.srcEvent.target;r&&i(r)||(null==D?void 0:D.getViewport())&&"y"===e.axis&&(n+=e.deltaY,o.spring({clamp:!0,mass:1,tension:860,friction:17,restDelta:.01,restSpeed:.01}).from({y:t}).to({y:n}).start())})).on("end",(function(e){o.pause(),"y"===e.axis&&Math.abs(e.velocityY)>5&&Math.abs(n)>0?Ee(e.srcEvent,"f-throwOut"+(e.velocityY>0?"Down":"Up")):0!==n&&(n=0,o.spring({clamp:!0,mass:1,tension:140,friction:25,restDelta:.1,restSpeed:.1,maxSpeed:1/0}).from({y:t}).to({y:n}).start())}))}(),document.body.addEventListener("click",Q),document.body.addEventListener("keydown",ue,{passive:!1,capture:!0}),ve();const t=$("sync");t&&(null===(e=t.getTween())||void 0===e||e.start())}function se(){(null==D?void 0:D.canGoNext())?ve():be()}function le(e){if(!(W&&D&&1===D.getState()&&e&&e.index===D.getOptions().initialPage&&e.el&&e.el.parentElement))return;if(void 0!==e.state&&1!==e.state)return;W=!1;const t=$("zoomEffect")?pe(e):void 0,n=e.panzoomRef,o=null==n?void 0:n.getTween();if(n&&o&&t){const e=n.getScale("base")||1,{x:i,y:r}=n.getMousemovePos(e)||{x:0,y:0};return void o.spring({tension:225,friction:25,restDelta:.001,restSpeed:.001,maxSpeed:1/0}).from(t).to({x:i,y:r,scale:e}).start()}const i=(null==n?void 0:n.getWrapper())||e.htmlEl;i&&A(i,$("showClass",e))}function ae(e,t){oe(t),le(t)}function ce(){he()}function ue(e){if(!de())return;if(H!==k.Ready)return;const t=e.key,o=$("keyboard");if(!o)return;if(e.ctrlKey||e.altKey||e.shiftKey)return;const i=e.composedPath()[0];if(!n(i))return;if("Escape"!==t&&(e=>{const t=["input","textarea","select","option","video","iframe","[contenteditable]","[data-selectable]","[data-draggable]"].join(",");return e.matches(t)||e.closest(t)})(i))return;if(G("keydown",e),e.defaultPrevented)return;const r=o[t];if(r)switch(r){case"close":Ee(e);break;case"next":e.preventDefault(),null==D||D.next();break;case"prev":e.preventDefault(),null==D||D.prev()}}function de(){var e;return(null===(e=I.getInstance())||void 0===e?void 0:e.getId())===N}function fe(){var e;return null===(e=null==D?void 0:D.getPage())||void 0===e?void 0:e.slides[0]}function me(){const e=fe();return e?e.triggerEl||$("triggerEl"):void 0}function pe(e){var t,n;const o=null===(n=null===(t=e.panzoomRef)||void 0===t?void 0:t.getWrapper())||void 0===n?void 0:n.getBoundingClientRect(),i=null==o?void 0:o.width,r=null==o?void 0:o.height;if(!i||!r)return;const s=e.thumbEl;if(!s)return;const l=s.getBoundingClientRect();let a=l.width,c=l.height,u=l.left,d=l.top;if(!l||!a||!c)return;if(!(e=>{const t=e.getBoundingClientRect(),n=e.closest("[style]"),o=null==n?void 0:n.parentElement;if(n&&n.style.transform&&o){const e=o.getBoundingClientRect();if(t.left<e.left||t.left>e.left+e.width-t.width)return!1;if(t.top<e.top||t.top>e.top+e.height-t.height)return!1}const i=Math.max(document.documentElement.clientHeight,window.innerHeight),r=Math.max(document.documentElement.clientWidth,window.innerWidth);return!(t.bottom<0||t.top-i>=0||t.right<0||t.left-r>=0)})(s))return;if(s instanceof HTMLImageElement){const e=window.getComputedStyle(s).getPropertyValue("object-fit");if("contain"===e||"scale-down"===e){const{width:t,height:n}=((e,t,n,o,i="contain")=>{if("contain"===i||e>n||t>o){const i=n/e,r=o/t,s=Math.min(i,r);e*=s,t*=s}return{width:e,height:t}})(s.naturalWidth,s.naturalHeight,a,c,e);u+=.5*(a-t),d+=.5*(c-n),a=t,c=n}}if(Math.abs(i/r-a/c)>.1)return;return{x:u+.5*a-(o.left+.5*i),y:d+.5*c-(o.top+.5*r),scale:a/i}}function ge(){z&&clearTimeout(z),z=void 0,document.removeEventListener("mousemove",ce)}function ve(){if(F)return;if(z)return;const e=$("idle");e&&(z=setTimeout(ye,e))}function ye(){w&&(ge(),c(w,"is-idle"),document.addEventListener("mousemove",ce),F=!0)}function he(){F&&(be(),ve())}function be(){ge(),null==w||w.classList.remove("is-idle"),F=!1}function Ee(e,t){var n,o,i,r,l,a;if(H===k.Closing||H===k.Destroyed)return;if(H=k.Closing,ge(),e){if(e.defaultPrevented)return;e.cancelable&&e.preventDefault(),e.stopPropagation(),e.stopImmediatePropagation()}if(D){null===(n=D.getGestures())||void 0===n||n.destroy(),null===(o=D.getTween())||void 0===o||o.pause();const e=fe(),t=null==e?void 0:e.panzoomRef;e&&t&&s(t.getOptions(),{clickAction:!1,wheelAction:!1,bounds:!1,minScale:0,maxScale:1/0});for(const e of D.getSlides())null===(r=null===(i=e.panzoomRef)||void 0===i?void 0:i.getGestures())||void 0===r||r.destroy(),null===(a=null===(l=e.panzoomRef)||void 0===l?void 0:l.getTween())||void 0===a||a.pause()}const c=null==D?void 0:D.getPlugins().fullscreen;c&&c.inFullscreen()?Promise.resolve(c.exit()).then((()=>{setTimeout((()=>{xe(e,t)}),150)})):xe(e,t)}function xe(e,t){var n,o,i,r,s;if(H!==k.Closing)return;if(G("close",e),$("placeFocusBack")){const e=me();!e||(s=e.getBoundingClientRect()).bottom>0&&s.right>0&&s.left<(window.innerWidth||document.documentElement.clientWidth)&&s.top<(window.innerHeight||document.documentElement.clientHeight)||e.scrollIntoView({behavior:"instant",block:"center",inline:"center"})}$("fadeEffect")&&(null==w||w.classList.remove("is-ready"),null==w||w.classList.add("is-hiding")),null==w||w.classList.add("is-closing");const l=fe(),a=null==l?void 0:l.panzoomRef,c=null===(n=null==l?void 0:l.panzoomRef)||void 0===n?void 0:n.getTween(),d=t||$("hideClass");let f=!1,m=!1;if(D&&l&&a&&c){let e;$("zoomEffect")&&((null===(i=null===(o=D.getTween())||void 0===o?void 0:o.getCurrentVelocities())||void 0===i?void 0:i.pos)||0)<700&&1===l.state&&(e=pe(l)),e&&(f=!0,D.on("refresh",(()=>{const e=pe(l);e&&c.to(Object.assign(Object.assign({},u),e))})),c.easing(L.Easings.EaseOut).duration(350).from(Object.assign({},a.getTransform())).to(Object.assign(Object.assign({},u),e)).start())}const p=(null==l?void 0:l.htmlEl)||(null===(r=null==l?void 0:l.panzoomRef)||void 0===r?void 0:r.getWrapper());p&&T(p),!f&&d&&p&&(m=!0,A(p,d,(()=>{we()}))),f||m?setTimeout((()=>{we()}),350):we()}function we(){var e,t,n,o,i;if(H===k.Destroyed)return;H=k.Destroyed,document.body.removeEventListener("click",Q),document.body.removeEventListener("keydown",ue,{passive:!1,capture:!0});const s=me();G("destroy"),null===(t=null===(e=$("sync"))||void 0===e?void 0:e.getPlugins().Autoplay)||void 0===t||t.resume(),null===(o=null===(n=$("sync"))||void 0===n?void 0:n.getPlugins().Autoscroll)||void 0===o||o.resume(),l instanceof HTMLDialogElement&&l.close(),null===(i=null==D?void 0:D.getContainer())||void 0===i||i.classList.remove("is-idle"),null==D||D.destroy();for(const e of Object.values(q))null==e||e.destroy();if(q={},null==l||l.remove(),l=void 0,w=void 0,D=void 0,M.delete(N),!M.size&&(r(!1),document.documentElement.classList.remove(R),$("placeFocusBack")))try{null==s||s.focus({preventScroll:!0})}catch(e){}}const Le={close:Ee,destroy:we,getCarousel:function(){return D},getContainer:function(){return w},getId:function(){return N},getOptions:function(){return B},getPlugins:function(){return q},getSlide:function(){return fe()},getState:function(){return H},init:function(e=[],t={}){return X(e,t),Le},isCurrentSlide:function(e){const t=fe();return!(!e||!t)&&t.index===e.index},isTopMost:function(){return de()},off:function(e,t){return U.has(e)&&U.set(e,U.get(e).filter((e=>e!==t))),Le},on:function(e,t){return U.set(e,[...U.get(e)||[],t]),Le},toggleIdle(e){(F||!0===e)&&ye(),F&&!1!==e||be()}};return Le};const I={Plugins:{Hash:w},version:"6.0.14",openers:new Map,bind:function(e,n,o){if(!l())return;let i=document.body,r="[data-fancybox]",s={};if(t(e)?(i=document.body,r=e,"object"==typeof n&&(s=n||{})):e instanceof Element&&(i=e,t(n)&&(r=n),"object"==typeof o&&(s=o||{})),!(i&&i instanceof Element&&r))return!1;const a=I.openers.get(i)||new Map;if(a.set(r,s),I.openers.set(i,a),1===a.size){i.addEventListener("click",I.fromEvent);for(const e of Object.values(I.Plugins)){const t=e.setup;"function"==typeof t&&t(I)}}return!0},close:function(e=!0,...t){if(e)for(const e of M.values())e.close(...t);else{const e=I.getInstance();e&&e.close(...t)}},destroy:function(){let e;for(;e=I.getInstance();)e.destroy();for(const e of I.openers.keys())e.removeEventListener("click",I.fromEvent);I.openers.clear()},fromEvent:function(e){var t,n,o;if(e.defaultPrevented)return;if(e.button&&0!==e.button)return;if(e.ctrlKey||e.metaKey||e.shiftKey)return;let i=e.composedPath()[0];if(i.closest(".fancybox__container.is-hiding"))return e.preventDefault(),void e.stopPropagation();const r=i.closest("[data-fancybox-delegate]")||void 0;if(r){const e=r.dataset.fancyboxDelegate||"",t=document.querySelectorAll(`[data-fancybox="${e}"]`);i=t[parseInt(r.dataset.fancyboxIndex||"",10)||0]||t[0]}if(!(i&&i instanceof Element))return;let l,a,c;for(const e of Array.from(I.openers.keys()).reverse()){const t=I.openers.get(e);if(t&&e.contains(i))for(const n of Array.from(t.keys()).reverse()){let o=null;try{o=i.closest(n)}catch(e){}if(o){i=o,l=e,a=n,c=t.get(n);break}}}if(!(l&&a&&c))return;e.preventDefault();const u=s({},O,{triggerEvent:e,triggerEl:i,delegateEl:r},c),d=u.groupAll,f=u.groupAttr,m=f&&i?i.getAttribute(`${f}`):"";let p=[];const g=null===(t=i.closest(".f-carousel"))||void 0===t?void 0:t.carousel;if(g){const e=[];for(const t of null==g?void 0:g.getSlides()){const n=t.el;n&&(n.matches(a)?e.push(n):e.push(...[].slice.call(n.querySelectorAll(a))))}e.length&&(p=[...e],null===(n=g.getPlugins().Autoplay)||void 0===n||n.pause(),null===(o=g.getPlugins().Autoscroll)||void 0===o||o.pause(),u.sync=g)}else(!i||m||d)&&(p=[].slice.call(l.querySelectorAll(a)));if(i&&!d&&(p=m?p.filter((e=>e.getAttribute(`${f}`)===m)):[i]),!p.length)return;const v=I.getInstance();if(v){const e=v.getOptions().triggerEl;if(e&&p.indexOf(e)>-1)return}return Object.assign({},u.Carousel||{}).rtl&&(p=p.reverse()),i&&(u.startIndex=p.indexOf(i)),I.fromNodes(p,u)},fromNodes:function(e,t){t=s({},O,t||{});const n=[],o=e=>e instanceof HTMLImageElement?e:e instanceof HTMLElement?e.querySelector("img:not([aria-hidden])"):void 0;for(const i of e){const r=i.dataset||{},s=t.delegateEl&&e.indexOf(i)===t.startIndex?t.delegateEl:void 0,l=o(s)||o(i)||void 0,a=r.src||i.getAttribute("href")||i.getAttribute("currentSrc")||i.getAttribute("src")||void 0,c=r.thumb||r.thumbSrc||(null==l?void 0:l.getAttribute("currentSrc"))||(null==l?void 0:l.getAttribute("src"))||(null==l?void 0:l.dataset.lazySrc)||void 0,u={src:a,alt:r.alt||(null==l?void 0:l.getAttribute("alt"))||void 0,thumbSrc:c,thumbEl:l,triggerEl:i,delegateEl:s};for(const e in r){let t=r[e]+"";t="false"!==t&&("true"===t||t),u[e]=t}n.push(u)}return I.show(n,t)},fromSelector:function(e,n,o){let i=document.body,r="",l={};if(t(e)?r=e:e instanceof Element&&(i=e,t(n)&&(r=n),"object"==typeof o&&(l=o||{})),!(i&&i instanceof Element&&r))return;const a=I.openers.get(i);return a?(l=s({},a.get(r)||{},l),l?I.fromNodes(Array.from(i.querySelectorAll(r)),l):void 0):void 0},getCarousel:function(){var e;return(null===(e=I.getInstance())||void 0===e?void 0:e.getCarousel())||void 0},getDefaults:function(){return O},getInstance:function(e){if(e){const t=M.get(e);return t&&t.getState()!==k.Destroyed?t:void 0}return Array.from(M.values()).reverse().find((e=>{if(e.getState()!==k.Destroyed)return e}))||void 0},getSlide:function(){var e;return(null===(e=I.getInstance())||void 0===e?void 0:e.getSlide())||void 0},show:function(e=[],t={}){return D().init(e,t)},unbind:function(e,n){let o=document.body,i="";if(t(e)?i=e:e instanceof Element&&(o=e,t(n)&&(i=n)),o){const e=I.openers.get(o);e&&i&&e.delete(i),(null==e?void 0:e.size)&&i||I.openers.delete(o),o.removeEventListener("click",I.fromEvent)}}};export{g as Arrows,y as Autoplay,d as Carousel,I as Fancybox,k as FancyboxState,x as Fullscreen,b as Html,p as Lazyload,u as PANZOOM_DEFAULT_POS,m as Sync,h as Thumbs,v as Toolbar,E as Video,f as Zoomable};