{"version":3,"file":"js/2214.0a767b644eb506e6.js","mappings":";;;;;AAaA,SAASA,EAAcC,EAAWC,EAASC,GACzC,MAAMC,EAAKC,SAASL,cAAcE,GAUlC,OARID,IACFG,EAAGH,UAAYA,GAGbE,GACFA,EAAWG,YAAYF,GAGlBA,CACT,CAUA,SAASG,EAAkBC,EAAGC,EAAGC,GAC/B,IAAIC,EAAY,eAAeH,OAAOC,GAAK,SAM3C,YAJcG,IAAVF,IACFC,GAAa,YAAYD,KAASA,QAG7BC,CACT,CASA,SAASE,EAAeT,EAAIU,EAAGC,GAC7BX,EAAGY,MAAMC,MAAqB,kBAANH,EAAiB,GAAGA,MAAQA,EACpDV,EAAGY,MAAME,OAAsB,kBAANH,EAAiB,GAAGA,MAAQA,CACvD,C,iBAKA,MAAMI,EAAa,CACjBC,KAAM,OACNC,QAAS,UACTC,OAAQ,SACRC,MAAO,SAUT,SAASC,EAAeC,GACtB,MAAO,WAAYA,GAAkB,IAAbA,EAAEC,QAAgBD,EAAEE,SAAWF,EAAEG,SAAWH,EAAEI,QAAUJ,EAAEK,QACpF,CAUA,SAASC,EAAsBC,EAAQC,EAAgBC,EAAS7B,UAE9D,IAAI8B,EAAW,GAEf,GAAIH,aAAkBI,QACpBD,EAAW,CAACH,QACP,GAAIA,aAAkBK,UAAYC,MAAMC,QAAQP,GACrDG,EAAWG,MAAME,KAAKR,OACjB,CACL,MAAMS,EAA6B,kBAAXT,EAAsBA,EAASC,EAEnDQ,IACFN,EAAWG,MAAME,KAAKN,EAAOQ,iBAAiBD,IAElD,CAEA,OAAON,CACT,CAQA,SAASQ,EAAYC,GACnB,MAAqB,oBAAPA,GAAqBA,EAAGC,WAAaD,EAAGC,UAAUC,IAClE,CAOA,SAASC,IACP,SAAUC,UAAUC,SAAUD,UAAUC,OAAOC,MAAM,UACvD,CA4NA,MAAMC,EAKJ,WAAAC,CAAYC,EAAMC,GAChBC,KAAKF,KAAOA,EACZE,KAAKC,kBAAmB,EAEpBF,GACFG,OAAOC,OAAOH,KAAMD,EAExB,CAEA,cAAAK,GACEJ,KAAKC,kBAAmB,CAC1B,EASF,MAAMI,EACJ,WAAAR,GAIEG,KAAKM,WAAa,CAAC,EAKnBN,KAAKO,SAAW,CAAC,EAGjBP,KAAKQ,UAAOnD,EAGZ2C,KAAKS,aAAUpD,CACjB,CASA,SAAAqD,CAAUC,EAAMtB,EAAIuB,EAAW,KAC7B,IAAIC,EAAqBC,EAAsBC,EAE1Cf,KAAKO,SAASI,KACjBX,KAAKO,SAASI,GAAQ,IAGwB,QAA/CE,EAAsBb,KAAKO,SAASI,UAA2C,IAAxBE,GAAkCA,EAAoBG,KAAK,CACjH3B,KACAuB,aAE+C,QAAhDE,EAAuBd,KAAKO,SAASI,UAA4C,IAAzBG,GAAmCA,EAAqBG,MAAK,CAACC,EAAIC,IAAOD,EAAGN,SAAWO,EAAGP,WACtH,QAA5BG,EAAaf,KAAKQ,YAAiC,IAAfO,GAAyBA,EAAWL,UAAUC,EAAMtB,EAAIuB,EAC/F,CAQA,YAAAQ,CAAaT,EAAMtB,GACbW,KAAKO,SAASI,KAEhBX,KAAKO,SAASI,GAAQX,KAAKO,SAASI,GAAMU,QAAOA,GAAUA,EAAOhC,KAAOA,KAGvEW,KAAKQ,MACPR,KAAKQ,KAAKY,aAAaT,EAAMtB,EAEjC,CASA,YAAAiC,CAAaX,KAASY,GACpB,IAAIC,EAMJ,OAJiD,QAAhDA,EAAuBxB,KAAKO,SAASI,UAA4C,IAAzBa,GAAmCA,EAAqBC,SAAQJ,IAEvHE,EAAK,GAAKF,EAAOhC,GAAGqC,MAAM1B,KAAMuB,EAAK,IAEhCA,EAAK,EACd,CAQA,EAAAI,CAAGhB,EAAMtB,GACP,IAAIuC,EAAuBC,EAEtB7B,KAAKM,WAAWK,KACnBX,KAAKM,WAAWK,GAAQ,IAG0B,QAAnDiB,EAAwB5B,KAAKM,WAAWK,UAA6C,IAA1BiB,GAAoCA,EAAsBZ,KAAK3B,GAI7F,QAA7BwC,EAAc7B,KAAKQ,YAAkC,IAAhBqB,GAA0BA,EAAYF,GAAGhB,EAAMtB,EACvF,CAQA,GAAAyC,CAAInB,EAAMtB,GACR,IAAI0C,EAEA/B,KAAKM,WAAWK,KAElBX,KAAKM,WAAWK,GAAQX,KAAKM,WAAWK,GAAMU,QAAOW,GAAY3C,IAAO2C,KAG5C,QAA7BD,EAAc/B,KAAKQ,YAAkC,IAAhBuB,GAA0BA,EAAYD,IAAInB,EAAMtB,EACxF,CASA,QAAA4C,CAAStB,EAAMZ,GACb,IAAImC,EAEJ,GAAIlC,KAAKQ,KACP,OAAOR,KAAKQ,KAAKyB,SAAStB,EAAMZ,GAGlC,MAAMoC,EAEN,IAAIvC,EAAgBe,EAAMZ,GAI1B,OAHqD,QAApDmC,EAAyBlC,KAAKM,WAAWK,UAA8C,IAA3BuB,GAAqCA,EAAuBT,SAAQO,IAC/HA,EAASI,KAAKpC,KAAMmC,EAAM,IAErBA,CACT,EAIF,MAAME,EAKJ,WAAAxC,CAAYyC,EAAUC,GAOpB,GAFAvC,KAAKwC,QAAU/F,EAAc,mCAAoC6F,EAAW,MAAQ,MAAOC,GAEvFD,EAAU,CACZ,MAAMG,EAENzC,KAAKwC,QACLC,EAAMC,SAAW,QACjBD,EAAME,IAAM,GACZF,EAAMG,IAAMN,EACZG,EAAMI,aAAa,OAAQ,eAC7B,CAEA7C,KAAKwC,QAAQK,aAAa,cAAe,OAC3C,CAOA,gBAAAC,CAAiBpF,EAAOC,GACjBqC,KAAKwC,UAImB,QAAzBxC,KAAKwC,QAAQ7F,SAIfW,EAAe0C,KAAKwC,QAAS,IAAK,QAClCxC,KAAKwC,QAAQ/E,MAAMsF,gBAAkB,MACrC/C,KAAKwC,QAAQ/E,MAAMuF,UAAYhG,EAAkB,EAAG,EAAGU,EAAQ,MAE/DJ,EAAe0C,KAAKwC,QAAS9E,EAAOC,GAExC,CAEA,OAAAsF,GACE,IAAIC,EAEmC,QAAlCA,EAAgBlD,KAAKwC,eAAuC,IAAlBU,GAA4BA,EAAcC,YACvFnD,KAAKwC,QAAQY,SAGfpD,KAAKwC,QAAU,IACjB,EAYF,MAAMa,EAMJ,WAAAxD,CAAYyD,EAAUC,EAAUC,GAC9BxD,KAAKuD,SAAWA,EAChBvD,KAAKyD,KAAOH,EACZtD,KAAKwD,MAAQA,EAGbxD,KAAKwC,aAAUnF,EAGf2C,KAAK0D,iBAAcrG,EAGnB2C,KAAK2D,WAAQtG,EACb2C,KAAK4D,oBAAsB,EAC3B5D,KAAK6D,qBAAuB,EAC5B7D,KAAKtC,MAAQoG,OAAO9D,KAAKyD,KAAKlG,IAAMuG,OAAO9D,KAAKyD,KAAK/F,QAAU,EAC/DsC,KAAKrC,OAASmG,OAAO9D,KAAKyD,KAAKjG,IAAMsG,OAAO9D,KAAKyD,KAAK9F,SAAW,EACjEqC,KAAK+D,YAAa,EAClB/D,KAAKgE,UAAW,EAChBhE,KAAKiE,YAAa,EAGlBjE,KAAKkE,MAAQtG,EAAWC,KAEpBmC,KAAKyD,KAAK3D,KACZE,KAAKF,KAAOE,KAAKyD,KAAK3D,KACbE,KAAKyD,KAAKb,IACnB5C,KAAKF,KAAO,QAEZE,KAAKF,KAAO,OAGdE,KAAKuD,SAAStB,SAAS,cAAe,CACpCkC,QAASnE,MAEb,CAEA,iBAAAoE,GACMpE,KAAK0D,cAAgB1D,KAAKqE,mBAE5BC,YAAW,KACLtE,KAAK0D,cACP1D,KAAK0D,YAAYT,UACjBjD,KAAK0D,iBAAcrG,EACrB,GACC,IAEP,CASA,IAAAkH,CAAKC,EAAQC,GACX,GAAIzE,KAAK2D,OAAS3D,KAAK0E,iBACrB,GAAK1E,KAAK0D,YAKH,CACL,MAAMiB,EAAgB3E,KAAK0D,YAAYlB,QAEnCmC,IAAkBA,EAAcC,eAClC5E,KAAK2D,MAAMpB,UAAUsC,QAAQF,EAEjC,KAXuB,CACrB,MAAMG,EAAiB9E,KAAKuD,SAASjC,aAAa,oBAElDtB,KAAKyD,KAAKsB,OAAQ/E,KAAK2D,MAAMqB,eAAehF,KAAKyD,KAAKsB,KAAc/E,MACpEA,KAAK0D,YAAc,IAAIrB,EAAYyC,EAAgB9E,KAAK2D,MAAMpB,UAChE,CASEvC,KAAKwC,UAAYiC,GAIjBzE,KAAKuD,SAAStB,SAAS,cAAe,CACxCkC,QAASnE,KACTwE,WACCvE,mBAICD,KAAKiF,kBACPjF,KAAKwC,QAAU/F,EAAc,YAAa,OAGtCuD,KAAK4D,qBACP5D,KAAKkF,UAAUV,KAGjBxE,KAAKwC,QAAU/F,EAAc,gBAAiB,OAC9CuD,KAAKwC,QAAQ2C,UAAYnF,KAAKyD,KAAK2B,MAAQ,IAGzCX,GAAUzE,KAAK2D,OACjB3D,KAAK2D,MAAM0B,mBAAkB,GAEjC,CAQA,SAAAH,CAAUV,GACR,IAAIc,EAAgBC,EAEpB,IAAKvF,KAAKiF,mBAAqBjF,KAAKwC,SAAWxC,KAAKuD,SAAStB,SAAS,mBAAoB,CACxFkC,QAASnE,KACTwE,WACCvE,iBACD,OAGF,MAAMuF,EAENxF,KAAKwC,QACLxC,KAAKyF,oBAEDzF,KAAKyD,KAAKiC,SACZF,EAAaE,OAAS1F,KAAKyD,KAAKiC,QAGlCF,EAAa5C,IAA2C,QAApC0C,EAAiBtF,KAAKyD,KAAKb,WAAoC,IAAnB0C,EAA4BA,EAAiB,GAC7GE,EAAa7C,IAA2C,QAApC4C,EAAiBvF,KAAKyD,KAAKd,WAAoC,IAAnB4C,EAA4BA,EAAiB,GAC7GvF,KAAKkE,MAAQtG,EAAWE,QAEpB0H,EAAaG,SACf3F,KAAK4F,YAELJ,EAAaK,OAAS,KACpB7F,KAAK4F,UAAU,EAGjBJ,EAAaM,QAAU,KACrB9F,KAAK+F,SAAS,EAGpB,CAQA,QAAAC,CAASrC,GACP3D,KAAK2D,MAAQA,EACb3D,KAAKgE,UAAW,EAChBhE,KAAKuD,SAAWI,EAAMnD,IACxB,CAMA,QAAAoF,GACE5F,KAAKkE,MAAQtG,EAAWG,OAEpBiC,KAAK2D,OAAS3D,KAAKwC,UACrBxC,KAAKuD,SAAStB,SAAS,eAAgB,CACrC0B,MAAO3D,KAAK2D,MACZQ,QAASnE,OAGPA,KAAK2D,MAAMsC,UAAYjG,KAAK2D,MAAMuC,gBAAkBlG,KAAKwC,QAAQW,aACnEnD,KAAKmG,SACLnG,KAAK2D,MAAM0B,mBAAkB,IAG3BrF,KAAKkE,QAAUtG,EAAWG,QAAUiC,KAAKkE,QAAUtG,EAAWI,OAChEgC,KAAKoE,oBAGX,CAMA,OAAA2B,GACE/F,KAAKkE,MAAQtG,EAAWI,MAEpBgC,KAAK2D,QACP3D,KAAKoG,eACLpG,KAAKuD,SAAStB,SAAS,eAAgB,CACrC0B,MAAO3D,KAAK2D,MACZ0C,SAAS,EACTlC,QAASnE,OAEXA,KAAKuD,SAAStB,SAAS,YAAa,CAClC0B,MAAO3D,KAAK2D,MACZQ,QAASnE,OAGf,CAMA,SAAAsG,GACE,OAAOtG,KAAKuD,SAASjC,aAAa,mBAAoBtB,KAAKkE,QAAUtG,EAAWE,QAASkC,KAC3F,CAMA,OAAAqG,GACE,OAAOrG,KAAKkE,QAAUtG,EAAWI,KACnC,CAMA,cAAAiH,GACE,MAAqB,UAAdjF,KAAKF,IACd,CASA,gBAAAgD,CAAiBpF,EAAOC,GACtB,GAAKqC,KAAKwC,UAINxC,KAAK0D,aACP1D,KAAK0D,YAAYZ,iBAAiBpF,EAAOC,IAGvCqC,KAAKuD,SAAStB,SAAS,gBAAiB,CAC1CkC,QAASnE,KACTtC,QACAC,WACCsC,mBAIH3C,EAAe0C,KAAKwC,QAAS9E,EAAOC,GAEhCqC,KAAKiF,mBAAqBjF,KAAKqG,YAAW,CAC5C,MAAME,GAAuBvG,KAAK4D,qBAAuBlG,EACzDsC,KAAK4D,oBAAsBlG,EAC3BsC,KAAK6D,qBAAuBlG,EAExB4I,EACFvG,KAAKkF,WAAU,GAEflF,KAAKyF,oBAGHzF,KAAK2D,OACP3D,KAAKuD,SAAStB,SAAS,kBAAmB,CACxC0B,MAAO3D,KAAK2D,MACZjG,QACAC,SACAwG,QAASnE,MAGf,CACF,CAMA,UAAAwG,GACE,OAAOxG,KAAKuD,SAASjC,aAAa,oBAAqBtB,KAAKiF,kBAAoBjF,KAAKkE,QAAUtG,EAAWI,MAAOgC,KACnH,CAMA,iBAAAyF,GAME,IAAKzF,KAAKiF,mBAAqBjF,KAAKwC,UAAYxC,KAAKyD,KAAKiC,OACxD,OAGF,MAAMe,EAENzG,KAAKwC,QACCkE,EAAa1G,KAAKuD,SAASjC,aAAa,mBAAoBtB,KAAK4D,oBAAqB5D,QAEvFyG,EAAME,QAAQC,iBAAmBF,EAAaG,SAASJ,EAAME,QAAQC,gBAAiB,OACzFH,EAAMK,MAAQJ,EAAa,KAC3BD,EAAME,QAAQC,gBAAkBG,OAAOL,GAE3C,CAMA,cAAAhC,GACE,OAAO1E,KAAKuD,SAASjC,aAAa,wBAAyBtB,KAAKiF,iBAAkBjF,KACpF,CAMA,QAAAgH,GACMhH,KAAKuD,SAAStB,SAAS,kBAAmB,CAC5CkC,QAASnE,OACRC,kBAIHD,KAAKuE,MAAK,EACZ,CAMA,eAAAF,GACE,OAAOrE,KAAKuD,SAASjC,aAAa,uBAAwBtB,KAAKsG,YAAatG,KAC9E,CAMA,OAAAiD,GACEjD,KAAKgE,UAAW,EAChBhE,KAAK2D,WAAQtG,EAET2C,KAAKuD,SAAStB,SAAS,iBAAkB,CAC3CkC,QAASnE,OACRC,mBAIHD,KAAKoD,SAEDpD,KAAK0D,cACP1D,KAAK0D,YAAYT,UACjBjD,KAAK0D,iBAAcrG,GAGjB2C,KAAKiF,kBAAoBjF,KAAKwC,UAChCxC,KAAKwC,QAAQqD,OAAS,KACtB7F,KAAKwC,QAAQsD,QAAU,KACvB9F,KAAKwC,aAAUnF,GAEnB,CAMA,YAAA+I,GACE,GAAIpG,KAAK2D,MAAO,CACd,IAAIsD,EAAuBC,EAE3B,IAAIC,EAAa1K,EAAc,kBAAmB,OAClD0K,EAAWC,UAAoL,QAAvKH,EAA6E,QAApDC,EAAyBlH,KAAKuD,SAAS9C,eAAgD,IAA3ByG,OAAoC,EAASA,EAAuBG,gBAAgD,IAA1BJ,EAAmCA,EAAwB,GAClQE,EAEAnH,KAAKuD,SAASjC,aAAa,sBAAuB6F,EAAYnH,MAC9DA,KAAKwC,QAAU/F,EAAc,0CAA2C,OACxEuD,KAAKwC,QAAQzF,YAAYoK,GACzBnH,KAAK2D,MAAMpB,UAAU6E,UAAY,GACjCpH,KAAK2D,MAAMpB,UAAUxF,YAAYiD,KAAKwC,SACtCxC,KAAK2D,MAAM0B,mBAAkB,GAC7BrF,KAAKoE,mBACP,CACF,CAMA,MAAA+B,GACE,GAAInG,KAAK+D,aAAe/D,KAAKwC,QAC3B,OAKF,GAFAxC,KAAK+D,YAAa,EAEd/D,KAAKkE,QAAUtG,EAAWI,MAE5B,YADAgC,KAAKoG,eAIP,GAAIpG,KAAKuD,SAAStB,SAAS,gBAAiB,CAC1CkC,QAASnE,OACRC,iBACD,OAGF,MAAMqH,EAAkB,WAAYtH,KAAKwC,QAErCxC,KAAKiF,iBAaHqC,GAAkBtH,KAAK2D,SAAW3D,KAAK2D,MAAMsC,UAAYzG,MAC3DQ,KAAKiE,YAAa,EAKlBjE,KAAKwC,QAAQ+E,SAASC,OAAM,SAAUC,SAAQ,KAC5CzH,KAAKiE,YAAa,EAClBjE,KAAK0H,aAAa,KAGpB1H,KAAK0H,cAEE1H,KAAK2D,QAAU3D,KAAKwC,QAAQW,YACrCnD,KAAK2D,MAAMpB,UAAUxF,YAAYiD,KAAKwC,QAE1C,CAQA,QAAAmF,IACM3H,KAAKuD,SAAStB,SAAS,kBAAmB,CAC5CkC,QAASnE,OACRC,kBAAqBD,KAAK2D,QAIzB3D,KAAKiF,kBAAoBjF,KAAKiE,aAAezE,IAG/CQ,KAAK0H,cACI1H,KAAKqG,WACdrG,KAAKuE,MAAK,GAAO,GAGfvE,KAAK2D,MAAMiE,eACb5H,KAAK2D,MAAMiE,cAAc/E,aAAa,cAAe,SAEzD,CAMA,UAAAgF,GACE7H,KAAKuD,SAAStB,SAAS,oBAAqB,CAC1CkC,QAASnE,OAGPA,KAAK2D,OAAS3D,KAAK2D,MAAMiE,eAC3B5H,KAAK2D,MAAMiE,cAAc/E,aAAa,cAAe,OAEzD,CAMA,MAAAO,GACEpD,KAAK+D,YAAa,EAEd/D,KAAKuD,SAAStB,SAAS,gBAAiB,CAC1CkC,QAASnE,OACRC,mBAICD,KAAKwC,SAAWxC,KAAKwC,QAAQW,YAC/BnD,KAAKwC,QAAQY,SAGXpD,KAAK0D,aAAe1D,KAAK0D,YAAYlB,SACvCxC,KAAK0D,YAAYlB,QAAQY,SAE7B,CAMA,WAAAsE,GACO1H,KAAK+D,aAIN/D,KAAKuD,SAAStB,SAAS,qBAAsB,CAC/CkC,QAASnE,OACRC,mBAKCD,KAAK2D,OAAS3D,KAAKwC,UAAYxC,KAAKwC,QAAQW,YAC9CnD,KAAK2D,MAAMpB,UAAUxF,YAAYiD,KAAKwC,SAGpCxC,KAAKkE,QAAUtG,EAAWG,QAAUiC,KAAKkE,QAAUtG,EAAWI,OAChEgC,KAAKoE,qBAET,EAiBF,SAAS0D,EAAgBrH,EAASD,GAChC,GAAIC,EAAQsH,kBAAmB,CAC7B,MAAMC,EAAkBvH,EAAQsH,kBAAkBtH,EAASD,GAE3D,GAAIwH,EACF,OAAOA,CAEX,CAEA,MAAO,CACL/K,EAAGH,SAASmL,gBAAgBC,YAK5BhL,EAAGiL,OAAOC,YAEd,CAqCA,SAASC,EAAmBC,EAAM7H,EAAS8H,EAAcjF,EAAUE,GACjE,IAAIgF,EAAe,EAEnB,GAAI/H,EAAQgI,UACVD,EAAe/H,EAAQgI,UAAUF,EAAcjF,EAAUE,GAAO8E,QAC3D,GAAI7H,EAAQiI,QACjBF,EAAe/H,EAAQiI,QAAQJ,OAC1B,CACL,MAAMK,EAAiB,UAAYL,EAAK,GAAGM,cAAgBN,EAAKO,MAAM,GAElEpI,EAAQkI,KAEVH,EAAe/H,EAAQkI,GAE3B,CAEA,OAAO7E,OAAO0E,IAAiB,CACjC,CASA,SAASM,EAAerI,EAAS8H,EAAcjF,EAAUE,GACvD,MAAO,CACLvG,EAAGsL,EAAatL,EAAIoL,EAAmB,OAAQ5H,EAAS8H,EAAcjF,EAAUE,GAAS6E,EAAmB,QAAS5H,EAAS8H,EAAcjF,EAAUE,GACtJtG,EAAGqL,EAAarL,EAAImL,EAAmB,MAAO5H,EAAS8H,EAAcjF,EAAUE,GAAS6E,EAAmB,SAAU5H,EAAS8H,EAAcjF,EAAUE,GAE1J,CAEA,MAAMuF,EAAkB,IAgBxB,MAAMC,EAOJ,WAAAnJ,CAAYY,EAAS6C,EAAUE,EAAOhD,GACpCR,KAAKQ,KAAOA,EACZR,KAAKS,QAAUA,EACfT,KAAKsD,SAAWA,EAChBtD,KAAKwD,MAAQA,EAGbxD,KAAKiJ,YAAc,KAGnBjJ,KAAKkJ,YAAc,KACnBlJ,KAAKmJ,IAAM,EACXnJ,KAAKoJ,KAAO,EACZpJ,KAAKqJ,MAAQ,EACbrJ,KAAKsJ,QAAU,EACftJ,KAAKuJ,UAAY,EACjBvJ,KAAKwJ,IAAM,EACXxJ,KAAKyJ,IAAM,CACb,CAYA,MAAAC,CAAOC,EAAUC,EAAWX,GAE1B,MAAMC,EAAc,CAClBjM,EAAG0M,EACHzM,EAAG0M,GAEL5J,KAAKkJ,YAAcA,EACnBlJ,KAAKiJ,YAAcA,EACnB,MAAMY,EAASZ,EAAYhM,EAAIiM,EAAYjM,EACrC6M,EAASb,EAAY/L,EAAIgM,EAAYhM,EAC3C8C,KAAKmJ,IAAMY,KAAKN,IAAI,EAAGI,EAASC,EAASD,EAASC,GAClD9J,KAAKoJ,KAAOW,KAAKN,IAAI,EAAGI,EAASC,EAASD,EAASC,GAGnD9J,KAAKqJ,MAAQU,KAAKN,IAAI,EAAGK,GACzB9J,KAAKsJ,QAAUtJ,KAAKgK,cACpBhK,KAAKuJ,UAAYvJ,KAAKiK,gBACtBjK,KAAKwJ,IAAMO,KAAKP,IAAIxJ,KAAKsJ,QAAStJ,KAAKuJ,UAAWvJ,KAAKkK,WACvDlK,KAAKyJ,IAAMM,KAAKN,IAAIzJ,KAAKmJ,IAAKnJ,KAAKsJ,QAAStJ,KAAKuJ,WAE7CvJ,KAAKQ,MACPR,KAAKQ,KAAKyB,SAAS,mBAAoB,CACrCkI,WAAYnK,KACZoK,UAAWpK,KAAKsD,UAGtB,CAUA,qBAAA+G,CAAsBC,GACpB,MAAMC,EAEND,EAAe,YACTE,EAAcxK,KAAKS,QAAQ8J,GAEjC,GAAKC,EAIL,MAA2B,oBAAhBA,EACFA,EAAYxK,MAGD,SAAhBwK,EACKxK,KAAKoJ,KAGM,QAAhBoB,EACKxK,KAAKmJ,IAGPrF,OAAO0G,EAChB,CAYA,aAAAP,GACE,IAAIQ,EAAgBzK,KAAKqK,sBAAsB,aAE/C,OAAII,IAKJA,EAAgBV,KAAKN,IAAI,EAAc,EAAXzJ,KAAKmJ,KAE7BnJ,KAAKkJ,aAAeuB,EAAgBzK,KAAKkJ,YAAYjM,EAAI8L,IAC3D0B,EAAgB1B,EAAkB/I,KAAKkJ,YAAYjM,GAG9CwN,EACT,CASA,WAAAT,GACE,OAAOhK,KAAKqK,sBAAsB,YAAcrK,KAAKmJ,GACvD,CAWA,OAAAe,GAGE,OAAOlK,KAAKqK,sBAAsB,QAAUN,KAAKP,IAAI,EAAc,EAAXxJ,KAAKmJ,IAC/D,EAeF,SAASuB,EAAapH,EAAUC,EAAUC,GACxC,MAAMW,EAAUZ,EAASoH,sBAAsBrH,EAAUE,GAGzD,IAAIoH,EACJ,MAAM,QACJnK,GACE8C,EAGJ,GAAI9C,EAAS,CAEX,IAAI8H,EADJqC,EAAY,IAAI5B,EAAUvI,EAAS6C,GAAW,GAI5CiF,EADEhF,EAAS/C,KACI+C,EAAS/C,KAAK+H,aAEdT,EAAgBrH,EAAS8C,GAG1C,MAAM0F,EAAcH,EAAerI,EAAS8H,EAAcjF,EAAUE,GACpEoH,EAAUlB,OAAOvF,EAAQzG,MAAOyG,EAAQxG,OAAQsL,EAClD,CAQA,OANA9E,EAAQ6C,WAEJ4D,GACFzG,EAAQrB,iBAAiBiH,KAAKc,KAAK1G,EAAQzG,MAAQkN,EAAUtB,SAAUS,KAAKc,KAAK1G,EAAQxG,OAASiN,EAAUtB,UAGvGnF,CACT,CAaA,SAAS2G,EAActH,EAAOD,GAC5B,MAAMD,EAAWC,EAASwH,YAAYvH,GAEtC,IAAID,EAAStB,SAAS,gBAAiB,CACrCuB,QACAF,aACCrD,iBAIH,OAAOyK,EAAapH,EAAUC,EAAUC,EAC1C,CAWA,MAAMwH,UAAuB3K,EAM3B,WAAA4K,GACE,IAAIC,EAEJ,IAAIC,EAAW,EACf,MAAMC,EAAgD,QAAlCF,EAAgBlL,KAAKS,eAAuC,IAAlByK,OAA2B,EAASA,EAAcE,WAE5GA,GAAc,WAAYA,EAE5BD,EAAWC,EAAWC,OACbD,GAAc,YAAaA,IAE/BA,EAAWE,QACdF,EAAWE,MAAQtL,KAAKuL,uBAAuBH,EAAWI,UAGxDJ,EAAWE,QACbH,EAAWC,EAAWE,MAAMD,SAKhC,MAAMlJ,EAAQnC,KAAKiC,SAAS,WAAY,CACtCmJ,aACAD,aAEF,OAAOnL,KAAKsB,aAAa,WAAYa,EAAMgJ,SAAUC,EACvD,CAQA,qBAAAT,CAAsBP,EAAW5G,GAC/B,OAAO,IAAIH,EAAQ+G,EAAWpK,KAAMwD,EACtC,CAaA,WAAAuH,CAAYvH,GACV,IAAIiI,EAEJ,MAAML,EAAiD,QAAnCK,EAAiBzL,KAAKS,eAAwC,IAAnBgL,OAA4B,EAASA,EAAeL,WAGnH,IAAIM,EAAiB,CAAC,EAElB3M,MAAMC,QAAQoM,GAEhBM,EAAiBN,EAAW5H,GACnB4H,GAAc,YAAaA,IAK/BA,EAAWE,QACdF,EAAWE,MAAQtL,KAAKuL,uBAAuBH,EAAWI,UAG5DE,EAAiBN,EAAWE,MAAM9H,IAGpC,IAAIF,EAAWoI,EAEXpI,aAAoBzE,UACtByE,EAAWtD,KAAK2L,sBAAsBrI,IAKxC,MAAMnB,EAAQnC,KAAKiC,SAAS,WAAY,CACtCqB,SAAUA,GAAY,CAAC,EACvBE,UAEF,OAAOxD,KAAKsB,aAAa,WAAYa,EAAMmB,SAAUE,EACvD,CAUA,sBAAA+H,CAAuBK,GACrB,IAAIC,EAAgBC,EAEpB,OAAwC,QAAnCD,EAAiB7L,KAAKS,eAAwC,IAAnBoL,GAA6BA,EAAeE,UAAgD,QAAnCD,EAAiB9L,KAAKS,eAAwC,IAAnBqL,GAA6BA,EAAeE,cACvLxN,EAAsBwB,KAAKS,QAAQsL,SAAU/L,KAAKS,QAAQuL,cAAeJ,IAAmB,GAG9F,CAACA,EACV,CASA,qBAAAD,CAAsBnJ,GAEpB,MAAMc,EAAW,CACfd,WAEIyJ,EAEc,MAApBzJ,EAAQ7F,QAAkB6F,EAAUA,EAAQ0J,cAAc,KAE1D,GAAID,EAAQ,CAGV3I,EAASV,IAAMqJ,EAAOtF,QAAQwF,SAAWF,EAAOG,KAE5CH,EAAOtF,QAAQ0F,aACjB/I,EAASoC,OAASuG,EAAOtF,QAAQ0F,YAGnC/I,EAAS5F,MAAQuO,EAAOtF,QAAQ2F,UAAYzF,SAASoF,EAAOtF,QAAQ2F,UAAW,IAAM,EACrFhJ,EAAS3F,OAASsO,EAAOtF,QAAQ4F,WAAa1F,SAASoF,EAAOtF,QAAQ4F,WAAY,IAAM,EAExFjJ,EAAS/F,EAAI+F,EAAS5F,MACtB4F,EAAS9F,EAAI8F,EAAS3F,OAElBsO,EAAOtF,QAAQ6F,WACjBlJ,EAASxD,KAAOmM,EAAOtF,QAAQ6F,UAGjC,MAAMC,EAAcjK,EAAQ0J,cAAc,OAGxC,IAAIQ,EADN,GAAID,EAKFnJ,EAASyB,KAAO0H,EAAYE,YAAcF,EAAY7J,IACtDU,EAASX,IAAoE,QAA7D+J,EAAwBD,EAAYG,aAAa,cAA8C,IAA1BF,EAAmCA,EAAwB,IAG9IT,EAAOtF,QAAQkG,aAAeZ,EAAOtF,QAAQmG,WAC/CxJ,EAASyJ,cAAe,EAE5B,CAEA,OAAO/M,KAAKsB,aAAa,cAAegC,EAAUd,EAASyJ,EAC7D,CAUA,YAAAvB,CAAapH,EAAUE,GACrB,OAAOkH,EAAapH,EAAUtD,KAAMwD,EACtC,EA4CF,MAAMwJ,UAA2BhC,EAI/B,WAAAnL,CAAYY,GACVwM,QAGAjN,KAAKS,QAAUA,GAAW,CAAC,EAC3BT,KAAKkN,KAAO,EACZlN,KAAKmN,YAAa,EAMlBnN,KAAKoN,uBAAoB/P,EACzB2C,KAAKqN,kBAAoBrN,KAAKqN,kBAAkBC,KAAKtN,KACvD,CAOA,IAAAuN,GAEE/O,EAAsBwB,KAAKS,QAAQ+K,QAASxL,KAAKS,QAAQ+M,iBAAiB/L,SAAQmK,IAChFA,EAAe6B,iBAAiB,QAASzN,KAAKqN,mBAAmB,EAAM,GAE3E,CAMA,iBAAAA,CAAkBnP,GAEhB,GAAID,EAAeC,IAChBiK,OAAO3H,KAER,OAYF,IAAIkN,EAAe,CACjBzQ,EAAGiB,EAAEyP,QACLzQ,EAAGgB,EAAE0P,SAGFF,EAAazQ,GAAMyQ,EAAaxQ,IACnCwQ,EAAe,MAGjB,IAAIG,EAAe7N,KAAK8N,gBAAgB5P,GACxC2P,EAAe7N,KAAKsB,aAAa,eAAgBuM,EAAc3P,EAAG8B,MAGlE,MAAMoL,EAAa,CACjBI,QAEAtN,EAAE6P,eAGAF,GAAgB,IAClB3P,EAAEkC,iBACFJ,KAAKgO,YAAYH,EAAczC,EAAYsC,GAE/C,CASA,eAAAI,CAAgB5P,GAEd,GAAI8B,KAAKS,QAAQwN,kBACf,OAAOjO,KAAKS,QAAQwN,kBAAkB7L,KAAKpC,KAAM9B,GAGnD,MAAMgQ,EAENhQ,EAAEiQ,OACIC,EAAgB5P,EAAsBwB,KAAKS,QAAQsL,SAAU/L,KAAKS,QAAQuL,cAEhF9N,EAAE6P,eACIM,EAAoBD,EAAcE,WAAUC,GAASA,IAAUL,GAAiBK,EAAMC,SAASN,KAErG,OAA2B,IAAvBG,EACKA,EACErO,KAAKS,QAAQsL,UAAY/L,KAAKS,QAAQuL,eAEvC,EAIH,CACT,CAWA,WAAAgC,CAAYxK,EAAO4H,EAAYsC,GAE7B,GAAIvF,OAAO3H,OAASR,KAAKS,QACvB,OAAO,EAIT,IAAK2K,GAAcpL,KAAKS,QAAQ+K,SAAWxL,KAAKS,QAAQsL,SAAU,CAChE,MAAM0C,EAAkBjQ,EAAsBwB,KAAKS,QAAQ+K,SAEvDiD,EAAgB,KAClBrD,EAAa,CACXI,QAASiD,EAAgB,IAG/B,CAQA,OALAzO,KAAKS,QAAQ+C,MAAQA,EAErBxD,KAAKS,QAAQiO,kBAAoBhB,EACjC1N,KAAKmN,YAAa,EAClBnN,KAAK2O,QAAQnL,EAAO4H,IACb,CACT,CASA,OAAAuD,CAAQnL,EAAO4H,GACb,MAAM,QACJ3K,GACET,KAEAoL,IACF3K,EAAQ2K,WAAaA,GAMvB,MAAMwD,EAAe,GACfC,SAAwBpO,EAAQqO,WAEtC,GAAI1P,EAAYqB,EAAQqO,YACtBF,EAAa5N,KAAK+N,QAAQC,QAE1BvO,EAAQqO,iBACH,IAAuB,WAAnBD,EACT,MAAM,IAAII,MAAM,+CACX,GAAuB,aAAnBJ,EAKT,MAAM,IAAII,MAAM,2BAJhBL,EAAa5N,KAEbP,EAAQqO,aAGV,CAGmC,oBAAxBrO,EAAQyO,aAEjBN,EAAa5N,KAAKP,EAAQyO,gBAGM,IAA9BzO,EAAQ0O,mBAA+B3L,GAAS,IAClDxD,KAAKoN,kBAAoBtC,EAActH,EAAOxD,OAIhD,MAAMoP,IAAQpP,KAAKkN,KACnB6B,QAAQM,IAAIT,GAAcU,MAAKC,IAC7B,GAAIvP,KAAKmN,WAAY,CACnB,MAAMqC,EAAaD,EAAgB,GAEnCvP,KAAKyP,gBAAgBD,EAAYJ,EACnC,IAEJ,CAQA,eAAAK,CAAgBC,EAAQN,GAMtB,GAAIA,IAAQpP,KAAKkN,MAAQlN,KAAKmN,WAC5B,OAKF,GAFAnN,KAAKmN,YAAa,EAEdhF,OAAO3H,KACT,OASF,MAAMA,EAAyB,kBAAXkP,EAAsB,IAAIA,EAAOC,QAAQ3P,KAAKS,SAChE,IAAIiP,EAAO1P,KAAKS,SAElBT,KAAKQ,KAAOA,EACZ2H,OAAO3H,KAAOA,EAIdN,OAAO0P,KAAK5P,KAAKM,YAAYmB,SAAQd,IACnC,IAAIiB,EAEgD,QAAnDA,EAAwB5B,KAAKM,WAAWK,UAA6C,IAA1BiB,GAAoCA,EAAsBH,SAAQpC,IAC5HmB,EAAKmB,GAAGhB,EAERtB,EAAG,GACH,IAKJa,OAAO0P,KAAK5P,KAAKO,UAAUkB,SAAQd,IACjC,IAAIE,EAE4C,QAA/CA,EAAsBb,KAAKO,SAASI,UAA2C,IAAxBE,GAAkCA,EAAoBY,SAAQJ,IACpHb,EAAKE,UAAUC,EAAMU,EAAOhC,GAAIgC,EAAOT,SAAS,GAChD,IAGAZ,KAAKoN,oBACP5M,EAAKqP,cAAcC,WAAW9P,KAAKoN,mBACnCpN,KAAKoN,uBAAoB/P,GAG3BmD,EAAKmB,GAAG,WAAW,KAEjB3B,KAAKQ,UAAOnD,SACL8K,OAAO3H,IAAI,IAEpBA,EAAK+M,MACP,CAMA,OAAAtK,GACE,IAAIlC,EAEyB,QAA5BA,EAAaf,KAAKQ,YAAiC,IAAfO,GAAyBA,EAAWkC,UACzEjD,KAAKmN,YAAa,EAClBnN,KAAKM,WAAa,CAAC,EACnB9B,EAAsBwB,KAAKS,QAAQ+K,QAASxL,KAAKS,QAAQ+M,iBAAiB/L,SAAQmK,IAChFA,EAAemE,oBAAoB,QAAS/P,KAAKqN,mBAAmB,EAAM,GAE9E,E","sources":["webpack://@sazka/web/./node_modules/photoswipe/dist/photoswipe-lightbox.esm.js"],"sourcesContent":["/*!\n * PhotoSwipe Lightbox 5.4.4 - https://photoswipe.com\n * (c) 2024 Dmytro Semenov\n */\n/** @typedef {import('../photoswipe.js').Point} Point */\n\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 */\nfunction createElement(className, tagName, appendToEl) {\n const el = document.createElement(tagName);\n\n if (className) {\n el.className = className;\n }\n\n if (appendToEl) {\n appendToEl.appendChild(el);\n }\n\n return el;\n}\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 */\n\nfunction toTransformString(x, y, scale) {\n let propValue = `translate3d(${x}px,${y || 0}px,0)`;\n\n if (scale !== undefined) {\n propValue += ` scale3d(${scale},${scale},1)`;\n }\n\n return propValue;\n}\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 */\n\nfunction setWidthHeight(el, w, h) {\n el.style.width = typeof w === 'number' ? `${w}px` : w;\n el.style.height = typeof h === 'number' ? `${h}px` : h;\n}\n/** @typedef {LOAD_STATE[keyof LOAD_STATE]} LoadState */\n\n/** @type {{ IDLE: 'idle'; LOADING: 'loading'; LOADED: 'loaded'; ERROR: 'error' }} */\n\nconst LOAD_STATE = {\n IDLE: 'idle',\n LOADING: 'loading',\n LOADED: 'loaded',\n ERROR: 'error'\n};\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 */\n\nfunction specialKeyUsed(e) {\n return 'button' in e && e.button === 1 || e.ctrlKey || e.metaKey || e.altKey || e.shiftKey;\n}\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 */\n\nfunction getElementsFromOption(option, legacySelector, parent = document) {\n /** @type {HTMLElement[]} */\n let elements = [];\n\n if (option instanceof Element) {\n elements = [option];\n } else if (option instanceof NodeList || Array.isArray(option)) {\n elements = Array.from(option);\n } else {\n const selector = typeof option === 'string' ? option : legacySelector;\n\n if (selector) {\n elements = Array.from(parent.querySelectorAll(selector));\n }\n }\n\n return elements;\n}\n/**\r\n * Check if variable is PhotoSwipe class\r\n *\r\n * @param {any} fn\r\n * @returns {boolean}\r\n */\n\nfunction isPswpClass(fn) {\n return typeof fn === 'function' && fn.prototype && fn.prototype.goTo;\n}\n/**\r\n * Check if browser is Safari\r\n *\r\n * @returns {boolean}\r\n */\n\nfunction isSafari() {\n return !!(navigator.vendor && navigator.vendor.match(/apple/i));\n}\n\n/** @typedef {import('../lightbox/lightbox.js').default} PhotoSwipeLightbox */\n\n/** @typedef {import('../photoswipe.js').default} PhotoSwipe */\n\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\n\n/** @typedef {import('../photoswipe.js').DataSource} DataSource */\n\n/** @typedef {import('../ui/ui-element.js').UIElementData} UIElementData */\n\n/** @typedef {import('../slide/content.js').default} ContentDefault */\n\n/** @typedef {import('../slide/slide.js').default} Slide */\n\n/** @typedef {import('../slide/slide.js').SlideData} SlideData */\n\n/** @typedef {import('../slide/zoom-level.js').default} ZoomLevel */\n\n/** @typedef {import('../slide/get-thumb-bounds.js').Bounds} Bounds */\n\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<string, any>} Content\r\n */\n\n/** @typedef {{ x?: number; y?: number }} Point */\n\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 */\n\n/**\r\n * @typedef {Object} PhotoSwipeFiltersMap https://photoswipe.com/filters/\r\n *\r\n * @prop {(numItems: number, dataSource: DataSource | undefined) => number} numItems\r\n * Modify the total amount of slides. Example on Data sources page.\r\n * https://photoswipe.com/filters/#numitems\r\n *\r\n * @prop {(itemData: SlideData, index: number) => SlideData} itemData\r\n * Modify slide item data. Example on Data sources page.\r\n * https://photoswipe.com/filters/#itemdata\r\n *\r\n * @prop {(itemData: SlideData, element: HTMLElement, linkEl: HTMLAnchorElement) => SlideData} domItemData\r\n * Modify item data when it's parsed from DOM element. Example on Data sources page.\r\n * https://photoswipe.com/filters/#domitemdata\r\n *\r\n * @prop {(clickedIndex: number, e: MouseEvent, instance: PhotoSwipeLightbox) => number} clickedIndex\r\n * Modify clicked gallery item index.\r\n * https://photoswipe.com/filters/#clickedindex\r\n *\r\n * @prop {(placeholderSrc: string | false, content: Content) => string | false} placeholderSrc\r\n * Modify placeholder image source.\r\n * https://photoswipe.com/filters/#placeholdersrc\r\n *\r\n * @prop {(isContentLoading: boolean, content: Content) => boolean} isContentLoading\r\n * Modify if the content is currently loading.\r\n * https://photoswipe.com/filters/#iscontentloading\r\n *\r\n * @prop {(isContentZoomable: boolean, content: Content) => boolean} isContentZoomable\r\n * Modify if the content can be zoomed.\r\n * https://photoswipe.com/filters/#iscontentzoomable\r\n *\r\n * @prop {(useContentPlaceholder: boolean, content: Content) => boolean} useContentPlaceholder\r\n * Modify if the placeholder should be used for the content.\r\n * https://photoswipe.com/filters/#usecontentplaceholder\r\n *\r\n * @prop {(isKeepingPlaceholder: boolean, content: Content) => boolean} isKeepingPlaceholder\r\n * Modify if the placeholder should be kept after the content is loaded.\r\n * https://photoswipe.com/filters/#iskeepingplaceholder\r\n *\r\n *\r\n * @prop {(contentErrorElement: HTMLElement, content: Content) => HTMLElement} contentErrorElement\r\n * Modify an element when the content has error state (for example, if image cannot be loaded).\r\n * https://photoswipe.com/filters/#contenterrorelement\r\n *\r\n * @prop {(element: HTMLElement, data: UIElementData) => HTMLElement} uiElement\r\n * Modify a UI element that's being created.\r\n * https://photoswipe.com/filters/#uielement\r\n *\r\n * @prop {(thumbnail: HTMLElement | null | undefined, itemData: SlideData, index: number) => HTMLElement} thumbEl\r\n * Modify the thumbnail element from which opening zoom animation starts or ends.\r\n * https://photoswipe.com/filters/#thumbel\r\n *\r\n * @prop {(thumbBounds: Bounds | undefined, itemData: SlideData, index: number) => Bounds} thumbBounds\r\n * Modify the thumbnail bounds from which opening zoom animation starts or ends.\r\n * https://photoswipe.com/filters/#thumbbounds\r\n *\r\n * @prop {(srcsetSizesWidth: number, content: Content) => number} srcsetSizesWidth\r\n *\r\n * @prop {(preventPointerEvent: boolean, event: PointerEvent, pointerType: string) => boolean} preventPointerEvent\r\n *\r\n */\n\n/**\r\n * @template {keyof PhotoSwipeFiltersMap} T\r\n * @typedef {{ fn: PhotoSwipeFiltersMap[T], priority: number }} Filter\r\n */\n\n/**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @typedef {PhotoSwipeEventsMap[T] extends undefined ? PhotoSwipeEvent<T> : PhotoSwipeEvent<T> & PhotoSwipeEventsMap[T]} AugmentedEvent\r\n */\n\n/**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @typedef {(event: AugmentedEvent<T>) => void} EventCallback\r\n */\n\n/**\r\n * Base PhotoSwipe event object\r\n *\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n */\nclass PhotoSwipeEvent {\n /**\r\n * @param {T} type\r\n * @param {PhotoSwipeEventsMap[T]} [details]\r\n */\n constructor(type, details) {\n this.type = type;\n this.defaultPrevented = false;\n\n if (details) {\n Object.assign(this, details);\n }\n }\n\n preventDefault() {\n this.defaultPrevented = true;\n }\n\n}\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 */\n\n\nclass Eventable {\n constructor() {\n /**\r\n * @type {{ [T in keyof PhotoSwipeEventsMap]?: ((event: AugmentedEvent<T>) => void)[] }}\r\n */\n this._listeners = {};\n /**\r\n * @type {{ [T in keyof PhotoSwipeFiltersMap]?: Filter<T>[] }}\r\n */\n\n this._filters = {};\n /** @type {PhotoSwipe | undefined} */\n\n this.pswp = undefined;\n /** @type {PhotoSwipeOptions | undefined} */\n\n this.options = undefined;\n }\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 */\n\n\n addFilter(name, fn, priority = 100) {\n var _this$_filters$name, _this$_filters$name2, _this$pswp;\n\n if (!this._filters[name]) {\n this._filters[name] = [];\n }\n\n (_this$_filters$name = this._filters[name]) === null || _this$_filters$name === void 0 || _this$_filters$name.push({\n fn,\n priority\n });\n (_this$_filters$name2 = this._filters[name]) === null || _this$_filters$name2 === void 0 || _this$_filters$name2.sort((f1, f2) => f1.priority - f2.priority);\n (_this$pswp = this.pswp) === null || _this$pswp === void 0 || _this$pswp.addFilter(name, fn, priority);\n }\n /**\r\n * @template {keyof PhotoSwipeFiltersMap} T\r\n * @param {T} name\r\n * @param {PhotoSwipeFiltersMap[T]} fn\r\n */\n\n\n removeFilter(name, fn) {\n if (this._filters[name]) {\n // @ts-expect-error\n this._filters[name] = this._filters[name].filter(filter => filter.fn !== fn);\n }\n\n if (this.pswp) {\n this.pswp.removeFilter(name, fn);\n }\n }\n /**\r\n * @template {keyof PhotoSwipeFiltersMap} T\r\n * @param {T} name\r\n * @param {Parameters<PhotoSwipeFiltersMap[T]>} args\r\n * @returns {Parameters<PhotoSwipeFiltersMap[T]>[0]}\r\n */\n\n\n applyFilters(name, ...args) {\n var _this$_filters$name3;\n\n (_this$_filters$name3 = this._filters[name]) === null || _this$_filters$name3 === void 0 || _this$_filters$name3.forEach(filter => {\n // @ts-expect-error\n args[0] = filter.fn.apply(this, args);\n });\n return args[0];\n }\n /**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @param {T} name\r\n * @param {EventCallback<T>} fn\r\n */\n\n\n on(name, fn) {\n var _this$_listeners$name, _this$pswp2;\n\n if (!this._listeners[name]) {\n this._listeners[name] = [];\n }\n\n (_this$_listeners$name = this._listeners[name]) === null || _this$_listeners$name === void 0 || _this$_listeners$name.push(fn); // When binding events to lightbox,\n // also bind events to PhotoSwipe Core,\n // if it's open.\n\n (_this$pswp2 = this.pswp) === null || _this$pswp2 === void 0 || _this$pswp2.on(name, fn);\n }\n /**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @param {T} name\r\n * @param {EventCallback<T>} fn\r\n */\n\n\n off(name, fn) {\n var _this$pswp3;\n\n if (this._listeners[name]) {\n // @ts-expect-error\n this._listeners[name] = this._listeners[name].filter(listener => fn !== listener);\n }\n\n (_this$pswp3 = this.pswp) === null || _this$pswp3 === void 0 || _this$pswp3.off(name, fn);\n }\n /**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @param {T} name\r\n * @param {PhotoSwipeEventsMap[T]} [details]\r\n * @returns {AugmentedEvent<T>}\r\n */\n\n\n dispatch(name, details) {\n var _this$_listeners$name2;\n\n if (this.pswp) {\n return this.pswp.dispatch(name, details);\n }\n\n const event =\n /** @type {AugmentedEvent<T>} */\n new PhotoSwipeEvent(name, details);\n (_this$_listeners$name2 = this._listeners[name]) === null || _this$_listeners$name2 === void 0 || _this$_listeners$name2.forEach(listener => {\n listener.call(this, event);\n });\n return event;\n }\n\n}\n\nclass Placeholder {\n /**\r\n * @param {string | false} imageSrc\r\n * @param {HTMLElement} container\r\n */\n constructor(imageSrc, container) {\n // Create placeholder\n // (stretched thumbnail or simple div behind the main image)\n\n /** @type {HTMLImageElement | HTMLDivElement | null} */\n this.element = createElement('pswp__img pswp__img--placeholder', imageSrc ? 'img' : 'div', container);\n\n if (imageSrc) {\n const imgEl =\n /** @type {HTMLImageElement} */\n this.element;\n imgEl.decoding = 'async';\n imgEl.alt = '';\n imgEl.src = imageSrc;\n imgEl.setAttribute('role', 'presentation');\n }\n\n this.element.setAttribute('aria-hidden', 'true');\n }\n /**\r\n * @param {number} width\r\n * @param {number} height\r\n */\n\n\n setDisplayedSize(width, height) {\n if (!this.element) {\n return;\n }\n\n if (this.element.tagName === 'IMG') {\n // Use transform scale() to modify img placeholder size\n // (instead of changing width/height directly).\n // This helps with performance, specifically in iOS15 Safari.\n setWidthHeight(this.element, 250, 'auto');\n this.element.style.transformOrigin = '0 0';\n this.element.style.transform = toTransformString(0, 0, width / 250);\n } else {\n setWidthHeight(this.element, width, height);\n }\n }\n\n destroy() {\n var _this$element;\n\n if ((_this$element = this.element) !== null && _this$element !== void 0 && _this$element.parentNode) {\n this.element.remove();\n }\n\n this.element = null;\n }\n\n}\n\n/** @typedef {import('./slide.js').default} Slide */\n\n/** @typedef {import('./slide.js').SlideData} SlideData */\n\n/** @typedef {import('../core/base.js').default} PhotoSwipeBase */\n\n/** @typedef {import('../util/util.js').LoadState} LoadState */\n\nclass Content {\n /**\r\n * @param {SlideData} itemData Slide data\r\n * @param {PhotoSwipeBase} instance PhotoSwipe or PhotoSwipeLightbox instance\r\n * @param {number} index\r\n */\n constructor(itemData, instance, index) {\n this.instance = instance;\n this.data = itemData;\n this.index = index;\n /** @type {HTMLImageElement | HTMLDivElement | undefined} */\n\n this.element = undefined;\n /** @type {Placeholder | undefined} */\n\n this.placeholder = undefined;\n /** @type {Slide | undefined} */\n\n this.slide = undefined;\n this.displayedImageWidth = 0;\n this.displayedImageHeight = 0;\n this.width = Number(this.data.w) || Number(this.data.width) || 0;\n this.height = Number(this.data.h) || Number(this.data.height) || 0;\n this.isAttached = false;\n this.hasSlide = false;\n this.isDecoding = false;\n /** @type {LoadState} */\n\n this.state = LOAD_STATE.IDLE;\n\n if (this.data.type) {\n this.type = this.data.type;\n } else if (this.data.src) {\n this.type = 'image';\n } else {\n this.type = 'html';\n }\n\n this.instance.dispatch('contentInit', {\n content: this\n });\n }\n\n removePlaceholder() {\n if (this.placeholder && !this.keepPlaceholder()) {\n // With delay, as image might be loaded, but not rendered\n setTimeout(() => {\n if (this.placeholder) {\n this.placeholder.destroy();\n this.placeholder = undefined;\n }\n }, 1000);\n }\n }\n /**\r\n * Preload content\r\n *\r\n * @param {boolean} isLazy\r\n * @param {boolean} [reload]\r\n */\n\n\n load(isLazy, reload) {\n if (this.slide && this.usePlaceholder()) {\n if (!this.placeholder) {\n const placeholderSrc = this.instance.applyFilters('placeholderSrc', // use image-based placeholder only for the first slide,\n // as rendering (even small stretched thumbnail) is an expensive operation\n this.data.msrc && this.slide.isFirstSlide ? this.data.msrc : false, this);\n this.placeholder = new Placeholder(placeholderSrc, this.slide.container);\n } else {\n const placeholderEl = this.placeholder.element; // Add placeholder to DOM if it was already created\n\n if (placeholderEl && !placeholderEl.parentElement) {\n this.slide.container.prepend(placeholderEl);\n }\n }\n }\n\n if (this.element && !reload) {\n return;\n }\n\n if (this.instance.dispatch('contentLoad', {\n content: this,\n isLazy\n }).defaultPrevented) {\n return;\n }\n\n if (this.isImageContent()) {\n this.element = createElement('pswp__img', 'img'); // Start loading only after width is defined, as sizes might depend on it.\n // Due to Safari feature, we must define sizes before srcset.\n\n if (this.displayedImageWidth) {\n this.loadImage(isLazy);\n }\n } else {\n this.element = createElement('pswp__content', 'div');\n this.element.innerHTML = this.data.html || '';\n }\n\n if (reload && this.slide) {\n this.slide.updateContentSize(true);\n }\n }\n /**\r\n * Preload image\r\n *\r\n * @param {boolean} isLazy\r\n */\n\n\n loadImage(isLazy) {\n var _this$data$src, _this$data$alt;\n\n if (!this.isImageContent() || !this.element || this.instance.dispatch('contentLoadImage', {\n content: this,\n isLazy\n }).defaultPrevented) {\n return;\n }\n\n const imageElement =\n /** @type HTMLImageElement */\n this.element;\n this.updateSrcsetSizes();\n\n if (this.data.srcset) {\n imageElement.srcset = this.data.srcset;\n }\n\n imageElement.src = (_this$data$src = this.data.src) !== null && _this$data$src !== void 0 ? _this$data$src : '';\n imageElement.alt = (_this$data$alt = this.data.alt) !== null && _this$data$alt !== void 0 ? _this$data$alt : '';\n this.state = LOAD_STATE.LOADING;\n\n if (imageElement.complete) {\n this.onLoaded();\n } else {\n imageElement.onload = () => {\n this.onLoaded();\n };\n\n imageElement.onerror = () => {\n this.onError();\n };\n }\n }\n /**\r\n * Assign slide to content\r\n *\r\n * @param {Slide} slide\r\n */\n\n\n setSlide(slide) {\n this.slide = slide;\n this.hasSlide = true;\n this.instance = slide.pswp; // todo: do we need to unset slide?\n }\n /**\r\n * Content load success handler\r\n */\n\n\n onLoaded() {\n this.state = LOAD_STATE.LOADED;\n\n if (this.slide && this.element) {\n this.instance.dispatch('loadComplete', {\n slide: this.slide,\n content: this\n }); // if content is reloaded\n\n if (this.slide.isActive && this.slide.heavyAppended && !this.element.parentNode) {\n this.append();\n this.slide.updateContentSize(true);\n }\n\n if (this.state === LOAD_STATE.LOADED || this.state === LOAD_STATE.ERROR) {\n this.removePlaceholder();\n }\n }\n }\n /**\r\n * Content load error handler\r\n */\n\n\n onError() {\n this.state = LOAD_STATE.ERROR;\n\n if (this.slide) {\n this.displayError();\n this.instance.dispatch('loadComplete', {\n slide: this.slide,\n isError: true,\n content: this\n });\n this.instance.dispatch('loadError', {\n slide: this.slide,\n content: this\n });\n }\n }\n /**\r\n * @returns {Boolean} If the content is currently loading\r\n */\n\n\n isLoading() {\n return this.instance.applyFilters('isContentLoading', this.state === LOAD_STATE.LOADING, this);\n }\n /**\r\n * @returns {Boolean} If the content is in error state\r\n */\n\n\n isError() {\n return this.state === LOAD_STATE.ERROR;\n }\n /**\r\n * @returns {boolean} If the content is image\r\n */\n\n\n isImageContent() {\n return this.type === 'image';\n }\n /**\r\n * Update content size\r\n *\r\n * @param {Number} width\r\n * @param {Number} height\r\n */\n\n\n setDisplayedSize(width, height) {\n if (!this.element) {\n return;\n }\n\n if (this.placeholder) {\n this.placeholder.setDisplayedSize(width, height);\n }\n\n if (this.instance.dispatch('contentResize', {\n content: this,\n width,\n height\n }).defaultPrevented) {\n return;\n }\n\n setWidthHeight(this.element, width, height);\n\n if (this.isImageContent() && !this.isError()) {\n const isInitialSizeUpdate = !this.displayedImageWidth && width;\n this.displayedImageWidth = width;\n this.displayedImageHeight = height;\n\n if (isInitialSizeUpdate) {\n this.loadImage(false);\n } else {\n this.updateSrcsetSizes();\n }\n\n if (this.slide) {\n this.instance.dispatch('imageSizeChange', {\n slide: this.slide,\n width,\n height,\n content: this\n });\n }\n }\n }\n /**\r\n * @returns {boolean} If the content can be zoomed\r\n */\n\n\n isZoomable() {\n return this.instance.applyFilters('isContentZoomable', this.isImageContent() && this.state !== LOAD_STATE.ERROR, this);\n }\n /**\r\n * Update image srcset sizes attribute based on width and height\r\n */\n\n\n updateSrcsetSizes() {\n // Handle srcset sizes attribute.\n //\n // Never lower quality, if it was increased previously.\n // Chrome does this automatically, Firefox and Safari do not,\n // so we store largest used size in dataset.\n if (!this.isImageContent() || !this.element || !this.data.srcset) {\n return;\n }\n\n const image =\n /** @type HTMLImageElement */\n this.element;\n const sizesWidth = this.instance.applyFilters('srcsetSizesWidth', this.displayedImageWidth, this);\n\n if (!image.dataset.largestUsedSize || sizesWidth > parseInt(image.dataset.largestUsedSize, 10)) {\n image.sizes = sizesWidth + 'px';\n image.dataset.largestUsedSize = String(sizesWidth);\n }\n }\n /**\r\n * @returns {boolean} If content should use a placeholder (from msrc by default)\r\n */\n\n\n usePlaceholder() {\n return this.instance.applyFilters('useContentPlaceholder', this.isImageContent(), this);\n }\n /**\r\n * Preload content with lazy-loading param\r\n */\n\n\n lazyLoad() {\n if (this.instance.dispatch('contentLazyLoad', {\n content: this\n }).defaultPrevented) {\n return;\n }\n\n this.load(true);\n }\n /**\r\n * @returns {boolean} If placeholder should be kept after content is loaded\r\n */\n\n\n keepPlaceholder() {\n return this.instance.applyFilters('isKeepingPlaceholder', this.isLoading(), this);\n }\n /**\r\n * Destroy the content\r\n */\n\n\n destroy() {\n this.hasSlide = false;\n this.slide = undefined;\n\n if (this.instance.dispatch('contentDestroy', {\n content: this\n }).defaultPrevented) {\n return;\n }\n\n this.remove();\n\n if (this.placeholder) {\n this.placeholder.destroy();\n this.placeholder = undefined;\n }\n\n if (this.isImageContent() && this.element) {\n this.element.onload = null;\n this.element.onerror = null;\n this.element = undefined;\n }\n }\n /**\r\n * Display error message\r\n */\n\n\n displayError() {\n if (this.slide) {\n var _this$instance$option, _this$instance$option2;\n\n let errorMsgEl = createElement('pswp__error-msg', 'div');\n errorMsgEl.innerText = (_this$instance$option = (_this$instance$option2 = this.instance.options) === null || _this$instance$option2 === void 0 ? void 0 : _this$instance$option2.errorMsg) !== null && _this$instance$option !== void 0 ? _this$instance$option : '';\n errorMsgEl =\n /** @type {HTMLDivElement} */\n this.instance.applyFilters('contentErrorElement', errorMsgEl, this);\n this.element = createElement('pswp__content pswp__error-msg-container', 'div');\n this.element.appendChild(errorMsgEl);\n this.slide.container.innerText = '';\n this.slide.container.appendChild(this.element);\n this.slide.updateContentSize(true);\n this.removePlaceholder();\n }\n }\n /**\r\n * Append the content\r\n */\n\n\n append() {\n if (this.isAttached || !this.element) {\n return;\n }\n\n this.isAttached = true;\n\n if (this.state === LOAD_STATE.ERROR) {\n this.displayError();\n return;\n }\n\n if (this.instance.dispatch('contentAppend', {\n content: this\n }).defaultPrevented) {\n return;\n }\n\n const supportsDecode = ('decode' in this.element);\n\n if (this.isImageContent()) {\n // Use decode() on nearby slides\n //\n // Nearby slide images are in DOM and not hidden via display:none.\n // However, they are placed offscreen (to the left and right side).\n //\n // Some browsers do not composite the image until it's actually visible,\n // using decode() helps.\n //\n // You might ask \"why dont you just decode() and then append all images\",\n // that's because I want to show image before it's fully loaded,\n // as browser can render parts of image while it is loading.\n // We do not do this in Safari due to partial loading bug.\n if (supportsDecode && this.slide && (!this.slide.isActive || isSafari())) {\n this.isDecoding = true; // purposefully using finally instead of then,\n // as if srcset sizes changes dynamically - it may cause decode error\n\n /** @type {HTMLImageElement} */\n\n this.element.decode().catch(() => {}).finally(() => {\n this.isDecoding = false;\n this.appendImage();\n });\n } else {\n this.appendImage();\n }\n } else if (this.slide && !this.element.parentNode) {\n this.slide.container.appendChild(this.element);\n }\n }\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 */\n\n\n activate() {\n if (this.instance.dispatch('contentActivate', {\n content: this\n }).defaultPrevented || !this.slide) {\n return;\n }\n\n if (this.isImageContent() && this.isDecoding && !isSafari()) {\n // add image to slide when it becomes active,\n // even if it's not finished decoding\n this.appendImage();\n } else if (this.isError()) {\n this.load(false, true); // try to reload\n }\n\n if (this.slide.holderElement) {\n this.slide.holderElement.setAttribute('aria-hidden', 'false');\n }\n }\n /**\r\n * Deactivate the content\r\n */\n\n\n deactivate() {\n this.instance.dispatch('contentDeactivate', {\n content: this\n });\n\n if (this.slide && this.slide.holderElement) {\n this.slide.holderElement.setAttribute('aria-hidden', 'true');\n }\n }\n /**\r\n * Remove the content from DOM\r\n */\n\n\n remove() {\n this.isAttached = false;\n\n if (this.instance.dispatch('contentRemove', {\n content: this\n }).defaultPrevented) {\n return;\n }\n\n if (this.element && this.element.parentNode) {\n this.element.remove();\n }\n\n if (this.placeholder && this.placeholder.element) {\n this.placeholder.element.remove();\n }\n }\n /**\r\n * Append the image content to slide container\r\n */\n\n\n appendImage() {\n if (!this.isAttached) {\n return;\n }\n\n if (this.instance.dispatch('contentAppendImage', {\n content: this\n }).defaultPrevented) {\n return;\n } // ensure that element exists and is not already appended\n\n\n if (this.slide && this.element && !this.element.parentNode) {\n this.slide.container.appendChild(this.element);\n }\n\n if (this.state === LOAD_STATE.LOADED || this.state === LOAD_STATE.ERROR) {\n this.removePlaceholder();\n }\n }\n\n}\n\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\n\n/** @typedef {import('../core/base.js').default} PhotoSwipeBase */\n\n/** @typedef {import('../photoswipe.js').Point} Point */\n\n/** @typedef {import('../slide/slide.js').SlideData} SlideData */\n\n/**\r\n * @param {PhotoSwipeOptions} options\r\n * @param {PhotoSwipeBase} pswp\r\n * @returns {Point}\r\n */\nfunction getViewportSize(options, pswp) {\n if (options.getViewportSizeFn) {\n const newViewportSize = options.getViewportSizeFn(options, pswp);\n\n if (newViewportSize) {\n return newViewportSize;\n }\n }\n\n return {\n x: document.documentElement.clientWidth,\n // TODO: height on mobile is very incosistent due to toolbar\n // find a way to improve this\n //\n // document.documentElement.clientHeight - doesn't seem to work well\n y: window.innerHeight\n };\n}\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 */\n\nfunction parsePaddingOption(prop, options, viewportSize, itemData, index) {\n let paddingValue = 0;\n\n if (options.paddingFn) {\n paddingValue = options.paddingFn(viewportSize, itemData, index)[prop];\n } else if (options.padding) {\n paddingValue = options.padding[prop];\n } else {\n const legacyPropName = 'padding' + prop[0].toUpperCase() + prop.slice(1); // @ts-expect-error\n\n if (options[legacyPropName]) {\n // @ts-expect-error\n paddingValue = options[legacyPropName];\n }\n }\n\n return Number(paddingValue) || 0;\n}\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 */\n\nfunction getPanAreaSize(options, viewportSize, itemData, index) {\n return {\n x: viewportSize.x - parsePaddingOption('left', options, viewportSize, itemData, index) - parsePaddingOption('right', options, viewportSize, itemData, index),\n y: viewportSize.y - parsePaddingOption('top', options, viewportSize, itemData, index) - parsePaddingOption('bottom', options, viewportSize, itemData, index)\n };\n}\n\nconst MAX_IMAGE_WIDTH = 4000;\n/** @typedef {import('../photoswipe.js').default} PhotoSwipe */\n\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\n\n/** @typedef {import('../photoswipe.js').Point} Point */\n\n/** @typedef {import('../slide/slide.js').SlideData} SlideData */\n\n/** @typedef {'fit' | 'fill' | number | ((zoomLevelObject: ZoomLevel) => number)} ZoomLevelOption */\n\n/**\r\n * Calculates zoom levels for specific slide.\r\n * Depends on viewport size and image size.\r\n */\n\nclass ZoomLevel {\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 */\n constructor(options, itemData, index, pswp) {\n this.pswp = pswp;\n this.options = options;\n this.itemData = itemData;\n this.index = index;\n /** @type { Point | null } */\n\n this.panAreaSize = null;\n /** @type { Point | null } */\n\n this.elementSize = null;\n this.fit = 1;\n this.fill = 1;\n this.vFill = 1;\n this.initial = 1;\n this.secondary = 1;\n this.max = 1;\n this.min = 1;\n }\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 */\n\n\n update(maxWidth, maxHeight, panAreaSize) {\n /** @type {Point} */\n const elementSize = {\n x: maxWidth,\n y: maxHeight\n };\n this.elementSize = elementSize;\n this.panAreaSize = panAreaSize;\n const hRatio = panAreaSize.x / elementSize.x;\n const vRatio = panAreaSize.y / elementSize.y;\n this.fit = Math.min(1, hRatio < vRatio ? hRatio : vRatio);\n this.fill = Math.min(1, hRatio > vRatio ? hRatio : vRatio); // zoom.vFill defines zoom level of the image\n // when it has 100% of viewport vertical space (height)\n\n this.vFill = Math.min(1, vRatio);\n this.initial = this._getInitial();\n this.secondary = this._getSecondary();\n this.max = Math.max(this.initial, this.secondary, this._getMax());\n this.min = Math.min(this.fit, this.initial, this.secondary);\n\n if (this.pswp) {\n this.pswp.dispatch('zoomLevelsUpdate', {\n zoomLevels: this,\n slideData: this.itemData\n });\n }\n }\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 */\n\n\n _parseZoomLevelOption(optionPrefix) {\n const optionName =\n /** @type {'initialZoomLevel' | 'secondaryZoomLevel' | 'maxZoomLevel'} */\n optionPrefix + 'ZoomLevel';\n const optionValue = this.options[optionName];\n\n if (!optionValue) {\n return;\n }\n\n if (typeof optionValue === 'function') {\n return optionValue(this);\n }\n\n if (optionValue === 'fill') {\n return this.fill;\n }\n\n if (optionValue === 'fit') {\n return this.fit;\n }\n\n return Number(optionValue);\n }\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 */\n\n\n _getSecondary() {\n let currZoomLevel = this._parseZoomLevelOption('secondary');\n\n if (currZoomLevel) {\n return currZoomLevel;\n } // 3x of \"fit\" state, but not larger than original\n\n\n currZoomLevel = Math.min(1, this.fit * 3);\n\n if (this.elementSize && currZoomLevel * this.elementSize.x > MAX_IMAGE_WIDTH) {\n currZoomLevel = MAX_IMAGE_WIDTH / this.elementSize.x;\n }\n\n return currZoomLevel;\n }\n /**\r\n * Get initial image zoom level.\r\n *\r\n * @private\r\n * @return {number}\r\n */\n\n\n _getInitial() {\n return this._parseZoomLevelOption('initial') || this.fit;\n }\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 */\n\n\n _getMax() {\n // max zoom level is x4 from \"fit state\",\n // used for zoom gesture and ctrl/trackpad zoom\n return this._parseZoomLevelOption('max') || Math.max(1, this.fit * 4);\n }\n\n}\n\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 */\n\nfunction lazyLoadData(itemData, instance, index) {\n const content = instance.createContentFromData(itemData, index);\n /** @type {ZoomLevel | undefined} */\n\n let zoomLevel;\n const {\n options\n } = instance; // We need to know dimensions of the image to preload it,\n // as it might use srcset, and we need to define sizes\n\n if (options) {\n zoomLevel = new ZoomLevel(options, itemData, -1);\n let viewportSize;\n\n if (instance.pswp) {\n viewportSize = instance.pswp.viewportSize;\n } else {\n viewportSize = getViewportSize(options, instance);\n }\n\n const panAreaSize = getPanAreaSize(options, viewportSize, itemData, index);\n zoomLevel.update(content.width, content.height, panAreaSize);\n }\n\n content.lazyLoad();\n\n if (zoomLevel) {\n content.setDisplayedSize(Math.ceil(content.width * zoomLevel.initial), Math.ceil(content.height * zoomLevel.initial));\n }\n\n return content;\n}\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 */\n\nfunction lazyLoadSlide(index, instance) {\n const itemData = instance.getItemData(index);\n\n if (instance.dispatch('lazyLoadSlide', {\n index,\n itemData\n }).defaultPrevented) {\n return;\n }\n\n return lazyLoadData(itemData, instance, index);\n}\n\n/** @typedef {import(\"../photoswipe.js\").default} PhotoSwipe */\n\n/** @typedef {import(\"../slide/slide.js\").SlideData} SlideData */\n\n/**\r\n * PhotoSwipe base class that can retrieve data about every slide.\r\n * Shared by PhotoSwipe Core and PhotoSwipe Lightbox\r\n */\n\nclass PhotoSwipeBase extends Eventable {\n /**\r\n * Get total number of slides\r\n *\r\n * @returns {number}\r\n */\n getNumItems() {\n var _this$options;\n\n let numItems = 0;\n const dataSource = (_this$options = this.options) === null || _this$options === void 0 ? void 0 : _this$options.dataSource;\n\n if (dataSource && 'length' in dataSource) {\n // may be an array or just object with length property\n numItems = dataSource.length;\n } else if (dataSource && 'gallery' in dataSource) {\n // query DOM elements\n if (!dataSource.items) {\n dataSource.items = this._getGalleryDOMElements(dataSource.gallery);\n }\n\n if (dataSource.items) {\n numItems = dataSource.items.length;\n }\n } // legacy event, before filters were introduced\n\n\n const event = this.dispatch('numItems', {\n dataSource,\n numItems\n });\n return this.applyFilters('numItems', event.numItems, dataSource);\n }\n /**\r\n * @param {SlideData} slideData\r\n * @param {number} index\r\n * @returns {Content}\r\n */\n\n\n createContentFromData(slideData, index) {\n return new Content(slideData, this, index);\n }\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 */\n\n\n getItemData(index) {\n var _this$options2;\n\n const dataSource = (_this$options2 = this.options) === null || _this$options2 === void 0 ? void 0 : _this$options2.dataSource;\n /** @type {SlideData | HTMLElement} */\n\n let dataSourceItem = {};\n\n if (Array.isArray(dataSource)) {\n // Datasource is an array of elements\n dataSourceItem = dataSource[index];\n } else if (dataSource && 'gallery' in dataSource) {\n // dataSource has gallery property,\n // thus it was created by Lightbox, based on\n // gallery and children options\n // query DOM elements\n if (!dataSource.items) {\n dataSource.items = this._getGalleryDOMElements(dataSource.gallery);\n }\n\n dataSourceItem = dataSource.items[index];\n }\n\n let itemData = dataSourceItem;\n\n if (itemData instanceof Element) {\n itemData = this._domElementToItemData(itemData);\n } // Dispatching the itemData event,\n // it's a legacy verion before filters were introduced\n\n\n const event = this.dispatch('itemData', {\n itemData: itemData || {},\n index\n });\n return this.applyFilters('itemData', event.itemData, index);\n }\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 */\n\n\n _getGalleryDOMElements(galleryElement) {\n var _this$options3, _this$options4;\n\n if ((_this$options3 = this.options) !== null && _this$options3 !== void 0 && _this$options3.children || (_this$options4 = this.options) !== null && _this$options4 !== void 0 && _this$options4.childSelector) {\n return getElementsFromOption(this.options.children, this.options.childSelector, galleryElement) || [];\n }\n\n return [galleryElement];\n }\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 */\n\n\n _domElementToItemData(element) {\n /** @type {SlideData} */\n const itemData = {\n element\n };\n const linkEl =\n /** @type {HTMLAnchorElement} */\n element.tagName === 'A' ? element : element.querySelector('a');\n\n if (linkEl) {\n // src comes from data-pswp-src attribute,\n // if it's empty link href is used\n itemData.src = linkEl.dataset.pswpSrc || linkEl.href;\n\n if (linkEl.dataset.pswpSrcset) {\n itemData.srcset = linkEl.dataset.pswpSrcset;\n }\n\n itemData.width = linkEl.dataset.pswpWidth ? parseInt(linkEl.dataset.pswpWidth, 10) : 0;\n itemData.height = linkEl.dataset.pswpHeight ? parseInt(linkEl.dataset.pswpHeight, 10) : 0; // support legacy w & h properties\n\n itemData.w = itemData.width;\n itemData.h = itemData.height;\n\n if (linkEl.dataset.pswpType) {\n itemData.type = linkEl.dataset.pswpType;\n }\n\n const thumbnailEl = element.querySelector('img');\n\n if (thumbnailEl) {\n var _thumbnailEl$getAttri;\n\n // msrc is URL to placeholder image that's displayed before large image is loaded\n // by default it's displayed only for the first slide\n itemData.msrc = thumbnailEl.currentSrc || thumbnailEl.src;\n itemData.alt = (_thumbnailEl$getAttri = thumbnailEl.getAttribute('alt')) !== null && _thumbnailEl$getAttri !== void 0 ? _thumbnailEl$getAttri : '';\n }\n\n if (linkEl.dataset.pswpCropped || linkEl.dataset.cropped) {\n itemData.thumbCropped = true;\n }\n }\n\n return this.applyFilters('domItemData', itemData, element, linkEl);\n }\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 */\n\n\n lazyLoadData(itemData, index) {\n return lazyLoadData(itemData, this, index);\n }\n\n}\n\n/**\r\n * @template T\r\n * @typedef {import('../types.js').Type<T>} Type<T>\r\n */\n\n/** @typedef {import('../photoswipe.js').default} PhotoSwipe */\n\n/** @typedef {import('../photoswipe.js').PhotoSwipeOptions} PhotoSwipeOptions */\n\n/** @typedef {import('../photoswipe.js').DataSource} DataSource */\n\n/** @typedef {import('../photoswipe.js').Point} Point */\n\n/** @typedef {import('../slide/content.js').default} Content */\n\n/** @typedef {import('../core/eventable.js').PhotoSwipeEventsMap} PhotoSwipeEventsMap */\n\n/** @typedef {import('../core/eventable.js').PhotoSwipeFiltersMap} PhotoSwipeFiltersMap */\n\n/**\r\n * @template {keyof PhotoSwipeEventsMap} T\r\n * @typedef {import('../core/eventable.js').EventCallback<T>} EventCallback<T>\r\n */\n\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 */\n\nclass PhotoSwipeLightbox extends PhotoSwipeBase {\n /**\r\n * @param {PhotoSwipeOptions} [options]\r\n */\n constructor(options) {\n super();\n /** @type {PhotoSwipeOptions} */\n\n this.options = options || {};\n this._uid = 0;\n this.shouldOpen = false;\n /**\r\n * @private\r\n * @type {Content | undefined}\r\n */\n\n this._preloadedContent = undefined;\n this.onThumbnailsClick = this.onThumbnailsClick.bind(this);\n }\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 */\n\n\n init() {\n // Bind click events to each gallery\n getElementsFromOption(this.options.gallery, this.options.gallerySelector).forEach(galleryElement => {\n galleryElement.addEventListener('click', this.onThumbnailsClick, false);\n });\n }\n /**\r\n * @param {MouseEvent} e\r\n */\n\n\n onThumbnailsClick(e) {\n // Exit and allow default browser action if:\n if (specialKeyUsed(e) // ... if clicked with a special key (ctrl/cmd...)\n || window.pswp) {\n // ... if PhotoSwipe is already open\n return;\n } // If both clientX and clientY are 0 or not defined,\n // the event is likely triggered by keyboard,\n // so we do not pass the initialPoint\n //\n // Note that some screen readers emulate the mouse position,\n // so it's not the ideal way to detect them.\n //\n\n /** @type {Point | null} */\n\n\n let initialPoint = {\n x: e.clientX,\n y: e.clientY\n };\n\n if (!initialPoint.x && !initialPoint.y) {\n initialPoint = null;\n }\n\n let clickedIndex = this.getClickedIndex(e);\n clickedIndex = this.applyFilters('clickedIndex', clickedIndex, e, this);\n /** @type {DataSource} */\n\n const dataSource = {\n gallery:\n /** @type {HTMLElement} */\n e.currentTarget\n };\n\n if (clickedIndex >= 0) {\n e.preventDefault();\n this.loadAndOpen(clickedIndex, dataSource, initialPoint);\n }\n }\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 */\n\n\n getClickedIndex(e) {\n // legacy option\n if (this.options.getClickedIndexFn) {\n return this.options.getClickedIndexFn.call(this, e);\n }\n\n const clickedTarget =\n /** @type {HTMLElement} */\n e.target;\n const childElements = getElementsFromOption(this.options.children, this.options.childSelector,\n /** @type {HTMLElement} */\n e.currentTarget);\n const clickedChildIndex = childElements.findIndex(child => child === clickedTarget || child.contains(clickedTarget));\n\n if (clickedChildIndex !== -1) {\n return clickedChildIndex;\n } else if (this.options.children || this.options.childSelector) {\n // click wasn't on a child element\n return -1;\n } // There is only one item (which is the gallery)\n\n\n return 0;\n }\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 */\n\n\n loadAndOpen(index, dataSource, initialPoint) {\n // Check if the gallery is already open\n if (window.pswp || !this.options) {\n return false;\n } // Use the first gallery element if dataSource is not provided\n\n\n if (!dataSource && this.options.gallery && this.options.children) {\n const galleryElements = getElementsFromOption(this.options.gallery);\n\n if (galleryElements[0]) {\n dataSource = {\n gallery: galleryElements[0]\n };\n }\n } // set initial index\n\n\n this.options.index = index; // define options for PhotoSwipe constructor\n\n this.options.initialPointerPos = initialPoint;\n this.shouldOpen = true;\n this.preload(index, dataSource);\n return true;\n }\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 */\n\n\n preload(index, dataSource) {\n const {\n options\n } = this;\n\n if (dataSource) {\n options.dataSource = dataSource;\n } // Add the main module\n\n /** @type {Promise<Type<PhotoSwipe>>[]} */\n\n\n const promiseArray = [];\n const pswpModuleType = typeof options.pswpModule;\n\n if (isPswpClass(options.pswpModule)) {\n promiseArray.push(Promise.resolve(\n /** @type {Type<PhotoSwipe>} */\n options.pswpModule));\n } else if (pswpModuleType === 'string') {\n throw new Error('pswpModule as string is no longer supported');\n } else if (pswpModuleType === 'function') {\n promiseArray.push(\n /** @type {() => Promise<Type<PhotoSwipe>>} */\n options.pswpModule());\n } else {\n throw new Error('pswpModule is not valid');\n } // Add custom-defined promise, if any\n\n\n if (typeof options.openPromise === 'function') {\n // allow developers to perform some task before opening\n promiseArray.push(options.openPromise());\n }\n\n if (options.preloadFirstSlide !== false && index >= 0) {\n this._preloadedContent = lazyLoadSlide(index, this);\n } // Wait till all promises resolve and open PhotoSwipe\n\n\n const uid = ++this._uid;\n Promise.all(promiseArray).then(iterableModules => {\n if (this.shouldOpen) {\n const mainModule = iterableModules[0];\n\n this._openPhotoswipe(mainModule, uid);\n }\n });\n }\n /**\r\n * @private\r\n * @param {Type<PhotoSwipe> | { default: Type<PhotoSwipe> }} module\r\n * @param {number} uid\r\n */\n\n\n _openPhotoswipe(module, uid) {\n // Cancel opening if UID doesn't match the current one\n // (if user clicked on another gallery item before current was loaded).\n //\n // Or if shouldOpen flag is set to false\n // (developer may modify it via public API)\n if (uid !== this._uid && this.shouldOpen) {\n return;\n }\n\n this.shouldOpen = false; // PhotoSwipe is already open\n\n if (window.pswp) {\n return;\n }\n /**\r\n * Pass data to PhotoSwipe and open init\r\n *\r\n * @type {PhotoSwipe}\r\n */\n\n\n const pswp = typeof module === 'object' ? new module.default(this.options) // eslint-disable-line\n : new module(this.options); // eslint-disable-line\n\n this.pswp = pswp;\n window.pswp = pswp; // map listeners from Lightbox to PhotoSwipe Core\n\n /** @type {(keyof PhotoSwipeEventsMap)[]} */\n\n Object.keys(this._listeners).forEach(name => {\n var _this$_listeners$name;\n\n (_this$_listeners$name = this._listeners[name]) === null || _this$_listeners$name === void 0 || _this$_listeners$name.forEach(fn => {\n pswp.on(name,\n /** @type {EventCallback<typeof name>} */\n fn);\n });\n }); // same with filters\n\n /** @type {(keyof PhotoSwipeFiltersMap)[]} */\n\n Object.keys(this._filters).forEach(name => {\n var _this$_filters$name;\n\n (_this$_filters$name = this._filters[name]) === null || _this$_filters$name === void 0 || _this$_filters$name.forEach(filter => {\n pswp.addFilter(name, filter.fn, filter.priority);\n });\n });\n\n if (this._preloadedContent) {\n pswp.contentLoader.addToCache(this._preloadedContent);\n this._preloadedContent = undefined;\n }\n\n pswp.on('destroy', () => {\n // clean up public variables\n this.pswp = undefined;\n delete window.pswp;\n });\n pswp.init();\n }\n /**\r\n * Unbinds all events, closes PhotoSwipe if it's open.\r\n */\n\n\n destroy() {\n var _this$pswp;\n\n (_this$pswp = this.pswp) === null || _this$pswp === void 0 || _this$pswp.destroy();\n this.shouldOpen = false;\n this._listeners = {};\n getElementsFromOption(this.options.gallery, this.options.gallerySelector).forEach(galleryElement => {\n galleryElement.removeEventListener('click', this.onThumbnailsClick, false);\n });\n }\n\n}\n\nexport { PhotoSwipeLightbox as default };\n//# sourceMappingURL=photoswipe-lightbox.esm.js.map\n"],"names":["createElement","className","tagName","appendToEl","el","document","appendChild","toTransformString","x","y","scale","propValue","undefined","setWidthHeight","w","h","style","width","height","LOAD_STATE","IDLE","LOADING","LOADED","ERROR","specialKeyUsed","e","button","ctrlKey","metaKey","altKey","shiftKey","getElementsFromOption","option","legacySelector","parent","elements","Element","NodeList","Array","isArray","from","selector","querySelectorAll","isPswpClass","fn","prototype","goTo","isSafari","navigator","vendor","match","PhotoSwipeEvent","constructor","type","details","this","defaultPrevented","Object","assign","preventDefault","Eventable","_listeners","_filters","pswp","options","addFilter","name","priority","_this$_filters$name","_this$_filters$name2","_this$pswp","push","sort","f1","f2","removeFilter","filter","applyFilters","args","_this$_filters$name3","forEach","apply","on","_this$_listeners$name","_this$pswp2","off","_this$pswp3","listener","dispatch","_this$_listeners$name2","event","call","Placeholder","imageSrc","container","element","imgEl","decoding","alt","src","setAttribute","setDisplayedSize","transformOrigin","transform","destroy","_this$element","parentNode","remove","Content","itemData","instance","index","data","placeholder","slide","displayedImageWidth","displayedImageHeight","Number","isAttached","hasSlide","isDecoding","state","content","removePlaceholder","keepPlaceholder","setTimeout","load","isLazy","reload","usePlaceholder","placeholderEl","parentElement","prepend","placeholderSrc","msrc","isFirstSlide","isImageContent","loadImage","innerHTML","html","updateContentSize","_this$data$src","_this$data$alt","imageElement","updateSrcsetSizes","srcset","complete","onLoaded","onload","onerror","onError","setSlide","isActive","heavyAppended","append","displayError","isError","isLoading","isInitialSizeUpdate","isZoomable","image","sizesWidth","dataset","largestUsedSize","parseInt","sizes","String","lazyLoad","_this$instance$option","_this$instance$option2","errorMsgEl","innerText","errorMsg","supportsDecode","decode","catch","finally","appendImage","activate","holderElement","deactivate","getViewportSize","getViewportSizeFn","newViewportSize","documentElement","clientWidth","window","innerHeight","parsePaddingOption","prop","viewportSize","paddingValue","paddingFn","padding","legacyPropName","toUpperCase","slice","getPanAreaSize","MAX_IMAGE_WIDTH","ZoomLevel","panAreaSize","elementSize","fit","fill","vFill","initial","secondary","max","min","update","maxWidth","maxHeight","hRatio","vRatio","Math","_getInitial","_getSecondary","_getMax","zoomLevels","slideData","_parseZoomLevelOption","optionPrefix","optionName","optionValue","currZoomLevel","lazyLoadData","createContentFromData","zoomLevel","ceil","lazyLoadSlide","getItemData","PhotoSwipeBase","getNumItems","_this$options","numItems","dataSource","length","items","_getGalleryDOMElements","gallery","_this$options2","dataSourceItem","_domElementToItemData","galleryElement","_this$options3","_this$options4","children","childSelector","linkEl","querySelector","pswpSrc","href","pswpSrcset","pswpWidth","pswpHeight","pswpType","thumbnailEl","_thumbnailEl$getAttri","currentSrc","getAttribute","pswpCropped","cropped","thumbCropped","PhotoSwipeLightbox","super","_uid","shouldOpen","_preloadedContent","onThumbnailsClick","bind","init","gallerySelector","addEventListener","initialPoint","clientX","clientY","clickedIndex","getClickedIndex","currentTarget","loadAndOpen","getClickedIndexFn","clickedTarget","target","childElements","clickedChildIndex","findIndex","child","contains","galleryElements","initialPointerPos","preload","promiseArray","pswpModuleType","pswpModule","Promise","resolve","Error","openPromise","preloadFirstSlide","uid","all","then","iterableModules","mainModule","_openPhotoswipe","module","default","keys","contentLoader","addToCache","removeEventListener"],"sourceRoot":""}