swiper-bundle.js 336 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594859585968597859885998600860186028603860486058606860786088609861086118612861386148615861686178618861986208621862286238624862586268627862886298630863186328633863486358636863786388639864086418642864386448645864686478648864986508651865286538654865586568657865886598660866186628663866486658666866786688669867086718672867386748675867686778678867986808681868286838684868586868687868886898690869186928693869486958696869786988699870087018702870387048705870687078708870987108711871287138714871587168717871887198720872187228723872487258726872787288729873087318732873387348735873687378738873987408741874287438744874587468747874887498750875187528753875487558756875787588759876087618762876387648765876687678768876987708771877287738774877587768777877887798780878187828783878487858786878787888789879087918792879387948795879687978798879988008801880288038804880588068807880888098810881188128813881488158816881788188819882088218822882388248825882688278828882988308831883288338834883588368837883888398840884188428843884488458846884788488849885088518852885388548855885688578858885988608861886288638864886588668867886888698870887188728873887488758876887788788879888088818882888388848885888688878888888988908891889288938894889588968897889888998900890189028903890489058906890789088909891089118912891389148915891689178918891989208921892289238924892589268927892889298930893189328933893489358936893789388939894089418942894389448945894689478948894989508951895289538954895589568957895889598960896189628963896489658966896789688969897089718972897389748975897689778978897989808981898289838984898589868987898889898990899189928993899489958996899789988999900090019002900390049005900690079008900990109011901290139014901590169017901890199020902190229023902490259026902790289029903090319032903390349035903690379038903990409041904290439044904590469047904890499050905190529053905490559056905790589059906090619062906390649065906690679068906990709071907290739074907590769077907890799080908190829083908490859086908790889089909090919092909390949095909690979098909991009101910291039104910591069107910891099110911191129113911491159116911791189119912091219122912391249125912691279128912991309131913291339134913591369137913891399140914191429143914491459146914791489149915091519152915391549155915691579158915991609161916291639164916591669167916891699170917191729173917491759176917791789179918091819182918391849185918691879188918991909191919291939194919591969197919891999200920192029203920492059206920792089209921092119212921392149215921692179218921992209221922292239224922592269227922892299230923192329233923492359236923792389239924092419242924392449245924692479248924992509251925292539254925592569257925892599260926192629263926492659266926792689269927092719272927392749275927692779278927992809281928292839284928592869287928892899290929192929293929492959296929792989299930093019302930393049305930693079308930993109311931293139314931593169317931893199320932193229323932493259326932793289329933093319332933393349335933693379338933993409341934293439344934593469347934893499350935193529353935493559356935793589359936093619362936393649365936693679368936993709371937293739374937593769377937893799380938193829383938493859386938793889389939093919392939393949395939693979398939994009401940294039404940594069407940894099410941194129413941494159416941794189419942094219422942394249425942694279428942994309431943294339434943594369437943894399440944194429443944494459446944794489449945094519452945394549455945694579458945994609461946294639464946594669467946894699470947194729473947494759476947794789479948094819482948394849485948694879488948994909491949294939494949594969497949894999500950195029503950495059506950795089509951095119512951395149515951695179518951995209521952295239524952595269527952895299530953195329533
  1. /*!
  2. Swiper
  3. Version: 11.0.5
  4. Plugin URL: https://swiperjs.com
  5. License: Copyright 2014-2023 Vladimir Kharlampidi | Released under the MIT License
  6. !*/
  7. var Swiper = (function () {
  8. 'use strict';
  9. /**
  10. * SSR Window 4.0.2
  11. * Better handling for window object in SSR environment
  12. * https://github.com/nolimits4web/ssr-window
  13. *
  14. * Copyright 2021, Vladimir Kharlampidi
  15. *
  16. * Licensed under MIT
  17. *
  18. * Released on: December 13, 2021
  19. */
  20. /* eslint-disable no-param-reassign */
  21. function isObject$1(obj) {
  22. return obj !== null && typeof obj === 'object' && 'constructor' in obj && obj.constructor === Object;
  23. }
  24. function extend$1(target, src) {
  25. if (target === void 0) {
  26. target = {};
  27. }
  28. if (src === void 0) {
  29. src = {};
  30. }
  31. Object.keys(src).forEach(key => {
  32. if (typeof target[key] === 'undefined') target[key] = src[key];else if (isObject$1(src[key]) && isObject$1(target[key]) && Object.keys(src[key]).length > 0) {
  33. extend$1(target[key], src[key]);
  34. }
  35. });
  36. }
  37. const ssrDocument = {
  38. body: {},
  39. addEventListener() {},
  40. removeEventListener() {},
  41. activeElement: {
  42. blur() {},
  43. nodeName: ''
  44. },
  45. querySelector() {
  46. return null;
  47. },
  48. querySelectorAll() {
  49. return [];
  50. },
  51. getElementById() {
  52. return null;
  53. },
  54. createEvent() {
  55. return {
  56. initEvent() {}
  57. };
  58. },
  59. createElement() {
  60. return {
  61. children: [],
  62. childNodes: [],
  63. style: {},
  64. setAttribute() {},
  65. getElementsByTagName() {
  66. return [];
  67. }
  68. };
  69. },
  70. createElementNS() {
  71. return {};
  72. },
  73. importNode() {
  74. return null;
  75. },
  76. location: {
  77. hash: '',
  78. host: '',
  79. hostname: '',
  80. href: '',
  81. origin: '',
  82. pathname: '',
  83. protocol: '',
  84. search: ''
  85. }
  86. };
  87. function getDocument() {
  88. const doc = typeof document !== 'undefined' ? document : {};
  89. extend$1(doc, ssrDocument);
  90. return doc;
  91. }
  92. const ssrWindow = {
  93. document: ssrDocument,
  94. navigator: {
  95. userAgent: ''
  96. },
  97. location: {
  98. hash: '',
  99. host: '',
  100. hostname: '',
  101. href: '',
  102. origin: '',
  103. pathname: '',
  104. protocol: '',
  105. search: ''
  106. },
  107. history: {
  108. replaceState() {},
  109. pushState() {},
  110. go() {},
  111. back() {}
  112. },
  113. CustomEvent: function CustomEvent() {
  114. return this;
  115. },
  116. addEventListener() {},
  117. removeEventListener() {},
  118. getComputedStyle() {
  119. return {
  120. getPropertyValue() {
  121. return '';
  122. }
  123. };
  124. },
  125. Image() {},
  126. Date() {},
  127. screen: {},
  128. setTimeout() {},
  129. clearTimeout() {},
  130. matchMedia() {
  131. return {};
  132. },
  133. requestAnimationFrame(callback) {
  134. if (typeof setTimeout === 'undefined') {
  135. callback();
  136. return null;
  137. }
  138. return setTimeout(callback, 0);
  139. },
  140. cancelAnimationFrame(id) {
  141. if (typeof setTimeout === 'undefined') {
  142. return;
  143. }
  144. clearTimeout(id);
  145. }
  146. };
  147. function getWindow() {
  148. const win = typeof window !== 'undefined' ? window : {};
  149. extend$1(win, ssrWindow);
  150. return win;
  151. }
  152. function classesToTokens(classes) {
  153. if (classes === void 0) {
  154. classes = '';
  155. }
  156. return classes.trim().split(' ').filter(c => !!c.trim());
  157. }
  158. function deleteProps(obj) {
  159. const object = obj;
  160. Object.keys(object).forEach(key => {
  161. try {
  162. object[key] = null;
  163. } catch (e) {
  164. // no getter for object
  165. }
  166. try {
  167. delete object[key];
  168. } catch (e) {
  169. // something got wrong
  170. }
  171. });
  172. }
  173. function nextTick(callback, delay) {
  174. if (delay === void 0) {
  175. delay = 0;
  176. }
  177. return setTimeout(callback, delay);
  178. }
  179. function now() {
  180. return Date.now();
  181. }
  182. function getComputedStyle$1(el) {
  183. const window = getWindow();
  184. let style;
  185. if (window.getComputedStyle) {
  186. style = window.getComputedStyle(el, null);
  187. }
  188. if (!style && el.currentStyle) {
  189. style = el.currentStyle;
  190. }
  191. if (!style) {
  192. style = el.style;
  193. }
  194. return style;
  195. }
  196. function getTranslate(el, axis) {
  197. if (axis === void 0) {
  198. axis = 'x';
  199. }
  200. const window = getWindow();
  201. let matrix;
  202. let curTransform;
  203. let transformMatrix;
  204. const curStyle = getComputedStyle$1(el);
  205. if (window.WebKitCSSMatrix) {
  206. curTransform = curStyle.transform || curStyle.webkitTransform;
  207. if (curTransform.split(',').length > 6) {
  208. curTransform = curTransform.split(', ').map(a => a.replace(',', '.')).join(', ');
  209. }
  210. // Some old versions of Webkit choke when 'none' is passed; pass
  211. // empty string instead in this case
  212. transformMatrix = new window.WebKitCSSMatrix(curTransform === 'none' ? '' : curTransform);
  213. } else {
  214. transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue('transform').replace('translate(', 'matrix(1, 0, 0, 1,');
  215. matrix = transformMatrix.toString().split(',');
  216. }
  217. if (axis === 'x') {
  218. // Latest Chrome and webkits Fix
  219. if (window.WebKitCSSMatrix) curTransform = transformMatrix.m41;
  220. // Crazy IE10 Matrix
  221. else if (matrix.length === 16) curTransform = parseFloat(matrix[12]);
  222. // Normal Browsers
  223. else curTransform = parseFloat(matrix[4]);
  224. }
  225. if (axis === 'y') {
  226. // Latest Chrome and webkits Fix
  227. if (window.WebKitCSSMatrix) curTransform = transformMatrix.m42;
  228. // Crazy IE10 Matrix
  229. else if (matrix.length === 16) curTransform = parseFloat(matrix[13]);
  230. // Normal Browsers
  231. else curTransform = parseFloat(matrix[5]);
  232. }
  233. return curTransform || 0;
  234. }
  235. function isObject(o) {
  236. return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';
  237. }
  238. function isNode(node) {
  239. // eslint-disable-next-line
  240. if (typeof window !== 'undefined' && typeof window.HTMLElement !== 'undefined') {
  241. return node instanceof HTMLElement;
  242. }
  243. return node && (node.nodeType === 1 || node.nodeType === 11);
  244. }
  245. function extend() {
  246. const to = Object(arguments.length <= 0 ? undefined : arguments[0]);
  247. const noExtend = ['__proto__', 'constructor', 'prototype'];
  248. for (let i = 1; i < arguments.length; i += 1) {
  249. const nextSource = i < 0 || arguments.length <= i ? undefined : arguments[i];
  250. if (nextSource !== undefined && nextSource !== null && !isNode(nextSource)) {
  251. const keysArray = Object.keys(Object(nextSource)).filter(key => noExtend.indexOf(key) < 0);
  252. for (let nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) {
  253. const nextKey = keysArray[nextIndex];
  254. const desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);
  255. if (desc !== undefined && desc.enumerable) {
  256. if (isObject(to[nextKey]) && isObject(nextSource[nextKey])) {
  257. if (nextSource[nextKey].__swiper__) {
  258. to[nextKey] = nextSource[nextKey];
  259. } else {
  260. extend(to[nextKey], nextSource[nextKey]);
  261. }
  262. } else if (!isObject(to[nextKey]) && isObject(nextSource[nextKey])) {
  263. to[nextKey] = {};
  264. if (nextSource[nextKey].__swiper__) {
  265. to[nextKey] = nextSource[nextKey];
  266. } else {
  267. extend(to[nextKey], nextSource[nextKey]);
  268. }
  269. } else {
  270. to[nextKey] = nextSource[nextKey];
  271. }
  272. }
  273. }
  274. }
  275. }
  276. return to;
  277. }
  278. function setCSSProperty(el, varName, varValue) {
  279. el.style.setProperty(varName, varValue);
  280. }
  281. function animateCSSModeScroll(_ref) {
  282. let {
  283. swiper,
  284. targetPosition,
  285. side
  286. } = _ref;
  287. const window = getWindow();
  288. const startPosition = -swiper.translate;
  289. let startTime = null;
  290. let time;
  291. const duration = swiper.params.speed;
  292. swiper.wrapperEl.style.scrollSnapType = 'none';
  293. window.cancelAnimationFrame(swiper.cssModeFrameID);
  294. const dir = targetPosition > startPosition ? 'next' : 'prev';
  295. const isOutOfBound = (current, target) => {
  296. return dir === 'next' && current >= target || dir === 'prev' && current <= target;
  297. };
  298. const animate = () => {
  299. time = new Date().getTime();
  300. if (startTime === null) {
  301. startTime = time;
  302. }
  303. const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);
  304. const easeProgress = 0.5 - Math.cos(progress * Math.PI) / 2;
  305. let currentPosition = startPosition + easeProgress * (targetPosition - startPosition);
  306. if (isOutOfBound(currentPosition, targetPosition)) {
  307. currentPosition = targetPosition;
  308. }
  309. swiper.wrapperEl.scrollTo({
  310. [side]: currentPosition
  311. });
  312. if (isOutOfBound(currentPosition, targetPosition)) {
  313. swiper.wrapperEl.style.overflow = 'hidden';
  314. swiper.wrapperEl.style.scrollSnapType = '';
  315. setTimeout(() => {
  316. swiper.wrapperEl.style.overflow = '';
  317. swiper.wrapperEl.scrollTo({
  318. [side]: currentPosition
  319. });
  320. });
  321. window.cancelAnimationFrame(swiper.cssModeFrameID);
  322. return;
  323. }
  324. swiper.cssModeFrameID = window.requestAnimationFrame(animate);
  325. };
  326. animate();
  327. }
  328. function getSlideTransformEl(slideEl) {
  329. return slideEl.querySelector('.swiper-slide-transform') || slideEl.shadowRoot && slideEl.shadowRoot.querySelector('.swiper-slide-transform') || slideEl;
  330. }
  331. function elementChildren(element, selector) {
  332. if (selector === void 0) {
  333. selector = '';
  334. }
  335. return [...element.children].filter(el => el.matches(selector));
  336. }
  337. function showWarning(text) {
  338. try {
  339. console.warn(text);
  340. return;
  341. } catch (err) {
  342. // err
  343. }
  344. }
  345. function createElement(tag, classes) {
  346. if (classes === void 0) {
  347. classes = [];
  348. }
  349. const el = document.createElement(tag);
  350. el.classList.add(...(Array.isArray(classes) ? classes : classesToTokens(classes)));
  351. return el;
  352. }
  353. function elementOffset(el) {
  354. const window = getWindow();
  355. const document = getDocument();
  356. const box = el.getBoundingClientRect();
  357. const body = document.body;
  358. const clientTop = el.clientTop || body.clientTop || 0;
  359. const clientLeft = el.clientLeft || body.clientLeft || 0;
  360. const scrollTop = el === window ? window.scrollY : el.scrollTop;
  361. const scrollLeft = el === window ? window.scrollX : el.scrollLeft;
  362. return {
  363. top: box.top + scrollTop - clientTop,
  364. left: box.left + scrollLeft - clientLeft
  365. };
  366. }
  367. function elementPrevAll(el, selector) {
  368. const prevEls = [];
  369. while (el.previousElementSibling) {
  370. const prev = el.previousElementSibling; // eslint-disable-line
  371. if (selector) {
  372. if (prev.matches(selector)) prevEls.push(prev);
  373. } else prevEls.push(prev);
  374. el = prev;
  375. }
  376. return prevEls;
  377. }
  378. function elementNextAll(el, selector) {
  379. const nextEls = [];
  380. while (el.nextElementSibling) {
  381. const next = el.nextElementSibling; // eslint-disable-line
  382. if (selector) {
  383. if (next.matches(selector)) nextEls.push(next);
  384. } else nextEls.push(next);
  385. el = next;
  386. }
  387. return nextEls;
  388. }
  389. function elementStyle(el, prop) {
  390. const window = getWindow();
  391. return window.getComputedStyle(el, null).getPropertyValue(prop);
  392. }
  393. function elementIndex(el) {
  394. let child = el;
  395. let i;
  396. if (child) {
  397. i = 0;
  398. // eslint-disable-next-line
  399. while ((child = child.previousSibling) !== null) {
  400. if (child.nodeType === 1) i += 1;
  401. }
  402. return i;
  403. }
  404. return undefined;
  405. }
  406. function elementParents(el, selector) {
  407. const parents = []; // eslint-disable-line
  408. let parent = el.parentElement; // eslint-disable-line
  409. while (parent) {
  410. if (selector) {
  411. if (parent.matches(selector)) parents.push(parent);
  412. } else {
  413. parents.push(parent);
  414. }
  415. parent = parent.parentElement;
  416. }
  417. return parents;
  418. }
  419. function elementTransitionEnd(el, callback) {
  420. function fireCallBack(e) {
  421. if (e.target !== el) return;
  422. callback.call(el, e);
  423. el.removeEventListener('transitionend', fireCallBack);
  424. }
  425. if (callback) {
  426. el.addEventListener('transitionend', fireCallBack);
  427. }
  428. }
  429. function elementOuterSize(el, size, includeMargins) {
  430. const window = getWindow();
  431. if (includeMargins) {
  432. return el[size === 'width' ? 'offsetWidth' : 'offsetHeight'] + parseFloat(window.getComputedStyle(el, null).getPropertyValue(size === 'width' ? 'margin-right' : 'margin-top')) + parseFloat(window.getComputedStyle(el, null).getPropertyValue(size === 'width' ? 'margin-left' : 'margin-bottom'));
  433. }
  434. return el.offsetWidth;
  435. }
  436. let support;
  437. function calcSupport() {
  438. const window = getWindow();
  439. const document = getDocument();
  440. return {
  441. smoothScroll: document.documentElement && document.documentElement.style && 'scrollBehavior' in document.documentElement.style,
  442. touch: !!('ontouchstart' in window || window.DocumentTouch && document instanceof window.DocumentTouch)
  443. };
  444. }
  445. function getSupport() {
  446. if (!support) {
  447. support = calcSupport();
  448. }
  449. return support;
  450. }
  451. let deviceCached;
  452. function calcDevice(_temp) {
  453. let {
  454. userAgent
  455. } = _temp === void 0 ? {} : _temp;
  456. const support = getSupport();
  457. const window = getWindow();
  458. const platform = window.navigator.platform;
  459. const ua = userAgent || window.navigator.userAgent;
  460. const device = {
  461. ios: false,
  462. android: false
  463. };
  464. const screenWidth = window.screen.width;
  465. const screenHeight = window.screen.height;
  466. const android = ua.match(/(Android);?[\s\/]+([\d.]+)?/); // eslint-disable-line
  467. let ipad = ua.match(/(iPad).*OS\s([\d_]+)/);
  468. const ipod = ua.match(/(iPod)(.*OS\s([\d_]+))?/);
  469. const iphone = !ipad && ua.match(/(iPhone\sOS|iOS)\s([\d_]+)/);
  470. const windows = platform === 'Win32';
  471. let macos = platform === 'MacIntel';
  472. // iPadOs 13 fix
  473. const iPadScreens = ['1024x1366', '1366x1024', '834x1194', '1194x834', '834x1112', '1112x834', '768x1024', '1024x768', '820x1180', '1180x820', '810x1080', '1080x810'];
  474. if (!ipad && macos && support.touch && iPadScreens.indexOf(`${screenWidth}x${screenHeight}`) >= 0) {
  475. ipad = ua.match(/(Version)\/([\d.]+)/);
  476. if (!ipad) ipad = [0, 1, '13_0_0'];
  477. macos = false;
  478. }
  479. // Android
  480. if (android && !windows) {
  481. device.os = 'android';
  482. device.android = true;
  483. }
  484. if (ipad || iphone || ipod) {
  485. device.os = 'ios';
  486. device.ios = true;
  487. }
  488. // Export object
  489. return device;
  490. }
  491. function getDevice(overrides) {
  492. if (overrides === void 0) {
  493. overrides = {};
  494. }
  495. if (!deviceCached) {
  496. deviceCached = calcDevice(overrides);
  497. }
  498. return deviceCached;
  499. }
  500. let browser;
  501. function calcBrowser() {
  502. const window = getWindow();
  503. let needPerspectiveFix = false;
  504. function isSafari() {
  505. const ua = window.navigator.userAgent.toLowerCase();
  506. return ua.indexOf('safari') >= 0 && ua.indexOf('chrome') < 0 && ua.indexOf('android') < 0;
  507. }
  508. if (isSafari()) {
  509. const ua = String(window.navigator.userAgent);
  510. if (ua.includes('Version/')) {
  511. const [major, minor] = ua.split('Version/')[1].split(' ')[0].split('.').map(num => Number(num));
  512. needPerspectiveFix = major < 16 || major === 16 && minor < 2;
  513. }
  514. }
  515. return {
  516. isSafari: needPerspectiveFix || isSafari(),
  517. needPerspectiveFix,
  518. isWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(window.navigator.userAgent)
  519. };
  520. }
  521. function getBrowser() {
  522. if (!browser) {
  523. browser = calcBrowser();
  524. }
  525. return browser;
  526. }
  527. function Resize(_ref) {
  528. let {
  529. swiper,
  530. on,
  531. emit
  532. } = _ref;
  533. const window = getWindow();
  534. let observer = null;
  535. let animationFrame = null;
  536. const resizeHandler = () => {
  537. if (!swiper || swiper.destroyed || !swiper.initialized) return;
  538. emit('beforeResize');
  539. emit('resize');
  540. };
  541. const createObserver = () => {
  542. if (!swiper || swiper.destroyed || !swiper.initialized) return;
  543. observer = new ResizeObserver(entries => {
  544. animationFrame = window.requestAnimationFrame(() => {
  545. const {
  546. width,
  547. height
  548. } = swiper;
  549. let newWidth = width;
  550. let newHeight = height;
  551. entries.forEach(_ref2 => {
  552. let {
  553. contentBoxSize,
  554. contentRect,
  555. target
  556. } = _ref2;
  557. if (target && target !== swiper.el) return;
  558. newWidth = contentRect ? contentRect.width : (contentBoxSize[0] || contentBoxSize).inlineSize;
  559. newHeight = contentRect ? contentRect.height : (contentBoxSize[0] || contentBoxSize).blockSize;
  560. });
  561. if (newWidth !== width || newHeight !== height) {
  562. resizeHandler();
  563. }
  564. });
  565. });
  566. observer.observe(swiper.el);
  567. };
  568. const removeObserver = () => {
  569. if (animationFrame) {
  570. window.cancelAnimationFrame(animationFrame);
  571. }
  572. if (observer && observer.unobserve && swiper.el) {
  573. observer.unobserve(swiper.el);
  574. observer = null;
  575. }
  576. };
  577. const orientationChangeHandler = () => {
  578. if (!swiper || swiper.destroyed || !swiper.initialized) return;
  579. emit('orientationchange');
  580. };
  581. on('init', () => {
  582. if (swiper.params.resizeObserver && typeof window.ResizeObserver !== 'undefined') {
  583. createObserver();
  584. return;
  585. }
  586. window.addEventListener('resize', resizeHandler);
  587. window.addEventListener('orientationchange', orientationChangeHandler);
  588. });
  589. on('destroy', () => {
  590. removeObserver();
  591. window.removeEventListener('resize', resizeHandler);
  592. window.removeEventListener('orientationchange', orientationChangeHandler);
  593. });
  594. }
  595. function Observer(_ref) {
  596. let {
  597. swiper,
  598. extendParams,
  599. on,
  600. emit
  601. } = _ref;
  602. const observers = [];
  603. const window = getWindow();
  604. const attach = function (target, options) {
  605. if (options === void 0) {
  606. options = {};
  607. }
  608. const ObserverFunc = window.MutationObserver || window.WebkitMutationObserver;
  609. const observer = new ObserverFunc(mutations => {
  610. // The observerUpdate event should only be triggered
  611. // once despite the number of mutations. Additional
  612. // triggers are redundant and are very costly
  613. if (swiper.__preventObserver__) return;
  614. if (mutations.length === 1) {
  615. emit('observerUpdate', mutations[0]);
  616. return;
  617. }
  618. const observerUpdate = function observerUpdate() {
  619. emit('observerUpdate', mutations[0]);
  620. };
  621. if (window.requestAnimationFrame) {
  622. window.requestAnimationFrame(observerUpdate);
  623. } else {
  624. window.setTimeout(observerUpdate, 0);
  625. }
  626. });
  627. observer.observe(target, {
  628. attributes: typeof options.attributes === 'undefined' ? true : options.attributes,
  629. childList: typeof options.childList === 'undefined' ? true : options.childList,
  630. characterData: typeof options.characterData === 'undefined' ? true : options.characterData
  631. });
  632. observers.push(observer);
  633. };
  634. const init = () => {
  635. if (!swiper.params.observer) return;
  636. if (swiper.params.observeParents) {
  637. const containerParents = elementParents(swiper.hostEl);
  638. for (let i = 0; i < containerParents.length; i += 1) {
  639. attach(containerParents[i]);
  640. }
  641. }
  642. // Observe container
  643. attach(swiper.hostEl, {
  644. childList: swiper.params.observeSlideChildren
  645. });
  646. // Observe wrapper
  647. attach(swiper.wrapperEl, {
  648. attributes: false
  649. });
  650. };
  651. const destroy = () => {
  652. observers.forEach(observer => {
  653. observer.disconnect();
  654. });
  655. observers.splice(0, observers.length);
  656. };
  657. extendParams({
  658. observer: false,
  659. observeParents: false,
  660. observeSlideChildren: false
  661. });
  662. on('init', init);
  663. on('destroy', destroy);
  664. }
  665. /* eslint-disable no-underscore-dangle */
  666. var eventsEmitter = {
  667. on(events, handler, priority) {
  668. const self = this;
  669. if (!self.eventsListeners || self.destroyed) return self;
  670. if (typeof handler !== 'function') return self;
  671. const method = priority ? 'unshift' : 'push';
  672. events.split(' ').forEach(event => {
  673. if (!self.eventsListeners[event]) self.eventsListeners[event] = [];
  674. self.eventsListeners[event][method](handler);
  675. });
  676. return self;
  677. },
  678. once(events, handler, priority) {
  679. const self = this;
  680. if (!self.eventsListeners || self.destroyed) return self;
  681. if (typeof handler !== 'function') return self;
  682. function onceHandler() {
  683. self.off(events, onceHandler);
  684. if (onceHandler.__emitterProxy) {
  685. delete onceHandler.__emitterProxy;
  686. }
  687. for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
  688. args[_key] = arguments[_key];
  689. }
  690. handler.apply(self, args);
  691. }
  692. onceHandler.__emitterProxy = handler;
  693. return self.on(events, onceHandler, priority);
  694. },
  695. onAny(handler, priority) {
  696. const self = this;
  697. if (!self.eventsListeners || self.destroyed) return self;
  698. if (typeof handler !== 'function') return self;
  699. const method = priority ? 'unshift' : 'push';
  700. if (self.eventsAnyListeners.indexOf(handler) < 0) {
  701. self.eventsAnyListeners[method](handler);
  702. }
  703. return self;
  704. },
  705. offAny(handler) {
  706. const self = this;
  707. if (!self.eventsListeners || self.destroyed) return self;
  708. if (!self.eventsAnyListeners) return self;
  709. const index = self.eventsAnyListeners.indexOf(handler);
  710. if (index >= 0) {
  711. self.eventsAnyListeners.splice(index, 1);
  712. }
  713. return self;
  714. },
  715. off(events, handler) {
  716. const self = this;
  717. if (!self.eventsListeners || self.destroyed) return self;
  718. if (!self.eventsListeners) return self;
  719. events.split(' ').forEach(event => {
  720. if (typeof handler === 'undefined') {
  721. self.eventsListeners[event] = [];
  722. } else if (self.eventsListeners[event]) {
  723. self.eventsListeners[event].forEach((eventHandler, index) => {
  724. if (eventHandler === handler || eventHandler.__emitterProxy && eventHandler.__emitterProxy === handler) {
  725. self.eventsListeners[event].splice(index, 1);
  726. }
  727. });
  728. }
  729. });
  730. return self;
  731. },
  732. emit() {
  733. const self = this;
  734. if (!self.eventsListeners || self.destroyed) return self;
  735. if (!self.eventsListeners) return self;
  736. let events;
  737. let data;
  738. let context;
  739. for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
  740. args[_key2] = arguments[_key2];
  741. }
  742. if (typeof args[0] === 'string' || Array.isArray(args[0])) {
  743. events = args[0];
  744. data = args.slice(1, args.length);
  745. context = self;
  746. } else {
  747. events = args[0].events;
  748. data = args[0].data;
  749. context = args[0].context || self;
  750. }
  751. data.unshift(context);
  752. const eventsArray = Array.isArray(events) ? events : events.split(' ');
  753. eventsArray.forEach(event => {
  754. if (self.eventsAnyListeners && self.eventsAnyListeners.length) {
  755. self.eventsAnyListeners.forEach(eventHandler => {
  756. eventHandler.apply(context, [event, ...data]);
  757. });
  758. }
  759. if (self.eventsListeners && self.eventsListeners[event]) {
  760. self.eventsListeners[event].forEach(eventHandler => {
  761. eventHandler.apply(context, data);
  762. });
  763. }
  764. });
  765. return self;
  766. }
  767. };
  768. function updateSize() {
  769. const swiper = this;
  770. let width;
  771. let height;
  772. const el = swiper.el;
  773. if (typeof swiper.params.width !== 'undefined' && swiper.params.width !== null) {
  774. width = swiper.params.width;
  775. } else {
  776. width = el.clientWidth;
  777. }
  778. if (typeof swiper.params.height !== 'undefined' && swiper.params.height !== null) {
  779. height = swiper.params.height;
  780. } else {
  781. height = el.clientHeight;
  782. }
  783. if (width === 0 && swiper.isHorizontal() || height === 0 && swiper.isVertical()) {
  784. return;
  785. }
  786. // Subtract paddings
  787. width = width - parseInt(elementStyle(el, 'padding-left') || 0, 10) - parseInt(elementStyle(el, 'padding-right') || 0, 10);
  788. height = height - parseInt(elementStyle(el, 'padding-top') || 0, 10) - parseInt(elementStyle(el, 'padding-bottom') || 0, 10);
  789. if (Number.isNaN(width)) width = 0;
  790. if (Number.isNaN(height)) height = 0;
  791. Object.assign(swiper, {
  792. width,
  793. height,
  794. size: swiper.isHorizontal() ? width : height
  795. });
  796. }
  797. function updateSlides() {
  798. const swiper = this;
  799. function getDirectionPropertyValue(node, label) {
  800. return parseFloat(node.getPropertyValue(swiper.getDirectionLabel(label)) || 0);
  801. }
  802. const params = swiper.params;
  803. const {
  804. wrapperEl,
  805. slidesEl,
  806. size: swiperSize,
  807. rtlTranslate: rtl,
  808. wrongRTL
  809. } = swiper;
  810. const isVirtual = swiper.virtual && params.virtual.enabled;
  811. const previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length;
  812. const slides = elementChildren(slidesEl, `.${swiper.params.slideClass}, swiper-slide`);
  813. const slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length;
  814. let snapGrid = [];
  815. const slidesGrid = [];
  816. const slidesSizesGrid = [];
  817. let offsetBefore = params.slidesOffsetBefore;
  818. if (typeof offsetBefore === 'function') {
  819. offsetBefore = params.slidesOffsetBefore.call(swiper);
  820. }
  821. let offsetAfter = params.slidesOffsetAfter;
  822. if (typeof offsetAfter === 'function') {
  823. offsetAfter = params.slidesOffsetAfter.call(swiper);
  824. }
  825. const previousSnapGridLength = swiper.snapGrid.length;
  826. const previousSlidesGridLength = swiper.slidesGrid.length;
  827. let spaceBetween = params.spaceBetween;
  828. let slidePosition = -offsetBefore;
  829. let prevSlideSize = 0;
  830. let index = 0;
  831. if (typeof swiperSize === 'undefined') {
  832. return;
  833. }
  834. if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {
  835. spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiperSize;
  836. } else if (typeof spaceBetween === 'string') {
  837. spaceBetween = parseFloat(spaceBetween);
  838. }
  839. swiper.virtualSize = -spaceBetween;
  840. // reset margins
  841. slides.forEach(slideEl => {
  842. if (rtl) {
  843. slideEl.style.marginLeft = '';
  844. } else {
  845. slideEl.style.marginRight = '';
  846. }
  847. slideEl.style.marginBottom = '';
  848. slideEl.style.marginTop = '';
  849. });
  850. // reset cssMode offsets
  851. if (params.centeredSlides && params.cssMode) {
  852. setCSSProperty(wrapperEl, '--swiper-centered-offset-before', '');
  853. setCSSProperty(wrapperEl, '--swiper-centered-offset-after', '');
  854. }
  855. const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid;
  856. if (gridEnabled) {
  857. swiper.grid.initSlides(slides);
  858. } else if (swiper.grid) {
  859. swiper.grid.unsetSlides();
  860. }
  861. // Calc slides
  862. let slideSize;
  863. const shouldResetSlideSize = params.slidesPerView === 'auto' && params.breakpoints && Object.keys(params.breakpoints).filter(key => {
  864. return typeof params.breakpoints[key].slidesPerView !== 'undefined';
  865. }).length > 0;
  866. for (let i = 0; i < slidesLength; i += 1) {
  867. slideSize = 0;
  868. let slide;
  869. if (slides[i]) slide = slides[i];
  870. if (gridEnabled) {
  871. swiper.grid.updateSlide(i, slide, slides);
  872. }
  873. if (slides[i] && elementStyle(slide, 'display') === 'none') continue; // eslint-disable-line
  874. if (params.slidesPerView === 'auto') {
  875. if (shouldResetSlideSize) {
  876. slides[i].style[swiper.getDirectionLabel('width')] = ``;
  877. }
  878. const slideStyles = getComputedStyle(slide);
  879. const currentTransform = slide.style.transform;
  880. const currentWebKitTransform = slide.style.webkitTransform;
  881. if (currentTransform) {
  882. slide.style.transform = 'none';
  883. }
  884. if (currentWebKitTransform) {
  885. slide.style.webkitTransform = 'none';
  886. }
  887. if (params.roundLengths) {
  888. slideSize = swiper.isHorizontal() ? elementOuterSize(slide, 'width', true) : elementOuterSize(slide, 'height', true);
  889. } else {
  890. // eslint-disable-next-line
  891. const width = getDirectionPropertyValue(slideStyles, 'width');
  892. const paddingLeft = getDirectionPropertyValue(slideStyles, 'padding-left');
  893. const paddingRight = getDirectionPropertyValue(slideStyles, 'padding-right');
  894. const marginLeft = getDirectionPropertyValue(slideStyles, 'margin-left');
  895. const marginRight = getDirectionPropertyValue(slideStyles, 'margin-right');
  896. const boxSizing = slideStyles.getPropertyValue('box-sizing');
  897. if (boxSizing && boxSizing === 'border-box') {
  898. slideSize = width + marginLeft + marginRight;
  899. } else {
  900. const {
  901. clientWidth,
  902. offsetWidth
  903. } = slide;
  904. slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight + (offsetWidth - clientWidth);
  905. }
  906. }
  907. if (currentTransform) {
  908. slide.style.transform = currentTransform;
  909. }
  910. if (currentWebKitTransform) {
  911. slide.style.webkitTransform = currentWebKitTransform;
  912. }
  913. if (params.roundLengths) slideSize = Math.floor(slideSize);
  914. } else {
  915. slideSize = (swiperSize - (params.slidesPerView - 1) * spaceBetween) / params.slidesPerView;
  916. if (params.roundLengths) slideSize = Math.floor(slideSize);
  917. if (slides[i]) {
  918. slides[i].style[swiper.getDirectionLabel('width')] = `${slideSize}px`;
  919. }
  920. }
  921. if (slides[i]) {
  922. slides[i].swiperSlideSize = slideSize;
  923. }
  924. slidesSizesGrid.push(slideSize);
  925. if (params.centeredSlides) {
  926. slidePosition = slidePosition + slideSize / 2 + prevSlideSize / 2 + spaceBetween;
  927. if (prevSlideSize === 0 && i !== 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;
  928. if (i === 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;
  929. if (Math.abs(slidePosition) < 1 / 1000) slidePosition = 0;
  930. if (params.roundLengths) slidePosition = Math.floor(slidePosition);
  931. if (index % params.slidesPerGroup === 0) snapGrid.push(slidePosition);
  932. slidesGrid.push(slidePosition);
  933. } else {
  934. if (params.roundLengths) slidePosition = Math.floor(slidePosition);
  935. if ((index - Math.min(swiper.params.slidesPerGroupSkip, index)) % swiper.params.slidesPerGroup === 0) snapGrid.push(slidePosition);
  936. slidesGrid.push(slidePosition);
  937. slidePosition = slidePosition + slideSize + spaceBetween;
  938. }
  939. swiper.virtualSize += slideSize + spaceBetween;
  940. prevSlideSize = slideSize;
  941. index += 1;
  942. }
  943. swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter;
  944. if (rtl && wrongRTL && (params.effect === 'slide' || params.effect === 'coverflow')) {
  945. wrapperEl.style.width = `${swiper.virtualSize + spaceBetween}px`;
  946. }
  947. if (params.setWrapperSize) {
  948. wrapperEl.style[swiper.getDirectionLabel('width')] = `${swiper.virtualSize + spaceBetween}px`;
  949. }
  950. if (gridEnabled) {
  951. swiper.grid.updateWrapperSize(slideSize, snapGrid);
  952. }
  953. // Remove last grid elements depending on width
  954. if (!params.centeredSlides) {
  955. const newSlidesGrid = [];
  956. for (let i = 0; i < snapGrid.length; i += 1) {
  957. let slidesGridItem = snapGrid[i];
  958. if (params.roundLengths) slidesGridItem = Math.floor(slidesGridItem);
  959. if (snapGrid[i] <= swiper.virtualSize - swiperSize) {
  960. newSlidesGrid.push(slidesGridItem);
  961. }
  962. }
  963. snapGrid = newSlidesGrid;
  964. if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) {
  965. snapGrid.push(swiper.virtualSize - swiperSize);
  966. }
  967. }
  968. if (isVirtual && params.loop) {
  969. const size = slidesSizesGrid[0] + spaceBetween;
  970. if (params.slidesPerGroup > 1) {
  971. const groups = Math.ceil((swiper.virtual.slidesBefore + swiper.virtual.slidesAfter) / params.slidesPerGroup);
  972. const groupSize = size * params.slidesPerGroup;
  973. for (let i = 0; i < groups; i += 1) {
  974. snapGrid.push(snapGrid[snapGrid.length - 1] + groupSize);
  975. }
  976. }
  977. for (let i = 0; i < swiper.virtual.slidesBefore + swiper.virtual.slidesAfter; i += 1) {
  978. if (params.slidesPerGroup === 1) {
  979. snapGrid.push(snapGrid[snapGrid.length - 1] + size);
  980. }
  981. slidesGrid.push(slidesGrid[slidesGrid.length - 1] + size);
  982. swiper.virtualSize += size;
  983. }
  984. }
  985. if (snapGrid.length === 0) snapGrid = [0];
  986. if (spaceBetween !== 0) {
  987. const key = swiper.isHorizontal() && rtl ? 'marginLeft' : swiper.getDirectionLabel('marginRight');
  988. slides.filter((_, slideIndex) => {
  989. if (!params.cssMode || params.loop) return true;
  990. if (slideIndex === slides.length - 1) {
  991. return false;
  992. }
  993. return true;
  994. }).forEach(slideEl => {
  995. slideEl.style[key] = `${spaceBetween}px`;
  996. });
  997. }
  998. if (params.centeredSlides && params.centeredSlidesBounds) {
  999. let allSlidesSize = 0;
  1000. slidesSizesGrid.forEach(slideSizeValue => {
  1001. allSlidesSize += slideSizeValue + (spaceBetween || 0);
  1002. });
  1003. allSlidesSize -= spaceBetween;
  1004. const maxSnap = allSlidesSize - swiperSize;
  1005. snapGrid = snapGrid.map(snap => {
  1006. if (snap <= 0) return -offsetBefore;
  1007. if (snap > maxSnap) return maxSnap + offsetAfter;
  1008. return snap;
  1009. });
  1010. }
  1011. if (params.centerInsufficientSlides) {
  1012. let allSlidesSize = 0;
  1013. slidesSizesGrid.forEach(slideSizeValue => {
  1014. allSlidesSize += slideSizeValue + (spaceBetween || 0);
  1015. });
  1016. allSlidesSize -= spaceBetween;
  1017. if (allSlidesSize < swiperSize) {
  1018. const allSlidesOffset = (swiperSize - allSlidesSize) / 2;
  1019. snapGrid.forEach((snap, snapIndex) => {
  1020. snapGrid[snapIndex] = snap - allSlidesOffset;
  1021. });
  1022. slidesGrid.forEach((snap, snapIndex) => {
  1023. slidesGrid[snapIndex] = snap + allSlidesOffset;
  1024. });
  1025. }
  1026. }
  1027. Object.assign(swiper, {
  1028. slides,
  1029. snapGrid,
  1030. slidesGrid,
  1031. slidesSizesGrid
  1032. });
  1033. if (params.centeredSlides && params.cssMode && !params.centeredSlidesBounds) {
  1034. setCSSProperty(wrapperEl, '--swiper-centered-offset-before', `${-snapGrid[0]}px`);
  1035. setCSSProperty(wrapperEl, '--swiper-centered-offset-after', `${swiper.size / 2 - slidesSizesGrid[slidesSizesGrid.length - 1] / 2}px`);
  1036. const addToSnapGrid = -swiper.snapGrid[0];
  1037. const addToSlidesGrid = -swiper.slidesGrid[0];
  1038. swiper.snapGrid = swiper.snapGrid.map(v => v + addToSnapGrid);
  1039. swiper.slidesGrid = swiper.slidesGrid.map(v => v + addToSlidesGrid);
  1040. }
  1041. if (slidesLength !== previousSlidesLength) {
  1042. swiper.emit('slidesLengthChange');
  1043. }
  1044. if (snapGrid.length !== previousSnapGridLength) {
  1045. if (swiper.params.watchOverflow) swiper.checkOverflow();
  1046. swiper.emit('snapGridLengthChange');
  1047. }
  1048. if (slidesGrid.length !== previousSlidesGridLength) {
  1049. swiper.emit('slidesGridLengthChange');
  1050. }
  1051. if (params.watchSlidesProgress) {
  1052. swiper.updateSlidesOffset();
  1053. }
  1054. swiper.emit('slidesUpdated');
  1055. if (!isVirtual && !params.cssMode && (params.effect === 'slide' || params.effect === 'fade')) {
  1056. const backFaceHiddenClass = `${params.containerModifierClass}backface-hidden`;
  1057. const hasClassBackfaceClassAdded = swiper.el.classList.contains(backFaceHiddenClass);
  1058. if (slidesLength <= params.maxBackfaceHiddenSlides) {
  1059. if (!hasClassBackfaceClassAdded) swiper.el.classList.add(backFaceHiddenClass);
  1060. } else if (hasClassBackfaceClassAdded) {
  1061. swiper.el.classList.remove(backFaceHiddenClass);
  1062. }
  1063. }
  1064. }
  1065. function updateAutoHeight(speed) {
  1066. const swiper = this;
  1067. const activeSlides = [];
  1068. const isVirtual = swiper.virtual && swiper.params.virtual.enabled;
  1069. let newHeight = 0;
  1070. let i;
  1071. if (typeof speed === 'number') {
  1072. swiper.setTransition(speed);
  1073. } else if (speed === true) {
  1074. swiper.setTransition(swiper.params.speed);
  1075. }
  1076. const getSlideByIndex = index => {
  1077. if (isVirtual) {
  1078. return swiper.slides[swiper.getSlideIndexByData(index)];
  1079. }
  1080. return swiper.slides[index];
  1081. };
  1082. // Find slides currently in view
  1083. if (swiper.params.slidesPerView !== 'auto' && swiper.params.slidesPerView > 1) {
  1084. if (swiper.params.centeredSlides) {
  1085. (swiper.visibleSlides || []).forEach(slide => {
  1086. activeSlides.push(slide);
  1087. });
  1088. } else {
  1089. for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) {
  1090. const index = swiper.activeIndex + i;
  1091. if (index > swiper.slides.length && !isVirtual) break;
  1092. activeSlides.push(getSlideByIndex(index));
  1093. }
  1094. }
  1095. } else {
  1096. activeSlides.push(getSlideByIndex(swiper.activeIndex));
  1097. }
  1098. // Find new height from highest slide in view
  1099. for (i = 0; i < activeSlides.length; i += 1) {
  1100. if (typeof activeSlides[i] !== 'undefined') {
  1101. const height = activeSlides[i].offsetHeight;
  1102. newHeight = height > newHeight ? height : newHeight;
  1103. }
  1104. }
  1105. // Update Height
  1106. if (newHeight || newHeight === 0) swiper.wrapperEl.style.height = `${newHeight}px`;
  1107. }
  1108. function updateSlidesOffset() {
  1109. const swiper = this;
  1110. const slides = swiper.slides;
  1111. // eslint-disable-next-line
  1112. const minusOffset = swiper.isElement ? swiper.isHorizontal() ? swiper.wrapperEl.offsetLeft : swiper.wrapperEl.offsetTop : 0;
  1113. for (let i = 0; i < slides.length; i += 1) {
  1114. slides[i].swiperSlideOffset = (swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop) - minusOffset - swiper.cssOverflowAdjustment();
  1115. }
  1116. }
  1117. function updateSlidesProgress(translate) {
  1118. if (translate === void 0) {
  1119. translate = this && this.translate || 0;
  1120. }
  1121. const swiper = this;
  1122. const params = swiper.params;
  1123. const {
  1124. slides,
  1125. rtlTranslate: rtl,
  1126. snapGrid
  1127. } = swiper;
  1128. if (slides.length === 0) return;
  1129. if (typeof slides[0].swiperSlideOffset === 'undefined') swiper.updateSlidesOffset();
  1130. let offsetCenter = -translate;
  1131. if (rtl) offsetCenter = translate;
  1132. // Visible Slides
  1133. slides.forEach(slideEl => {
  1134. slideEl.classList.remove(params.slideVisibleClass, params.slideFullyVisibleClass);
  1135. });
  1136. swiper.visibleSlidesIndexes = [];
  1137. swiper.visibleSlides = [];
  1138. let spaceBetween = params.spaceBetween;
  1139. if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {
  1140. spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiper.size;
  1141. } else if (typeof spaceBetween === 'string') {
  1142. spaceBetween = parseFloat(spaceBetween);
  1143. }
  1144. for (let i = 0; i < slides.length; i += 1) {
  1145. const slide = slides[i];
  1146. let slideOffset = slide.swiperSlideOffset;
  1147. if (params.cssMode && params.centeredSlides) {
  1148. slideOffset -= slides[0].swiperSlideOffset;
  1149. }
  1150. const slideProgress = (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + spaceBetween);
  1151. const originalSlideProgress = (offsetCenter - snapGrid[0] + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + spaceBetween);
  1152. const slideBefore = -(offsetCenter - slideOffset);
  1153. const slideAfter = slideBefore + swiper.slidesSizesGrid[i];
  1154. const isFullyVisible = slideBefore >= 0 && slideBefore <= swiper.size - swiper.slidesSizesGrid[i];
  1155. const isVisible = slideBefore >= 0 && slideBefore < swiper.size - 1 || slideAfter > 1 && slideAfter <= swiper.size || slideBefore <= 0 && slideAfter >= swiper.size;
  1156. if (isVisible) {
  1157. swiper.visibleSlides.push(slide);
  1158. swiper.visibleSlidesIndexes.push(i);
  1159. slides[i].classList.add(params.slideVisibleClass);
  1160. }
  1161. if (isFullyVisible) {
  1162. slides[i].classList.add(params.slideFullyVisibleClass);
  1163. }
  1164. slide.progress = rtl ? -slideProgress : slideProgress;
  1165. slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress;
  1166. }
  1167. }
  1168. function updateProgress(translate) {
  1169. const swiper = this;
  1170. if (typeof translate === 'undefined') {
  1171. const multiplier = swiper.rtlTranslate ? -1 : 1;
  1172. // eslint-disable-next-line
  1173. translate = swiper && swiper.translate && swiper.translate * multiplier || 0;
  1174. }
  1175. const params = swiper.params;
  1176. const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();
  1177. let {
  1178. progress,
  1179. isBeginning,
  1180. isEnd,
  1181. progressLoop
  1182. } = swiper;
  1183. const wasBeginning = isBeginning;
  1184. const wasEnd = isEnd;
  1185. if (translatesDiff === 0) {
  1186. progress = 0;
  1187. isBeginning = true;
  1188. isEnd = true;
  1189. } else {
  1190. progress = (translate - swiper.minTranslate()) / translatesDiff;
  1191. const isBeginningRounded = Math.abs(translate - swiper.minTranslate()) < 1;
  1192. const isEndRounded = Math.abs(translate - swiper.maxTranslate()) < 1;
  1193. isBeginning = isBeginningRounded || progress <= 0;
  1194. isEnd = isEndRounded || progress >= 1;
  1195. if (isBeginningRounded) progress = 0;
  1196. if (isEndRounded) progress = 1;
  1197. }
  1198. if (params.loop) {
  1199. const firstSlideIndex = swiper.getSlideIndexByData(0);
  1200. const lastSlideIndex = swiper.getSlideIndexByData(swiper.slides.length - 1);
  1201. const firstSlideTranslate = swiper.slidesGrid[firstSlideIndex];
  1202. const lastSlideTranslate = swiper.slidesGrid[lastSlideIndex];
  1203. const translateMax = swiper.slidesGrid[swiper.slidesGrid.length - 1];
  1204. const translateAbs = Math.abs(translate);
  1205. if (translateAbs >= firstSlideTranslate) {
  1206. progressLoop = (translateAbs - firstSlideTranslate) / translateMax;
  1207. } else {
  1208. progressLoop = (translateAbs + translateMax - lastSlideTranslate) / translateMax;
  1209. }
  1210. if (progressLoop > 1) progressLoop -= 1;
  1211. }
  1212. Object.assign(swiper, {
  1213. progress,
  1214. progressLoop,
  1215. isBeginning,
  1216. isEnd
  1217. });
  1218. if (params.watchSlidesProgress || params.centeredSlides && params.autoHeight) swiper.updateSlidesProgress(translate);
  1219. if (isBeginning && !wasBeginning) {
  1220. swiper.emit('reachBeginning toEdge');
  1221. }
  1222. if (isEnd && !wasEnd) {
  1223. swiper.emit('reachEnd toEdge');
  1224. }
  1225. if (wasBeginning && !isBeginning || wasEnd && !isEnd) {
  1226. swiper.emit('fromEdge');
  1227. }
  1228. swiper.emit('progress', progress);
  1229. }
  1230. function updateSlidesClasses() {
  1231. const swiper = this;
  1232. const {
  1233. slides,
  1234. params,
  1235. slidesEl,
  1236. activeIndex
  1237. } = swiper;
  1238. const isVirtual = swiper.virtual && params.virtual.enabled;
  1239. const gridEnabled = swiper.grid && params.grid && params.grid.rows > 1;
  1240. const getFilteredSlide = selector => {
  1241. return elementChildren(slidesEl, `.${params.slideClass}${selector}, swiper-slide${selector}`)[0];
  1242. };
  1243. slides.forEach(slideEl => {
  1244. slideEl.classList.remove(params.slideActiveClass, params.slideNextClass, params.slidePrevClass);
  1245. });
  1246. let activeSlide;
  1247. let prevSlide;
  1248. let nextSlide;
  1249. if (isVirtual) {
  1250. if (params.loop) {
  1251. let slideIndex = activeIndex - swiper.virtual.slidesBefore;
  1252. if (slideIndex < 0) slideIndex = swiper.virtual.slides.length + slideIndex;
  1253. if (slideIndex >= swiper.virtual.slides.length) slideIndex -= swiper.virtual.slides.length;
  1254. activeSlide = getFilteredSlide(`[data-swiper-slide-index="${slideIndex}"]`);
  1255. } else {
  1256. activeSlide = getFilteredSlide(`[data-swiper-slide-index="${activeIndex}"]`);
  1257. }
  1258. } else {
  1259. if (gridEnabled) {
  1260. activeSlide = slides.filter(slideEl => slideEl.column === activeIndex)[0];
  1261. nextSlide = slides.filter(slideEl => slideEl.column === activeIndex + 1)[0];
  1262. prevSlide = slides.filter(slideEl => slideEl.column === activeIndex - 1)[0];
  1263. } else {
  1264. activeSlide = slides[activeIndex];
  1265. }
  1266. }
  1267. if (activeSlide) {
  1268. // Active classes
  1269. activeSlide.classList.add(params.slideActiveClass);
  1270. if (gridEnabled) {
  1271. if (nextSlide) {
  1272. nextSlide.classList.add(params.slideNextClass);
  1273. }
  1274. if (prevSlide) {
  1275. prevSlide.classList.add(params.slidePrevClass);
  1276. }
  1277. } else {
  1278. // Next Slide
  1279. nextSlide = elementNextAll(activeSlide, `.${params.slideClass}, swiper-slide`)[0];
  1280. if (params.loop && !nextSlide) {
  1281. nextSlide = slides[0];
  1282. }
  1283. if (nextSlide) {
  1284. nextSlide.classList.add(params.slideNextClass);
  1285. }
  1286. // Prev Slide
  1287. prevSlide = elementPrevAll(activeSlide, `.${params.slideClass}, swiper-slide`)[0];
  1288. if (params.loop && !prevSlide === 0) {
  1289. prevSlide = slides[slides.length - 1];
  1290. }
  1291. if (prevSlide) {
  1292. prevSlide.classList.add(params.slidePrevClass);
  1293. }
  1294. }
  1295. }
  1296. swiper.emitSlidesClasses();
  1297. }
  1298. const processLazyPreloader = (swiper, imageEl) => {
  1299. if (!swiper || swiper.destroyed || !swiper.params) return;
  1300. const slideSelector = () => swiper.isElement ? `swiper-slide` : `.${swiper.params.slideClass}`;
  1301. const slideEl = imageEl.closest(slideSelector());
  1302. if (slideEl) {
  1303. let lazyEl = slideEl.querySelector(`.${swiper.params.lazyPreloaderClass}`);
  1304. if (!lazyEl && swiper.isElement) {
  1305. if (slideEl.shadowRoot) {
  1306. lazyEl = slideEl.shadowRoot.querySelector(`.${swiper.params.lazyPreloaderClass}`);
  1307. } else {
  1308. // init later
  1309. requestAnimationFrame(() => {
  1310. if (slideEl.shadowRoot) {
  1311. lazyEl = slideEl.shadowRoot.querySelector(`.${swiper.params.lazyPreloaderClass}`);
  1312. if (lazyEl) lazyEl.remove();
  1313. }
  1314. });
  1315. }
  1316. }
  1317. if (lazyEl) lazyEl.remove();
  1318. }
  1319. };
  1320. const unlazy = (swiper, index) => {
  1321. if (!swiper.slides[index]) return;
  1322. const imageEl = swiper.slides[index].querySelector('[loading="lazy"]');
  1323. if (imageEl) imageEl.removeAttribute('loading');
  1324. };
  1325. const preload = swiper => {
  1326. if (!swiper || swiper.destroyed || !swiper.params) return;
  1327. let amount = swiper.params.lazyPreloadPrevNext;
  1328. const len = swiper.slides.length;
  1329. if (!len || !amount || amount < 0) return;
  1330. amount = Math.min(amount, len);
  1331. const slidesPerView = swiper.params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : Math.ceil(swiper.params.slidesPerView);
  1332. const activeIndex = swiper.activeIndex;
  1333. if (swiper.params.grid && swiper.params.grid.rows > 1) {
  1334. const activeColumn = activeIndex;
  1335. const preloadColumns = [activeColumn - amount];
  1336. preloadColumns.push(...Array.from({
  1337. length: amount
  1338. }).map((_, i) => {
  1339. return activeColumn + slidesPerView + i;
  1340. }));
  1341. swiper.slides.forEach((slideEl, i) => {
  1342. if (preloadColumns.includes(slideEl.column)) unlazy(swiper, i);
  1343. });
  1344. return;
  1345. }
  1346. const slideIndexLastInView = activeIndex + slidesPerView - 1;
  1347. if (swiper.params.rewind || swiper.params.loop) {
  1348. for (let i = activeIndex - amount; i <= slideIndexLastInView + amount; i += 1) {
  1349. const realIndex = (i % len + len) % len;
  1350. if (realIndex < activeIndex || realIndex > slideIndexLastInView) unlazy(swiper, realIndex);
  1351. }
  1352. } else {
  1353. for (let i = Math.max(activeIndex - amount, 0); i <= Math.min(slideIndexLastInView + amount, len - 1); i += 1) {
  1354. if (i !== activeIndex && (i > slideIndexLastInView || i < activeIndex)) {
  1355. unlazy(swiper, i);
  1356. }
  1357. }
  1358. }
  1359. };
  1360. function getActiveIndexByTranslate(swiper) {
  1361. const {
  1362. slidesGrid,
  1363. params
  1364. } = swiper;
  1365. const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;
  1366. let activeIndex;
  1367. for (let i = 0; i < slidesGrid.length; i += 1) {
  1368. if (typeof slidesGrid[i + 1] !== 'undefined') {
  1369. if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - (slidesGrid[i + 1] - slidesGrid[i]) / 2) {
  1370. activeIndex = i;
  1371. } else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) {
  1372. activeIndex = i + 1;
  1373. }
  1374. } else if (translate >= slidesGrid[i]) {
  1375. activeIndex = i;
  1376. }
  1377. }
  1378. // Normalize slideIndex
  1379. if (params.normalizeSlideIndex) {
  1380. if (activeIndex < 0 || typeof activeIndex === 'undefined') activeIndex = 0;
  1381. }
  1382. return activeIndex;
  1383. }
  1384. function updateActiveIndex(newActiveIndex) {
  1385. const swiper = this;
  1386. const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;
  1387. const {
  1388. snapGrid,
  1389. params,
  1390. activeIndex: previousIndex,
  1391. realIndex: previousRealIndex,
  1392. snapIndex: previousSnapIndex
  1393. } = swiper;
  1394. let activeIndex = newActiveIndex;
  1395. let snapIndex;
  1396. const getVirtualRealIndex = aIndex => {
  1397. let realIndex = aIndex - swiper.virtual.slidesBefore;
  1398. if (realIndex < 0) {
  1399. realIndex = swiper.virtual.slides.length + realIndex;
  1400. }
  1401. if (realIndex >= swiper.virtual.slides.length) {
  1402. realIndex -= swiper.virtual.slides.length;
  1403. }
  1404. return realIndex;
  1405. };
  1406. if (typeof activeIndex === 'undefined') {
  1407. activeIndex = getActiveIndexByTranslate(swiper);
  1408. }
  1409. if (snapGrid.indexOf(translate) >= 0) {
  1410. snapIndex = snapGrid.indexOf(translate);
  1411. } else {
  1412. const skip = Math.min(params.slidesPerGroupSkip, activeIndex);
  1413. snapIndex = skip + Math.floor((activeIndex - skip) / params.slidesPerGroup);
  1414. }
  1415. if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;
  1416. if (activeIndex === previousIndex && !swiper.params.loop) {
  1417. if (snapIndex !== previousSnapIndex) {
  1418. swiper.snapIndex = snapIndex;
  1419. swiper.emit('snapIndexChange');
  1420. }
  1421. return;
  1422. }
  1423. if (activeIndex === previousIndex && swiper.params.loop && swiper.virtual && swiper.params.virtual.enabled) {
  1424. swiper.realIndex = getVirtualRealIndex(activeIndex);
  1425. return;
  1426. }
  1427. const gridEnabled = swiper.grid && params.grid && params.grid.rows > 1;
  1428. // Get real index
  1429. let realIndex;
  1430. if (swiper.virtual && params.virtual.enabled && params.loop) {
  1431. realIndex = getVirtualRealIndex(activeIndex);
  1432. } else if (gridEnabled) {
  1433. const firstSlideInColumn = swiper.slides.filter(slideEl => slideEl.column === activeIndex)[0];
  1434. let activeSlideIndex = parseInt(firstSlideInColumn.getAttribute('data-swiper-slide-index'), 10);
  1435. if (Number.isNaN(activeSlideIndex)) {
  1436. activeSlideIndex = Math.max(swiper.slides.indexOf(firstSlideInColumn), 0);
  1437. }
  1438. realIndex = Math.floor(activeSlideIndex / params.grid.rows);
  1439. } else if (swiper.slides[activeIndex]) {
  1440. const slideIndex = swiper.slides[activeIndex].getAttribute('data-swiper-slide-index');
  1441. if (slideIndex) {
  1442. realIndex = parseInt(slideIndex, 10);
  1443. } else {
  1444. realIndex = activeIndex;
  1445. }
  1446. } else {
  1447. realIndex = activeIndex;
  1448. }
  1449. Object.assign(swiper, {
  1450. previousSnapIndex,
  1451. snapIndex,
  1452. previousRealIndex,
  1453. realIndex,
  1454. previousIndex,
  1455. activeIndex
  1456. });
  1457. if (swiper.initialized) {
  1458. preload(swiper);
  1459. }
  1460. swiper.emit('activeIndexChange');
  1461. swiper.emit('snapIndexChange');
  1462. if (swiper.initialized || swiper.params.runCallbacksOnInit) {
  1463. if (previousRealIndex !== realIndex) {
  1464. swiper.emit('realIndexChange');
  1465. }
  1466. swiper.emit('slideChange');
  1467. }
  1468. }
  1469. function updateClickedSlide(el, path) {
  1470. const swiper = this;
  1471. const params = swiper.params;
  1472. let slide = el.closest(`.${params.slideClass}, swiper-slide`);
  1473. if (!slide && swiper.isElement && path && path.length > 1 && path.includes(el)) {
  1474. [...path.slice(path.indexOf(el) + 1, path.length)].forEach(pathEl => {
  1475. if (!slide && pathEl.matches && pathEl.matches(`.${params.slideClass}, swiper-slide`)) {
  1476. slide = pathEl;
  1477. }
  1478. });
  1479. }
  1480. let slideFound = false;
  1481. let slideIndex;
  1482. if (slide) {
  1483. for (let i = 0; i < swiper.slides.length; i += 1) {
  1484. if (swiper.slides[i] === slide) {
  1485. slideFound = true;
  1486. slideIndex = i;
  1487. break;
  1488. }
  1489. }
  1490. }
  1491. if (slide && slideFound) {
  1492. swiper.clickedSlide = slide;
  1493. if (swiper.virtual && swiper.params.virtual.enabled) {
  1494. swiper.clickedIndex = parseInt(slide.getAttribute('data-swiper-slide-index'), 10);
  1495. } else {
  1496. swiper.clickedIndex = slideIndex;
  1497. }
  1498. } else {
  1499. swiper.clickedSlide = undefined;
  1500. swiper.clickedIndex = undefined;
  1501. return;
  1502. }
  1503. if (params.slideToClickedSlide && swiper.clickedIndex !== undefined && swiper.clickedIndex !== swiper.activeIndex) {
  1504. swiper.slideToClickedSlide();
  1505. }
  1506. }
  1507. var update = {
  1508. updateSize,
  1509. updateSlides,
  1510. updateAutoHeight,
  1511. updateSlidesOffset,
  1512. updateSlidesProgress,
  1513. updateProgress,
  1514. updateSlidesClasses,
  1515. updateActiveIndex,
  1516. updateClickedSlide
  1517. };
  1518. function getSwiperTranslate(axis) {
  1519. if (axis === void 0) {
  1520. axis = this.isHorizontal() ? 'x' : 'y';
  1521. }
  1522. const swiper = this;
  1523. const {
  1524. params,
  1525. rtlTranslate: rtl,
  1526. translate,
  1527. wrapperEl
  1528. } = swiper;
  1529. if (params.virtualTranslate) {
  1530. return rtl ? -translate : translate;
  1531. }
  1532. if (params.cssMode) {
  1533. return translate;
  1534. }
  1535. let currentTranslate = getTranslate(wrapperEl, axis);
  1536. currentTranslate += swiper.cssOverflowAdjustment();
  1537. if (rtl) currentTranslate = -currentTranslate;
  1538. return currentTranslate || 0;
  1539. }
  1540. function setTranslate(translate, byController) {
  1541. const swiper = this;
  1542. const {
  1543. rtlTranslate: rtl,
  1544. params,
  1545. wrapperEl,
  1546. progress
  1547. } = swiper;
  1548. let x = 0;
  1549. let y = 0;
  1550. const z = 0;
  1551. if (swiper.isHorizontal()) {
  1552. x = rtl ? -translate : translate;
  1553. } else {
  1554. y = translate;
  1555. }
  1556. if (params.roundLengths) {
  1557. x = Math.floor(x);
  1558. y = Math.floor(y);
  1559. }
  1560. swiper.previousTranslate = swiper.translate;
  1561. swiper.translate = swiper.isHorizontal() ? x : y;
  1562. if (params.cssMode) {
  1563. wrapperEl[swiper.isHorizontal() ? 'scrollLeft' : 'scrollTop'] = swiper.isHorizontal() ? -x : -y;
  1564. } else if (!params.virtualTranslate) {
  1565. if (swiper.isHorizontal()) {
  1566. x -= swiper.cssOverflowAdjustment();
  1567. } else {
  1568. y -= swiper.cssOverflowAdjustment();
  1569. }
  1570. wrapperEl.style.transform = `translate3d(${x}px, ${y}px, ${z}px)`;
  1571. }
  1572. // Check if we need to update progress
  1573. let newProgress;
  1574. const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();
  1575. if (translatesDiff === 0) {
  1576. newProgress = 0;
  1577. } else {
  1578. newProgress = (translate - swiper.minTranslate()) / translatesDiff;
  1579. }
  1580. if (newProgress !== progress) {
  1581. swiper.updateProgress(translate);
  1582. }
  1583. swiper.emit('setTranslate', swiper.translate, byController);
  1584. }
  1585. function minTranslate() {
  1586. return -this.snapGrid[0];
  1587. }
  1588. function maxTranslate() {
  1589. return -this.snapGrid[this.snapGrid.length - 1];
  1590. }
  1591. function translateTo(translate, speed, runCallbacks, translateBounds, internal) {
  1592. if (translate === void 0) {
  1593. translate = 0;
  1594. }
  1595. if (speed === void 0) {
  1596. speed = this.params.speed;
  1597. }
  1598. if (runCallbacks === void 0) {
  1599. runCallbacks = true;
  1600. }
  1601. if (translateBounds === void 0) {
  1602. translateBounds = true;
  1603. }
  1604. const swiper = this;
  1605. const {
  1606. params,
  1607. wrapperEl
  1608. } = swiper;
  1609. if (swiper.animating && params.preventInteractionOnTransition) {
  1610. return false;
  1611. }
  1612. const minTranslate = swiper.minTranslate();
  1613. const maxTranslate = swiper.maxTranslate();
  1614. let newTranslate;
  1615. if (translateBounds && translate > minTranslate) newTranslate = minTranslate;else if (translateBounds && translate < maxTranslate) newTranslate = maxTranslate;else newTranslate = translate;
  1616. // Update progress
  1617. swiper.updateProgress(newTranslate);
  1618. if (params.cssMode) {
  1619. const isH = swiper.isHorizontal();
  1620. if (speed === 0) {
  1621. wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = -newTranslate;
  1622. } else {
  1623. if (!swiper.support.smoothScroll) {
  1624. animateCSSModeScroll({
  1625. swiper,
  1626. targetPosition: -newTranslate,
  1627. side: isH ? 'left' : 'top'
  1628. });
  1629. return true;
  1630. }
  1631. wrapperEl.scrollTo({
  1632. [isH ? 'left' : 'top']: -newTranslate,
  1633. behavior: 'smooth'
  1634. });
  1635. }
  1636. return true;
  1637. }
  1638. if (speed === 0) {
  1639. swiper.setTransition(0);
  1640. swiper.setTranslate(newTranslate);
  1641. if (runCallbacks) {
  1642. swiper.emit('beforeTransitionStart', speed, internal);
  1643. swiper.emit('transitionEnd');
  1644. }
  1645. } else {
  1646. swiper.setTransition(speed);
  1647. swiper.setTranslate(newTranslate);
  1648. if (runCallbacks) {
  1649. swiper.emit('beforeTransitionStart', speed, internal);
  1650. swiper.emit('transitionStart');
  1651. }
  1652. if (!swiper.animating) {
  1653. swiper.animating = true;
  1654. if (!swiper.onTranslateToWrapperTransitionEnd) {
  1655. swiper.onTranslateToWrapperTransitionEnd = function transitionEnd(e) {
  1656. if (!swiper || swiper.destroyed) return;
  1657. if (e.target !== this) return;
  1658. swiper.wrapperEl.removeEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);
  1659. swiper.onTranslateToWrapperTransitionEnd = null;
  1660. delete swiper.onTranslateToWrapperTransitionEnd;
  1661. if (runCallbacks) {
  1662. swiper.emit('transitionEnd');
  1663. }
  1664. };
  1665. }
  1666. swiper.wrapperEl.addEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);
  1667. }
  1668. }
  1669. return true;
  1670. }
  1671. var translate = {
  1672. getTranslate: getSwiperTranslate,
  1673. setTranslate,
  1674. minTranslate,
  1675. maxTranslate,
  1676. translateTo
  1677. };
  1678. function setTransition(duration, byController) {
  1679. const swiper = this;
  1680. if (!swiper.params.cssMode) {
  1681. swiper.wrapperEl.style.transitionDuration = `${duration}ms`;
  1682. swiper.wrapperEl.style.transitionDelay = duration === 0 ? `0ms` : '';
  1683. }
  1684. swiper.emit('setTransition', duration, byController);
  1685. }
  1686. function transitionEmit(_ref) {
  1687. let {
  1688. swiper,
  1689. runCallbacks,
  1690. direction,
  1691. step
  1692. } = _ref;
  1693. const {
  1694. activeIndex,
  1695. previousIndex
  1696. } = swiper;
  1697. let dir = direction;
  1698. if (!dir) {
  1699. if (activeIndex > previousIndex) dir = 'next';else if (activeIndex < previousIndex) dir = 'prev';else dir = 'reset';
  1700. }
  1701. swiper.emit(`transition${step}`);
  1702. if (runCallbacks && activeIndex !== previousIndex) {
  1703. if (dir === 'reset') {
  1704. swiper.emit(`slideResetTransition${step}`);
  1705. return;
  1706. }
  1707. swiper.emit(`slideChangeTransition${step}`);
  1708. if (dir === 'next') {
  1709. swiper.emit(`slideNextTransition${step}`);
  1710. } else {
  1711. swiper.emit(`slidePrevTransition${step}`);
  1712. }
  1713. }
  1714. }
  1715. function transitionStart(runCallbacks, direction) {
  1716. if (runCallbacks === void 0) {
  1717. runCallbacks = true;
  1718. }
  1719. const swiper = this;
  1720. const {
  1721. params
  1722. } = swiper;
  1723. if (params.cssMode) return;
  1724. if (params.autoHeight) {
  1725. swiper.updateAutoHeight();
  1726. }
  1727. transitionEmit({
  1728. swiper,
  1729. runCallbacks,
  1730. direction,
  1731. step: 'Start'
  1732. });
  1733. }
  1734. function transitionEnd(runCallbacks, direction) {
  1735. if (runCallbacks === void 0) {
  1736. runCallbacks = true;
  1737. }
  1738. const swiper = this;
  1739. const {
  1740. params
  1741. } = swiper;
  1742. swiper.animating = false;
  1743. if (params.cssMode) return;
  1744. swiper.setTransition(0);
  1745. transitionEmit({
  1746. swiper,
  1747. runCallbacks,
  1748. direction,
  1749. step: 'End'
  1750. });
  1751. }
  1752. var transition = {
  1753. setTransition,
  1754. transitionStart,
  1755. transitionEnd
  1756. };
  1757. function slideTo(index, speed, runCallbacks, internal, initial) {
  1758. if (index === void 0) {
  1759. index = 0;
  1760. }
  1761. if (speed === void 0) {
  1762. speed = this.params.speed;
  1763. }
  1764. if (runCallbacks === void 0) {
  1765. runCallbacks = true;
  1766. }
  1767. if (typeof index === 'string') {
  1768. index = parseInt(index, 10);
  1769. }
  1770. const swiper = this;
  1771. let slideIndex = index;
  1772. if (slideIndex < 0) slideIndex = 0;
  1773. const {
  1774. params,
  1775. snapGrid,
  1776. slidesGrid,
  1777. previousIndex,
  1778. activeIndex,
  1779. rtlTranslate: rtl,
  1780. wrapperEl,
  1781. enabled
  1782. } = swiper;
  1783. if (swiper.animating && params.preventInteractionOnTransition || !enabled && !internal && !initial) {
  1784. return false;
  1785. }
  1786. const skip = Math.min(swiper.params.slidesPerGroupSkip, slideIndex);
  1787. let snapIndex = skip + Math.floor((slideIndex - skip) / swiper.params.slidesPerGroup);
  1788. if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;
  1789. const translate = -snapGrid[snapIndex];
  1790. // Normalize slideIndex
  1791. if (params.normalizeSlideIndex) {
  1792. for (let i = 0; i < slidesGrid.length; i += 1) {
  1793. const normalizedTranslate = -Math.floor(translate * 100);
  1794. const normalizedGrid = Math.floor(slidesGrid[i] * 100);
  1795. const normalizedGridNext = Math.floor(slidesGrid[i + 1] * 100);
  1796. if (typeof slidesGrid[i + 1] !== 'undefined') {
  1797. if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext - (normalizedGridNext - normalizedGrid) / 2) {
  1798. slideIndex = i;
  1799. } else if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext) {
  1800. slideIndex = i + 1;
  1801. }
  1802. } else if (normalizedTranslate >= normalizedGrid) {
  1803. slideIndex = i;
  1804. }
  1805. }
  1806. }
  1807. // Directions locks
  1808. if (swiper.initialized && slideIndex !== activeIndex) {
  1809. if (!swiper.allowSlideNext && (rtl ? translate > swiper.translate && translate > swiper.minTranslate() : translate < swiper.translate && translate < swiper.minTranslate())) {
  1810. return false;
  1811. }
  1812. if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {
  1813. if ((activeIndex || 0) !== slideIndex) {
  1814. return false;
  1815. }
  1816. }
  1817. }
  1818. if (slideIndex !== (previousIndex || 0) && runCallbacks) {
  1819. swiper.emit('beforeSlideChangeStart');
  1820. }
  1821. // Update progress
  1822. swiper.updateProgress(translate);
  1823. let direction;
  1824. if (slideIndex > activeIndex) direction = 'next';else if (slideIndex < activeIndex) direction = 'prev';else direction = 'reset';
  1825. // Update Index
  1826. if (rtl && -translate === swiper.translate || !rtl && translate === swiper.translate) {
  1827. swiper.updateActiveIndex(slideIndex);
  1828. // Update Height
  1829. if (params.autoHeight) {
  1830. swiper.updateAutoHeight();
  1831. }
  1832. swiper.updateSlidesClasses();
  1833. if (params.effect !== 'slide') {
  1834. swiper.setTranslate(translate);
  1835. }
  1836. if (direction !== 'reset') {
  1837. swiper.transitionStart(runCallbacks, direction);
  1838. swiper.transitionEnd(runCallbacks, direction);
  1839. }
  1840. return false;
  1841. }
  1842. if (params.cssMode) {
  1843. const isH = swiper.isHorizontal();
  1844. const t = rtl ? translate : -translate;
  1845. if (speed === 0) {
  1846. const isVirtual = swiper.virtual && swiper.params.virtual.enabled;
  1847. if (isVirtual) {
  1848. swiper.wrapperEl.style.scrollSnapType = 'none';
  1849. swiper._immediateVirtual = true;
  1850. }
  1851. if (isVirtual && !swiper._cssModeVirtualInitialSet && swiper.params.initialSlide > 0) {
  1852. swiper._cssModeVirtualInitialSet = true;
  1853. requestAnimationFrame(() => {
  1854. wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;
  1855. });
  1856. } else {
  1857. wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;
  1858. }
  1859. if (isVirtual) {
  1860. requestAnimationFrame(() => {
  1861. swiper.wrapperEl.style.scrollSnapType = '';
  1862. swiper._immediateVirtual = false;
  1863. });
  1864. }
  1865. } else {
  1866. if (!swiper.support.smoothScroll) {
  1867. animateCSSModeScroll({
  1868. swiper,
  1869. targetPosition: t,
  1870. side: isH ? 'left' : 'top'
  1871. });
  1872. return true;
  1873. }
  1874. wrapperEl.scrollTo({
  1875. [isH ? 'left' : 'top']: t,
  1876. behavior: 'smooth'
  1877. });
  1878. }
  1879. return true;
  1880. }
  1881. swiper.setTransition(speed);
  1882. swiper.setTranslate(translate);
  1883. swiper.updateActiveIndex(slideIndex);
  1884. swiper.updateSlidesClasses();
  1885. swiper.emit('beforeTransitionStart', speed, internal);
  1886. swiper.transitionStart(runCallbacks, direction);
  1887. if (speed === 0) {
  1888. swiper.transitionEnd(runCallbacks, direction);
  1889. } else if (!swiper.animating) {
  1890. swiper.animating = true;
  1891. if (!swiper.onSlideToWrapperTransitionEnd) {
  1892. swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) {
  1893. if (!swiper || swiper.destroyed) return;
  1894. if (e.target !== this) return;
  1895. swiper.wrapperEl.removeEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);
  1896. swiper.onSlideToWrapperTransitionEnd = null;
  1897. delete swiper.onSlideToWrapperTransitionEnd;
  1898. swiper.transitionEnd(runCallbacks, direction);
  1899. };
  1900. }
  1901. swiper.wrapperEl.addEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);
  1902. }
  1903. return true;
  1904. }
  1905. function slideToLoop(index, speed, runCallbacks, internal) {
  1906. if (index === void 0) {
  1907. index = 0;
  1908. }
  1909. if (speed === void 0) {
  1910. speed = this.params.speed;
  1911. }
  1912. if (runCallbacks === void 0) {
  1913. runCallbacks = true;
  1914. }
  1915. if (typeof index === 'string') {
  1916. const indexAsNumber = parseInt(index, 10);
  1917. index = indexAsNumber;
  1918. }
  1919. const swiper = this;
  1920. const gridEnabled = swiper.grid && swiper.params.grid && swiper.params.grid.rows > 1;
  1921. let newIndex = index;
  1922. if (swiper.params.loop) {
  1923. if (swiper.virtual && swiper.params.virtual.enabled) {
  1924. // eslint-disable-next-line
  1925. newIndex = newIndex + swiper.virtual.slidesBefore;
  1926. } else {
  1927. let targetSlideIndex;
  1928. if (gridEnabled) {
  1929. const slideIndex = newIndex * swiper.params.grid.rows;
  1930. targetSlideIndex = swiper.slides.filter(slideEl => slideEl.getAttribute('data-swiper-slide-index') * 1 === slideIndex)[0].column;
  1931. } else {
  1932. targetSlideIndex = swiper.getSlideIndexByData(newIndex);
  1933. }
  1934. const cols = gridEnabled ? Math.ceil(swiper.slides.length / swiper.params.grid.rows) : swiper.slides.length;
  1935. const {
  1936. centeredSlides
  1937. } = swiper.params;
  1938. let slidesPerView = swiper.params.slidesPerView;
  1939. if (slidesPerView === 'auto') {
  1940. slidesPerView = swiper.slidesPerViewDynamic();
  1941. } else {
  1942. slidesPerView = Math.ceil(parseFloat(swiper.params.slidesPerView, 10));
  1943. if (centeredSlides && slidesPerView % 2 === 0) {
  1944. slidesPerView = slidesPerView + 1;
  1945. }
  1946. }
  1947. let needLoopFix = cols - targetSlideIndex < slidesPerView;
  1948. if (centeredSlides) {
  1949. needLoopFix = needLoopFix || targetSlideIndex < Math.ceil(slidesPerView / 2);
  1950. }
  1951. if (needLoopFix) {
  1952. const direction = centeredSlides ? targetSlideIndex < swiper.activeIndex ? 'prev' : 'next' : targetSlideIndex - swiper.activeIndex - 1 < swiper.params.slidesPerView ? 'next' : 'prev';
  1953. swiper.loopFix({
  1954. direction,
  1955. slideTo: true,
  1956. activeSlideIndex: direction === 'next' ? targetSlideIndex + 1 : targetSlideIndex - cols + 1,
  1957. slideRealIndex: direction === 'next' ? swiper.realIndex : undefined
  1958. });
  1959. }
  1960. if (gridEnabled) {
  1961. const slideIndex = newIndex * swiper.params.grid.rows;
  1962. newIndex = swiper.slides.filter(slideEl => slideEl.getAttribute('data-swiper-slide-index') * 1 === slideIndex)[0].column;
  1963. } else {
  1964. newIndex = swiper.getSlideIndexByData(newIndex);
  1965. }
  1966. }
  1967. }
  1968. requestAnimationFrame(() => {
  1969. swiper.slideTo(newIndex, speed, runCallbacks, internal);
  1970. });
  1971. return swiper;
  1972. }
  1973. /* eslint no-unused-vars: "off" */
  1974. function slideNext(speed, runCallbacks, internal) {
  1975. if (speed === void 0) {
  1976. speed = this.params.speed;
  1977. }
  1978. if (runCallbacks === void 0) {
  1979. runCallbacks = true;
  1980. }
  1981. const swiper = this;
  1982. const {
  1983. enabled,
  1984. params,
  1985. animating
  1986. } = swiper;
  1987. if (!enabled) return swiper;
  1988. let perGroup = params.slidesPerGroup;
  1989. if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {
  1990. perGroup = Math.max(swiper.slidesPerViewDynamic('current', true), 1);
  1991. }
  1992. const increment = swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup;
  1993. const isVirtual = swiper.virtual && params.virtual.enabled;
  1994. if (params.loop) {
  1995. if (animating && !isVirtual && params.loopPreventsSliding) return false;
  1996. swiper.loopFix({
  1997. direction: 'next'
  1998. });
  1999. // eslint-disable-next-line
  2000. swiper._clientLeft = swiper.wrapperEl.clientLeft;
  2001. if (swiper.activeIndex === swiper.slides.length - 1 && params.cssMode) {
  2002. requestAnimationFrame(() => {
  2003. swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal);
  2004. });
  2005. return true;
  2006. }
  2007. }
  2008. if (params.rewind && swiper.isEnd) {
  2009. return swiper.slideTo(0, speed, runCallbacks, internal);
  2010. }
  2011. return swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal);
  2012. }
  2013. /* eslint no-unused-vars: "off" */
  2014. function slidePrev(speed, runCallbacks, internal) {
  2015. if (speed === void 0) {
  2016. speed = this.params.speed;
  2017. }
  2018. if (runCallbacks === void 0) {
  2019. runCallbacks = true;
  2020. }
  2021. const swiper = this;
  2022. const {
  2023. params,
  2024. snapGrid,
  2025. slidesGrid,
  2026. rtlTranslate,
  2027. enabled,
  2028. animating
  2029. } = swiper;
  2030. if (!enabled) return swiper;
  2031. const isVirtual = swiper.virtual && params.virtual.enabled;
  2032. if (params.loop) {
  2033. if (animating && !isVirtual && params.loopPreventsSliding) return false;
  2034. swiper.loopFix({
  2035. direction: 'prev'
  2036. });
  2037. // eslint-disable-next-line
  2038. swiper._clientLeft = swiper.wrapperEl.clientLeft;
  2039. }
  2040. const translate = rtlTranslate ? swiper.translate : -swiper.translate;
  2041. function normalize(val) {
  2042. if (val < 0) return -Math.floor(Math.abs(val));
  2043. return Math.floor(val);
  2044. }
  2045. const normalizedTranslate = normalize(translate);
  2046. const normalizedSnapGrid = snapGrid.map(val => normalize(val));
  2047. let prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1];
  2048. if (typeof prevSnap === 'undefined' && params.cssMode) {
  2049. let prevSnapIndex;
  2050. snapGrid.forEach((snap, snapIndex) => {
  2051. if (normalizedTranslate >= snap) {
  2052. // prevSnap = snap;
  2053. prevSnapIndex = snapIndex;
  2054. }
  2055. });
  2056. if (typeof prevSnapIndex !== 'undefined') {
  2057. prevSnap = snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex];
  2058. }
  2059. }
  2060. let prevIndex = 0;
  2061. if (typeof prevSnap !== 'undefined') {
  2062. prevIndex = slidesGrid.indexOf(prevSnap);
  2063. if (prevIndex < 0) prevIndex = swiper.activeIndex - 1;
  2064. if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {
  2065. prevIndex = prevIndex - swiper.slidesPerViewDynamic('previous', true) + 1;
  2066. prevIndex = Math.max(prevIndex, 0);
  2067. }
  2068. }
  2069. if (params.rewind && swiper.isBeginning) {
  2070. const lastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;
  2071. return swiper.slideTo(lastIndex, speed, runCallbacks, internal);
  2072. } else if (params.loop && swiper.activeIndex === 0 && params.cssMode) {
  2073. requestAnimationFrame(() => {
  2074. swiper.slideTo(prevIndex, speed, runCallbacks, internal);
  2075. });
  2076. return true;
  2077. }
  2078. return swiper.slideTo(prevIndex, speed, runCallbacks, internal);
  2079. }
  2080. /* eslint no-unused-vars: "off" */
  2081. function slideReset(speed, runCallbacks, internal) {
  2082. if (speed === void 0) {
  2083. speed = this.params.speed;
  2084. }
  2085. if (runCallbacks === void 0) {
  2086. runCallbacks = true;
  2087. }
  2088. const swiper = this;
  2089. return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);
  2090. }
  2091. /* eslint no-unused-vars: "off" */
  2092. function slideToClosest(speed, runCallbacks, internal, threshold) {
  2093. if (speed === void 0) {
  2094. speed = this.params.speed;
  2095. }
  2096. if (runCallbacks === void 0) {
  2097. runCallbacks = true;
  2098. }
  2099. if (threshold === void 0) {
  2100. threshold = 0.5;
  2101. }
  2102. const swiper = this;
  2103. let index = swiper.activeIndex;
  2104. const skip = Math.min(swiper.params.slidesPerGroupSkip, index);
  2105. const snapIndex = skip + Math.floor((index - skip) / swiper.params.slidesPerGroup);
  2106. const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;
  2107. if (translate >= swiper.snapGrid[snapIndex]) {
  2108. // The current translate is on or after the current snap index, so the choice
  2109. // is between the current index and the one after it.
  2110. const currentSnap = swiper.snapGrid[snapIndex];
  2111. const nextSnap = swiper.snapGrid[snapIndex + 1];
  2112. if (translate - currentSnap > (nextSnap - currentSnap) * threshold) {
  2113. index += swiper.params.slidesPerGroup;
  2114. }
  2115. } else {
  2116. // The current translate is before the current snap index, so the choice
  2117. // is between the current index and the one before it.
  2118. const prevSnap = swiper.snapGrid[snapIndex - 1];
  2119. const currentSnap = swiper.snapGrid[snapIndex];
  2120. if (translate - prevSnap <= (currentSnap - prevSnap) * threshold) {
  2121. index -= swiper.params.slidesPerGroup;
  2122. }
  2123. }
  2124. index = Math.max(index, 0);
  2125. index = Math.min(index, swiper.slidesGrid.length - 1);
  2126. return swiper.slideTo(index, speed, runCallbacks, internal);
  2127. }
  2128. function slideToClickedSlide() {
  2129. const swiper = this;
  2130. const {
  2131. params,
  2132. slidesEl
  2133. } = swiper;
  2134. const slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : params.slidesPerView;
  2135. let slideToIndex = swiper.clickedIndex;
  2136. let realIndex;
  2137. const slideSelector = swiper.isElement ? `swiper-slide` : `.${params.slideClass}`;
  2138. if (params.loop) {
  2139. if (swiper.animating) return;
  2140. realIndex = parseInt(swiper.clickedSlide.getAttribute('data-swiper-slide-index'), 10);
  2141. if (params.centeredSlides) {
  2142. if (slideToIndex < swiper.loopedSlides - slidesPerView / 2 || slideToIndex > swiper.slides.length - swiper.loopedSlides + slidesPerView / 2) {
  2143. swiper.loopFix();
  2144. slideToIndex = swiper.getSlideIndex(elementChildren(slidesEl, `${slideSelector}[data-swiper-slide-index="${realIndex}"]`)[0]);
  2145. nextTick(() => {
  2146. swiper.slideTo(slideToIndex);
  2147. });
  2148. } else {
  2149. swiper.slideTo(slideToIndex);
  2150. }
  2151. } else if (slideToIndex > swiper.slides.length - slidesPerView) {
  2152. swiper.loopFix();
  2153. slideToIndex = swiper.getSlideIndex(elementChildren(slidesEl, `${slideSelector}[data-swiper-slide-index="${realIndex}"]`)[0]);
  2154. nextTick(() => {
  2155. swiper.slideTo(slideToIndex);
  2156. });
  2157. } else {
  2158. swiper.slideTo(slideToIndex);
  2159. }
  2160. } else {
  2161. swiper.slideTo(slideToIndex);
  2162. }
  2163. }
  2164. var slide = {
  2165. slideTo,
  2166. slideToLoop,
  2167. slideNext,
  2168. slidePrev,
  2169. slideReset,
  2170. slideToClosest,
  2171. slideToClickedSlide
  2172. };
  2173. function loopCreate(slideRealIndex) {
  2174. const swiper = this;
  2175. const {
  2176. params,
  2177. slidesEl
  2178. } = swiper;
  2179. if (!params.loop || swiper.virtual && swiper.params.virtual.enabled) return;
  2180. const initSlides = () => {
  2181. const slides = elementChildren(slidesEl, `.${params.slideClass}, swiper-slide`);
  2182. slides.forEach((el, index) => {
  2183. el.setAttribute('data-swiper-slide-index', index);
  2184. });
  2185. };
  2186. const gridEnabled = swiper.grid && params.grid && params.grid.rows > 1;
  2187. const slidesPerGroup = params.slidesPerGroup * (gridEnabled ? params.grid.rows : 1);
  2188. const shouldFillGroup = swiper.slides.length % slidesPerGroup !== 0;
  2189. const shouldFillGrid = gridEnabled && swiper.slides.length % params.grid.rows !== 0;
  2190. const addBlankSlides = amountOfSlides => {
  2191. for (let i = 0; i < amountOfSlides; i += 1) {
  2192. const slideEl = swiper.isElement ? createElement('swiper-slide', [params.slideBlankClass]) : createElement('div', [params.slideClass, params.slideBlankClass]);
  2193. swiper.slidesEl.append(slideEl);
  2194. }
  2195. };
  2196. if (shouldFillGroup) {
  2197. if (params.loopAddBlankSlides) {
  2198. const slidesToAdd = slidesPerGroup - swiper.slides.length % slidesPerGroup;
  2199. addBlankSlides(slidesToAdd);
  2200. swiper.recalcSlides();
  2201. swiper.updateSlides();
  2202. } else {
  2203. showWarning('Swiper Loop Warning: The number of slides is not even to slidesPerGroup, loop mode may not function properly. You need to add more slides (or make duplicates, or empty slides)');
  2204. }
  2205. initSlides();
  2206. } else if (shouldFillGrid) {
  2207. if (params.loopAddBlankSlides) {
  2208. const slidesToAdd = params.grid.rows - swiper.slides.length % params.grid.rows;
  2209. addBlankSlides(slidesToAdd);
  2210. swiper.recalcSlides();
  2211. swiper.updateSlides();
  2212. } else {
  2213. showWarning('Swiper Loop Warning: The number of slides is not even to grid.rows, loop mode may not function properly. You need to add more slides (or make duplicates, or empty slides)');
  2214. }
  2215. initSlides();
  2216. } else {
  2217. initSlides();
  2218. }
  2219. swiper.loopFix({
  2220. slideRealIndex,
  2221. direction: params.centeredSlides ? undefined : 'next'
  2222. });
  2223. }
  2224. function loopFix(_temp) {
  2225. let {
  2226. slideRealIndex,
  2227. slideTo = true,
  2228. direction,
  2229. setTranslate,
  2230. activeSlideIndex,
  2231. byController,
  2232. byMousewheel
  2233. } = _temp === void 0 ? {} : _temp;
  2234. const swiper = this;
  2235. if (!swiper.params.loop) return;
  2236. swiper.emit('beforeLoopFix');
  2237. const {
  2238. slides,
  2239. allowSlidePrev,
  2240. allowSlideNext,
  2241. slidesEl,
  2242. params
  2243. } = swiper;
  2244. const {
  2245. centeredSlides
  2246. } = params;
  2247. swiper.allowSlidePrev = true;
  2248. swiper.allowSlideNext = true;
  2249. if (swiper.virtual && params.virtual.enabled) {
  2250. if (slideTo) {
  2251. if (!params.centeredSlides && swiper.snapIndex === 0) {
  2252. swiper.slideTo(swiper.virtual.slides.length, 0, false, true);
  2253. } else if (params.centeredSlides && swiper.snapIndex < params.slidesPerView) {
  2254. swiper.slideTo(swiper.virtual.slides.length + swiper.snapIndex, 0, false, true);
  2255. } else if (swiper.snapIndex === swiper.snapGrid.length - 1) {
  2256. swiper.slideTo(swiper.virtual.slidesBefore, 0, false, true);
  2257. }
  2258. }
  2259. swiper.allowSlidePrev = allowSlidePrev;
  2260. swiper.allowSlideNext = allowSlideNext;
  2261. swiper.emit('loopFix');
  2262. return;
  2263. }
  2264. let slidesPerView = params.slidesPerView;
  2265. if (slidesPerView === 'auto') {
  2266. slidesPerView = swiper.slidesPerViewDynamic();
  2267. } else {
  2268. slidesPerView = Math.ceil(parseFloat(params.slidesPerView, 10));
  2269. if (centeredSlides && slidesPerView % 2 === 0) {
  2270. slidesPerView = slidesPerView + 1;
  2271. }
  2272. }
  2273. const slidesPerGroup = params.slidesPerGroupAuto ? slidesPerView : params.slidesPerGroup;
  2274. let loopedSlides = slidesPerGroup;
  2275. if (loopedSlides % slidesPerGroup !== 0) {
  2276. loopedSlides += slidesPerGroup - loopedSlides % slidesPerGroup;
  2277. }
  2278. loopedSlides += params.loopAdditionalSlides;
  2279. swiper.loopedSlides = loopedSlides;
  2280. const gridEnabled = swiper.grid && params.grid && params.grid.rows > 1;
  2281. if (slides.length < slidesPerView + loopedSlides) {
  2282. showWarning('Swiper Loop Warning: The number of slides is not enough for loop mode, it will be disabled and not function properly. You need to add more slides (or make duplicates) or lower the values of slidesPerView and slidesPerGroup parameters');
  2283. } else if (gridEnabled && params.grid.fill === 'row') {
  2284. showWarning('Swiper Loop Warning: Loop mode is not compatible with grid.fill = `row`');
  2285. }
  2286. const prependSlidesIndexes = [];
  2287. const appendSlidesIndexes = [];
  2288. let activeIndex = swiper.activeIndex;
  2289. if (typeof activeSlideIndex === 'undefined') {
  2290. activeSlideIndex = swiper.getSlideIndex(slides.filter(el => el.classList.contains(params.slideActiveClass))[0]);
  2291. } else {
  2292. activeIndex = activeSlideIndex;
  2293. }
  2294. const isNext = direction === 'next' || !direction;
  2295. const isPrev = direction === 'prev' || !direction;
  2296. let slidesPrepended = 0;
  2297. let slidesAppended = 0;
  2298. const cols = gridEnabled ? Math.ceil(slides.length / params.grid.rows) : slides.length;
  2299. const activeColIndex = gridEnabled ? slides[activeSlideIndex].column : activeSlideIndex;
  2300. const activeColIndexWithShift = activeColIndex + (centeredSlides && typeof setTranslate === 'undefined' ? -slidesPerView / 2 + 0.5 : 0);
  2301. // prepend last slides before start
  2302. if (activeColIndexWithShift < loopedSlides) {
  2303. slidesPrepended = Math.max(loopedSlides - activeColIndexWithShift, slidesPerGroup);
  2304. for (let i = 0; i < loopedSlides - activeColIndexWithShift; i += 1) {
  2305. const index = i - Math.floor(i / cols) * cols;
  2306. if (gridEnabled) {
  2307. const colIndexToPrepend = cols - index - 1;
  2308. for (let i = slides.length - 1; i >= 0; i -= 1) {
  2309. if (slides[i].column === colIndexToPrepend) prependSlidesIndexes.push(i);
  2310. }
  2311. // slides.forEach((slide, slideIndex) => {
  2312. // if (slide.column === colIndexToPrepend) prependSlidesIndexes.push(slideIndex);
  2313. // });
  2314. } else {
  2315. prependSlidesIndexes.push(cols - index - 1);
  2316. }
  2317. }
  2318. } else if (activeColIndexWithShift + slidesPerView > cols - loopedSlides) {
  2319. slidesAppended = Math.max(activeColIndexWithShift - (cols - loopedSlides * 2), slidesPerGroup);
  2320. for (let i = 0; i < slidesAppended; i += 1) {
  2321. const index = i - Math.floor(i / cols) * cols;
  2322. if (gridEnabled) {
  2323. slides.forEach((slide, slideIndex) => {
  2324. if (slide.column === index) appendSlidesIndexes.push(slideIndex);
  2325. });
  2326. } else {
  2327. appendSlidesIndexes.push(index);
  2328. }
  2329. }
  2330. }
  2331. swiper.__preventObserver__ = true;
  2332. requestAnimationFrame(() => {
  2333. swiper.__preventObserver__ = false;
  2334. });
  2335. if (isPrev) {
  2336. prependSlidesIndexes.forEach(index => {
  2337. slides[index].swiperLoopMoveDOM = true;
  2338. slidesEl.prepend(slides[index]);
  2339. slides[index].swiperLoopMoveDOM = false;
  2340. });
  2341. }
  2342. if (isNext) {
  2343. appendSlidesIndexes.forEach(index => {
  2344. slides[index].swiperLoopMoveDOM = true;
  2345. slidesEl.append(slides[index]);
  2346. slides[index].swiperLoopMoveDOM = false;
  2347. });
  2348. }
  2349. swiper.recalcSlides();
  2350. if (params.slidesPerView === 'auto') {
  2351. swiper.updateSlides();
  2352. } else if (gridEnabled && (prependSlidesIndexes.length > 0 && isPrev || appendSlidesIndexes.length > 0 && isNext)) {
  2353. swiper.slides.forEach((slide, slideIndex) => {
  2354. swiper.grid.updateSlide(slideIndex, slide, swiper.slides);
  2355. });
  2356. }
  2357. if (params.watchSlidesProgress) {
  2358. swiper.updateSlidesOffset();
  2359. }
  2360. if (slideTo) {
  2361. if (prependSlidesIndexes.length > 0 && isPrev) {
  2362. if (typeof slideRealIndex === 'undefined') {
  2363. const currentSlideTranslate = swiper.slidesGrid[activeIndex];
  2364. const newSlideTranslate = swiper.slidesGrid[activeIndex + slidesPrepended];
  2365. const diff = newSlideTranslate - currentSlideTranslate;
  2366. if (byMousewheel) {
  2367. swiper.setTranslate(swiper.translate - diff);
  2368. } else {
  2369. swiper.slideTo(activeIndex + slidesPrepended, 0, false, true);
  2370. if (setTranslate) {
  2371. swiper.touchEventsData.startTranslate = swiper.touchEventsData.startTranslate - diff;
  2372. swiper.touchEventsData.currentTranslate = swiper.touchEventsData.currentTranslate - diff;
  2373. }
  2374. }
  2375. } else {
  2376. if (setTranslate) {
  2377. const shift = gridEnabled ? prependSlidesIndexes.length / params.grid.rows : prependSlidesIndexes.length;
  2378. swiper.slideTo(swiper.activeIndex + shift, 0, false, true);
  2379. swiper.touchEventsData.currentTranslate = swiper.translate;
  2380. }
  2381. }
  2382. } else if (appendSlidesIndexes.length > 0 && isNext) {
  2383. if (typeof slideRealIndex === 'undefined') {
  2384. const currentSlideTranslate = swiper.slidesGrid[activeIndex];
  2385. const newSlideTranslate = swiper.slidesGrid[activeIndex - slidesAppended];
  2386. const diff = newSlideTranslate - currentSlideTranslate;
  2387. if (byMousewheel) {
  2388. swiper.setTranslate(swiper.translate - diff);
  2389. } else {
  2390. swiper.slideTo(activeIndex - slidesAppended, 0, false, true);
  2391. if (setTranslate) {
  2392. swiper.touchEventsData.startTranslate = swiper.touchEventsData.startTranslate - diff;
  2393. swiper.touchEventsData.currentTranslate = swiper.touchEventsData.currentTranslate - diff;
  2394. }
  2395. }
  2396. } else {
  2397. const shift = gridEnabled ? appendSlidesIndexes.length / params.grid.rows : appendSlidesIndexes.length;
  2398. swiper.slideTo(swiper.activeIndex - shift, 0, false, true);
  2399. }
  2400. }
  2401. }
  2402. swiper.allowSlidePrev = allowSlidePrev;
  2403. swiper.allowSlideNext = allowSlideNext;
  2404. if (swiper.controller && swiper.controller.control && !byController) {
  2405. const loopParams = {
  2406. slideRealIndex,
  2407. direction,
  2408. setTranslate,
  2409. activeSlideIndex,
  2410. byController: true
  2411. };
  2412. if (Array.isArray(swiper.controller.control)) {
  2413. swiper.controller.control.forEach(c => {
  2414. if (!c.destroyed && c.params.loop) c.loopFix({
  2415. ...loopParams,
  2416. slideTo: c.params.slidesPerView === params.slidesPerView ? slideTo : false
  2417. });
  2418. });
  2419. } else if (swiper.controller.control instanceof swiper.constructor && swiper.controller.control.params.loop) {
  2420. swiper.controller.control.loopFix({
  2421. ...loopParams,
  2422. slideTo: swiper.controller.control.params.slidesPerView === params.slidesPerView ? slideTo : false
  2423. });
  2424. }
  2425. }
  2426. swiper.emit('loopFix');
  2427. }
  2428. function loopDestroy() {
  2429. const swiper = this;
  2430. const {
  2431. params,
  2432. slidesEl
  2433. } = swiper;
  2434. if (!params.loop || swiper.virtual && swiper.params.virtual.enabled) return;
  2435. swiper.recalcSlides();
  2436. const newSlidesOrder = [];
  2437. swiper.slides.forEach(slideEl => {
  2438. const index = typeof slideEl.swiperSlideIndex === 'undefined' ? slideEl.getAttribute('data-swiper-slide-index') * 1 : slideEl.swiperSlideIndex;
  2439. newSlidesOrder[index] = slideEl;
  2440. });
  2441. swiper.slides.forEach(slideEl => {
  2442. slideEl.removeAttribute('data-swiper-slide-index');
  2443. });
  2444. newSlidesOrder.forEach(slideEl => {
  2445. slidesEl.append(slideEl);
  2446. });
  2447. swiper.recalcSlides();
  2448. swiper.slideTo(swiper.realIndex, 0);
  2449. }
  2450. var loop = {
  2451. loopCreate,
  2452. loopFix,
  2453. loopDestroy
  2454. };
  2455. function setGrabCursor(moving) {
  2456. const swiper = this;
  2457. if (!swiper.params.simulateTouch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return;
  2458. const el = swiper.params.touchEventsTarget === 'container' ? swiper.el : swiper.wrapperEl;
  2459. if (swiper.isElement) {
  2460. swiper.__preventObserver__ = true;
  2461. }
  2462. el.style.cursor = 'move';
  2463. el.style.cursor = moving ? 'grabbing' : 'grab';
  2464. if (swiper.isElement) {
  2465. requestAnimationFrame(() => {
  2466. swiper.__preventObserver__ = false;
  2467. });
  2468. }
  2469. }
  2470. function unsetGrabCursor() {
  2471. const swiper = this;
  2472. if (swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) {
  2473. return;
  2474. }
  2475. if (swiper.isElement) {
  2476. swiper.__preventObserver__ = true;
  2477. }
  2478. swiper[swiper.params.touchEventsTarget === 'container' ? 'el' : 'wrapperEl'].style.cursor = '';
  2479. if (swiper.isElement) {
  2480. requestAnimationFrame(() => {
  2481. swiper.__preventObserver__ = false;
  2482. });
  2483. }
  2484. }
  2485. var grabCursor = {
  2486. setGrabCursor,
  2487. unsetGrabCursor
  2488. };
  2489. // Modified from https://stackoverflow.com/questions/54520554/custom-element-getrootnode-closest-function-crossing-multiple-parent-shadowd
  2490. function closestElement(selector, base) {
  2491. if (base === void 0) {
  2492. base = this;
  2493. }
  2494. function __closestFrom(el) {
  2495. if (!el || el === getDocument() || el === getWindow()) return null;
  2496. if (el.assignedSlot) el = el.assignedSlot;
  2497. const found = el.closest(selector);
  2498. if (!found && !el.getRootNode) {
  2499. return null;
  2500. }
  2501. return found || __closestFrom(el.getRootNode().host);
  2502. }
  2503. return __closestFrom(base);
  2504. }
  2505. function preventEdgeSwipe(swiper, event, startX) {
  2506. const window = getWindow();
  2507. const {
  2508. params
  2509. } = swiper;
  2510. const edgeSwipeDetection = params.edgeSwipeDetection;
  2511. const edgeSwipeThreshold = params.edgeSwipeThreshold;
  2512. if (edgeSwipeDetection && (startX <= edgeSwipeThreshold || startX >= window.innerWidth - edgeSwipeThreshold)) {
  2513. if (edgeSwipeDetection === 'prevent') {
  2514. event.preventDefault();
  2515. return true;
  2516. }
  2517. return false;
  2518. }
  2519. return true;
  2520. }
  2521. function onTouchStart(event) {
  2522. const swiper = this;
  2523. const document = getDocument();
  2524. let e = event;
  2525. if (e.originalEvent) e = e.originalEvent;
  2526. const data = swiper.touchEventsData;
  2527. if (e.type === 'pointerdown') {
  2528. if (data.pointerId !== null && data.pointerId !== e.pointerId) {
  2529. return;
  2530. }
  2531. data.pointerId = e.pointerId;
  2532. } else if (e.type === 'touchstart' && e.targetTouches.length === 1) {
  2533. data.touchId = e.targetTouches[0].identifier;
  2534. }
  2535. if (e.type === 'touchstart') {
  2536. // don't proceed touch event
  2537. preventEdgeSwipe(swiper, e, e.targetTouches[0].pageX);
  2538. return;
  2539. }
  2540. const {
  2541. params,
  2542. touches,
  2543. enabled
  2544. } = swiper;
  2545. if (!enabled) return;
  2546. if (!params.simulateTouch && e.pointerType === 'mouse') return;
  2547. if (swiper.animating && params.preventInteractionOnTransition) {
  2548. return;
  2549. }
  2550. if (!swiper.animating && params.cssMode && params.loop) {
  2551. swiper.loopFix();
  2552. }
  2553. let targetEl = e.target;
  2554. if (params.touchEventsTarget === 'wrapper') {
  2555. if (!swiper.wrapperEl.contains(targetEl)) return;
  2556. }
  2557. if ('which' in e && e.which === 3) return;
  2558. if ('button' in e && e.button > 0) return;
  2559. if (data.isTouched && data.isMoved) return;
  2560. // change target el for shadow root component
  2561. const swipingClassHasValue = !!params.noSwipingClass && params.noSwipingClass !== '';
  2562. // eslint-disable-next-line
  2563. const eventPath = e.composedPath ? e.composedPath() : e.path;
  2564. if (swipingClassHasValue && e.target && e.target.shadowRoot && eventPath) {
  2565. targetEl = eventPath[0];
  2566. }
  2567. const noSwipingSelector = params.noSwipingSelector ? params.noSwipingSelector : `.${params.noSwipingClass}`;
  2568. const isTargetShadow = !!(e.target && e.target.shadowRoot);
  2569. // use closestElement for shadow root element to get the actual closest for nested shadow root element
  2570. if (params.noSwiping && (isTargetShadow ? closestElement(noSwipingSelector, targetEl) : targetEl.closest(noSwipingSelector))) {
  2571. swiper.allowClick = true;
  2572. return;
  2573. }
  2574. if (params.swipeHandler) {
  2575. if (!targetEl.closest(params.swipeHandler)) return;
  2576. }
  2577. touches.currentX = e.pageX;
  2578. touches.currentY = e.pageY;
  2579. const startX = touches.currentX;
  2580. const startY = touches.currentY;
  2581. // Do NOT start if iOS edge swipe is detected. Otherwise iOS app cannot swipe-to-go-back anymore
  2582. if (!preventEdgeSwipe(swiper, e, startX)) {
  2583. return;
  2584. }
  2585. Object.assign(data, {
  2586. isTouched: true,
  2587. isMoved: false,
  2588. allowTouchCallbacks: true,
  2589. isScrolling: undefined,
  2590. startMoving: undefined
  2591. });
  2592. touches.startX = startX;
  2593. touches.startY = startY;
  2594. data.touchStartTime = now();
  2595. swiper.allowClick = true;
  2596. swiper.updateSize();
  2597. swiper.swipeDirection = undefined;
  2598. if (params.threshold > 0) data.allowThresholdMove = false;
  2599. let preventDefault = true;
  2600. if (targetEl.matches(data.focusableElements)) {
  2601. preventDefault = false;
  2602. if (targetEl.nodeName === 'SELECT') {
  2603. data.isTouched = false;
  2604. }
  2605. }
  2606. if (document.activeElement && document.activeElement.matches(data.focusableElements) && document.activeElement !== targetEl) {
  2607. document.activeElement.blur();
  2608. }
  2609. const shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;
  2610. if ((params.touchStartForcePreventDefault || shouldPreventDefault) && !targetEl.isContentEditable) {
  2611. e.preventDefault();
  2612. }
  2613. if (params.freeMode && params.freeMode.enabled && swiper.freeMode && swiper.animating && !params.cssMode) {
  2614. swiper.freeMode.onTouchStart();
  2615. }
  2616. swiper.emit('touchStart', e);
  2617. }
  2618. function onTouchMove(event) {
  2619. const document = getDocument();
  2620. const swiper = this;
  2621. const data = swiper.touchEventsData;
  2622. const {
  2623. params,
  2624. touches,
  2625. rtlTranslate: rtl,
  2626. enabled
  2627. } = swiper;
  2628. if (!enabled) return;
  2629. if (!params.simulateTouch && event.pointerType === 'mouse') return;
  2630. let e = event;
  2631. if (e.originalEvent) e = e.originalEvent;
  2632. if (e.type === 'pointermove') {
  2633. if (data.touchId !== null) return; // return from pointer if we use touch
  2634. const id = e.pointerId;
  2635. if (id !== data.pointerId) return;
  2636. }
  2637. let targetTouch;
  2638. if (e.type === 'touchmove') {
  2639. targetTouch = [...e.changedTouches].filter(t => t.identifier === data.touchId)[0];
  2640. if (!targetTouch || targetTouch.identifier !== data.touchId) return;
  2641. } else {
  2642. targetTouch = e;
  2643. }
  2644. if (!data.isTouched) {
  2645. if (data.startMoving && data.isScrolling) {
  2646. swiper.emit('touchMoveOpposite', e);
  2647. }
  2648. return;
  2649. }
  2650. const pageX = targetTouch.pageX;
  2651. const pageY = targetTouch.pageY;
  2652. if (e.preventedByNestedSwiper) {
  2653. touches.startX = pageX;
  2654. touches.startY = pageY;
  2655. return;
  2656. }
  2657. if (!swiper.allowTouchMove) {
  2658. if (!e.target.matches(data.focusableElements)) {
  2659. swiper.allowClick = false;
  2660. }
  2661. if (data.isTouched) {
  2662. Object.assign(touches, {
  2663. startX: pageX,
  2664. startY: pageY,
  2665. currentX: pageX,
  2666. currentY: pageY
  2667. });
  2668. data.touchStartTime = now();
  2669. }
  2670. return;
  2671. }
  2672. if (params.touchReleaseOnEdges && !params.loop) {
  2673. if (swiper.isVertical()) {
  2674. // Vertical
  2675. if (pageY < touches.startY && swiper.translate <= swiper.maxTranslate() || pageY > touches.startY && swiper.translate >= swiper.minTranslate()) {
  2676. data.isTouched = false;
  2677. data.isMoved = false;
  2678. return;
  2679. }
  2680. } else if (pageX < touches.startX && swiper.translate <= swiper.maxTranslate() || pageX > touches.startX && swiper.translate >= swiper.minTranslate()) {
  2681. return;
  2682. }
  2683. }
  2684. if (document.activeElement) {
  2685. if (e.target === document.activeElement && e.target.matches(data.focusableElements)) {
  2686. data.isMoved = true;
  2687. swiper.allowClick = false;
  2688. return;
  2689. }
  2690. }
  2691. if (data.allowTouchCallbacks) {
  2692. swiper.emit('touchMove', e);
  2693. }
  2694. touches.previousX = touches.currentX;
  2695. touches.previousY = touches.currentY;
  2696. touches.currentX = pageX;
  2697. touches.currentY = pageY;
  2698. const diffX = touches.currentX - touches.startX;
  2699. const diffY = touches.currentY - touches.startY;
  2700. if (swiper.params.threshold && Math.sqrt(diffX ** 2 + diffY ** 2) < swiper.params.threshold) return;
  2701. if (typeof data.isScrolling === 'undefined') {
  2702. let touchAngle;
  2703. if (swiper.isHorizontal() && touches.currentY === touches.startY || swiper.isVertical() && touches.currentX === touches.startX) {
  2704. data.isScrolling = false;
  2705. } else {
  2706. // eslint-disable-next-line
  2707. if (diffX * diffX + diffY * diffY >= 25) {
  2708. touchAngle = Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180 / Math.PI;
  2709. data.isScrolling = swiper.isHorizontal() ? touchAngle > params.touchAngle : 90 - touchAngle > params.touchAngle;
  2710. }
  2711. }
  2712. }
  2713. if (data.isScrolling) {
  2714. swiper.emit('touchMoveOpposite', e);
  2715. }
  2716. if (typeof data.startMoving === 'undefined') {
  2717. if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) {
  2718. data.startMoving = true;
  2719. }
  2720. }
  2721. if (data.isScrolling) {
  2722. data.isTouched = false;
  2723. return;
  2724. }
  2725. if (!data.startMoving) {
  2726. return;
  2727. }
  2728. swiper.allowClick = false;
  2729. if (!params.cssMode && e.cancelable) {
  2730. e.preventDefault();
  2731. }
  2732. if (params.touchMoveStopPropagation && !params.nested) {
  2733. e.stopPropagation();
  2734. }
  2735. let diff = swiper.isHorizontal() ? diffX : diffY;
  2736. let touchesDiff = swiper.isHorizontal() ? touches.currentX - touches.previousX : touches.currentY - touches.previousY;
  2737. if (params.oneWayMovement) {
  2738. diff = Math.abs(diff) * (rtl ? 1 : -1);
  2739. touchesDiff = Math.abs(touchesDiff) * (rtl ? 1 : -1);
  2740. }
  2741. touches.diff = diff;
  2742. diff *= params.touchRatio;
  2743. if (rtl) {
  2744. diff = -diff;
  2745. touchesDiff = -touchesDiff;
  2746. }
  2747. const prevTouchesDirection = swiper.touchesDirection;
  2748. swiper.swipeDirection = diff > 0 ? 'prev' : 'next';
  2749. swiper.touchesDirection = touchesDiff > 0 ? 'prev' : 'next';
  2750. const isLoop = swiper.params.loop && !params.cssMode;
  2751. const allowLoopFix = swiper.touchesDirection === 'next' && swiper.allowSlideNext || swiper.touchesDirection === 'prev' && swiper.allowSlidePrev;
  2752. if (!data.isMoved) {
  2753. if (isLoop && allowLoopFix) {
  2754. swiper.loopFix({
  2755. direction: swiper.swipeDirection
  2756. });
  2757. }
  2758. data.startTranslate = swiper.getTranslate();
  2759. swiper.setTransition(0);
  2760. if (swiper.animating) {
  2761. const evt = new window.CustomEvent('transitionend', {
  2762. bubbles: true,
  2763. cancelable: true
  2764. });
  2765. swiper.wrapperEl.dispatchEvent(evt);
  2766. }
  2767. data.allowMomentumBounce = false;
  2768. // Grab Cursor
  2769. if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {
  2770. swiper.setGrabCursor(true);
  2771. }
  2772. swiper.emit('sliderFirstMove', e);
  2773. }
  2774. let loopFixed;
  2775. new Date().getTime();
  2776. if (data.isMoved && data.allowThresholdMove && prevTouchesDirection !== swiper.touchesDirection && isLoop && allowLoopFix && Math.abs(diff) >= 1) {
  2777. Object.assign(touches, {
  2778. startX: pageX,
  2779. startY: pageY,
  2780. currentX: pageX,
  2781. currentY: pageY,
  2782. startTranslate: data.currentTranslate
  2783. });
  2784. data.loopSwapReset = true;
  2785. data.startTranslate = data.currentTranslate;
  2786. return;
  2787. }
  2788. swiper.emit('sliderMove', e);
  2789. data.isMoved = true;
  2790. data.currentTranslate = diff + data.startTranslate;
  2791. let disableParentSwiper = true;
  2792. let resistanceRatio = params.resistanceRatio;
  2793. if (params.touchReleaseOnEdges) {
  2794. resistanceRatio = 0;
  2795. }
  2796. if (diff > 0) {
  2797. if (isLoop && allowLoopFix && !loopFixed && data.allowThresholdMove && data.currentTranslate > (params.centeredSlides ? swiper.minTranslate() - swiper.slidesSizesGrid[swiper.activeIndex + 1] : swiper.minTranslate())) {
  2798. swiper.loopFix({
  2799. direction: 'prev',
  2800. setTranslate: true,
  2801. activeSlideIndex: 0
  2802. });
  2803. }
  2804. if (data.currentTranslate > swiper.minTranslate()) {
  2805. disableParentSwiper = false;
  2806. if (params.resistance) {
  2807. data.currentTranslate = swiper.minTranslate() - 1 + (-swiper.minTranslate() + data.startTranslate + diff) ** resistanceRatio;
  2808. }
  2809. }
  2810. } else if (diff < 0) {
  2811. if (isLoop && allowLoopFix && !loopFixed && data.allowThresholdMove && data.currentTranslate < (params.centeredSlides ? swiper.maxTranslate() + swiper.slidesSizesGrid[swiper.slidesSizesGrid.length - 1] : swiper.maxTranslate())) {
  2812. swiper.loopFix({
  2813. direction: 'next',
  2814. setTranslate: true,
  2815. activeSlideIndex: swiper.slides.length - (params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : Math.ceil(parseFloat(params.slidesPerView, 10)))
  2816. });
  2817. }
  2818. if (data.currentTranslate < swiper.maxTranslate()) {
  2819. disableParentSwiper = false;
  2820. if (params.resistance) {
  2821. data.currentTranslate = swiper.maxTranslate() + 1 - (swiper.maxTranslate() - data.startTranslate - diff) ** resistanceRatio;
  2822. }
  2823. }
  2824. }
  2825. if (disableParentSwiper) {
  2826. e.preventedByNestedSwiper = true;
  2827. }
  2828. // Directions locks
  2829. if (!swiper.allowSlideNext && swiper.swipeDirection === 'next' && data.currentTranslate < data.startTranslate) {
  2830. data.currentTranslate = data.startTranslate;
  2831. }
  2832. if (!swiper.allowSlidePrev && swiper.swipeDirection === 'prev' && data.currentTranslate > data.startTranslate) {
  2833. data.currentTranslate = data.startTranslate;
  2834. }
  2835. if (!swiper.allowSlidePrev && !swiper.allowSlideNext) {
  2836. data.currentTranslate = data.startTranslate;
  2837. }
  2838. // Threshold
  2839. if (params.threshold > 0) {
  2840. if (Math.abs(diff) > params.threshold || data.allowThresholdMove) {
  2841. if (!data.allowThresholdMove) {
  2842. data.allowThresholdMove = true;
  2843. touches.startX = touches.currentX;
  2844. touches.startY = touches.currentY;
  2845. data.currentTranslate = data.startTranslate;
  2846. touches.diff = swiper.isHorizontal() ? touches.currentX - touches.startX : touches.currentY - touches.startY;
  2847. return;
  2848. }
  2849. } else {
  2850. data.currentTranslate = data.startTranslate;
  2851. return;
  2852. }
  2853. }
  2854. if (!params.followFinger || params.cssMode) return;
  2855. // Update active index in free mode
  2856. if (params.freeMode && params.freeMode.enabled && swiper.freeMode || params.watchSlidesProgress) {
  2857. swiper.updateActiveIndex();
  2858. swiper.updateSlidesClasses();
  2859. }
  2860. if (params.freeMode && params.freeMode.enabled && swiper.freeMode) {
  2861. swiper.freeMode.onTouchMove();
  2862. }
  2863. // Update progress
  2864. swiper.updateProgress(data.currentTranslate);
  2865. // Update translate
  2866. swiper.setTranslate(data.currentTranslate);
  2867. }
  2868. function onTouchEnd(event) {
  2869. const swiper = this;
  2870. const data = swiper.touchEventsData;
  2871. let e = event;
  2872. if (e.originalEvent) e = e.originalEvent;
  2873. let targetTouch;
  2874. const isTouchEvent = e.type === 'touchend' || e.type === 'touchcancel';
  2875. if (!isTouchEvent) {
  2876. if (data.touchId !== null) return; // return from pointer if we use touch
  2877. if (e.pointerId !== data.pointerId) return;
  2878. targetTouch = e;
  2879. } else {
  2880. targetTouch = [...e.changedTouches].filter(t => t.identifier === data.touchId)[0];
  2881. if (!targetTouch || targetTouch.identifier !== data.touchId) return;
  2882. }
  2883. if (['pointercancel', 'pointerout', 'pointerleave', 'contextmenu'].includes(e.type)) {
  2884. const proceed = ['pointercancel', 'contextmenu'].includes(e.type) && (swiper.browser.isSafari || swiper.browser.isWebView);
  2885. if (!proceed) {
  2886. return;
  2887. }
  2888. }
  2889. data.pointerId = null;
  2890. data.touchId = null;
  2891. const {
  2892. params,
  2893. touches,
  2894. rtlTranslate: rtl,
  2895. slidesGrid,
  2896. enabled
  2897. } = swiper;
  2898. if (!enabled) return;
  2899. if (!params.simulateTouch && e.pointerType === 'mouse') return;
  2900. if (data.allowTouchCallbacks) {
  2901. swiper.emit('touchEnd', e);
  2902. }
  2903. data.allowTouchCallbacks = false;
  2904. if (!data.isTouched) {
  2905. if (data.isMoved && params.grabCursor) {
  2906. swiper.setGrabCursor(false);
  2907. }
  2908. data.isMoved = false;
  2909. data.startMoving = false;
  2910. return;
  2911. }
  2912. // Return Grab Cursor
  2913. if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {
  2914. swiper.setGrabCursor(false);
  2915. }
  2916. // Time diff
  2917. const touchEndTime = now();
  2918. const timeDiff = touchEndTime - data.touchStartTime;
  2919. // Tap, doubleTap, Click
  2920. if (swiper.allowClick) {
  2921. const pathTree = e.path || e.composedPath && e.composedPath();
  2922. swiper.updateClickedSlide(pathTree && pathTree[0] || e.target, pathTree);
  2923. swiper.emit('tap click', e);
  2924. if (timeDiff < 300 && touchEndTime - data.lastClickTime < 300) {
  2925. swiper.emit('doubleTap doubleClick', e);
  2926. }
  2927. }
  2928. data.lastClickTime = now();
  2929. nextTick(() => {
  2930. if (!swiper.destroyed) swiper.allowClick = true;
  2931. });
  2932. if (!data.isTouched || !data.isMoved || !swiper.swipeDirection || touches.diff === 0 && !data.loopSwapReset || data.currentTranslate === data.startTranslate && !data.loopSwapReset) {
  2933. data.isTouched = false;
  2934. data.isMoved = false;
  2935. data.startMoving = false;
  2936. return;
  2937. }
  2938. data.isTouched = false;
  2939. data.isMoved = false;
  2940. data.startMoving = false;
  2941. let currentPos;
  2942. if (params.followFinger) {
  2943. currentPos = rtl ? swiper.translate : -swiper.translate;
  2944. } else {
  2945. currentPos = -data.currentTranslate;
  2946. }
  2947. if (params.cssMode) {
  2948. return;
  2949. }
  2950. if (params.freeMode && params.freeMode.enabled) {
  2951. swiper.freeMode.onTouchEnd({
  2952. currentPos
  2953. });
  2954. return;
  2955. }
  2956. // Find current slide
  2957. const swipeToLast = currentPos >= -swiper.maxTranslate() && !swiper.params.loop;
  2958. let stopIndex = 0;
  2959. let groupSize = swiper.slidesSizesGrid[0];
  2960. for (let i = 0; i < slidesGrid.length; i += i < params.slidesPerGroupSkip ? 1 : params.slidesPerGroup) {
  2961. const increment = i < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;
  2962. if (typeof slidesGrid[i + increment] !== 'undefined') {
  2963. if (swipeToLast || currentPos >= slidesGrid[i] && currentPos < slidesGrid[i + increment]) {
  2964. stopIndex = i;
  2965. groupSize = slidesGrid[i + increment] - slidesGrid[i];
  2966. }
  2967. } else if (swipeToLast || currentPos >= slidesGrid[i]) {
  2968. stopIndex = i;
  2969. groupSize = slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2];
  2970. }
  2971. }
  2972. let rewindFirstIndex = null;
  2973. let rewindLastIndex = null;
  2974. if (params.rewind) {
  2975. if (swiper.isBeginning) {
  2976. rewindLastIndex = params.virtual && params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;
  2977. } else if (swiper.isEnd) {
  2978. rewindFirstIndex = 0;
  2979. }
  2980. }
  2981. // Find current slide size
  2982. const ratio = (currentPos - slidesGrid[stopIndex]) / groupSize;
  2983. const increment = stopIndex < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;
  2984. if (timeDiff > params.longSwipesMs) {
  2985. // Long touches
  2986. if (!params.longSwipes) {
  2987. swiper.slideTo(swiper.activeIndex);
  2988. return;
  2989. }
  2990. if (swiper.swipeDirection === 'next') {
  2991. if (ratio >= params.longSwipesRatio) swiper.slideTo(params.rewind && swiper.isEnd ? rewindFirstIndex : stopIndex + increment);else swiper.slideTo(stopIndex);
  2992. }
  2993. if (swiper.swipeDirection === 'prev') {
  2994. if (ratio > 1 - params.longSwipesRatio) {
  2995. swiper.slideTo(stopIndex + increment);
  2996. } else if (rewindLastIndex !== null && ratio < 0 && Math.abs(ratio) > params.longSwipesRatio) {
  2997. swiper.slideTo(rewindLastIndex);
  2998. } else {
  2999. swiper.slideTo(stopIndex);
  3000. }
  3001. }
  3002. } else {
  3003. // Short swipes
  3004. if (!params.shortSwipes) {
  3005. swiper.slideTo(swiper.activeIndex);
  3006. return;
  3007. }
  3008. const isNavButtonTarget = swiper.navigation && (e.target === swiper.navigation.nextEl || e.target === swiper.navigation.prevEl);
  3009. if (!isNavButtonTarget) {
  3010. if (swiper.swipeDirection === 'next') {
  3011. swiper.slideTo(rewindFirstIndex !== null ? rewindFirstIndex : stopIndex + increment);
  3012. }
  3013. if (swiper.swipeDirection === 'prev') {
  3014. swiper.slideTo(rewindLastIndex !== null ? rewindLastIndex : stopIndex);
  3015. }
  3016. } else if (e.target === swiper.navigation.nextEl) {
  3017. swiper.slideTo(stopIndex + increment);
  3018. } else {
  3019. swiper.slideTo(stopIndex);
  3020. }
  3021. }
  3022. }
  3023. function onResize() {
  3024. const swiper = this;
  3025. const {
  3026. params,
  3027. el
  3028. } = swiper;
  3029. if (el && el.offsetWidth === 0) return;
  3030. // Breakpoints
  3031. if (params.breakpoints) {
  3032. swiper.setBreakpoint();
  3033. }
  3034. // Save locks
  3035. const {
  3036. allowSlideNext,
  3037. allowSlidePrev,
  3038. snapGrid
  3039. } = swiper;
  3040. const isVirtual = swiper.virtual && swiper.params.virtual.enabled;
  3041. // Disable locks on resize
  3042. swiper.allowSlideNext = true;
  3043. swiper.allowSlidePrev = true;
  3044. swiper.updateSize();
  3045. swiper.updateSlides();
  3046. swiper.updateSlidesClasses();
  3047. const isVirtualLoop = isVirtual && params.loop;
  3048. if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !swiper.isBeginning && !swiper.params.centeredSlides && !isVirtualLoop) {
  3049. swiper.slideTo(swiper.slides.length - 1, 0, false, true);
  3050. } else {
  3051. if (swiper.params.loop && !isVirtual) {
  3052. swiper.slideToLoop(swiper.realIndex, 0, false, true);
  3053. } else {
  3054. swiper.slideTo(swiper.activeIndex, 0, false, true);
  3055. }
  3056. }
  3057. if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {
  3058. clearTimeout(swiper.autoplay.resizeTimeout);
  3059. swiper.autoplay.resizeTimeout = setTimeout(() => {
  3060. if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {
  3061. swiper.autoplay.resume();
  3062. }
  3063. }, 500);
  3064. }
  3065. // Return locks after resize
  3066. swiper.allowSlidePrev = allowSlidePrev;
  3067. swiper.allowSlideNext = allowSlideNext;
  3068. if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) {
  3069. swiper.checkOverflow();
  3070. }
  3071. }
  3072. function onClick(e) {
  3073. const swiper = this;
  3074. if (!swiper.enabled) return;
  3075. if (!swiper.allowClick) {
  3076. if (swiper.params.preventClicks) e.preventDefault();
  3077. if (swiper.params.preventClicksPropagation && swiper.animating) {
  3078. e.stopPropagation();
  3079. e.stopImmediatePropagation();
  3080. }
  3081. }
  3082. }
  3083. function onScroll() {
  3084. const swiper = this;
  3085. const {
  3086. wrapperEl,
  3087. rtlTranslate,
  3088. enabled
  3089. } = swiper;
  3090. if (!enabled) return;
  3091. swiper.previousTranslate = swiper.translate;
  3092. if (swiper.isHorizontal()) {
  3093. swiper.translate = -wrapperEl.scrollLeft;
  3094. } else {
  3095. swiper.translate = -wrapperEl.scrollTop;
  3096. }
  3097. // eslint-disable-next-line
  3098. if (swiper.translate === 0) swiper.translate = 0;
  3099. swiper.updateActiveIndex();
  3100. swiper.updateSlidesClasses();
  3101. let newProgress;
  3102. const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();
  3103. if (translatesDiff === 0) {
  3104. newProgress = 0;
  3105. } else {
  3106. newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff;
  3107. }
  3108. if (newProgress !== swiper.progress) {
  3109. swiper.updateProgress(rtlTranslate ? -swiper.translate : swiper.translate);
  3110. }
  3111. swiper.emit('setTranslate', swiper.translate, false);
  3112. }
  3113. function onLoad(e) {
  3114. const swiper = this;
  3115. processLazyPreloader(swiper, e.target);
  3116. if (swiper.params.cssMode || swiper.params.slidesPerView !== 'auto' && !swiper.params.autoHeight) {
  3117. return;
  3118. }
  3119. swiper.update();
  3120. }
  3121. function onDocumentTouchStart() {
  3122. const swiper = this;
  3123. if (swiper.documentTouchHandlerProceeded) return;
  3124. swiper.documentTouchHandlerProceeded = true;
  3125. if (swiper.params.touchReleaseOnEdges) {
  3126. swiper.el.style.touchAction = 'auto';
  3127. }
  3128. }
  3129. const events = (swiper, method) => {
  3130. const document = getDocument();
  3131. const {
  3132. params,
  3133. el,
  3134. wrapperEl,
  3135. device
  3136. } = swiper;
  3137. const capture = !!params.nested;
  3138. const domMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';
  3139. const swiperMethod = method;
  3140. // Touch Events
  3141. document[domMethod]('touchstart', swiper.onDocumentTouchStart, {
  3142. passive: false,
  3143. capture
  3144. });
  3145. el[domMethod]('touchstart', swiper.onTouchStart, {
  3146. passive: false
  3147. });
  3148. el[domMethod]('pointerdown', swiper.onTouchStart, {
  3149. passive: false
  3150. });
  3151. document[domMethod]('touchmove', swiper.onTouchMove, {
  3152. passive: false,
  3153. capture
  3154. });
  3155. document[domMethod]('pointermove', swiper.onTouchMove, {
  3156. passive: false,
  3157. capture
  3158. });
  3159. document[domMethod]('touchend', swiper.onTouchEnd, {
  3160. passive: true
  3161. });
  3162. document[domMethod]('pointerup', swiper.onTouchEnd, {
  3163. passive: true
  3164. });
  3165. document[domMethod]('pointercancel', swiper.onTouchEnd, {
  3166. passive: true
  3167. });
  3168. document[domMethod]('touchcancel', swiper.onTouchEnd, {
  3169. passive: true
  3170. });
  3171. document[domMethod]('pointerout', swiper.onTouchEnd, {
  3172. passive: true
  3173. });
  3174. document[domMethod]('pointerleave', swiper.onTouchEnd, {
  3175. passive: true
  3176. });
  3177. document[domMethod]('contextmenu', swiper.onTouchEnd, {
  3178. passive: true
  3179. });
  3180. // Prevent Links Clicks
  3181. if (params.preventClicks || params.preventClicksPropagation) {
  3182. el[domMethod]('click', swiper.onClick, true);
  3183. }
  3184. if (params.cssMode) {
  3185. wrapperEl[domMethod]('scroll', swiper.onScroll);
  3186. }
  3187. // Resize handler
  3188. if (params.updateOnWindowResize) {
  3189. swiper[swiperMethod](device.ios || device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate', onResize, true);
  3190. } else {
  3191. swiper[swiperMethod]('observerUpdate', onResize, true);
  3192. }
  3193. // Images loader
  3194. el[domMethod]('load', swiper.onLoad, {
  3195. capture: true
  3196. });
  3197. };
  3198. function attachEvents() {
  3199. const swiper = this;
  3200. const {
  3201. params
  3202. } = swiper;
  3203. swiper.onTouchStart = onTouchStart.bind(swiper);
  3204. swiper.onTouchMove = onTouchMove.bind(swiper);
  3205. swiper.onTouchEnd = onTouchEnd.bind(swiper);
  3206. swiper.onDocumentTouchStart = onDocumentTouchStart.bind(swiper);
  3207. if (params.cssMode) {
  3208. swiper.onScroll = onScroll.bind(swiper);
  3209. }
  3210. swiper.onClick = onClick.bind(swiper);
  3211. swiper.onLoad = onLoad.bind(swiper);
  3212. events(swiper, 'on');
  3213. }
  3214. function detachEvents() {
  3215. const swiper = this;
  3216. events(swiper, 'off');
  3217. }
  3218. var events$1 = {
  3219. attachEvents,
  3220. detachEvents
  3221. };
  3222. const isGridEnabled = (swiper, params) => {
  3223. return swiper.grid && params.grid && params.grid.rows > 1;
  3224. };
  3225. function setBreakpoint() {
  3226. const swiper = this;
  3227. const {
  3228. realIndex,
  3229. initialized,
  3230. params,
  3231. el
  3232. } = swiper;
  3233. const breakpoints = params.breakpoints;
  3234. if (!breakpoints || breakpoints && Object.keys(breakpoints).length === 0) return;
  3235. // Get breakpoint for window width and update parameters
  3236. const breakpoint = swiper.getBreakpoint(breakpoints, swiper.params.breakpointsBase, swiper.el);
  3237. if (!breakpoint || swiper.currentBreakpoint === breakpoint) return;
  3238. const breakpointOnlyParams = breakpoint in breakpoints ? breakpoints[breakpoint] : undefined;
  3239. const breakpointParams = breakpointOnlyParams || swiper.originalParams;
  3240. const wasMultiRow = isGridEnabled(swiper, params);
  3241. const isMultiRow = isGridEnabled(swiper, breakpointParams);
  3242. const wasEnabled = params.enabled;
  3243. if (wasMultiRow && !isMultiRow) {
  3244. el.classList.remove(`${params.containerModifierClass}grid`, `${params.containerModifierClass}grid-column`);
  3245. swiper.emitContainerClasses();
  3246. } else if (!wasMultiRow && isMultiRow) {
  3247. el.classList.add(`${params.containerModifierClass}grid`);
  3248. if (breakpointParams.grid.fill && breakpointParams.grid.fill === 'column' || !breakpointParams.grid.fill && params.grid.fill === 'column') {
  3249. el.classList.add(`${params.containerModifierClass}grid-column`);
  3250. }
  3251. swiper.emitContainerClasses();
  3252. }
  3253. // Toggle navigation, pagination, scrollbar
  3254. ['navigation', 'pagination', 'scrollbar'].forEach(prop => {
  3255. if (typeof breakpointParams[prop] === 'undefined') return;
  3256. const wasModuleEnabled = params[prop] && params[prop].enabled;
  3257. const isModuleEnabled = breakpointParams[prop] && breakpointParams[prop].enabled;
  3258. if (wasModuleEnabled && !isModuleEnabled) {
  3259. swiper[prop].disable();
  3260. }
  3261. if (!wasModuleEnabled && isModuleEnabled) {
  3262. swiper[prop].enable();
  3263. }
  3264. });
  3265. const directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction;
  3266. const needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged);
  3267. const wasLoop = params.loop;
  3268. if (directionChanged && initialized) {
  3269. swiper.changeDirection();
  3270. }
  3271. extend(swiper.params, breakpointParams);
  3272. const isEnabled = swiper.params.enabled;
  3273. const hasLoop = swiper.params.loop;
  3274. Object.assign(swiper, {
  3275. allowTouchMove: swiper.params.allowTouchMove,
  3276. allowSlideNext: swiper.params.allowSlideNext,
  3277. allowSlidePrev: swiper.params.allowSlidePrev
  3278. });
  3279. if (wasEnabled && !isEnabled) {
  3280. swiper.disable();
  3281. } else if (!wasEnabled && isEnabled) {
  3282. swiper.enable();
  3283. }
  3284. swiper.currentBreakpoint = breakpoint;
  3285. swiper.emit('_beforeBreakpoint', breakpointParams);
  3286. if (initialized) {
  3287. if (needsReLoop) {
  3288. swiper.loopDestroy();
  3289. swiper.loopCreate(realIndex);
  3290. swiper.updateSlides();
  3291. } else if (!wasLoop && hasLoop) {
  3292. swiper.loopCreate(realIndex);
  3293. swiper.updateSlides();
  3294. } else if (wasLoop && !hasLoop) {
  3295. swiper.loopDestroy();
  3296. }
  3297. }
  3298. swiper.emit('breakpoint', breakpointParams);
  3299. }
  3300. function getBreakpoint(breakpoints, base, containerEl) {
  3301. if (base === void 0) {
  3302. base = 'window';
  3303. }
  3304. if (!breakpoints || base === 'container' && !containerEl) return undefined;
  3305. let breakpoint = false;
  3306. const window = getWindow();
  3307. const currentHeight = base === 'window' ? window.innerHeight : containerEl.clientHeight;
  3308. const points = Object.keys(breakpoints).map(point => {
  3309. if (typeof point === 'string' && point.indexOf('@') === 0) {
  3310. const minRatio = parseFloat(point.substr(1));
  3311. const value = currentHeight * minRatio;
  3312. return {
  3313. value,
  3314. point
  3315. };
  3316. }
  3317. return {
  3318. value: point,
  3319. point
  3320. };
  3321. });
  3322. points.sort((a, b) => parseInt(a.value, 10) - parseInt(b.value, 10));
  3323. for (let i = 0; i < points.length; i += 1) {
  3324. const {
  3325. point,
  3326. value
  3327. } = points[i];
  3328. if (base === 'window') {
  3329. if (window.matchMedia(`(min-width: ${value}px)`).matches) {
  3330. breakpoint = point;
  3331. }
  3332. } else if (value <= containerEl.clientWidth) {
  3333. breakpoint = point;
  3334. }
  3335. }
  3336. return breakpoint || 'max';
  3337. }
  3338. var breakpoints = {
  3339. setBreakpoint,
  3340. getBreakpoint
  3341. };
  3342. function prepareClasses(entries, prefix) {
  3343. const resultClasses = [];
  3344. entries.forEach(item => {
  3345. if (typeof item === 'object') {
  3346. Object.keys(item).forEach(classNames => {
  3347. if (item[classNames]) {
  3348. resultClasses.push(prefix + classNames);
  3349. }
  3350. });
  3351. } else if (typeof item === 'string') {
  3352. resultClasses.push(prefix + item);
  3353. }
  3354. });
  3355. return resultClasses;
  3356. }
  3357. function addClasses() {
  3358. const swiper = this;
  3359. const {
  3360. classNames,
  3361. params,
  3362. rtl,
  3363. el,
  3364. device
  3365. } = swiper;
  3366. // prettier-ignore
  3367. const suffixes = prepareClasses(['initialized', params.direction, {
  3368. 'free-mode': swiper.params.freeMode && params.freeMode.enabled
  3369. }, {
  3370. 'autoheight': params.autoHeight
  3371. }, {
  3372. 'rtl': rtl
  3373. }, {
  3374. 'grid': params.grid && params.grid.rows > 1
  3375. }, {
  3376. 'grid-column': params.grid && params.grid.rows > 1 && params.grid.fill === 'column'
  3377. }, {
  3378. 'android': device.android
  3379. }, {
  3380. 'ios': device.ios
  3381. }, {
  3382. 'css-mode': params.cssMode
  3383. }, {
  3384. 'centered': params.cssMode && params.centeredSlides
  3385. }, {
  3386. 'watch-progress': params.watchSlidesProgress
  3387. }], params.containerModifierClass);
  3388. classNames.push(...suffixes);
  3389. el.classList.add(...classNames);
  3390. swiper.emitContainerClasses();
  3391. }
  3392. function removeClasses() {
  3393. const swiper = this;
  3394. const {
  3395. el,
  3396. classNames
  3397. } = swiper;
  3398. el.classList.remove(...classNames);
  3399. swiper.emitContainerClasses();
  3400. }
  3401. var classes = {
  3402. addClasses,
  3403. removeClasses
  3404. };
  3405. function checkOverflow() {
  3406. const swiper = this;
  3407. const {
  3408. isLocked: wasLocked,
  3409. params
  3410. } = swiper;
  3411. const {
  3412. slidesOffsetBefore
  3413. } = params;
  3414. if (slidesOffsetBefore) {
  3415. const lastSlideIndex = swiper.slides.length - 1;
  3416. const lastSlideRightEdge = swiper.slidesGrid[lastSlideIndex] + swiper.slidesSizesGrid[lastSlideIndex] + slidesOffsetBefore * 2;
  3417. swiper.isLocked = swiper.size > lastSlideRightEdge;
  3418. } else {
  3419. swiper.isLocked = swiper.snapGrid.length === 1;
  3420. }
  3421. if (params.allowSlideNext === true) {
  3422. swiper.allowSlideNext = !swiper.isLocked;
  3423. }
  3424. if (params.allowSlidePrev === true) {
  3425. swiper.allowSlidePrev = !swiper.isLocked;
  3426. }
  3427. if (wasLocked && wasLocked !== swiper.isLocked) {
  3428. swiper.isEnd = false;
  3429. }
  3430. if (wasLocked !== swiper.isLocked) {
  3431. swiper.emit(swiper.isLocked ? 'lock' : 'unlock');
  3432. }
  3433. }
  3434. var checkOverflow$1 = {
  3435. checkOverflow
  3436. };
  3437. var defaults = {
  3438. init: true,
  3439. direction: 'horizontal',
  3440. oneWayMovement: false,
  3441. touchEventsTarget: 'wrapper',
  3442. initialSlide: 0,
  3443. speed: 300,
  3444. cssMode: false,
  3445. updateOnWindowResize: true,
  3446. resizeObserver: true,
  3447. nested: false,
  3448. createElements: false,
  3449. eventsPrefix: 'swiper',
  3450. enabled: true,
  3451. focusableElements: 'input, select, option, textarea, button, video, label',
  3452. // Overrides
  3453. width: null,
  3454. height: null,
  3455. //
  3456. preventInteractionOnTransition: false,
  3457. // ssr
  3458. userAgent: null,
  3459. url: null,
  3460. // To support iOS's swipe-to-go-back gesture (when being used in-app).
  3461. edgeSwipeDetection: false,
  3462. edgeSwipeThreshold: 20,
  3463. // Autoheight
  3464. autoHeight: false,
  3465. // Set wrapper width
  3466. setWrapperSize: false,
  3467. // Virtual Translate
  3468. virtualTranslate: false,
  3469. // Effects
  3470. effect: 'slide',
  3471. // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip'
  3472. // Breakpoints
  3473. breakpoints: undefined,
  3474. breakpointsBase: 'window',
  3475. // Slides grid
  3476. spaceBetween: 0,
  3477. slidesPerView: 1,
  3478. slidesPerGroup: 1,
  3479. slidesPerGroupSkip: 0,
  3480. slidesPerGroupAuto: false,
  3481. centeredSlides: false,
  3482. centeredSlidesBounds: false,
  3483. slidesOffsetBefore: 0,
  3484. // in px
  3485. slidesOffsetAfter: 0,
  3486. // in px
  3487. normalizeSlideIndex: true,
  3488. centerInsufficientSlides: false,
  3489. // Disable swiper and hide navigation when container not overflow
  3490. watchOverflow: true,
  3491. // Round length
  3492. roundLengths: false,
  3493. // Touches
  3494. touchRatio: 1,
  3495. touchAngle: 45,
  3496. simulateTouch: true,
  3497. shortSwipes: true,
  3498. longSwipes: true,
  3499. longSwipesRatio: 0.5,
  3500. longSwipesMs: 300,
  3501. followFinger: true,
  3502. allowTouchMove: true,
  3503. threshold: 5,
  3504. touchMoveStopPropagation: false,
  3505. touchStartPreventDefault: true,
  3506. touchStartForcePreventDefault: false,
  3507. touchReleaseOnEdges: false,
  3508. // Unique Navigation Elements
  3509. uniqueNavElements: true,
  3510. // Resistance
  3511. resistance: true,
  3512. resistanceRatio: 0.85,
  3513. // Progress
  3514. watchSlidesProgress: false,
  3515. // Cursor
  3516. grabCursor: false,
  3517. // Clicks
  3518. preventClicks: true,
  3519. preventClicksPropagation: true,
  3520. slideToClickedSlide: false,
  3521. // loop
  3522. loop: false,
  3523. loopAddBlankSlides: true,
  3524. loopAdditionalSlides: 0,
  3525. loopPreventsSliding: true,
  3526. // rewind
  3527. rewind: false,
  3528. // Swiping/no swiping
  3529. allowSlidePrev: true,
  3530. allowSlideNext: true,
  3531. swipeHandler: null,
  3532. // '.swipe-handler',
  3533. noSwiping: true,
  3534. noSwipingClass: 'swiper-no-swiping',
  3535. noSwipingSelector: null,
  3536. // Passive Listeners
  3537. passiveListeners: true,
  3538. maxBackfaceHiddenSlides: 10,
  3539. // NS
  3540. containerModifierClass: 'swiper-',
  3541. // NEW
  3542. slideClass: 'swiper-slide',
  3543. slideBlankClass: 'swiper-slide-blank',
  3544. slideActiveClass: 'swiper-slide-active',
  3545. slideVisibleClass: 'swiper-slide-visible',
  3546. slideFullyVisibleClass: 'swiper-slide-fully-visible',
  3547. slideNextClass: 'swiper-slide-next',
  3548. slidePrevClass: 'swiper-slide-prev',
  3549. wrapperClass: 'swiper-wrapper',
  3550. lazyPreloaderClass: 'swiper-lazy-preloader',
  3551. lazyPreloadPrevNext: 0,
  3552. // Callbacks
  3553. runCallbacksOnInit: true,
  3554. // Internals
  3555. _emitClasses: false
  3556. };
  3557. function moduleExtendParams(params, allModulesParams) {
  3558. return function extendParams(obj) {
  3559. if (obj === void 0) {
  3560. obj = {};
  3561. }
  3562. const moduleParamName = Object.keys(obj)[0];
  3563. const moduleParams = obj[moduleParamName];
  3564. if (typeof moduleParams !== 'object' || moduleParams === null) {
  3565. extend(allModulesParams, obj);
  3566. return;
  3567. }
  3568. if (params[moduleParamName] === true) {
  3569. params[moduleParamName] = {
  3570. enabled: true
  3571. };
  3572. }
  3573. if (moduleParamName === 'navigation' && params[moduleParamName] && params[moduleParamName].enabled && !params[moduleParamName].prevEl && !params[moduleParamName].nextEl) {
  3574. params[moduleParamName].auto = true;
  3575. }
  3576. if (['pagination', 'scrollbar'].indexOf(moduleParamName) >= 0 && params[moduleParamName] && params[moduleParamName].enabled && !params[moduleParamName].el) {
  3577. params[moduleParamName].auto = true;
  3578. }
  3579. if (!(moduleParamName in params && 'enabled' in moduleParams)) {
  3580. extend(allModulesParams, obj);
  3581. return;
  3582. }
  3583. if (typeof params[moduleParamName] === 'object' && !('enabled' in params[moduleParamName])) {
  3584. params[moduleParamName].enabled = true;
  3585. }
  3586. if (!params[moduleParamName]) params[moduleParamName] = {
  3587. enabled: false
  3588. };
  3589. extend(allModulesParams, obj);
  3590. };
  3591. }
  3592. /* eslint no-param-reassign: "off" */
  3593. const prototypes = {
  3594. eventsEmitter,
  3595. update,
  3596. translate,
  3597. transition,
  3598. slide,
  3599. loop,
  3600. grabCursor,
  3601. events: events$1,
  3602. breakpoints,
  3603. checkOverflow: checkOverflow$1,
  3604. classes
  3605. };
  3606. const extendedDefaults = {};
  3607. class Swiper {
  3608. constructor() {
  3609. let el;
  3610. let params;
  3611. for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
  3612. args[_key] = arguments[_key];
  3613. }
  3614. if (args.length === 1 && args[0].constructor && Object.prototype.toString.call(args[0]).slice(8, -1) === 'Object') {
  3615. params = args[0];
  3616. } else {
  3617. [el, params] = args;
  3618. }
  3619. if (!params) params = {};
  3620. params = extend({}, params);
  3621. if (el && !params.el) params.el = el;
  3622. const document = getDocument();
  3623. if (params.el && typeof params.el === 'string' && document.querySelectorAll(params.el).length > 1) {
  3624. const swipers = [];
  3625. document.querySelectorAll(params.el).forEach(containerEl => {
  3626. const newParams = extend({}, params, {
  3627. el: containerEl
  3628. });
  3629. swipers.push(new Swiper(newParams));
  3630. });
  3631. // eslint-disable-next-line no-constructor-return
  3632. return swipers;
  3633. }
  3634. // Swiper Instance
  3635. const swiper = this;
  3636. swiper.__swiper__ = true;
  3637. swiper.support = getSupport();
  3638. swiper.device = getDevice({
  3639. userAgent: params.userAgent
  3640. });
  3641. swiper.browser = getBrowser();
  3642. swiper.eventsListeners = {};
  3643. swiper.eventsAnyListeners = [];
  3644. swiper.modules = [...swiper.__modules__];
  3645. if (params.modules && Array.isArray(params.modules)) {
  3646. swiper.modules.push(...params.modules);
  3647. }
  3648. const allModulesParams = {};
  3649. swiper.modules.forEach(mod => {
  3650. mod({
  3651. params,
  3652. swiper,
  3653. extendParams: moduleExtendParams(params, allModulesParams),
  3654. on: swiper.on.bind(swiper),
  3655. once: swiper.once.bind(swiper),
  3656. off: swiper.off.bind(swiper),
  3657. emit: swiper.emit.bind(swiper)
  3658. });
  3659. });
  3660. // Extend defaults with modules params
  3661. const swiperParams = extend({}, defaults, allModulesParams);
  3662. // Extend defaults with passed params
  3663. swiper.params = extend({}, swiperParams, extendedDefaults, params);
  3664. swiper.originalParams = extend({}, swiper.params);
  3665. swiper.passedParams = extend({}, params);
  3666. // add event listeners
  3667. if (swiper.params && swiper.params.on) {
  3668. Object.keys(swiper.params.on).forEach(eventName => {
  3669. swiper.on(eventName, swiper.params.on[eventName]);
  3670. });
  3671. }
  3672. if (swiper.params && swiper.params.onAny) {
  3673. swiper.onAny(swiper.params.onAny);
  3674. }
  3675. // Extend Swiper
  3676. Object.assign(swiper, {
  3677. enabled: swiper.params.enabled,
  3678. el,
  3679. // Classes
  3680. classNames: [],
  3681. // Slides
  3682. slides: [],
  3683. slidesGrid: [],
  3684. snapGrid: [],
  3685. slidesSizesGrid: [],
  3686. // isDirection
  3687. isHorizontal() {
  3688. return swiper.params.direction === 'horizontal';
  3689. },
  3690. isVertical() {
  3691. return swiper.params.direction === 'vertical';
  3692. },
  3693. // Indexes
  3694. activeIndex: 0,
  3695. realIndex: 0,
  3696. //
  3697. isBeginning: true,
  3698. isEnd: false,
  3699. // Props
  3700. translate: 0,
  3701. previousTranslate: 0,
  3702. progress: 0,
  3703. velocity: 0,
  3704. animating: false,
  3705. cssOverflowAdjustment() {
  3706. // Returns 0 unless `translate` is > 2**23
  3707. // Should be subtracted from css values to prevent overflow
  3708. return Math.trunc(this.translate / 2 ** 23) * 2 ** 23;
  3709. },
  3710. // Locks
  3711. allowSlideNext: swiper.params.allowSlideNext,
  3712. allowSlidePrev: swiper.params.allowSlidePrev,
  3713. // Touch Events
  3714. touchEventsData: {
  3715. isTouched: undefined,
  3716. isMoved: undefined,
  3717. allowTouchCallbacks: undefined,
  3718. touchStartTime: undefined,
  3719. isScrolling: undefined,
  3720. currentTranslate: undefined,
  3721. startTranslate: undefined,
  3722. allowThresholdMove: undefined,
  3723. // Form elements to match
  3724. focusableElements: swiper.params.focusableElements,
  3725. // Last click time
  3726. lastClickTime: 0,
  3727. clickTimeout: undefined,
  3728. // Velocities
  3729. velocities: [],
  3730. allowMomentumBounce: undefined,
  3731. startMoving: undefined,
  3732. pointerId: null,
  3733. touchId: null
  3734. },
  3735. // Clicks
  3736. allowClick: true,
  3737. // Touches
  3738. allowTouchMove: swiper.params.allowTouchMove,
  3739. touches: {
  3740. startX: 0,
  3741. startY: 0,
  3742. currentX: 0,
  3743. currentY: 0,
  3744. diff: 0
  3745. },
  3746. // Images
  3747. imagesToLoad: [],
  3748. imagesLoaded: 0
  3749. });
  3750. swiper.emit('_swiper');
  3751. // Init
  3752. if (swiper.params.init) {
  3753. swiper.init();
  3754. }
  3755. // Return app instance
  3756. // eslint-disable-next-line no-constructor-return
  3757. return swiper;
  3758. }
  3759. getDirectionLabel(property) {
  3760. if (this.isHorizontal()) {
  3761. return property;
  3762. }
  3763. // prettier-ignore
  3764. return {
  3765. 'width': 'height',
  3766. 'margin-top': 'margin-left',
  3767. 'margin-bottom ': 'margin-right',
  3768. 'margin-left': 'margin-top',
  3769. 'margin-right': 'margin-bottom',
  3770. 'padding-left': 'padding-top',
  3771. 'padding-right': 'padding-bottom',
  3772. 'marginRight': 'marginBottom'
  3773. }[property];
  3774. }
  3775. getSlideIndex(slideEl) {
  3776. const {
  3777. slidesEl,
  3778. params
  3779. } = this;
  3780. const slides = elementChildren(slidesEl, `.${params.slideClass}, swiper-slide`);
  3781. const firstSlideIndex = elementIndex(slides[0]);
  3782. return elementIndex(slideEl) - firstSlideIndex;
  3783. }
  3784. getSlideIndexByData(index) {
  3785. return this.getSlideIndex(this.slides.filter(slideEl => slideEl.getAttribute('data-swiper-slide-index') * 1 === index)[0]);
  3786. }
  3787. recalcSlides() {
  3788. const swiper = this;
  3789. const {
  3790. slidesEl,
  3791. params
  3792. } = swiper;
  3793. swiper.slides = elementChildren(slidesEl, `.${params.slideClass}, swiper-slide`);
  3794. }
  3795. enable() {
  3796. const swiper = this;
  3797. if (swiper.enabled) return;
  3798. swiper.enabled = true;
  3799. if (swiper.params.grabCursor) {
  3800. swiper.setGrabCursor();
  3801. }
  3802. swiper.emit('enable');
  3803. }
  3804. disable() {
  3805. const swiper = this;
  3806. if (!swiper.enabled) return;
  3807. swiper.enabled = false;
  3808. if (swiper.params.grabCursor) {
  3809. swiper.unsetGrabCursor();
  3810. }
  3811. swiper.emit('disable');
  3812. }
  3813. setProgress(progress, speed) {
  3814. const swiper = this;
  3815. progress = Math.min(Math.max(progress, 0), 1);
  3816. const min = swiper.minTranslate();
  3817. const max = swiper.maxTranslate();
  3818. const current = (max - min) * progress + min;
  3819. swiper.translateTo(current, typeof speed === 'undefined' ? 0 : speed);
  3820. swiper.updateActiveIndex();
  3821. swiper.updateSlidesClasses();
  3822. }
  3823. emitContainerClasses() {
  3824. const swiper = this;
  3825. if (!swiper.params._emitClasses || !swiper.el) return;
  3826. const cls = swiper.el.className.split(' ').filter(className => {
  3827. return className.indexOf('swiper') === 0 || className.indexOf(swiper.params.containerModifierClass) === 0;
  3828. });
  3829. swiper.emit('_containerClasses', cls.join(' '));
  3830. }
  3831. getSlideClasses(slideEl) {
  3832. const swiper = this;
  3833. if (swiper.destroyed) return '';
  3834. return slideEl.className.split(' ').filter(className => {
  3835. return className.indexOf('swiper-slide') === 0 || className.indexOf(swiper.params.slideClass) === 0;
  3836. }).join(' ');
  3837. }
  3838. emitSlidesClasses() {
  3839. const swiper = this;
  3840. if (!swiper.params._emitClasses || !swiper.el) return;
  3841. const updates = [];
  3842. swiper.slides.forEach(slideEl => {
  3843. const classNames = swiper.getSlideClasses(slideEl);
  3844. updates.push({
  3845. slideEl,
  3846. classNames
  3847. });
  3848. swiper.emit('_slideClass', slideEl, classNames);
  3849. });
  3850. swiper.emit('_slideClasses', updates);
  3851. }
  3852. slidesPerViewDynamic(view, exact) {
  3853. if (view === void 0) {
  3854. view = 'current';
  3855. }
  3856. if (exact === void 0) {
  3857. exact = false;
  3858. }
  3859. const swiper = this;
  3860. const {
  3861. params,
  3862. slides,
  3863. slidesGrid,
  3864. slidesSizesGrid,
  3865. size: swiperSize,
  3866. activeIndex
  3867. } = swiper;
  3868. let spv = 1;
  3869. if (typeof params.slidesPerView === 'number') return params.slidesPerView;
  3870. if (params.centeredSlides) {
  3871. let slideSize = slides[activeIndex] ? slides[activeIndex].swiperSlideSize : 0;
  3872. let breakLoop;
  3873. for (let i = activeIndex + 1; i < slides.length; i += 1) {
  3874. if (slides[i] && !breakLoop) {
  3875. slideSize += slides[i].swiperSlideSize;
  3876. spv += 1;
  3877. if (slideSize > swiperSize) breakLoop = true;
  3878. }
  3879. }
  3880. for (let i = activeIndex - 1; i >= 0; i -= 1) {
  3881. if (slides[i] && !breakLoop) {
  3882. slideSize += slides[i].swiperSlideSize;
  3883. spv += 1;
  3884. if (slideSize > swiperSize) breakLoop = true;
  3885. }
  3886. }
  3887. } else {
  3888. // eslint-disable-next-line
  3889. if (view === 'current') {
  3890. for (let i = activeIndex + 1; i < slides.length; i += 1) {
  3891. const slideInView = exact ? slidesGrid[i] + slidesSizesGrid[i] - slidesGrid[activeIndex] < swiperSize : slidesGrid[i] - slidesGrid[activeIndex] < swiperSize;
  3892. if (slideInView) {
  3893. spv += 1;
  3894. }
  3895. }
  3896. } else {
  3897. // previous
  3898. for (let i = activeIndex - 1; i >= 0; i -= 1) {
  3899. const slideInView = slidesGrid[activeIndex] - slidesGrid[i] < swiperSize;
  3900. if (slideInView) {
  3901. spv += 1;
  3902. }
  3903. }
  3904. }
  3905. }
  3906. return spv;
  3907. }
  3908. update() {
  3909. const swiper = this;
  3910. if (!swiper || swiper.destroyed) return;
  3911. const {
  3912. snapGrid,
  3913. params
  3914. } = swiper;
  3915. // Breakpoints
  3916. if (params.breakpoints) {
  3917. swiper.setBreakpoint();
  3918. }
  3919. [...swiper.el.querySelectorAll('[loading="lazy"]')].forEach(imageEl => {
  3920. if (imageEl.complete) {
  3921. processLazyPreloader(swiper, imageEl);
  3922. }
  3923. });
  3924. swiper.updateSize();
  3925. swiper.updateSlides();
  3926. swiper.updateProgress();
  3927. swiper.updateSlidesClasses();
  3928. function setTranslate() {
  3929. const translateValue = swiper.rtlTranslate ? swiper.translate * -1 : swiper.translate;
  3930. const newTranslate = Math.min(Math.max(translateValue, swiper.maxTranslate()), swiper.minTranslate());
  3931. swiper.setTranslate(newTranslate);
  3932. swiper.updateActiveIndex();
  3933. swiper.updateSlidesClasses();
  3934. }
  3935. let translated;
  3936. if (params.freeMode && params.freeMode.enabled && !params.cssMode) {
  3937. setTranslate();
  3938. if (params.autoHeight) {
  3939. swiper.updateAutoHeight();
  3940. }
  3941. } else {
  3942. if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !params.centeredSlides) {
  3943. const slides = swiper.virtual && params.virtual.enabled ? swiper.virtual.slides : swiper.slides;
  3944. translated = swiper.slideTo(slides.length - 1, 0, false, true);
  3945. } else {
  3946. translated = swiper.slideTo(swiper.activeIndex, 0, false, true);
  3947. }
  3948. if (!translated) {
  3949. setTranslate();
  3950. }
  3951. }
  3952. if (params.watchOverflow && snapGrid !== swiper.snapGrid) {
  3953. swiper.checkOverflow();
  3954. }
  3955. swiper.emit('update');
  3956. }
  3957. changeDirection(newDirection, needUpdate) {
  3958. if (needUpdate === void 0) {
  3959. needUpdate = true;
  3960. }
  3961. const swiper = this;
  3962. const currentDirection = swiper.params.direction;
  3963. if (!newDirection) {
  3964. // eslint-disable-next-line
  3965. newDirection = currentDirection === 'horizontal' ? 'vertical' : 'horizontal';
  3966. }
  3967. if (newDirection === currentDirection || newDirection !== 'horizontal' && newDirection !== 'vertical') {
  3968. return swiper;
  3969. }
  3970. swiper.el.classList.remove(`${swiper.params.containerModifierClass}${currentDirection}`);
  3971. swiper.el.classList.add(`${swiper.params.containerModifierClass}${newDirection}`);
  3972. swiper.emitContainerClasses();
  3973. swiper.params.direction = newDirection;
  3974. swiper.slides.forEach(slideEl => {
  3975. if (newDirection === 'vertical') {
  3976. slideEl.style.width = '';
  3977. } else {
  3978. slideEl.style.height = '';
  3979. }
  3980. });
  3981. swiper.emit('changeDirection');
  3982. if (needUpdate) swiper.update();
  3983. return swiper;
  3984. }
  3985. changeLanguageDirection(direction) {
  3986. const swiper = this;
  3987. if (swiper.rtl && direction === 'rtl' || !swiper.rtl && direction === 'ltr') return;
  3988. swiper.rtl = direction === 'rtl';
  3989. swiper.rtlTranslate = swiper.params.direction === 'horizontal' && swiper.rtl;
  3990. if (swiper.rtl) {
  3991. swiper.el.classList.add(`${swiper.params.containerModifierClass}rtl`);
  3992. swiper.el.dir = 'rtl';
  3993. } else {
  3994. swiper.el.classList.remove(`${swiper.params.containerModifierClass}rtl`);
  3995. swiper.el.dir = 'ltr';
  3996. }
  3997. swiper.update();
  3998. }
  3999. mount(element) {
  4000. const swiper = this;
  4001. if (swiper.mounted) return true;
  4002. // Find el
  4003. let el = element || swiper.params.el;
  4004. if (typeof el === 'string') {
  4005. el = document.querySelector(el);
  4006. }
  4007. if (!el) {
  4008. return false;
  4009. }
  4010. el.swiper = swiper;
  4011. if (el.parentNode && el.parentNode.host && el.parentNode.host.nodeName === 'SWIPER-CONTAINER') {
  4012. swiper.isElement = true;
  4013. }
  4014. const getWrapperSelector = () => {
  4015. return `.${(swiper.params.wrapperClass || '').trim().split(' ').join('.')}`;
  4016. };
  4017. const getWrapper = () => {
  4018. if (el && el.shadowRoot && el.shadowRoot.querySelector) {
  4019. const res = el.shadowRoot.querySelector(getWrapperSelector());
  4020. // Children needs to return slot items
  4021. return res;
  4022. }
  4023. return elementChildren(el, getWrapperSelector())[0];
  4024. };
  4025. // Find Wrapper
  4026. let wrapperEl = getWrapper();
  4027. if (!wrapperEl && swiper.params.createElements) {
  4028. wrapperEl = createElement('div', swiper.params.wrapperClass);
  4029. el.append(wrapperEl);
  4030. elementChildren(el, `.${swiper.params.slideClass}`).forEach(slideEl => {
  4031. wrapperEl.append(slideEl);
  4032. });
  4033. }
  4034. Object.assign(swiper, {
  4035. el,
  4036. wrapperEl,
  4037. slidesEl: swiper.isElement && !el.parentNode.host.slideSlots ? el.parentNode.host : wrapperEl,
  4038. hostEl: swiper.isElement ? el.parentNode.host : el,
  4039. mounted: true,
  4040. // RTL
  4041. rtl: el.dir.toLowerCase() === 'rtl' || elementStyle(el, 'direction') === 'rtl',
  4042. rtlTranslate: swiper.params.direction === 'horizontal' && (el.dir.toLowerCase() === 'rtl' || elementStyle(el, 'direction') === 'rtl'),
  4043. wrongRTL: elementStyle(wrapperEl, 'display') === '-webkit-box'
  4044. });
  4045. return true;
  4046. }
  4047. init(el) {
  4048. const swiper = this;
  4049. if (swiper.initialized) return swiper;
  4050. const mounted = swiper.mount(el);
  4051. if (mounted === false) return swiper;
  4052. swiper.emit('beforeInit');
  4053. // Set breakpoint
  4054. if (swiper.params.breakpoints) {
  4055. swiper.setBreakpoint();
  4056. }
  4057. // Add Classes
  4058. swiper.addClasses();
  4059. // Update size
  4060. swiper.updateSize();
  4061. // Update slides
  4062. swiper.updateSlides();
  4063. if (swiper.params.watchOverflow) {
  4064. swiper.checkOverflow();
  4065. }
  4066. // Set Grab Cursor
  4067. if (swiper.params.grabCursor && swiper.enabled) {
  4068. swiper.setGrabCursor();
  4069. }
  4070. // Slide To Initial Slide
  4071. if (swiper.params.loop && swiper.virtual && swiper.params.virtual.enabled) {
  4072. swiper.slideTo(swiper.params.initialSlide + swiper.virtual.slidesBefore, 0, swiper.params.runCallbacksOnInit, false, true);
  4073. } else {
  4074. swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit, false, true);
  4075. }
  4076. // Create loop
  4077. if (swiper.params.loop) {
  4078. swiper.loopCreate();
  4079. }
  4080. // Attach events
  4081. swiper.attachEvents();
  4082. const lazyElements = [...swiper.el.querySelectorAll('[loading="lazy"]')];
  4083. if (swiper.isElement) {
  4084. lazyElements.push(...swiper.hostEl.querySelectorAll('[loading="lazy"]'));
  4085. }
  4086. lazyElements.forEach(imageEl => {
  4087. if (imageEl.complete) {
  4088. processLazyPreloader(swiper, imageEl);
  4089. } else {
  4090. imageEl.addEventListener('load', e => {
  4091. processLazyPreloader(swiper, e.target);
  4092. });
  4093. }
  4094. });
  4095. preload(swiper);
  4096. // Init Flag
  4097. swiper.initialized = true;
  4098. preload(swiper);
  4099. // Emit
  4100. swiper.emit('init');
  4101. swiper.emit('afterInit');
  4102. return swiper;
  4103. }
  4104. destroy(deleteInstance, cleanStyles) {
  4105. if (deleteInstance === void 0) {
  4106. deleteInstance = true;
  4107. }
  4108. if (cleanStyles === void 0) {
  4109. cleanStyles = true;
  4110. }
  4111. const swiper = this;
  4112. const {
  4113. params,
  4114. el,
  4115. wrapperEl,
  4116. slides
  4117. } = swiper;
  4118. if (typeof swiper.params === 'undefined' || swiper.destroyed) {
  4119. return null;
  4120. }
  4121. swiper.emit('beforeDestroy');
  4122. // Init Flag
  4123. swiper.initialized = false;
  4124. // Detach events
  4125. swiper.detachEvents();
  4126. // Destroy loop
  4127. if (params.loop) {
  4128. swiper.loopDestroy();
  4129. }
  4130. // Cleanup styles
  4131. if (cleanStyles) {
  4132. swiper.removeClasses();
  4133. el.removeAttribute('style');
  4134. wrapperEl.removeAttribute('style');
  4135. if (slides && slides.length) {
  4136. slides.forEach(slideEl => {
  4137. slideEl.classList.remove(params.slideVisibleClass, params.slideFullyVisibleClass, params.slideActiveClass, params.slideNextClass, params.slidePrevClass);
  4138. slideEl.removeAttribute('style');
  4139. slideEl.removeAttribute('data-swiper-slide-index');
  4140. });
  4141. }
  4142. }
  4143. swiper.emit('destroy');
  4144. // Detach emitter events
  4145. Object.keys(swiper.eventsListeners).forEach(eventName => {
  4146. swiper.off(eventName);
  4147. });
  4148. if (deleteInstance !== false) {
  4149. swiper.el.swiper = null;
  4150. deleteProps(swiper);
  4151. }
  4152. swiper.destroyed = true;
  4153. return null;
  4154. }
  4155. static extendDefaults(newDefaults) {
  4156. extend(extendedDefaults, newDefaults);
  4157. }
  4158. static get extendedDefaults() {
  4159. return extendedDefaults;
  4160. }
  4161. static get defaults() {
  4162. return defaults;
  4163. }
  4164. static installModule(mod) {
  4165. if (!Swiper.prototype.__modules__) Swiper.prototype.__modules__ = [];
  4166. const modules = Swiper.prototype.__modules__;
  4167. if (typeof mod === 'function' && modules.indexOf(mod) < 0) {
  4168. modules.push(mod);
  4169. }
  4170. }
  4171. static use(module) {
  4172. if (Array.isArray(module)) {
  4173. module.forEach(m => Swiper.installModule(m));
  4174. return Swiper;
  4175. }
  4176. Swiper.installModule(module);
  4177. return Swiper;
  4178. }
  4179. }
  4180. Object.keys(prototypes).forEach(prototypeGroup => {
  4181. Object.keys(prototypes[prototypeGroup]).forEach(protoMethod => {
  4182. Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod];
  4183. });
  4184. });
  4185. Swiper.use([Resize, Observer]);
  4186. function Virtual(_ref) {
  4187. let {
  4188. swiper,
  4189. extendParams,
  4190. on,
  4191. emit
  4192. } = _ref;
  4193. extendParams({
  4194. virtual: {
  4195. enabled: false,
  4196. slides: [],
  4197. cache: true,
  4198. renderSlide: null,
  4199. renderExternal: null,
  4200. renderExternalUpdate: true,
  4201. addSlidesBefore: 0,
  4202. addSlidesAfter: 0
  4203. }
  4204. });
  4205. let cssModeTimeout;
  4206. const document = getDocument();
  4207. swiper.virtual = {
  4208. cache: {},
  4209. from: undefined,
  4210. to: undefined,
  4211. slides: [],
  4212. offset: 0,
  4213. slidesGrid: []
  4214. };
  4215. const tempDOM = document.createElement('div');
  4216. function renderSlide(slide, index) {
  4217. const params = swiper.params.virtual;
  4218. if (params.cache && swiper.virtual.cache[index]) {
  4219. return swiper.virtual.cache[index];
  4220. }
  4221. // eslint-disable-next-line
  4222. let slideEl;
  4223. if (params.renderSlide) {
  4224. slideEl = params.renderSlide.call(swiper, slide, index);
  4225. if (typeof slideEl === 'string') {
  4226. tempDOM.innerHTML = slideEl;
  4227. slideEl = tempDOM.children[0];
  4228. }
  4229. } else if (swiper.isElement) {
  4230. slideEl = createElement('swiper-slide');
  4231. } else {
  4232. slideEl = createElement('div', swiper.params.slideClass);
  4233. }
  4234. slideEl.setAttribute('data-swiper-slide-index', index);
  4235. if (!params.renderSlide) {
  4236. slideEl.innerHTML = slide;
  4237. }
  4238. if (params.cache) {
  4239. swiper.virtual.cache[index] = slideEl;
  4240. }
  4241. return slideEl;
  4242. }
  4243. function update(force) {
  4244. const {
  4245. slidesPerView,
  4246. slidesPerGroup,
  4247. centeredSlides,
  4248. loop: isLoop
  4249. } = swiper.params;
  4250. const {
  4251. addSlidesBefore,
  4252. addSlidesAfter
  4253. } = swiper.params.virtual;
  4254. const {
  4255. from: previousFrom,
  4256. to: previousTo,
  4257. slides,
  4258. slidesGrid: previousSlidesGrid,
  4259. offset: previousOffset
  4260. } = swiper.virtual;
  4261. if (!swiper.params.cssMode) {
  4262. swiper.updateActiveIndex();
  4263. }
  4264. const activeIndex = swiper.activeIndex || 0;
  4265. let offsetProp;
  4266. if (swiper.rtlTranslate) offsetProp = 'right';else offsetProp = swiper.isHorizontal() ? 'left' : 'top';
  4267. let slidesAfter;
  4268. let slidesBefore;
  4269. if (centeredSlides) {
  4270. slidesAfter = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesAfter;
  4271. slidesBefore = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesBefore;
  4272. } else {
  4273. slidesAfter = slidesPerView + (slidesPerGroup - 1) + addSlidesAfter;
  4274. slidesBefore = (isLoop ? slidesPerView : slidesPerGroup) + addSlidesBefore;
  4275. }
  4276. let from = activeIndex - slidesBefore;
  4277. let to = activeIndex + slidesAfter;
  4278. if (!isLoop) {
  4279. from = Math.max(from, 0);
  4280. to = Math.min(to, slides.length - 1);
  4281. }
  4282. let offset = (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0);
  4283. if (isLoop && activeIndex >= slidesBefore) {
  4284. from -= slidesBefore;
  4285. if (!centeredSlides) offset += swiper.slidesGrid[0];
  4286. } else if (isLoop && activeIndex < slidesBefore) {
  4287. from = -slidesBefore;
  4288. if (centeredSlides) offset += swiper.slidesGrid[0];
  4289. }
  4290. Object.assign(swiper.virtual, {
  4291. from,
  4292. to,
  4293. offset,
  4294. slidesGrid: swiper.slidesGrid,
  4295. slidesBefore,
  4296. slidesAfter
  4297. });
  4298. function onRendered() {
  4299. swiper.updateSlides();
  4300. swiper.updateProgress();
  4301. swiper.updateSlidesClasses();
  4302. emit('virtualUpdate');
  4303. }
  4304. if (previousFrom === from && previousTo === to && !force) {
  4305. if (swiper.slidesGrid !== previousSlidesGrid && offset !== previousOffset) {
  4306. swiper.slides.forEach(slideEl => {
  4307. slideEl.style[offsetProp] = `${offset - Math.abs(swiper.cssOverflowAdjustment())}px`;
  4308. });
  4309. }
  4310. swiper.updateProgress();
  4311. emit('virtualUpdate');
  4312. return;
  4313. }
  4314. if (swiper.params.virtual.renderExternal) {
  4315. swiper.params.virtual.renderExternal.call(swiper, {
  4316. offset,
  4317. from,
  4318. to,
  4319. slides: function getSlides() {
  4320. const slidesToRender = [];
  4321. for (let i = from; i <= to; i += 1) {
  4322. slidesToRender.push(slides[i]);
  4323. }
  4324. return slidesToRender;
  4325. }()
  4326. });
  4327. if (swiper.params.virtual.renderExternalUpdate) {
  4328. onRendered();
  4329. } else {
  4330. emit('virtualUpdate');
  4331. }
  4332. return;
  4333. }
  4334. const prependIndexes = [];
  4335. const appendIndexes = [];
  4336. const getSlideIndex = index => {
  4337. let slideIndex = index;
  4338. if (index < 0) {
  4339. slideIndex = slides.length + index;
  4340. } else if (slideIndex >= slides.length) {
  4341. // eslint-disable-next-line
  4342. slideIndex = slideIndex - slides.length;
  4343. }
  4344. return slideIndex;
  4345. };
  4346. if (force) {
  4347. swiper.slides.filter(el => el.matches(`.${swiper.params.slideClass}, swiper-slide`)).forEach(slideEl => {
  4348. slideEl.remove();
  4349. });
  4350. } else {
  4351. for (let i = previousFrom; i <= previousTo; i += 1) {
  4352. if (i < from || i > to) {
  4353. const slideIndex = getSlideIndex(i);
  4354. swiper.slides.filter(el => el.matches(`.${swiper.params.slideClass}[data-swiper-slide-index="${slideIndex}"], swiper-slide[data-swiper-slide-index="${slideIndex}"]`)).forEach(slideEl => {
  4355. slideEl.remove();
  4356. });
  4357. }
  4358. }
  4359. }
  4360. const loopFrom = isLoop ? -slides.length : 0;
  4361. const loopTo = isLoop ? slides.length * 2 : slides.length;
  4362. for (let i = loopFrom; i < loopTo; i += 1) {
  4363. if (i >= from && i <= to) {
  4364. const slideIndex = getSlideIndex(i);
  4365. if (typeof previousTo === 'undefined' || force) {
  4366. appendIndexes.push(slideIndex);
  4367. } else {
  4368. if (i > previousTo) appendIndexes.push(slideIndex);
  4369. if (i < previousFrom) prependIndexes.push(slideIndex);
  4370. }
  4371. }
  4372. }
  4373. appendIndexes.forEach(index => {
  4374. swiper.slidesEl.append(renderSlide(slides[index], index));
  4375. });
  4376. if (isLoop) {
  4377. for (let i = prependIndexes.length - 1; i >= 0; i -= 1) {
  4378. const index = prependIndexes[i];
  4379. swiper.slidesEl.prepend(renderSlide(slides[index], index));
  4380. }
  4381. } else {
  4382. prependIndexes.sort((a, b) => b - a);
  4383. prependIndexes.forEach(index => {
  4384. swiper.slidesEl.prepend(renderSlide(slides[index], index));
  4385. });
  4386. }
  4387. elementChildren(swiper.slidesEl, '.swiper-slide, swiper-slide').forEach(slideEl => {
  4388. slideEl.style[offsetProp] = `${offset - Math.abs(swiper.cssOverflowAdjustment())}px`;
  4389. });
  4390. onRendered();
  4391. }
  4392. function appendSlide(slides) {
  4393. if (typeof slides === 'object' && 'length' in slides) {
  4394. for (let i = 0; i < slides.length; i += 1) {
  4395. if (slides[i]) swiper.virtual.slides.push(slides[i]);
  4396. }
  4397. } else {
  4398. swiper.virtual.slides.push(slides);
  4399. }
  4400. update(true);
  4401. }
  4402. function prependSlide(slides) {
  4403. const activeIndex = swiper.activeIndex;
  4404. let newActiveIndex = activeIndex + 1;
  4405. let numberOfNewSlides = 1;
  4406. if (Array.isArray(slides)) {
  4407. for (let i = 0; i < slides.length; i += 1) {
  4408. if (slides[i]) swiper.virtual.slides.unshift(slides[i]);
  4409. }
  4410. newActiveIndex = activeIndex + slides.length;
  4411. numberOfNewSlides = slides.length;
  4412. } else {
  4413. swiper.virtual.slides.unshift(slides);
  4414. }
  4415. if (swiper.params.virtual.cache) {
  4416. const cache = swiper.virtual.cache;
  4417. const newCache = {};
  4418. Object.keys(cache).forEach(cachedIndex => {
  4419. const cachedEl = cache[cachedIndex];
  4420. const cachedElIndex = cachedEl.getAttribute('data-swiper-slide-index');
  4421. if (cachedElIndex) {
  4422. cachedEl.setAttribute('data-swiper-slide-index', parseInt(cachedElIndex, 10) + numberOfNewSlides);
  4423. }
  4424. newCache[parseInt(cachedIndex, 10) + numberOfNewSlides] = cachedEl;
  4425. });
  4426. swiper.virtual.cache = newCache;
  4427. }
  4428. update(true);
  4429. swiper.slideTo(newActiveIndex, 0);
  4430. }
  4431. function removeSlide(slidesIndexes) {
  4432. if (typeof slidesIndexes === 'undefined' || slidesIndexes === null) return;
  4433. let activeIndex = swiper.activeIndex;
  4434. if (Array.isArray(slidesIndexes)) {
  4435. for (let i = slidesIndexes.length - 1; i >= 0; i -= 1) {
  4436. if (swiper.params.virtual.cache) {
  4437. delete swiper.virtual.cache[slidesIndexes[i]];
  4438. // shift cache indexes
  4439. Object.keys(swiper.virtual.cache).forEach(key => {
  4440. if (key > slidesIndexes) {
  4441. swiper.virtual.cache[key - 1] = swiper.virtual.cache[key];
  4442. swiper.virtual.cache[key - 1].setAttribute('data-swiper-slide-index', key - 1);
  4443. delete swiper.virtual.cache[key];
  4444. }
  4445. });
  4446. }
  4447. swiper.virtual.slides.splice(slidesIndexes[i], 1);
  4448. if (slidesIndexes[i] < activeIndex) activeIndex -= 1;
  4449. activeIndex = Math.max(activeIndex, 0);
  4450. }
  4451. } else {
  4452. if (swiper.params.virtual.cache) {
  4453. delete swiper.virtual.cache[slidesIndexes];
  4454. // shift cache indexes
  4455. Object.keys(swiper.virtual.cache).forEach(key => {
  4456. if (key > slidesIndexes) {
  4457. swiper.virtual.cache[key - 1] = swiper.virtual.cache[key];
  4458. swiper.virtual.cache[key - 1].setAttribute('data-swiper-slide-index', key - 1);
  4459. delete swiper.virtual.cache[key];
  4460. }
  4461. });
  4462. }
  4463. swiper.virtual.slides.splice(slidesIndexes, 1);
  4464. if (slidesIndexes < activeIndex) activeIndex -= 1;
  4465. activeIndex = Math.max(activeIndex, 0);
  4466. }
  4467. update(true);
  4468. swiper.slideTo(activeIndex, 0);
  4469. }
  4470. function removeAllSlides() {
  4471. swiper.virtual.slides = [];
  4472. if (swiper.params.virtual.cache) {
  4473. swiper.virtual.cache = {};
  4474. }
  4475. update(true);
  4476. swiper.slideTo(0, 0);
  4477. }
  4478. on('beforeInit', () => {
  4479. if (!swiper.params.virtual.enabled) return;
  4480. let domSlidesAssigned;
  4481. if (typeof swiper.passedParams.virtual.slides === 'undefined') {
  4482. const slides = [...swiper.slidesEl.children].filter(el => el.matches(`.${swiper.params.slideClass}, swiper-slide`));
  4483. if (slides && slides.length) {
  4484. swiper.virtual.slides = [...slides];
  4485. domSlidesAssigned = true;
  4486. slides.forEach((slideEl, slideIndex) => {
  4487. slideEl.setAttribute('data-swiper-slide-index', slideIndex);
  4488. swiper.virtual.cache[slideIndex] = slideEl;
  4489. slideEl.remove();
  4490. });
  4491. }
  4492. }
  4493. if (!domSlidesAssigned) {
  4494. swiper.virtual.slides = swiper.params.virtual.slides;
  4495. }
  4496. swiper.classNames.push(`${swiper.params.containerModifierClass}virtual`);
  4497. swiper.params.watchSlidesProgress = true;
  4498. swiper.originalParams.watchSlidesProgress = true;
  4499. update();
  4500. });
  4501. on('setTranslate', () => {
  4502. if (!swiper.params.virtual.enabled) return;
  4503. if (swiper.params.cssMode && !swiper._immediateVirtual) {
  4504. clearTimeout(cssModeTimeout);
  4505. cssModeTimeout = setTimeout(() => {
  4506. update();
  4507. }, 100);
  4508. } else {
  4509. update();
  4510. }
  4511. });
  4512. on('init update resize', () => {
  4513. if (!swiper.params.virtual.enabled) return;
  4514. if (swiper.params.cssMode) {
  4515. setCSSProperty(swiper.wrapperEl, '--swiper-virtual-size', `${swiper.virtualSize}px`);
  4516. }
  4517. });
  4518. Object.assign(swiper.virtual, {
  4519. appendSlide,
  4520. prependSlide,
  4521. removeSlide,
  4522. removeAllSlides,
  4523. update
  4524. });
  4525. }
  4526. /* eslint-disable consistent-return */
  4527. function Keyboard(_ref) {
  4528. let {
  4529. swiper,
  4530. extendParams,
  4531. on,
  4532. emit
  4533. } = _ref;
  4534. const document = getDocument();
  4535. const window = getWindow();
  4536. swiper.keyboard = {
  4537. enabled: false
  4538. };
  4539. extendParams({
  4540. keyboard: {
  4541. enabled: false,
  4542. onlyInViewport: true,
  4543. pageUpDown: true
  4544. }
  4545. });
  4546. function handle(event) {
  4547. if (!swiper.enabled) return;
  4548. const {
  4549. rtlTranslate: rtl
  4550. } = swiper;
  4551. let e = event;
  4552. if (e.originalEvent) e = e.originalEvent; // jquery fix
  4553. const kc = e.keyCode || e.charCode;
  4554. const pageUpDown = swiper.params.keyboard.pageUpDown;
  4555. const isPageUp = pageUpDown && kc === 33;
  4556. const isPageDown = pageUpDown && kc === 34;
  4557. const isArrowLeft = kc === 37;
  4558. const isArrowRight = kc === 39;
  4559. const isArrowUp = kc === 38;
  4560. const isArrowDown = kc === 40;
  4561. // Directions locks
  4562. if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {
  4563. return false;
  4564. }
  4565. if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {
  4566. return false;
  4567. }
  4568. if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {
  4569. return undefined;
  4570. }
  4571. if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {
  4572. return undefined;
  4573. }
  4574. if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {
  4575. let inView = false;
  4576. // Check that swiper should be inside of visible area of window
  4577. if (elementParents(swiper.el, `.${swiper.params.slideClass}, swiper-slide`).length > 0 && elementParents(swiper.el, `.${swiper.params.slideActiveClass}`).length === 0) {
  4578. return undefined;
  4579. }
  4580. const el = swiper.el;
  4581. const swiperWidth = el.clientWidth;
  4582. const swiperHeight = el.clientHeight;
  4583. const windowWidth = window.innerWidth;
  4584. const windowHeight = window.innerHeight;
  4585. const swiperOffset = elementOffset(el);
  4586. if (rtl) swiperOffset.left -= el.scrollLeft;
  4587. const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];
  4588. for (let i = 0; i < swiperCoord.length; i += 1) {
  4589. const point = swiperCoord[i];
  4590. if (point[0] >= 0 && point[0] <= windowWidth && point[1] >= 0 && point[1] <= windowHeight) {
  4591. if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line
  4592. inView = true;
  4593. }
  4594. }
  4595. if (!inView) return undefined;
  4596. }
  4597. if (swiper.isHorizontal()) {
  4598. if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {
  4599. if (e.preventDefault) e.preventDefault();else e.returnValue = false;
  4600. }
  4601. if ((isPageDown || isArrowRight) && !rtl || (isPageUp || isArrowLeft) && rtl) swiper.slideNext();
  4602. if ((isPageUp || isArrowLeft) && !rtl || (isPageDown || isArrowRight) && rtl) swiper.slidePrev();
  4603. } else {
  4604. if (isPageUp || isPageDown || isArrowUp || isArrowDown) {
  4605. if (e.preventDefault) e.preventDefault();else e.returnValue = false;
  4606. }
  4607. if (isPageDown || isArrowDown) swiper.slideNext();
  4608. if (isPageUp || isArrowUp) swiper.slidePrev();
  4609. }
  4610. emit('keyPress', kc);
  4611. return undefined;
  4612. }
  4613. function enable() {
  4614. if (swiper.keyboard.enabled) return;
  4615. document.addEventListener('keydown', handle);
  4616. swiper.keyboard.enabled = true;
  4617. }
  4618. function disable() {
  4619. if (!swiper.keyboard.enabled) return;
  4620. document.removeEventListener('keydown', handle);
  4621. swiper.keyboard.enabled = false;
  4622. }
  4623. on('init', () => {
  4624. if (swiper.params.keyboard.enabled) {
  4625. enable();
  4626. }
  4627. });
  4628. on('destroy', () => {
  4629. if (swiper.keyboard.enabled) {
  4630. disable();
  4631. }
  4632. });
  4633. Object.assign(swiper.keyboard, {
  4634. enable,
  4635. disable
  4636. });
  4637. }
  4638. /* eslint-disable consistent-return */
  4639. function Mousewheel(_ref) {
  4640. let {
  4641. swiper,
  4642. extendParams,
  4643. on,
  4644. emit
  4645. } = _ref;
  4646. const window = getWindow();
  4647. extendParams({
  4648. mousewheel: {
  4649. enabled: false,
  4650. releaseOnEdges: false,
  4651. invert: false,
  4652. forceToAxis: false,
  4653. sensitivity: 1,
  4654. eventsTarget: 'container',
  4655. thresholdDelta: null,
  4656. thresholdTime: null,
  4657. noMousewheelClass: 'swiper-no-mousewheel'
  4658. }
  4659. });
  4660. swiper.mousewheel = {
  4661. enabled: false
  4662. };
  4663. let timeout;
  4664. let lastScrollTime = now();
  4665. let lastEventBeforeSnap;
  4666. const recentWheelEvents = [];
  4667. function normalize(e) {
  4668. // Reasonable defaults
  4669. const PIXEL_STEP = 10;
  4670. const LINE_HEIGHT = 40;
  4671. const PAGE_HEIGHT = 800;
  4672. let sX = 0;
  4673. let sY = 0; // spinX, spinY
  4674. let pX = 0;
  4675. let pY = 0; // pixelX, pixelY
  4676. // Legacy
  4677. if ('detail' in e) {
  4678. sY = e.detail;
  4679. }
  4680. if ('wheelDelta' in e) {
  4681. sY = -e.wheelDelta / 120;
  4682. }
  4683. if ('wheelDeltaY' in e) {
  4684. sY = -e.wheelDeltaY / 120;
  4685. }
  4686. if ('wheelDeltaX' in e) {
  4687. sX = -e.wheelDeltaX / 120;
  4688. }
  4689. // side scrolling on FF with DOMMouseScroll
  4690. if ('axis' in e && e.axis === e.HORIZONTAL_AXIS) {
  4691. sX = sY;
  4692. sY = 0;
  4693. }
  4694. pX = sX * PIXEL_STEP;
  4695. pY = sY * PIXEL_STEP;
  4696. if ('deltaY' in e) {
  4697. pY = e.deltaY;
  4698. }
  4699. if ('deltaX' in e) {
  4700. pX = e.deltaX;
  4701. }
  4702. if (e.shiftKey && !pX) {
  4703. // if user scrolls with shift he wants horizontal scroll
  4704. pX = pY;
  4705. pY = 0;
  4706. }
  4707. if ((pX || pY) && e.deltaMode) {
  4708. if (e.deltaMode === 1) {
  4709. // delta in LINE units
  4710. pX *= LINE_HEIGHT;
  4711. pY *= LINE_HEIGHT;
  4712. } else {
  4713. // delta in PAGE units
  4714. pX *= PAGE_HEIGHT;
  4715. pY *= PAGE_HEIGHT;
  4716. }
  4717. }
  4718. // Fall-back if spin cannot be determined
  4719. if (pX && !sX) {
  4720. sX = pX < 1 ? -1 : 1;
  4721. }
  4722. if (pY && !sY) {
  4723. sY = pY < 1 ? -1 : 1;
  4724. }
  4725. return {
  4726. spinX: sX,
  4727. spinY: sY,
  4728. pixelX: pX,
  4729. pixelY: pY
  4730. };
  4731. }
  4732. function handleMouseEnter() {
  4733. if (!swiper.enabled) return;
  4734. swiper.mouseEntered = true;
  4735. }
  4736. function handleMouseLeave() {
  4737. if (!swiper.enabled) return;
  4738. swiper.mouseEntered = false;
  4739. }
  4740. function animateSlider(newEvent) {
  4741. if (swiper.params.mousewheel.thresholdDelta && newEvent.delta < swiper.params.mousewheel.thresholdDelta) {
  4742. // Prevent if delta of wheel scroll delta is below configured threshold
  4743. return false;
  4744. }
  4745. if (swiper.params.mousewheel.thresholdTime && now() - lastScrollTime < swiper.params.mousewheel.thresholdTime) {
  4746. // Prevent if time between scrolls is below configured threshold
  4747. return false;
  4748. }
  4749. // If the movement is NOT big enough and
  4750. // if the last time the user scrolled was too close to the current one (avoid continuously triggering the slider):
  4751. // Don't go any further (avoid insignificant scroll movement).
  4752. if (newEvent.delta >= 6 && now() - lastScrollTime < 60) {
  4753. // Return false as a default
  4754. return true;
  4755. }
  4756. // If user is scrolling towards the end:
  4757. // If the slider hasn't hit the latest slide or
  4758. // if the slider is a loop and
  4759. // if the slider isn't moving right now:
  4760. // Go to next slide and
  4761. // emit a scroll event.
  4762. // Else (the user is scrolling towards the beginning) and
  4763. // if the slider hasn't hit the first slide or
  4764. // if the slider is a loop and
  4765. // if the slider isn't moving right now:
  4766. // Go to prev slide and
  4767. // emit a scroll event.
  4768. if (newEvent.direction < 0) {
  4769. if ((!swiper.isEnd || swiper.params.loop) && !swiper.animating) {
  4770. swiper.slideNext();
  4771. emit('scroll', newEvent.raw);
  4772. }
  4773. } else if ((!swiper.isBeginning || swiper.params.loop) && !swiper.animating) {
  4774. swiper.slidePrev();
  4775. emit('scroll', newEvent.raw);
  4776. }
  4777. // If you got here is because an animation has been triggered so store the current time
  4778. lastScrollTime = new window.Date().getTime();
  4779. // Return false as a default
  4780. return false;
  4781. }
  4782. function releaseScroll(newEvent) {
  4783. const params = swiper.params.mousewheel;
  4784. if (newEvent.direction < 0) {
  4785. if (swiper.isEnd && !swiper.params.loop && params.releaseOnEdges) {
  4786. // Return true to animate scroll on edges
  4787. return true;
  4788. }
  4789. } else if (swiper.isBeginning && !swiper.params.loop && params.releaseOnEdges) {
  4790. // Return true to animate scroll on edges
  4791. return true;
  4792. }
  4793. return false;
  4794. }
  4795. function handle(event) {
  4796. let e = event;
  4797. let disableParentSwiper = true;
  4798. if (!swiper.enabled) return;
  4799. // Ignore event if the target or its parents have the swiper-no-mousewheel class
  4800. if (event.target.closest(`.${swiper.params.mousewheel.noMousewheelClass}`)) return;
  4801. const params = swiper.params.mousewheel;
  4802. if (swiper.params.cssMode) {
  4803. e.preventDefault();
  4804. }
  4805. let targetEl = swiper.el;
  4806. if (swiper.params.mousewheel.eventsTarget !== 'container') {
  4807. targetEl = document.querySelector(swiper.params.mousewheel.eventsTarget);
  4808. }
  4809. const targetElContainsTarget = targetEl && targetEl.contains(e.target);
  4810. if (!swiper.mouseEntered && !targetElContainsTarget && !params.releaseOnEdges) return true;
  4811. if (e.originalEvent) e = e.originalEvent; // jquery fix
  4812. let delta = 0;
  4813. const rtlFactor = swiper.rtlTranslate ? -1 : 1;
  4814. const data = normalize(e);
  4815. if (params.forceToAxis) {
  4816. if (swiper.isHorizontal()) {
  4817. if (Math.abs(data.pixelX) > Math.abs(data.pixelY)) delta = -data.pixelX * rtlFactor;else return true;
  4818. } else if (Math.abs(data.pixelY) > Math.abs(data.pixelX)) delta = -data.pixelY;else return true;
  4819. } else {
  4820. delta = Math.abs(data.pixelX) > Math.abs(data.pixelY) ? -data.pixelX * rtlFactor : -data.pixelY;
  4821. }
  4822. if (delta === 0) return true;
  4823. if (params.invert) delta = -delta;
  4824. // Get the scroll positions
  4825. let positions = swiper.getTranslate() + delta * params.sensitivity;
  4826. if (positions >= swiper.minTranslate()) positions = swiper.minTranslate();
  4827. if (positions <= swiper.maxTranslate()) positions = swiper.maxTranslate();
  4828. // When loop is true:
  4829. // the disableParentSwiper will be true.
  4830. // When loop is false:
  4831. // if the scroll positions is not on edge,
  4832. // then the disableParentSwiper will be true.
  4833. // if the scroll on edge positions,
  4834. // then the disableParentSwiper will be false.
  4835. disableParentSwiper = swiper.params.loop ? true : !(positions === swiper.minTranslate() || positions === swiper.maxTranslate());
  4836. if (disableParentSwiper && swiper.params.nested) e.stopPropagation();
  4837. if (!swiper.params.freeMode || !swiper.params.freeMode.enabled) {
  4838. // Register the new event in a variable which stores the relevant data
  4839. const newEvent = {
  4840. time: now(),
  4841. delta: Math.abs(delta),
  4842. direction: Math.sign(delta),
  4843. raw: event
  4844. };
  4845. // Keep the most recent events
  4846. if (recentWheelEvents.length >= 2) {
  4847. recentWheelEvents.shift(); // only store the last N events
  4848. }
  4849. const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;
  4850. recentWheelEvents.push(newEvent);
  4851. // If there is at least one previous recorded event:
  4852. // If direction has changed or
  4853. // if the scroll is quicker than the previous one:
  4854. // Animate the slider.
  4855. // Else (this is the first time the wheel is moved):
  4856. // Animate the slider.
  4857. if (prevEvent) {
  4858. if (newEvent.direction !== prevEvent.direction || newEvent.delta > prevEvent.delta || newEvent.time > prevEvent.time + 150) {
  4859. animateSlider(newEvent);
  4860. }
  4861. } else {
  4862. animateSlider(newEvent);
  4863. }
  4864. // If it's time to release the scroll:
  4865. // Return now so you don't hit the preventDefault.
  4866. if (releaseScroll(newEvent)) {
  4867. return true;
  4868. }
  4869. } else {
  4870. // Freemode or scrollContainer:
  4871. // If we recently snapped after a momentum scroll, then ignore wheel events
  4872. // to give time for the deceleration to finish. Stop ignoring after 500 msecs
  4873. // or if it's a new scroll (larger delta or inverse sign as last event before
  4874. // an end-of-momentum snap).
  4875. const newEvent = {
  4876. time: now(),
  4877. delta: Math.abs(delta),
  4878. direction: Math.sign(delta)
  4879. };
  4880. const ignoreWheelEvents = lastEventBeforeSnap && newEvent.time < lastEventBeforeSnap.time + 500 && newEvent.delta <= lastEventBeforeSnap.delta && newEvent.direction === lastEventBeforeSnap.direction;
  4881. if (!ignoreWheelEvents) {
  4882. lastEventBeforeSnap = undefined;
  4883. let position = swiper.getTranslate() + delta * params.sensitivity;
  4884. const wasBeginning = swiper.isBeginning;
  4885. const wasEnd = swiper.isEnd;
  4886. if (position >= swiper.minTranslate()) position = swiper.minTranslate();
  4887. if (position <= swiper.maxTranslate()) position = swiper.maxTranslate();
  4888. swiper.setTransition(0);
  4889. swiper.setTranslate(position);
  4890. swiper.updateProgress();
  4891. swiper.updateActiveIndex();
  4892. swiper.updateSlidesClasses();
  4893. if (!wasBeginning && swiper.isBeginning || !wasEnd && swiper.isEnd) {
  4894. swiper.updateSlidesClasses();
  4895. }
  4896. if (swiper.params.loop) {
  4897. swiper.loopFix({
  4898. direction: newEvent.direction < 0 ? 'next' : 'prev',
  4899. byMousewheel: true
  4900. });
  4901. }
  4902. if (swiper.params.freeMode.sticky) {
  4903. // When wheel scrolling starts with sticky (aka snap) enabled, then detect
  4904. // the end of a momentum scroll by storing recent (N=15?) wheel events.
  4905. // 1. do all N events have decreasing or same (absolute value) delta?
  4906. // 2. did all N events arrive in the last M (M=500?) msecs?
  4907. // 3. does the earliest event have an (absolute value) delta that's
  4908. // at least P (P=1?) larger than the most recent event's delta?
  4909. // 4. does the latest event have a delta that's smaller than Q (Q=6?) pixels?
  4910. // If 1-4 are "yes" then we're near the end of a momentum scroll deceleration.
  4911. // Snap immediately and ignore remaining wheel events in this scroll.
  4912. // See comment above for "remaining wheel events in this scroll" determination.
  4913. // If 1-4 aren't satisfied, then wait to snap until 500ms after the last event.
  4914. clearTimeout(timeout);
  4915. timeout = undefined;
  4916. if (recentWheelEvents.length >= 15) {
  4917. recentWheelEvents.shift(); // only store the last N events
  4918. }
  4919. const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;
  4920. const firstEvent = recentWheelEvents[0];
  4921. recentWheelEvents.push(newEvent);
  4922. if (prevEvent && (newEvent.delta > prevEvent.delta || newEvent.direction !== prevEvent.direction)) {
  4923. // Increasing or reverse-sign delta means the user started scrolling again. Clear the wheel event log.
  4924. recentWheelEvents.splice(0);
  4925. } else if (recentWheelEvents.length >= 15 && newEvent.time - firstEvent.time < 500 && firstEvent.delta - newEvent.delta >= 1 && newEvent.delta <= 6) {
  4926. // We're at the end of the deceleration of a momentum scroll, so there's no need
  4927. // to wait for more events. Snap ASAP on the next tick.
  4928. // Also, because there's some remaining momentum we'll bias the snap in the
  4929. // direction of the ongoing scroll because it's better UX for the scroll to snap
  4930. // in the same direction as the scroll instead of reversing to snap. Therefore,
  4931. // if it's already scrolled more than 20% in the current direction, keep going.
  4932. const snapToThreshold = delta > 0 ? 0.8 : 0.2;
  4933. lastEventBeforeSnap = newEvent;
  4934. recentWheelEvents.splice(0);
  4935. timeout = nextTick(() => {
  4936. swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);
  4937. }, 0); // no delay; move on next tick
  4938. }
  4939. if (!timeout) {
  4940. // if we get here, then we haven't detected the end of a momentum scroll, so
  4941. // we'll consider a scroll "complete" when there haven't been any wheel events
  4942. // for 500ms.
  4943. timeout = nextTick(() => {
  4944. const snapToThreshold = 0.5;
  4945. lastEventBeforeSnap = newEvent;
  4946. recentWheelEvents.splice(0);
  4947. swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);
  4948. }, 500);
  4949. }
  4950. }
  4951. // Emit event
  4952. if (!ignoreWheelEvents) emit('scroll', e);
  4953. // Stop autoplay
  4954. if (swiper.params.autoplay && swiper.params.autoplayDisableOnInteraction) swiper.autoplay.stop();
  4955. // Return page scroll on edge positions
  4956. if (params.releaseOnEdges && (position === swiper.minTranslate() || position === swiper.maxTranslate())) {
  4957. return true;
  4958. }
  4959. }
  4960. }
  4961. if (e.preventDefault) e.preventDefault();else e.returnValue = false;
  4962. return false;
  4963. }
  4964. function events(method) {
  4965. let targetEl = swiper.el;
  4966. if (swiper.params.mousewheel.eventsTarget !== 'container') {
  4967. targetEl = document.querySelector(swiper.params.mousewheel.eventsTarget);
  4968. }
  4969. targetEl[method]('mouseenter', handleMouseEnter);
  4970. targetEl[method]('mouseleave', handleMouseLeave);
  4971. targetEl[method]('wheel', handle);
  4972. }
  4973. function enable() {
  4974. if (swiper.params.cssMode) {
  4975. swiper.wrapperEl.removeEventListener('wheel', handle);
  4976. return true;
  4977. }
  4978. if (swiper.mousewheel.enabled) return false;
  4979. events('addEventListener');
  4980. swiper.mousewheel.enabled = true;
  4981. return true;
  4982. }
  4983. function disable() {
  4984. if (swiper.params.cssMode) {
  4985. swiper.wrapperEl.addEventListener(event, handle);
  4986. return true;
  4987. }
  4988. if (!swiper.mousewheel.enabled) return false;
  4989. events('removeEventListener');
  4990. swiper.mousewheel.enabled = false;
  4991. return true;
  4992. }
  4993. on('init', () => {
  4994. if (!swiper.params.mousewheel.enabled && swiper.params.cssMode) {
  4995. disable();
  4996. }
  4997. if (swiper.params.mousewheel.enabled) enable();
  4998. });
  4999. on('destroy', () => {
  5000. if (swiper.params.cssMode) {
  5001. enable();
  5002. }
  5003. if (swiper.mousewheel.enabled) disable();
  5004. });
  5005. Object.assign(swiper.mousewheel, {
  5006. enable,
  5007. disable
  5008. });
  5009. }
  5010. function createElementIfNotDefined(swiper, originalParams, params, checkProps) {
  5011. if (swiper.params.createElements) {
  5012. Object.keys(checkProps).forEach(key => {
  5013. if (!params[key] && params.auto === true) {
  5014. let element = elementChildren(swiper.el, `.${checkProps[key]}`)[0];
  5015. if (!element) {
  5016. element = createElement('div', checkProps[key]);
  5017. element.className = checkProps[key];
  5018. swiper.el.append(element);
  5019. }
  5020. params[key] = element;
  5021. originalParams[key] = element;
  5022. }
  5023. });
  5024. }
  5025. return params;
  5026. }
  5027. function Navigation(_ref) {
  5028. let {
  5029. swiper,
  5030. extendParams,
  5031. on,
  5032. emit
  5033. } = _ref;
  5034. extendParams({
  5035. navigation: {
  5036. nextEl: null,
  5037. prevEl: null,
  5038. hideOnClick: false,
  5039. disabledClass: 'swiper-button-disabled',
  5040. hiddenClass: 'swiper-button-hidden',
  5041. lockClass: 'swiper-button-lock',
  5042. navigationDisabledClass: 'swiper-navigation-disabled'
  5043. }
  5044. });
  5045. swiper.navigation = {
  5046. nextEl: null,
  5047. prevEl: null
  5048. };
  5049. const makeElementsArray = el => (Array.isArray(el) ? el : [el]).filter(e => !!e);
  5050. function getEl(el) {
  5051. let res;
  5052. if (el && typeof el === 'string' && swiper.isElement) {
  5053. res = swiper.el.querySelector(el);
  5054. if (res) return res;
  5055. }
  5056. if (el) {
  5057. if (typeof el === 'string') res = [...document.querySelectorAll(el)];
  5058. if (swiper.params.uniqueNavElements && typeof el === 'string' && res.length > 1 && swiper.el.querySelectorAll(el).length === 1) {
  5059. res = swiper.el.querySelector(el);
  5060. }
  5061. }
  5062. if (el && !res) return el;
  5063. // if (Array.isArray(res) && res.length === 1) res = res[0];
  5064. return res;
  5065. }
  5066. function toggleEl(el, disabled) {
  5067. const params = swiper.params.navigation;
  5068. el = makeElementsArray(el);
  5069. el.forEach(subEl => {
  5070. if (subEl) {
  5071. subEl.classList[disabled ? 'add' : 'remove'](...params.disabledClass.split(' '));
  5072. if (subEl.tagName === 'BUTTON') subEl.disabled = disabled;
  5073. if (swiper.params.watchOverflow && swiper.enabled) {
  5074. subEl.classList[swiper.isLocked ? 'add' : 'remove'](params.lockClass);
  5075. }
  5076. }
  5077. });
  5078. }
  5079. function update() {
  5080. // Update Navigation Buttons
  5081. const {
  5082. nextEl,
  5083. prevEl
  5084. } = swiper.navigation;
  5085. if (swiper.params.loop) {
  5086. toggleEl(prevEl, false);
  5087. toggleEl(nextEl, false);
  5088. return;
  5089. }
  5090. toggleEl(prevEl, swiper.isBeginning && !swiper.params.rewind);
  5091. toggleEl(nextEl, swiper.isEnd && !swiper.params.rewind);
  5092. }
  5093. function onPrevClick(e) {
  5094. e.preventDefault();
  5095. if (swiper.isBeginning && !swiper.params.loop && !swiper.params.rewind) return;
  5096. swiper.slidePrev();
  5097. emit('navigationPrev');
  5098. }
  5099. function onNextClick(e) {
  5100. e.preventDefault();
  5101. if (swiper.isEnd && !swiper.params.loop && !swiper.params.rewind) return;
  5102. swiper.slideNext();
  5103. emit('navigationNext');
  5104. }
  5105. function init() {
  5106. const params = swiper.params.navigation;
  5107. swiper.params.navigation = createElementIfNotDefined(swiper, swiper.originalParams.navigation, swiper.params.navigation, {
  5108. nextEl: 'swiper-button-next',
  5109. prevEl: 'swiper-button-prev'
  5110. });
  5111. if (!(params.nextEl || params.prevEl)) return;
  5112. let nextEl = getEl(params.nextEl);
  5113. let prevEl = getEl(params.prevEl);
  5114. Object.assign(swiper.navigation, {
  5115. nextEl,
  5116. prevEl
  5117. });
  5118. nextEl = makeElementsArray(nextEl);
  5119. prevEl = makeElementsArray(prevEl);
  5120. const initButton = (el, dir) => {
  5121. if (el) {
  5122. el.addEventListener('click', dir === 'next' ? onNextClick : onPrevClick);
  5123. }
  5124. if (!swiper.enabled && el) {
  5125. el.classList.add(...params.lockClass.split(' '));
  5126. }
  5127. };
  5128. nextEl.forEach(el => initButton(el, 'next'));
  5129. prevEl.forEach(el => initButton(el, 'prev'));
  5130. }
  5131. function destroy() {
  5132. let {
  5133. nextEl,
  5134. prevEl
  5135. } = swiper.navigation;
  5136. nextEl = makeElementsArray(nextEl);
  5137. prevEl = makeElementsArray(prevEl);
  5138. const destroyButton = (el, dir) => {
  5139. el.removeEventListener('click', dir === 'next' ? onNextClick : onPrevClick);
  5140. el.classList.remove(...swiper.params.navigation.disabledClass.split(' '));
  5141. };
  5142. nextEl.forEach(el => destroyButton(el, 'next'));
  5143. prevEl.forEach(el => destroyButton(el, 'prev'));
  5144. }
  5145. on('init', () => {
  5146. if (swiper.params.navigation.enabled === false) {
  5147. // eslint-disable-next-line
  5148. disable();
  5149. } else {
  5150. init();
  5151. update();
  5152. }
  5153. });
  5154. on('toEdge fromEdge lock unlock', () => {
  5155. update();
  5156. });
  5157. on('destroy', () => {
  5158. destroy();
  5159. });
  5160. on('enable disable', () => {
  5161. let {
  5162. nextEl,
  5163. prevEl
  5164. } = swiper.navigation;
  5165. nextEl = makeElementsArray(nextEl);
  5166. prevEl = makeElementsArray(prevEl);
  5167. if (swiper.enabled) {
  5168. update();
  5169. return;
  5170. }
  5171. [...nextEl, ...prevEl].filter(el => !!el).forEach(el => el.classList.add(swiper.params.navigation.lockClass));
  5172. });
  5173. on('click', (_s, e) => {
  5174. let {
  5175. nextEl,
  5176. prevEl
  5177. } = swiper.navigation;
  5178. nextEl = makeElementsArray(nextEl);
  5179. prevEl = makeElementsArray(prevEl);
  5180. const targetEl = e.target;
  5181. if (swiper.params.navigation.hideOnClick && !prevEl.includes(targetEl) && !nextEl.includes(targetEl)) {
  5182. if (swiper.pagination && swiper.params.pagination && swiper.params.pagination.clickable && (swiper.pagination.el === targetEl || swiper.pagination.el.contains(targetEl))) return;
  5183. let isHidden;
  5184. if (nextEl.length) {
  5185. isHidden = nextEl[0].classList.contains(swiper.params.navigation.hiddenClass);
  5186. } else if (prevEl.length) {
  5187. isHidden = prevEl[0].classList.contains(swiper.params.navigation.hiddenClass);
  5188. }
  5189. if (isHidden === true) {
  5190. emit('navigationShow');
  5191. } else {
  5192. emit('navigationHide');
  5193. }
  5194. [...nextEl, ...prevEl].filter(el => !!el).forEach(el => el.classList.toggle(swiper.params.navigation.hiddenClass));
  5195. }
  5196. });
  5197. const enable = () => {
  5198. swiper.el.classList.remove(...swiper.params.navigation.navigationDisabledClass.split(' '));
  5199. init();
  5200. update();
  5201. };
  5202. const disable = () => {
  5203. swiper.el.classList.add(...swiper.params.navigation.navigationDisabledClass.split(' '));
  5204. destroy();
  5205. };
  5206. Object.assign(swiper.navigation, {
  5207. enable,
  5208. disable,
  5209. update,
  5210. init,
  5211. destroy
  5212. });
  5213. }
  5214. function classesToSelector(classes) {
  5215. if (classes === void 0) {
  5216. classes = '';
  5217. }
  5218. return `.${classes.trim().replace(/([\.:!+\/])/g, '\\$1') // eslint-disable-line
  5219. .replace(/ /g, '.')}`;
  5220. }
  5221. function Pagination(_ref) {
  5222. let {
  5223. swiper,
  5224. extendParams,
  5225. on,
  5226. emit
  5227. } = _ref;
  5228. const pfx = 'swiper-pagination';
  5229. extendParams({
  5230. pagination: {
  5231. el: null,
  5232. bulletElement: 'span',
  5233. clickable: false,
  5234. hideOnClick: false,
  5235. renderBullet: null,
  5236. renderProgressbar: null,
  5237. renderFraction: null,
  5238. renderCustom: null,
  5239. progressbarOpposite: false,
  5240. type: 'bullets',
  5241. // 'bullets' or 'progressbar' or 'fraction' or 'custom'
  5242. dynamicBullets: false,
  5243. dynamicMainBullets: 1,
  5244. formatFractionCurrent: number => number,
  5245. formatFractionTotal: number => number,
  5246. bulletClass: `${pfx}-bullet`,
  5247. bulletActiveClass: `${pfx}-bullet-active`,
  5248. modifierClass: `${pfx}-`,
  5249. currentClass: `${pfx}-current`,
  5250. totalClass: `${pfx}-total`,
  5251. hiddenClass: `${pfx}-hidden`,
  5252. progressbarFillClass: `${pfx}-progressbar-fill`,
  5253. progressbarOppositeClass: `${pfx}-progressbar-opposite`,
  5254. clickableClass: `${pfx}-clickable`,
  5255. lockClass: `${pfx}-lock`,
  5256. horizontalClass: `${pfx}-horizontal`,
  5257. verticalClass: `${pfx}-vertical`,
  5258. paginationDisabledClass: `${pfx}-disabled`
  5259. }
  5260. });
  5261. swiper.pagination = {
  5262. el: null,
  5263. bullets: []
  5264. };
  5265. let bulletSize;
  5266. let dynamicBulletIndex = 0;
  5267. const makeElementsArray = el => (Array.isArray(el) ? el : [el]).filter(e => !!e);
  5268. function isPaginationDisabled() {
  5269. return !swiper.params.pagination.el || !swiper.pagination.el || Array.isArray(swiper.pagination.el) && swiper.pagination.el.length === 0;
  5270. }
  5271. function setSideBullets(bulletEl, position) {
  5272. const {
  5273. bulletActiveClass
  5274. } = swiper.params.pagination;
  5275. if (!bulletEl) return;
  5276. bulletEl = bulletEl[`${position === 'prev' ? 'previous' : 'next'}ElementSibling`];
  5277. if (bulletEl) {
  5278. bulletEl.classList.add(`${bulletActiveClass}-${position}`);
  5279. bulletEl = bulletEl[`${position === 'prev' ? 'previous' : 'next'}ElementSibling`];
  5280. if (bulletEl) {
  5281. bulletEl.classList.add(`${bulletActiveClass}-${position}-${position}`);
  5282. }
  5283. }
  5284. }
  5285. function onBulletClick(e) {
  5286. const bulletEl = e.target.closest(classesToSelector(swiper.params.pagination.bulletClass));
  5287. if (!bulletEl) {
  5288. return;
  5289. }
  5290. e.preventDefault();
  5291. const index = elementIndex(bulletEl) * swiper.params.slidesPerGroup;
  5292. if (swiper.params.loop) {
  5293. if (swiper.realIndex === index) return;
  5294. swiper.slideToLoop(index);
  5295. } else {
  5296. swiper.slideTo(index);
  5297. }
  5298. }
  5299. function update() {
  5300. // Render || Update Pagination bullets/items
  5301. const rtl = swiper.rtl;
  5302. const params = swiper.params.pagination;
  5303. if (isPaginationDisabled()) return;
  5304. let el = swiper.pagination.el;
  5305. el = makeElementsArray(el);
  5306. // Current/Total
  5307. let current;
  5308. let previousIndex;
  5309. const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;
  5310. const total = swiper.params.loop ? Math.ceil(slidesLength / swiper.params.slidesPerGroup) : swiper.snapGrid.length;
  5311. if (swiper.params.loop) {
  5312. previousIndex = swiper.previousRealIndex || 0;
  5313. current = swiper.params.slidesPerGroup > 1 ? Math.floor(swiper.realIndex / swiper.params.slidesPerGroup) : swiper.realIndex;
  5314. } else if (typeof swiper.snapIndex !== 'undefined') {
  5315. current = swiper.snapIndex;
  5316. previousIndex = swiper.previousSnapIndex;
  5317. } else {
  5318. previousIndex = swiper.previousIndex || 0;
  5319. current = swiper.activeIndex || 0;
  5320. }
  5321. // Types
  5322. if (params.type === 'bullets' && swiper.pagination.bullets && swiper.pagination.bullets.length > 0) {
  5323. const bullets = swiper.pagination.bullets;
  5324. let firstIndex;
  5325. let lastIndex;
  5326. let midIndex;
  5327. if (params.dynamicBullets) {
  5328. bulletSize = elementOuterSize(bullets[0], swiper.isHorizontal() ? 'width' : 'height', true);
  5329. el.forEach(subEl => {
  5330. subEl.style[swiper.isHorizontal() ? 'width' : 'height'] = `${bulletSize * (params.dynamicMainBullets + 4)}px`;
  5331. });
  5332. if (params.dynamicMainBullets > 1 && previousIndex !== undefined) {
  5333. dynamicBulletIndex += current - (previousIndex || 0);
  5334. if (dynamicBulletIndex > params.dynamicMainBullets - 1) {
  5335. dynamicBulletIndex = params.dynamicMainBullets - 1;
  5336. } else if (dynamicBulletIndex < 0) {
  5337. dynamicBulletIndex = 0;
  5338. }
  5339. }
  5340. firstIndex = Math.max(current - dynamicBulletIndex, 0);
  5341. lastIndex = firstIndex + (Math.min(bullets.length, params.dynamicMainBullets) - 1);
  5342. midIndex = (lastIndex + firstIndex) / 2;
  5343. }
  5344. bullets.forEach(bulletEl => {
  5345. const classesToRemove = [...['', '-next', '-next-next', '-prev', '-prev-prev', '-main'].map(suffix => `${params.bulletActiveClass}${suffix}`)].map(s => typeof s === 'string' && s.includes(' ') ? s.split(' ') : s).flat();
  5346. bulletEl.classList.remove(...classesToRemove);
  5347. });
  5348. if (el.length > 1) {
  5349. bullets.forEach(bullet => {
  5350. const bulletIndex = elementIndex(bullet);
  5351. if (bulletIndex === current) {
  5352. bullet.classList.add(...params.bulletActiveClass.split(' '));
  5353. } else if (swiper.isElement) {
  5354. bullet.setAttribute('part', 'bullet');
  5355. }
  5356. if (params.dynamicBullets) {
  5357. if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) {
  5358. bullet.classList.add(...`${params.bulletActiveClass}-main`.split(' '));
  5359. }
  5360. if (bulletIndex === firstIndex) {
  5361. setSideBullets(bullet, 'prev');
  5362. }
  5363. if (bulletIndex === lastIndex) {
  5364. setSideBullets(bullet, 'next');
  5365. }
  5366. }
  5367. });
  5368. } else {
  5369. const bullet = bullets[current];
  5370. if (bullet) {
  5371. bullet.classList.add(...params.bulletActiveClass.split(' '));
  5372. }
  5373. if (swiper.isElement) {
  5374. bullets.forEach((bulletEl, bulletIndex) => {
  5375. bulletEl.setAttribute('part', bulletIndex === current ? 'bullet-active' : 'bullet');
  5376. });
  5377. }
  5378. if (params.dynamicBullets) {
  5379. const firstDisplayedBullet = bullets[firstIndex];
  5380. const lastDisplayedBullet = bullets[lastIndex];
  5381. for (let i = firstIndex; i <= lastIndex; i += 1) {
  5382. if (bullets[i]) {
  5383. bullets[i].classList.add(...`${params.bulletActiveClass}-main`.split(' '));
  5384. }
  5385. }
  5386. setSideBullets(firstDisplayedBullet, 'prev');
  5387. setSideBullets(lastDisplayedBullet, 'next');
  5388. }
  5389. }
  5390. if (params.dynamicBullets) {
  5391. const dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4);
  5392. const bulletsOffset = (bulletSize * dynamicBulletsLength - bulletSize) / 2 - midIndex * bulletSize;
  5393. const offsetProp = rtl ? 'right' : 'left';
  5394. bullets.forEach(bullet => {
  5395. bullet.style[swiper.isHorizontal() ? offsetProp : 'top'] = `${bulletsOffset}px`;
  5396. });
  5397. }
  5398. }
  5399. el.forEach((subEl, subElIndex) => {
  5400. if (params.type === 'fraction') {
  5401. subEl.querySelectorAll(classesToSelector(params.currentClass)).forEach(fractionEl => {
  5402. fractionEl.textContent = params.formatFractionCurrent(current + 1);
  5403. });
  5404. subEl.querySelectorAll(classesToSelector(params.totalClass)).forEach(totalEl => {
  5405. totalEl.textContent = params.formatFractionTotal(total);
  5406. });
  5407. }
  5408. if (params.type === 'progressbar') {
  5409. let progressbarDirection;
  5410. if (params.progressbarOpposite) {
  5411. progressbarDirection = swiper.isHorizontal() ? 'vertical' : 'horizontal';
  5412. } else {
  5413. progressbarDirection = swiper.isHorizontal() ? 'horizontal' : 'vertical';
  5414. }
  5415. const scale = (current + 1) / total;
  5416. let scaleX = 1;
  5417. let scaleY = 1;
  5418. if (progressbarDirection === 'horizontal') {
  5419. scaleX = scale;
  5420. } else {
  5421. scaleY = scale;
  5422. }
  5423. subEl.querySelectorAll(classesToSelector(params.progressbarFillClass)).forEach(progressEl => {
  5424. progressEl.style.transform = `translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`;
  5425. progressEl.style.transitionDuration = `${swiper.params.speed}ms`;
  5426. });
  5427. }
  5428. if (params.type === 'custom' && params.renderCustom) {
  5429. subEl.innerHTML = params.renderCustom(swiper, current + 1, total);
  5430. if (subElIndex === 0) emit('paginationRender', subEl);
  5431. } else {
  5432. if (subElIndex === 0) emit('paginationRender', subEl);
  5433. emit('paginationUpdate', subEl);
  5434. }
  5435. if (swiper.params.watchOverflow && swiper.enabled) {
  5436. subEl.classList[swiper.isLocked ? 'add' : 'remove'](params.lockClass);
  5437. }
  5438. });
  5439. }
  5440. function render() {
  5441. // Render Container
  5442. const params = swiper.params.pagination;
  5443. if (isPaginationDisabled()) return;
  5444. const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.grid && swiper.params.grid.rows > 1 ? swiper.slides.length / Math.ceil(swiper.params.grid.rows) : swiper.slides.length;
  5445. let el = swiper.pagination.el;
  5446. el = makeElementsArray(el);
  5447. let paginationHTML = '';
  5448. if (params.type === 'bullets') {
  5449. let numberOfBullets = swiper.params.loop ? Math.ceil(slidesLength / swiper.params.slidesPerGroup) : swiper.snapGrid.length;
  5450. if (swiper.params.freeMode && swiper.params.freeMode.enabled && numberOfBullets > slidesLength) {
  5451. numberOfBullets = slidesLength;
  5452. }
  5453. for (let i = 0; i < numberOfBullets; i += 1) {
  5454. if (params.renderBullet) {
  5455. paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass);
  5456. } else {
  5457. // prettier-ignore
  5458. paginationHTML += `<${params.bulletElement} ${swiper.isElement ? 'part="bullet"' : ''} class="${params.bulletClass}"></${params.bulletElement}>`;
  5459. }
  5460. }
  5461. }
  5462. if (params.type === 'fraction') {
  5463. if (params.renderFraction) {
  5464. paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass);
  5465. } else {
  5466. paginationHTML = `<span class="${params.currentClass}"></span>` + ' / ' + `<span class="${params.totalClass}"></span>`;
  5467. }
  5468. }
  5469. if (params.type === 'progressbar') {
  5470. if (params.renderProgressbar) {
  5471. paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);
  5472. } else {
  5473. paginationHTML = `<span class="${params.progressbarFillClass}"></span>`;
  5474. }
  5475. }
  5476. swiper.pagination.bullets = [];
  5477. el.forEach(subEl => {
  5478. if (params.type !== 'custom') {
  5479. subEl.innerHTML = paginationHTML || '';
  5480. }
  5481. if (params.type === 'bullets') {
  5482. swiper.pagination.bullets.push(...subEl.querySelectorAll(classesToSelector(params.bulletClass)));
  5483. }
  5484. });
  5485. if (params.type !== 'custom') {
  5486. emit('paginationRender', el[0]);
  5487. }
  5488. }
  5489. function init() {
  5490. swiper.params.pagination = createElementIfNotDefined(swiper, swiper.originalParams.pagination, swiper.params.pagination, {
  5491. el: 'swiper-pagination'
  5492. });
  5493. const params = swiper.params.pagination;
  5494. if (!params.el) return;
  5495. let el;
  5496. if (typeof params.el === 'string' && swiper.isElement) {
  5497. el = swiper.el.querySelector(params.el);
  5498. }
  5499. if (!el && typeof params.el === 'string') {
  5500. el = [...document.querySelectorAll(params.el)];
  5501. }
  5502. if (!el) {
  5503. el = params.el;
  5504. }
  5505. if (!el || el.length === 0) return;
  5506. if (swiper.params.uniqueNavElements && typeof params.el === 'string' && Array.isArray(el) && el.length > 1) {
  5507. el = [...swiper.el.querySelectorAll(params.el)];
  5508. // check if it belongs to another nested Swiper
  5509. if (el.length > 1) {
  5510. el = el.filter(subEl => {
  5511. if (elementParents(subEl, '.swiper')[0] !== swiper.el) return false;
  5512. return true;
  5513. })[0];
  5514. }
  5515. }
  5516. if (Array.isArray(el) && el.length === 1) el = el[0];
  5517. Object.assign(swiper.pagination, {
  5518. el
  5519. });
  5520. el = makeElementsArray(el);
  5521. el.forEach(subEl => {
  5522. if (params.type === 'bullets' && params.clickable) {
  5523. subEl.classList.add(...(params.clickableClass || '').split(' '));
  5524. }
  5525. subEl.classList.add(params.modifierClass + params.type);
  5526. subEl.classList.add(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);
  5527. if (params.type === 'bullets' && params.dynamicBullets) {
  5528. subEl.classList.add(`${params.modifierClass}${params.type}-dynamic`);
  5529. dynamicBulletIndex = 0;
  5530. if (params.dynamicMainBullets < 1) {
  5531. params.dynamicMainBullets = 1;
  5532. }
  5533. }
  5534. if (params.type === 'progressbar' && params.progressbarOpposite) {
  5535. subEl.classList.add(params.progressbarOppositeClass);
  5536. }
  5537. if (params.clickable) {
  5538. subEl.addEventListener('click', onBulletClick);
  5539. }
  5540. if (!swiper.enabled) {
  5541. subEl.classList.add(params.lockClass);
  5542. }
  5543. });
  5544. }
  5545. function destroy() {
  5546. const params = swiper.params.pagination;
  5547. if (isPaginationDisabled()) return;
  5548. let el = swiper.pagination.el;
  5549. if (el) {
  5550. el = makeElementsArray(el);
  5551. el.forEach(subEl => {
  5552. subEl.classList.remove(params.hiddenClass);
  5553. subEl.classList.remove(params.modifierClass + params.type);
  5554. subEl.classList.remove(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);
  5555. if (params.clickable) {
  5556. subEl.classList.remove(...(params.clickableClass || '').split(' '));
  5557. subEl.removeEventListener('click', onBulletClick);
  5558. }
  5559. });
  5560. }
  5561. if (swiper.pagination.bullets) swiper.pagination.bullets.forEach(subEl => subEl.classList.remove(...params.bulletActiveClass.split(' ')));
  5562. }
  5563. on('changeDirection', () => {
  5564. if (!swiper.pagination || !swiper.pagination.el) return;
  5565. const params = swiper.params.pagination;
  5566. let {
  5567. el
  5568. } = swiper.pagination;
  5569. el = makeElementsArray(el);
  5570. el.forEach(subEl => {
  5571. subEl.classList.remove(params.horizontalClass, params.verticalClass);
  5572. subEl.classList.add(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);
  5573. });
  5574. });
  5575. on('init', () => {
  5576. if (swiper.params.pagination.enabled === false) {
  5577. // eslint-disable-next-line
  5578. disable();
  5579. } else {
  5580. init();
  5581. render();
  5582. update();
  5583. }
  5584. });
  5585. on('activeIndexChange', () => {
  5586. if (typeof swiper.snapIndex === 'undefined') {
  5587. update();
  5588. }
  5589. });
  5590. on('snapIndexChange', () => {
  5591. update();
  5592. });
  5593. on('snapGridLengthChange', () => {
  5594. render();
  5595. update();
  5596. });
  5597. on('destroy', () => {
  5598. destroy();
  5599. });
  5600. on('enable disable', () => {
  5601. let {
  5602. el
  5603. } = swiper.pagination;
  5604. if (el) {
  5605. el = makeElementsArray(el);
  5606. el.forEach(subEl => subEl.classList[swiper.enabled ? 'remove' : 'add'](swiper.params.pagination.lockClass));
  5607. }
  5608. });
  5609. on('lock unlock', () => {
  5610. update();
  5611. });
  5612. on('click', (_s, e) => {
  5613. const targetEl = e.target;
  5614. const el = makeElementsArray(swiper.pagination.el);
  5615. if (swiper.params.pagination.el && swiper.params.pagination.hideOnClick && el && el.length > 0 && !targetEl.classList.contains(swiper.params.pagination.bulletClass)) {
  5616. if (swiper.navigation && (swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl || swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl)) return;
  5617. const isHidden = el[0].classList.contains(swiper.params.pagination.hiddenClass);
  5618. if (isHidden === true) {
  5619. emit('paginationShow');
  5620. } else {
  5621. emit('paginationHide');
  5622. }
  5623. el.forEach(subEl => subEl.classList.toggle(swiper.params.pagination.hiddenClass));
  5624. }
  5625. });
  5626. const enable = () => {
  5627. swiper.el.classList.remove(swiper.params.pagination.paginationDisabledClass);
  5628. let {
  5629. el
  5630. } = swiper.pagination;
  5631. if (el) {
  5632. el = makeElementsArray(el);
  5633. el.forEach(subEl => subEl.classList.remove(swiper.params.pagination.paginationDisabledClass));
  5634. }
  5635. init();
  5636. render();
  5637. update();
  5638. };
  5639. const disable = () => {
  5640. swiper.el.classList.add(swiper.params.pagination.paginationDisabledClass);
  5641. let {
  5642. el
  5643. } = swiper.pagination;
  5644. if (el) {
  5645. el = makeElementsArray(el);
  5646. el.forEach(subEl => subEl.classList.add(swiper.params.pagination.paginationDisabledClass));
  5647. }
  5648. destroy();
  5649. };
  5650. Object.assign(swiper.pagination, {
  5651. enable,
  5652. disable,
  5653. render,
  5654. update,
  5655. init,
  5656. destroy
  5657. });
  5658. }
  5659. function Scrollbar(_ref) {
  5660. let {
  5661. swiper,
  5662. extendParams,
  5663. on,
  5664. emit
  5665. } = _ref;
  5666. const document = getDocument();
  5667. let isTouched = false;
  5668. let timeout = null;
  5669. let dragTimeout = null;
  5670. let dragStartPos;
  5671. let dragSize;
  5672. let trackSize;
  5673. let divider;
  5674. extendParams({
  5675. scrollbar: {
  5676. el: null,
  5677. dragSize: 'auto',
  5678. hide: false,
  5679. draggable: false,
  5680. snapOnRelease: true,
  5681. lockClass: 'swiper-scrollbar-lock',
  5682. dragClass: 'swiper-scrollbar-drag',
  5683. scrollbarDisabledClass: 'swiper-scrollbar-disabled',
  5684. horizontalClass: `swiper-scrollbar-horizontal`,
  5685. verticalClass: `swiper-scrollbar-vertical`
  5686. }
  5687. });
  5688. swiper.scrollbar = {
  5689. el: null,
  5690. dragEl: null
  5691. };
  5692. function setTranslate() {
  5693. if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;
  5694. const {
  5695. scrollbar,
  5696. rtlTranslate: rtl
  5697. } = swiper;
  5698. const {
  5699. dragEl,
  5700. el
  5701. } = scrollbar;
  5702. const params = swiper.params.scrollbar;
  5703. const progress = swiper.params.loop ? swiper.progressLoop : swiper.progress;
  5704. let newSize = dragSize;
  5705. let newPos = (trackSize - dragSize) * progress;
  5706. if (rtl) {
  5707. newPos = -newPos;
  5708. if (newPos > 0) {
  5709. newSize = dragSize - newPos;
  5710. newPos = 0;
  5711. } else if (-newPos + dragSize > trackSize) {
  5712. newSize = trackSize + newPos;
  5713. }
  5714. } else if (newPos < 0) {
  5715. newSize = dragSize + newPos;
  5716. newPos = 0;
  5717. } else if (newPos + dragSize > trackSize) {
  5718. newSize = trackSize - newPos;
  5719. }
  5720. if (swiper.isHorizontal()) {
  5721. dragEl.style.transform = `translate3d(${newPos}px, 0, 0)`;
  5722. dragEl.style.width = `${newSize}px`;
  5723. } else {
  5724. dragEl.style.transform = `translate3d(0px, ${newPos}px, 0)`;
  5725. dragEl.style.height = `${newSize}px`;
  5726. }
  5727. if (params.hide) {
  5728. clearTimeout(timeout);
  5729. el.style.opacity = 1;
  5730. timeout = setTimeout(() => {
  5731. el.style.opacity = 0;
  5732. el.style.transitionDuration = '400ms';
  5733. }, 1000);
  5734. }
  5735. }
  5736. function setTransition(duration) {
  5737. if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;
  5738. swiper.scrollbar.dragEl.style.transitionDuration = `${duration}ms`;
  5739. }
  5740. function updateSize() {
  5741. if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;
  5742. const {
  5743. scrollbar
  5744. } = swiper;
  5745. const {
  5746. dragEl,
  5747. el
  5748. } = scrollbar;
  5749. dragEl.style.width = '';
  5750. dragEl.style.height = '';
  5751. trackSize = swiper.isHorizontal() ? el.offsetWidth : el.offsetHeight;
  5752. divider = swiper.size / (swiper.virtualSize + swiper.params.slidesOffsetBefore - (swiper.params.centeredSlides ? swiper.snapGrid[0] : 0));
  5753. if (swiper.params.scrollbar.dragSize === 'auto') {
  5754. dragSize = trackSize * divider;
  5755. } else {
  5756. dragSize = parseInt(swiper.params.scrollbar.dragSize, 10);
  5757. }
  5758. if (swiper.isHorizontal()) {
  5759. dragEl.style.width = `${dragSize}px`;
  5760. } else {
  5761. dragEl.style.height = `${dragSize}px`;
  5762. }
  5763. if (divider >= 1) {
  5764. el.style.display = 'none';
  5765. } else {
  5766. el.style.display = '';
  5767. }
  5768. if (swiper.params.scrollbar.hide) {
  5769. el.style.opacity = 0;
  5770. }
  5771. if (swiper.params.watchOverflow && swiper.enabled) {
  5772. scrollbar.el.classList[swiper.isLocked ? 'add' : 'remove'](swiper.params.scrollbar.lockClass);
  5773. }
  5774. }
  5775. function getPointerPosition(e) {
  5776. return swiper.isHorizontal() ? e.clientX : e.clientY;
  5777. }
  5778. function setDragPosition(e) {
  5779. const {
  5780. scrollbar,
  5781. rtlTranslate: rtl
  5782. } = swiper;
  5783. const {
  5784. el
  5785. } = scrollbar;
  5786. let positionRatio;
  5787. positionRatio = (getPointerPosition(e) - elementOffset(el)[swiper.isHorizontal() ? 'left' : 'top'] - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / (trackSize - dragSize);
  5788. positionRatio = Math.max(Math.min(positionRatio, 1), 0);
  5789. if (rtl) {
  5790. positionRatio = 1 - positionRatio;
  5791. }
  5792. const position = swiper.minTranslate() + (swiper.maxTranslate() - swiper.minTranslate()) * positionRatio;
  5793. swiper.updateProgress(position);
  5794. swiper.setTranslate(position);
  5795. swiper.updateActiveIndex();
  5796. swiper.updateSlidesClasses();
  5797. }
  5798. function onDragStart(e) {
  5799. const params = swiper.params.scrollbar;
  5800. const {
  5801. scrollbar,
  5802. wrapperEl
  5803. } = swiper;
  5804. const {
  5805. el,
  5806. dragEl
  5807. } = scrollbar;
  5808. isTouched = true;
  5809. dragStartPos = e.target === dragEl ? getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? 'left' : 'top'] : null;
  5810. e.preventDefault();
  5811. e.stopPropagation();
  5812. wrapperEl.style.transitionDuration = '100ms';
  5813. dragEl.style.transitionDuration = '100ms';
  5814. setDragPosition(e);
  5815. clearTimeout(dragTimeout);
  5816. el.style.transitionDuration = '0ms';
  5817. if (params.hide) {
  5818. el.style.opacity = 1;
  5819. }
  5820. if (swiper.params.cssMode) {
  5821. swiper.wrapperEl.style['scroll-snap-type'] = 'none';
  5822. }
  5823. emit('scrollbarDragStart', e);
  5824. }
  5825. function onDragMove(e) {
  5826. const {
  5827. scrollbar,
  5828. wrapperEl
  5829. } = swiper;
  5830. const {
  5831. el,
  5832. dragEl
  5833. } = scrollbar;
  5834. if (!isTouched) return;
  5835. if (e.preventDefault) e.preventDefault();else e.returnValue = false;
  5836. setDragPosition(e);
  5837. wrapperEl.style.transitionDuration = '0ms';
  5838. el.style.transitionDuration = '0ms';
  5839. dragEl.style.transitionDuration = '0ms';
  5840. emit('scrollbarDragMove', e);
  5841. }
  5842. function onDragEnd(e) {
  5843. const params = swiper.params.scrollbar;
  5844. const {
  5845. scrollbar,
  5846. wrapperEl
  5847. } = swiper;
  5848. const {
  5849. el
  5850. } = scrollbar;
  5851. if (!isTouched) return;
  5852. isTouched = false;
  5853. if (swiper.params.cssMode) {
  5854. swiper.wrapperEl.style['scroll-snap-type'] = '';
  5855. wrapperEl.style.transitionDuration = '';
  5856. }
  5857. if (params.hide) {
  5858. clearTimeout(dragTimeout);
  5859. dragTimeout = nextTick(() => {
  5860. el.style.opacity = 0;
  5861. el.style.transitionDuration = '400ms';
  5862. }, 1000);
  5863. }
  5864. emit('scrollbarDragEnd', e);
  5865. if (params.snapOnRelease) {
  5866. swiper.slideToClosest();
  5867. }
  5868. }
  5869. function events(method) {
  5870. const {
  5871. scrollbar,
  5872. params
  5873. } = swiper;
  5874. const el = scrollbar.el;
  5875. if (!el) return;
  5876. const target = el;
  5877. const activeListener = params.passiveListeners ? {
  5878. passive: false,
  5879. capture: false
  5880. } : false;
  5881. const passiveListener = params.passiveListeners ? {
  5882. passive: true,
  5883. capture: false
  5884. } : false;
  5885. if (!target) return;
  5886. const eventMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';
  5887. target[eventMethod]('pointerdown', onDragStart, activeListener);
  5888. document[eventMethod]('pointermove', onDragMove, activeListener);
  5889. document[eventMethod]('pointerup', onDragEnd, passiveListener);
  5890. }
  5891. function enableDraggable() {
  5892. if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;
  5893. events('on');
  5894. }
  5895. function disableDraggable() {
  5896. if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;
  5897. events('off');
  5898. }
  5899. function init() {
  5900. const {
  5901. scrollbar,
  5902. el: swiperEl
  5903. } = swiper;
  5904. swiper.params.scrollbar = createElementIfNotDefined(swiper, swiper.originalParams.scrollbar, swiper.params.scrollbar, {
  5905. el: 'swiper-scrollbar'
  5906. });
  5907. const params = swiper.params.scrollbar;
  5908. if (!params.el) return;
  5909. let el;
  5910. if (typeof params.el === 'string' && swiper.isElement) {
  5911. el = swiper.el.querySelector(params.el);
  5912. }
  5913. if (!el && typeof params.el === 'string') {
  5914. el = document.querySelectorAll(params.el);
  5915. if (!el.length) return;
  5916. } else if (!el) {
  5917. el = params.el;
  5918. }
  5919. if (swiper.params.uniqueNavElements && typeof params.el === 'string' && el.length > 1 && swiperEl.querySelectorAll(params.el).length === 1) {
  5920. el = swiperEl.querySelector(params.el);
  5921. }
  5922. if (el.length > 0) el = el[0];
  5923. el.classList.add(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);
  5924. let dragEl;
  5925. if (el) {
  5926. dragEl = el.querySelector(classesToSelector(swiper.params.scrollbar.dragClass));
  5927. if (!dragEl) {
  5928. dragEl = createElement('div', swiper.params.scrollbar.dragClass);
  5929. el.append(dragEl);
  5930. }
  5931. }
  5932. Object.assign(scrollbar, {
  5933. el,
  5934. dragEl
  5935. });
  5936. if (params.draggable) {
  5937. enableDraggable();
  5938. }
  5939. if (el) {
  5940. el.classList[swiper.enabled ? 'remove' : 'add'](...classesToTokens(swiper.params.scrollbar.lockClass));
  5941. }
  5942. }
  5943. function destroy() {
  5944. const params = swiper.params.scrollbar;
  5945. const el = swiper.scrollbar.el;
  5946. if (el) {
  5947. el.classList.remove(...classesToTokens(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass));
  5948. }
  5949. disableDraggable();
  5950. }
  5951. on('init', () => {
  5952. if (swiper.params.scrollbar.enabled === false) {
  5953. // eslint-disable-next-line
  5954. disable();
  5955. } else {
  5956. init();
  5957. updateSize();
  5958. setTranslate();
  5959. }
  5960. });
  5961. on('update resize observerUpdate lock unlock', () => {
  5962. updateSize();
  5963. });
  5964. on('setTranslate', () => {
  5965. setTranslate();
  5966. });
  5967. on('setTransition', (_s, duration) => {
  5968. setTransition(duration);
  5969. });
  5970. on('enable disable', () => {
  5971. const {
  5972. el
  5973. } = swiper.scrollbar;
  5974. if (el) {
  5975. el.classList[swiper.enabled ? 'remove' : 'add'](...classesToTokens(swiper.params.scrollbar.lockClass));
  5976. }
  5977. });
  5978. on('destroy', () => {
  5979. destroy();
  5980. });
  5981. const enable = () => {
  5982. swiper.el.classList.remove(...classesToTokens(swiper.params.scrollbar.scrollbarDisabledClass));
  5983. if (swiper.scrollbar.el) {
  5984. swiper.scrollbar.el.classList.remove(...classesToTokens(swiper.params.scrollbar.scrollbarDisabledClass));
  5985. }
  5986. init();
  5987. updateSize();
  5988. setTranslate();
  5989. };
  5990. const disable = () => {
  5991. swiper.el.classList.add(...classesToTokens(swiper.params.scrollbar.scrollbarDisabledClass));
  5992. if (swiper.scrollbar.el) {
  5993. swiper.scrollbar.el.classList.add(...classesToTokens(swiper.params.scrollbar.scrollbarDisabledClass));
  5994. }
  5995. destroy();
  5996. };
  5997. Object.assign(swiper.scrollbar, {
  5998. enable,
  5999. disable,
  6000. updateSize,
  6001. setTranslate,
  6002. init,
  6003. destroy
  6004. });
  6005. }
  6006. function Parallax(_ref) {
  6007. let {
  6008. swiper,
  6009. extendParams,
  6010. on
  6011. } = _ref;
  6012. extendParams({
  6013. parallax: {
  6014. enabled: false
  6015. }
  6016. });
  6017. const elementsSelector = '[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]';
  6018. const setTransform = (el, progress) => {
  6019. const {
  6020. rtl
  6021. } = swiper;
  6022. const rtlFactor = rtl ? -1 : 1;
  6023. const p = el.getAttribute('data-swiper-parallax') || '0';
  6024. let x = el.getAttribute('data-swiper-parallax-x');
  6025. let y = el.getAttribute('data-swiper-parallax-y');
  6026. const scale = el.getAttribute('data-swiper-parallax-scale');
  6027. const opacity = el.getAttribute('data-swiper-parallax-opacity');
  6028. const rotate = el.getAttribute('data-swiper-parallax-rotate');
  6029. if (x || y) {
  6030. x = x || '0';
  6031. y = y || '0';
  6032. } else if (swiper.isHorizontal()) {
  6033. x = p;
  6034. y = '0';
  6035. } else {
  6036. y = p;
  6037. x = '0';
  6038. }
  6039. if (x.indexOf('%') >= 0) {
  6040. x = `${parseInt(x, 10) * progress * rtlFactor}%`;
  6041. } else {
  6042. x = `${x * progress * rtlFactor}px`;
  6043. }
  6044. if (y.indexOf('%') >= 0) {
  6045. y = `${parseInt(y, 10) * progress}%`;
  6046. } else {
  6047. y = `${y * progress}px`;
  6048. }
  6049. if (typeof opacity !== 'undefined' && opacity !== null) {
  6050. const currentOpacity = opacity - (opacity - 1) * (1 - Math.abs(progress));
  6051. el.style.opacity = currentOpacity;
  6052. }
  6053. let transform = `translate3d(${x}, ${y}, 0px)`;
  6054. if (typeof scale !== 'undefined' && scale !== null) {
  6055. const currentScale = scale - (scale - 1) * (1 - Math.abs(progress));
  6056. transform += ` scale(${currentScale})`;
  6057. }
  6058. if (rotate && typeof rotate !== 'undefined' && rotate !== null) {
  6059. const currentRotate = rotate * progress * -1;
  6060. transform += ` rotate(${currentRotate}deg)`;
  6061. }
  6062. el.style.transform = transform;
  6063. };
  6064. const setTranslate = () => {
  6065. const {
  6066. el,
  6067. slides,
  6068. progress,
  6069. snapGrid,
  6070. isElement
  6071. } = swiper;
  6072. const elements = elementChildren(el, elementsSelector);
  6073. if (swiper.isElement) {
  6074. elements.push(...elementChildren(swiper.hostEl, elementsSelector));
  6075. }
  6076. elements.forEach(subEl => {
  6077. setTransform(subEl, progress);
  6078. });
  6079. slides.forEach((slideEl, slideIndex) => {
  6080. let slideProgress = slideEl.progress;
  6081. if (swiper.params.slidesPerGroup > 1 && swiper.params.slidesPerView !== 'auto') {
  6082. slideProgress += Math.ceil(slideIndex / 2) - progress * (snapGrid.length - 1);
  6083. }
  6084. slideProgress = Math.min(Math.max(slideProgress, -1), 1);
  6085. slideEl.querySelectorAll(`${elementsSelector}, [data-swiper-parallax-rotate]`).forEach(subEl => {
  6086. setTransform(subEl, slideProgress);
  6087. });
  6088. });
  6089. };
  6090. const setTransition = function (duration) {
  6091. if (duration === void 0) {
  6092. duration = swiper.params.speed;
  6093. }
  6094. const {
  6095. el,
  6096. hostEl
  6097. } = swiper;
  6098. const elements = [...el.querySelectorAll(elementsSelector)];
  6099. if (swiper.isElement) {
  6100. elements.push(...hostEl.querySelectorAll(elementsSelector));
  6101. }
  6102. elements.forEach(parallaxEl => {
  6103. let parallaxDuration = parseInt(parallaxEl.getAttribute('data-swiper-parallax-duration'), 10) || duration;
  6104. if (duration === 0) parallaxDuration = 0;
  6105. parallaxEl.style.transitionDuration = `${parallaxDuration}ms`;
  6106. });
  6107. };
  6108. on('beforeInit', () => {
  6109. if (!swiper.params.parallax.enabled) return;
  6110. swiper.params.watchSlidesProgress = true;
  6111. swiper.originalParams.watchSlidesProgress = true;
  6112. });
  6113. on('init', () => {
  6114. if (!swiper.params.parallax.enabled) return;
  6115. setTranslate();
  6116. });
  6117. on('setTranslate', () => {
  6118. if (!swiper.params.parallax.enabled) return;
  6119. setTranslate();
  6120. });
  6121. on('setTransition', (_swiper, duration) => {
  6122. if (!swiper.params.parallax.enabled) return;
  6123. setTransition(duration);
  6124. });
  6125. }
  6126. function Zoom(_ref) {
  6127. let {
  6128. swiper,
  6129. extendParams,
  6130. on,
  6131. emit
  6132. } = _ref;
  6133. const window = getWindow();
  6134. extendParams({
  6135. zoom: {
  6136. enabled: false,
  6137. maxRatio: 3,
  6138. minRatio: 1,
  6139. toggle: true,
  6140. containerClass: 'swiper-zoom-container',
  6141. zoomedSlideClass: 'swiper-slide-zoomed'
  6142. }
  6143. });
  6144. swiper.zoom = {
  6145. enabled: false
  6146. };
  6147. let currentScale = 1;
  6148. let isScaling = false;
  6149. let fakeGestureTouched;
  6150. let fakeGestureMoved;
  6151. const evCache = [];
  6152. const gesture = {
  6153. originX: 0,
  6154. originY: 0,
  6155. slideEl: undefined,
  6156. slideWidth: undefined,
  6157. slideHeight: undefined,
  6158. imageEl: undefined,
  6159. imageWrapEl: undefined,
  6160. maxRatio: 3
  6161. };
  6162. const image = {
  6163. isTouched: undefined,
  6164. isMoved: undefined,
  6165. currentX: undefined,
  6166. currentY: undefined,
  6167. minX: undefined,
  6168. minY: undefined,
  6169. maxX: undefined,
  6170. maxY: undefined,
  6171. width: undefined,
  6172. height: undefined,
  6173. startX: undefined,
  6174. startY: undefined,
  6175. touchesStart: {},
  6176. touchesCurrent: {}
  6177. };
  6178. const velocity = {
  6179. x: undefined,
  6180. y: undefined,
  6181. prevPositionX: undefined,
  6182. prevPositionY: undefined,
  6183. prevTime: undefined
  6184. };
  6185. let scale = 1;
  6186. Object.defineProperty(swiper.zoom, 'scale', {
  6187. get() {
  6188. return scale;
  6189. },
  6190. set(value) {
  6191. if (scale !== value) {
  6192. const imageEl = gesture.imageEl;
  6193. const slideEl = gesture.slideEl;
  6194. emit('zoomChange', value, imageEl, slideEl);
  6195. }
  6196. scale = value;
  6197. }
  6198. });
  6199. function getDistanceBetweenTouches() {
  6200. if (evCache.length < 2) return 1;
  6201. const x1 = evCache[0].pageX;
  6202. const y1 = evCache[0].pageY;
  6203. const x2 = evCache[1].pageX;
  6204. const y2 = evCache[1].pageY;
  6205. const distance = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);
  6206. return distance;
  6207. }
  6208. function getScaleOrigin() {
  6209. if (evCache.length < 2) return {
  6210. x: null,
  6211. y: null
  6212. };
  6213. const box = gesture.imageEl.getBoundingClientRect();
  6214. return [(evCache[0].pageX + (evCache[1].pageX - evCache[0].pageX) / 2 - box.x - window.scrollX) / currentScale, (evCache[0].pageY + (evCache[1].pageY - evCache[0].pageY) / 2 - box.y - window.scrollY) / currentScale];
  6215. }
  6216. function getSlideSelector() {
  6217. return swiper.isElement ? `swiper-slide` : `.${swiper.params.slideClass}`;
  6218. }
  6219. function eventWithinSlide(e) {
  6220. const slideSelector = getSlideSelector();
  6221. if (e.target.matches(slideSelector)) return true;
  6222. if (swiper.slides.filter(slideEl => slideEl.contains(e.target)).length > 0) return true;
  6223. return false;
  6224. }
  6225. function eventWithinZoomContainer(e) {
  6226. const selector = `.${swiper.params.zoom.containerClass}`;
  6227. if (e.target.matches(selector)) return true;
  6228. if ([...swiper.hostEl.querySelectorAll(selector)].filter(containerEl => containerEl.contains(e.target)).length > 0) return true;
  6229. return false;
  6230. }
  6231. // Events
  6232. function onGestureStart(e) {
  6233. if (e.pointerType === 'mouse') {
  6234. evCache.splice(0, evCache.length);
  6235. }
  6236. if (!eventWithinSlide(e)) return;
  6237. const params = swiper.params.zoom;
  6238. fakeGestureTouched = false;
  6239. fakeGestureMoved = false;
  6240. evCache.push(e);
  6241. if (evCache.length < 2) {
  6242. return;
  6243. }
  6244. fakeGestureTouched = true;
  6245. gesture.scaleStart = getDistanceBetweenTouches();
  6246. if (!gesture.slideEl) {
  6247. gesture.slideEl = e.target.closest(`.${swiper.params.slideClass}, swiper-slide`);
  6248. if (!gesture.slideEl) gesture.slideEl = swiper.slides[swiper.activeIndex];
  6249. let imageEl = gesture.slideEl.querySelector(`.${params.containerClass}`);
  6250. if (imageEl) {
  6251. imageEl = imageEl.querySelectorAll('picture, img, svg, canvas, .swiper-zoom-target')[0];
  6252. }
  6253. gesture.imageEl = imageEl;
  6254. if (imageEl) {
  6255. gesture.imageWrapEl = elementParents(gesture.imageEl, `.${params.containerClass}`)[0];
  6256. } else {
  6257. gesture.imageWrapEl = undefined;
  6258. }
  6259. if (!gesture.imageWrapEl) {
  6260. gesture.imageEl = undefined;
  6261. return;
  6262. }
  6263. gesture.maxRatio = gesture.imageWrapEl.getAttribute('data-swiper-zoom') || params.maxRatio;
  6264. }
  6265. if (gesture.imageEl) {
  6266. const [originX, originY] = getScaleOrigin();
  6267. gesture.originX = originX;
  6268. gesture.originY = originY;
  6269. gesture.imageEl.style.transitionDuration = '0ms';
  6270. }
  6271. isScaling = true;
  6272. }
  6273. function onGestureChange(e) {
  6274. if (!eventWithinSlide(e)) return;
  6275. const params = swiper.params.zoom;
  6276. const zoom = swiper.zoom;
  6277. const pointerIndex = evCache.findIndex(cachedEv => cachedEv.pointerId === e.pointerId);
  6278. if (pointerIndex >= 0) evCache[pointerIndex] = e;
  6279. if (evCache.length < 2) {
  6280. return;
  6281. }
  6282. fakeGestureMoved = true;
  6283. gesture.scaleMove = getDistanceBetweenTouches();
  6284. if (!gesture.imageEl) {
  6285. return;
  6286. }
  6287. zoom.scale = gesture.scaleMove / gesture.scaleStart * currentScale;
  6288. if (zoom.scale > gesture.maxRatio) {
  6289. zoom.scale = gesture.maxRatio - 1 + (zoom.scale - gesture.maxRatio + 1) ** 0.5;
  6290. }
  6291. if (zoom.scale < params.minRatio) {
  6292. zoom.scale = params.minRatio + 1 - (params.minRatio - zoom.scale + 1) ** 0.5;
  6293. }
  6294. gesture.imageEl.style.transform = `translate3d(0,0,0) scale(${zoom.scale})`;
  6295. }
  6296. function onGestureEnd(e) {
  6297. if (!eventWithinSlide(e)) return;
  6298. if (e.pointerType === 'mouse' && e.type === 'pointerout') return;
  6299. const params = swiper.params.zoom;
  6300. const zoom = swiper.zoom;
  6301. const pointerIndex = evCache.findIndex(cachedEv => cachedEv.pointerId === e.pointerId);
  6302. if (pointerIndex >= 0) evCache.splice(pointerIndex, 1);
  6303. if (!fakeGestureTouched || !fakeGestureMoved) {
  6304. return;
  6305. }
  6306. fakeGestureTouched = false;
  6307. fakeGestureMoved = false;
  6308. if (!gesture.imageEl) return;
  6309. zoom.scale = Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);
  6310. gesture.imageEl.style.transitionDuration = `${swiper.params.speed}ms`;
  6311. gesture.imageEl.style.transform = `translate3d(0,0,0) scale(${zoom.scale})`;
  6312. currentScale = zoom.scale;
  6313. isScaling = false;
  6314. if (zoom.scale > 1 && gesture.slideEl) {
  6315. gesture.slideEl.classList.add(`${params.zoomedSlideClass}`);
  6316. } else if (zoom.scale <= 1 && gesture.slideEl) {
  6317. gesture.slideEl.classList.remove(`${params.zoomedSlideClass}`);
  6318. }
  6319. if (zoom.scale === 1) {
  6320. gesture.originX = 0;
  6321. gesture.originY = 0;
  6322. gesture.slideEl = undefined;
  6323. }
  6324. }
  6325. function onTouchStart(e) {
  6326. const device = swiper.device;
  6327. if (!gesture.imageEl) return;
  6328. if (image.isTouched) return;
  6329. if (device.android && e.cancelable) e.preventDefault();
  6330. image.isTouched = true;
  6331. const event = evCache.length > 0 ? evCache[0] : e;
  6332. image.touchesStart.x = event.pageX;
  6333. image.touchesStart.y = event.pageY;
  6334. }
  6335. function onTouchMove(e) {
  6336. if (!eventWithinSlide(e) || !eventWithinZoomContainer(e)) return;
  6337. const zoom = swiper.zoom;
  6338. if (!gesture.imageEl) return;
  6339. if (!image.isTouched || !gesture.slideEl) return;
  6340. if (!image.isMoved) {
  6341. image.width = gesture.imageEl.offsetWidth;
  6342. image.height = gesture.imageEl.offsetHeight;
  6343. image.startX = getTranslate(gesture.imageWrapEl, 'x') || 0;
  6344. image.startY = getTranslate(gesture.imageWrapEl, 'y') || 0;
  6345. gesture.slideWidth = gesture.slideEl.offsetWidth;
  6346. gesture.slideHeight = gesture.slideEl.offsetHeight;
  6347. gesture.imageWrapEl.style.transitionDuration = '0ms';
  6348. }
  6349. // Define if we need image drag
  6350. const scaledWidth = image.width * zoom.scale;
  6351. const scaledHeight = image.height * zoom.scale;
  6352. if (scaledWidth < gesture.slideWidth && scaledHeight < gesture.slideHeight) return;
  6353. image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);
  6354. image.maxX = -image.minX;
  6355. image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);
  6356. image.maxY = -image.minY;
  6357. image.touchesCurrent.x = evCache.length > 0 ? evCache[0].pageX : e.pageX;
  6358. image.touchesCurrent.y = evCache.length > 0 ? evCache[0].pageY : e.pageY;
  6359. const touchesDiff = Math.max(Math.abs(image.touchesCurrent.x - image.touchesStart.x), Math.abs(image.touchesCurrent.y - image.touchesStart.y));
  6360. if (touchesDiff > 5) {
  6361. swiper.allowClick = false;
  6362. }
  6363. if (!image.isMoved && !isScaling) {
  6364. if (swiper.isHorizontal() && (Math.floor(image.minX) === Math.floor(image.startX) && image.touchesCurrent.x < image.touchesStart.x || Math.floor(image.maxX) === Math.floor(image.startX) && image.touchesCurrent.x > image.touchesStart.x)) {
  6365. image.isTouched = false;
  6366. return;
  6367. }
  6368. if (!swiper.isHorizontal() && (Math.floor(image.minY) === Math.floor(image.startY) && image.touchesCurrent.y < image.touchesStart.y || Math.floor(image.maxY) === Math.floor(image.startY) && image.touchesCurrent.y > image.touchesStart.y)) {
  6369. image.isTouched = false;
  6370. return;
  6371. }
  6372. }
  6373. if (e.cancelable) {
  6374. e.preventDefault();
  6375. }
  6376. e.stopPropagation();
  6377. image.isMoved = true;
  6378. const scaleRatio = (zoom.scale - currentScale) / (gesture.maxRatio - swiper.params.zoom.minRatio);
  6379. const {
  6380. originX,
  6381. originY
  6382. } = gesture;
  6383. image.currentX = image.touchesCurrent.x - image.touchesStart.x + image.startX + scaleRatio * (image.width - originX * 2);
  6384. image.currentY = image.touchesCurrent.y - image.touchesStart.y + image.startY + scaleRatio * (image.height - originY * 2);
  6385. if (image.currentX < image.minX) {
  6386. image.currentX = image.minX + 1 - (image.minX - image.currentX + 1) ** 0.8;
  6387. }
  6388. if (image.currentX > image.maxX) {
  6389. image.currentX = image.maxX - 1 + (image.currentX - image.maxX + 1) ** 0.8;
  6390. }
  6391. if (image.currentY < image.minY) {
  6392. image.currentY = image.minY + 1 - (image.minY - image.currentY + 1) ** 0.8;
  6393. }
  6394. if (image.currentY > image.maxY) {
  6395. image.currentY = image.maxY - 1 + (image.currentY - image.maxY + 1) ** 0.8;
  6396. }
  6397. // Velocity
  6398. if (!velocity.prevPositionX) velocity.prevPositionX = image.touchesCurrent.x;
  6399. if (!velocity.prevPositionY) velocity.prevPositionY = image.touchesCurrent.y;
  6400. if (!velocity.prevTime) velocity.prevTime = Date.now();
  6401. velocity.x = (image.touchesCurrent.x - velocity.prevPositionX) / (Date.now() - velocity.prevTime) / 2;
  6402. velocity.y = (image.touchesCurrent.y - velocity.prevPositionY) / (Date.now() - velocity.prevTime) / 2;
  6403. if (Math.abs(image.touchesCurrent.x - velocity.prevPositionX) < 2) velocity.x = 0;
  6404. if (Math.abs(image.touchesCurrent.y - velocity.prevPositionY) < 2) velocity.y = 0;
  6405. velocity.prevPositionX = image.touchesCurrent.x;
  6406. velocity.prevPositionY = image.touchesCurrent.y;
  6407. velocity.prevTime = Date.now();
  6408. gesture.imageWrapEl.style.transform = `translate3d(${image.currentX}px, ${image.currentY}px,0)`;
  6409. }
  6410. function onTouchEnd() {
  6411. const zoom = swiper.zoom;
  6412. if (!gesture.imageEl) return;
  6413. if (!image.isTouched || !image.isMoved) {
  6414. image.isTouched = false;
  6415. image.isMoved = false;
  6416. return;
  6417. }
  6418. image.isTouched = false;
  6419. image.isMoved = false;
  6420. let momentumDurationX = 300;
  6421. let momentumDurationY = 300;
  6422. const momentumDistanceX = velocity.x * momentumDurationX;
  6423. const newPositionX = image.currentX + momentumDistanceX;
  6424. const momentumDistanceY = velocity.y * momentumDurationY;
  6425. const newPositionY = image.currentY + momentumDistanceY;
  6426. // Fix duration
  6427. if (velocity.x !== 0) momentumDurationX = Math.abs((newPositionX - image.currentX) / velocity.x);
  6428. if (velocity.y !== 0) momentumDurationY = Math.abs((newPositionY - image.currentY) / velocity.y);
  6429. const momentumDuration = Math.max(momentumDurationX, momentumDurationY);
  6430. image.currentX = newPositionX;
  6431. image.currentY = newPositionY;
  6432. // Define if we need image drag
  6433. const scaledWidth = image.width * zoom.scale;
  6434. const scaledHeight = image.height * zoom.scale;
  6435. image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);
  6436. image.maxX = -image.minX;
  6437. image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);
  6438. image.maxY = -image.minY;
  6439. image.currentX = Math.max(Math.min(image.currentX, image.maxX), image.minX);
  6440. image.currentY = Math.max(Math.min(image.currentY, image.maxY), image.minY);
  6441. gesture.imageWrapEl.style.transitionDuration = `${momentumDuration}ms`;
  6442. gesture.imageWrapEl.style.transform = `translate3d(${image.currentX}px, ${image.currentY}px,0)`;
  6443. }
  6444. function onTransitionEnd() {
  6445. const zoom = swiper.zoom;
  6446. if (gesture.slideEl && swiper.activeIndex !== swiper.slides.indexOf(gesture.slideEl)) {
  6447. if (gesture.imageEl) {
  6448. gesture.imageEl.style.transform = 'translate3d(0,0,0) scale(1)';
  6449. }
  6450. if (gesture.imageWrapEl) {
  6451. gesture.imageWrapEl.style.transform = 'translate3d(0,0,0)';
  6452. }
  6453. gesture.slideEl.classList.remove(`${swiper.params.zoom.zoomedSlideClass}`);
  6454. zoom.scale = 1;
  6455. currentScale = 1;
  6456. gesture.slideEl = undefined;
  6457. gesture.imageEl = undefined;
  6458. gesture.imageWrapEl = undefined;
  6459. gesture.originX = 0;
  6460. gesture.originY = 0;
  6461. }
  6462. }
  6463. function zoomIn(e) {
  6464. const zoom = swiper.zoom;
  6465. const params = swiper.params.zoom;
  6466. if (!gesture.slideEl) {
  6467. if (e && e.target) {
  6468. gesture.slideEl = e.target.closest(`.${swiper.params.slideClass}, swiper-slide`);
  6469. }
  6470. if (!gesture.slideEl) {
  6471. if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {
  6472. gesture.slideEl = elementChildren(swiper.slidesEl, `.${swiper.params.slideActiveClass}`)[0];
  6473. } else {
  6474. gesture.slideEl = swiper.slides[swiper.activeIndex];
  6475. }
  6476. }
  6477. let imageEl = gesture.slideEl.querySelector(`.${params.containerClass}`);
  6478. if (imageEl) {
  6479. imageEl = imageEl.querySelectorAll('picture, img, svg, canvas, .swiper-zoom-target')[0];
  6480. }
  6481. gesture.imageEl = imageEl;
  6482. if (imageEl) {
  6483. gesture.imageWrapEl = elementParents(gesture.imageEl, `.${params.containerClass}`)[0];
  6484. } else {
  6485. gesture.imageWrapEl = undefined;
  6486. }
  6487. }
  6488. if (!gesture.imageEl || !gesture.imageWrapEl) return;
  6489. if (swiper.params.cssMode) {
  6490. swiper.wrapperEl.style.overflow = 'hidden';
  6491. swiper.wrapperEl.style.touchAction = 'none';
  6492. }
  6493. gesture.slideEl.classList.add(`${params.zoomedSlideClass}`);
  6494. let touchX;
  6495. let touchY;
  6496. let offsetX;
  6497. let offsetY;
  6498. let diffX;
  6499. let diffY;
  6500. let translateX;
  6501. let translateY;
  6502. let imageWidth;
  6503. let imageHeight;
  6504. let scaledWidth;
  6505. let scaledHeight;
  6506. let translateMinX;
  6507. let translateMinY;
  6508. let translateMaxX;
  6509. let translateMaxY;
  6510. let slideWidth;
  6511. let slideHeight;
  6512. if (typeof image.touchesStart.x === 'undefined' && e) {
  6513. touchX = e.pageX;
  6514. touchY = e.pageY;
  6515. } else {
  6516. touchX = image.touchesStart.x;
  6517. touchY = image.touchesStart.y;
  6518. }
  6519. const forceZoomRatio = typeof e === 'number' ? e : null;
  6520. if (currentScale === 1 && forceZoomRatio) {
  6521. touchX = undefined;
  6522. touchY = undefined;
  6523. }
  6524. zoom.scale = forceZoomRatio || gesture.imageWrapEl.getAttribute('data-swiper-zoom') || params.maxRatio;
  6525. currentScale = forceZoomRatio || gesture.imageWrapEl.getAttribute('data-swiper-zoom') || params.maxRatio;
  6526. if (e && !(currentScale === 1 && forceZoomRatio)) {
  6527. slideWidth = gesture.slideEl.offsetWidth;
  6528. slideHeight = gesture.slideEl.offsetHeight;
  6529. offsetX = elementOffset(gesture.slideEl).left + window.scrollX;
  6530. offsetY = elementOffset(gesture.slideEl).top + window.scrollY;
  6531. diffX = offsetX + slideWidth / 2 - touchX;
  6532. diffY = offsetY + slideHeight / 2 - touchY;
  6533. imageWidth = gesture.imageEl.offsetWidth;
  6534. imageHeight = gesture.imageEl.offsetHeight;
  6535. scaledWidth = imageWidth * zoom.scale;
  6536. scaledHeight = imageHeight * zoom.scale;
  6537. translateMinX = Math.min(slideWidth / 2 - scaledWidth / 2, 0);
  6538. translateMinY = Math.min(slideHeight / 2 - scaledHeight / 2, 0);
  6539. translateMaxX = -translateMinX;
  6540. translateMaxY = -translateMinY;
  6541. translateX = diffX * zoom.scale;
  6542. translateY = diffY * zoom.scale;
  6543. if (translateX < translateMinX) {
  6544. translateX = translateMinX;
  6545. }
  6546. if (translateX > translateMaxX) {
  6547. translateX = translateMaxX;
  6548. }
  6549. if (translateY < translateMinY) {
  6550. translateY = translateMinY;
  6551. }
  6552. if (translateY > translateMaxY) {
  6553. translateY = translateMaxY;
  6554. }
  6555. } else {
  6556. translateX = 0;
  6557. translateY = 0;
  6558. }
  6559. if (forceZoomRatio && zoom.scale === 1) {
  6560. gesture.originX = 0;
  6561. gesture.originY = 0;
  6562. }
  6563. gesture.imageWrapEl.style.transitionDuration = '300ms';
  6564. gesture.imageWrapEl.style.transform = `translate3d(${translateX}px, ${translateY}px,0)`;
  6565. gesture.imageEl.style.transitionDuration = '300ms';
  6566. gesture.imageEl.style.transform = `translate3d(0,0,0) scale(${zoom.scale})`;
  6567. }
  6568. function zoomOut() {
  6569. const zoom = swiper.zoom;
  6570. const params = swiper.params.zoom;
  6571. if (!gesture.slideEl) {
  6572. if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {
  6573. gesture.slideEl = elementChildren(swiper.slidesEl, `.${swiper.params.slideActiveClass}`)[0];
  6574. } else {
  6575. gesture.slideEl = swiper.slides[swiper.activeIndex];
  6576. }
  6577. let imageEl = gesture.slideEl.querySelector(`.${params.containerClass}`);
  6578. if (imageEl) {
  6579. imageEl = imageEl.querySelectorAll('picture, img, svg, canvas, .swiper-zoom-target')[0];
  6580. }
  6581. gesture.imageEl = imageEl;
  6582. if (imageEl) {
  6583. gesture.imageWrapEl = elementParents(gesture.imageEl, `.${params.containerClass}`)[0];
  6584. } else {
  6585. gesture.imageWrapEl = undefined;
  6586. }
  6587. }
  6588. if (!gesture.imageEl || !gesture.imageWrapEl) return;
  6589. if (swiper.params.cssMode) {
  6590. swiper.wrapperEl.style.overflow = '';
  6591. swiper.wrapperEl.style.touchAction = '';
  6592. }
  6593. zoom.scale = 1;
  6594. currentScale = 1;
  6595. gesture.imageWrapEl.style.transitionDuration = '300ms';
  6596. gesture.imageWrapEl.style.transform = 'translate3d(0,0,0)';
  6597. gesture.imageEl.style.transitionDuration = '300ms';
  6598. gesture.imageEl.style.transform = 'translate3d(0,0,0) scale(1)';
  6599. gesture.slideEl.classList.remove(`${params.zoomedSlideClass}`);
  6600. gesture.slideEl = undefined;
  6601. gesture.originX = 0;
  6602. gesture.originY = 0;
  6603. }
  6604. // Toggle Zoom
  6605. function zoomToggle(e) {
  6606. const zoom = swiper.zoom;
  6607. if (zoom.scale && zoom.scale !== 1) {
  6608. // Zoom Out
  6609. zoomOut();
  6610. } else {
  6611. // Zoom In
  6612. zoomIn(e);
  6613. }
  6614. }
  6615. function getListeners() {
  6616. const passiveListener = swiper.params.passiveListeners ? {
  6617. passive: true,
  6618. capture: false
  6619. } : false;
  6620. const activeListenerWithCapture = swiper.params.passiveListeners ? {
  6621. passive: false,
  6622. capture: true
  6623. } : true;
  6624. return {
  6625. passiveListener,
  6626. activeListenerWithCapture
  6627. };
  6628. }
  6629. // Attach/Detach Events
  6630. function enable() {
  6631. const zoom = swiper.zoom;
  6632. if (zoom.enabled) return;
  6633. zoom.enabled = true;
  6634. const {
  6635. passiveListener,
  6636. activeListenerWithCapture
  6637. } = getListeners();
  6638. // Scale image
  6639. swiper.wrapperEl.addEventListener('pointerdown', onGestureStart, passiveListener);
  6640. swiper.wrapperEl.addEventListener('pointermove', onGestureChange, activeListenerWithCapture);
  6641. ['pointerup', 'pointercancel', 'pointerout'].forEach(eventName => {
  6642. swiper.wrapperEl.addEventListener(eventName, onGestureEnd, passiveListener);
  6643. });
  6644. // Move image
  6645. swiper.wrapperEl.addEventListener('pointermove', onTouchMove, activeListenerWithCapture);
  6646. }
  6647. function disable() {
  6648. const zoom = swiper.zoom;
  6649. if (!zoom.enabled) return;
  6650. zoom.enabled = false;
  6651. const {
  6652. passiveListener,
  6653. activeListenerWithCapture
  6654. } = getListeners();
  6655. // Scale image
  6656. swiper.wrapperEl.removeEventListener('pointerdown', onGestureStart, passiveListener);
  6657. swiper.wrapperEl.removeEventListener('pointermove', onGestureChange, activeListenerWithCapture);
  6658. ['pointerup', 'pointercancel', 'pointerout'].forEach(eventName => {
  6659. swiper.wrapperEl.removeEventListener(eventName, onGestureEnd, passiveListener);
  6660. });
  6661. // Move image
  6662. swiper.wrapperEl.removeEventListener('pointermove', onTouchMove, activeListenerWithCapture);
  6663. }
  6664. on('init', () => {
  6665. if (swiper.params.zoom.enabled) {
  6666. enable();
  6667. }
  6668. });
  6669. on('destroy', () => {
  6670. disable();
  6671. });
  6672. on('touchStart', (_s, e) => {
  6673. if (!swiper.zoom.enabled) return;
  6674. onTouchStart(e);
  6675. });
  6676. on('touchEnd', (_s, e) => {
  6677. if (!swiper.zoom.enabled) return;
  6678. onTouchEnd();
  6679. });
  6680. on('doubleTap', (_s, e) => {
  6681. if (!swiper.animating && swiper.params.zoom.enabled && swiper.zoom.enabled && swiper.params.zoom.toggle) {
  6682. zoomToggle(e);
  6683. }
  6684. });
  6685. on('transitionEnd', () => {
  6686. if (swiper.zoom.enabled && swiper.params.zoom.enabled) {
  6687. onTransitionEnd();
  6688. }
  6689. });
  6690. on('slideChange', () => {
  6691. if (swiper.zoom.enabled && swiper.params.zoom.enabled && swiper.params.cssMode) {
  6692. onTransitionEnd();
  6693. }
  6694. });
  6695. Object.assign(swiper.zoom, {
  6696. enable,
  6697. disable,
  6698. in: zoomIn,
  6699. out: zoomOut,
  6700. toggle: zoomToggle
  6701. });
  6702. }
  6703. /* eslint no-bitwise: ["error", { "allow": [">>"] }] */
  6704. function Controller(_ref) {
  6705. let {
  6706. swiper,
  6707. extendParams,
  6708. on
  6709. } = _ref;
  6710. extendParams({
  6711. controller: {
  6712. control: undefined,
  6713. inverse: false,
  6714. by: 'slide' // or 'container'
  6715. }
  6716. });
  6717. swiper.controller = {
  6718. control: undefined
  6719. };
  6720. function LinearSpline(x, y) {
  6721. const binarySearch = function search() {
  6722. let maxIndex;
  6723. let minIndex;
  6724. let guess;
  6725. return (array, val) => {
  6726. minIndex = -1;
  6727. maxIndex = array.length;
  6728. while (maxIndex - minIndex > 1) {
  6729. guess = maxIndex + minIndex >> 1;
  6730. if (array[guess] <= val) {
  6731. minIndex = guess;
  6732. } else {
  6733. maxIndex = guess;
  6734. }
  6735. }
  6736. return maxIndex;
  6737. };
  6738. }();
  6739. this.x = x;
  6740. this.y = y;
  6741. this.lastIndex = x.length - 1;
  6742. // Given an x value (x2), return the expected y2 value:
  6743. // (x1,y1) is the known point before given value,
  6744. // (x3,y3) is the known point after given value.
  6745. let i1;
  6746. let i3;
  6747. this.interpolate = function interpolate(x2) {
  6748. if (!x2) return 0;
  6749. // Get the indexes of x1 and x3 (the array indexes before and after given x2):
  6750. i3 = binarySearch(this.x, x2);
  6751. i1 = i3 - 1;
  6752. // We have our indexes i1 & i3, so we can calculate already:
  6753. // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1
  6754. return (x2 - this.x[i1]) * (this.y[i3] - this.y[i1]) / (this.x[i3] - this.x[i1]) + this.y[i1];
  6755. };
  6756. return this;
  6757. }
  6758. function getInterpolateFunction(c) {
  6759. swiper.controller.spline = swiper.params.loop ? new LinearSpline(swiper.slidesGrid, c.slidesGrid) : new LinearSpline(swiper.snapGrid, c.snapGrid);
  6760. }
  6761. function setTranslate(_t, byController) {
  6762. const controlled = swiper.controller.control;
  6763. let multiplier;
  6764. let controlledTranslate;
  6765. const Swiper = swiper.constructor;
  6766. function setControlledTranslate(c) {
  6767. if (c.destroyed) return;
  6768. // this will create an Interpolate function based on the snapGrids
  6769. // x is the Grid of the scrolled scroller and y will be the controlled scroller
  6770. // it makes sense to create this only once and recall it for the interpolation
  6771. // the function does a lot of value caching for performance
  6772. const translate = swiper.rtlTranslate ? -swiper.translate : swiper.translate;
  6773. if (swiper.params.controller.by === 'slide') {
  6774. getInterpolateFunction(c);
  6775. // i am not sure why the values have to be multiplicated this way, tried to invert the snapGrid
  6776. // but it did not work out
  6777. controlledTranslate = -swiper.controller.spline.interpolate(-translate);
  6778. }
  6779. if (!controlledTranslate || swiper.params.controller.by === 'container') {
  6780. multiplier = (c.maxTranslate() - c.minTranslate()) / (swiper.maxTranslate() - swiper.minTranslate());
  6781. if (Number.isNaN(multiplier) || !Number.isFinite(multiplier)) {
  6782. multiplier = 1;
  6783. }
  6784. controlledTranslate = (translate - swiper.minTranslate()) * multiplier + c.minTranslate();
  6785. }
  6786. if (swiper.params.controller.inverse) {
  6787. controlledTranslate = c.maxTranslate() - controlledTranslate;
  6788. }
  6789. c.updateProgress(controlledTranslate);
  6790. c.setTranslate(controlledTranslate, swiper);
  6791. c.updateActiveIndex();
  6792. c.updateSlidesClasses();
  6793. }
  6794. if (Array.isArray(controlled)) {
  6795. for (let i = 0; i < controlled.length; i += 1) {
  6796. if (controlled[i] !== byController && controlled[i] instanceof Swiper) {
  6797. setControlledTranslate(controlled[i]);
  6798. }
  6799. }
  6800. } else if (controlled instanceof Swiper && byController !== controlled) {
  6801. setControlledTranslate(controlled);
  6802. }
  6803. }
  6804. function setTransition(duration, byController) {
  6805. const Swiper = swiper.constructor;
  6806. const controlled = swiper.controller.control;
  6807. let i;
  6808. function setControlledTransition(c) {
  6809. if (c.destroyed) return;
  6810. c.setTransition(duration, swiper);
  6811. if (duration !== 0) {
  6812. c.transitionStart();
  6813. if (c.params.autoHeight) {
  6814. nextTick(() => {
  6815. c.updateAutoHeight();
  6816. });
  6817. }
  6818. elementTransitionEnd(c.wrapperEl, () => {
  6819. if (!controlled) return;
  6820. c.transitionEnd();
  6821. });
  6822. }
  6823. }
  6824. if (Array.isArray(controlled)) {
  6825. for (i = 0; i < controlled.length; i += 1) {
  6826. if (controlled[i] !== byController && controlled[i] instanceof Swiper) {
  6827. setControlledTransition(controlled[i]);
  6828. }
  6829. }
  6830. } else if (controlled instanceof Swiper && byController !== controlled) {
  6831. setControlledTransition(controlled);
  6832. }
  6833. }
  6834. function removeSpline() {
  6835. if (!swiper.controller.control) return;
  6836. if (swiper.controller.spline) {
  6837. swiper.controller.spline = undefined;
  6838. delete swiper.controller.spline;
  6839. }
  6840. }
  6841. on('beforeInit', () => {
  6842. if (typeof window !== 'undefined' && (
  6843. // eslint-disable-line
  6844. typeof swiper.params.controller.control === 'string' || swiper.params.controller.control instanceof HTMLElement)) {
  6845. const controlElement = document.querySelector(swiper.params.controller.control);
  6846. if (controlElement && controlElement.swiper) {
  6847. swiper.controller.control = controlElement.swiper;
  6848. } else if (controlElement) {
  6849. const onControllerSwiper = e => {
  6850. swiper.controller.control = e.detail[0];
  6851. swiper.update();
  6852. controlElement.removeEventListener('init', onControllerSwiper);
  6853. };
  6854. controlElement.addEventListener('init', onControllerSwiper);
  6855. }
  6856. return;
  6857. }
  6858. swiper.controller.control = swiper.params.controller.control;
  6859. });
  6860. on('update', () => {
  6861. removeSpline();
  6862. });
  6863. on('resize', () => {
  6864. removeSpline();
  6865. });
  6866. on('observerUpdate', () => {
  6867. removeSpline();
  6868. });
  6869. on('setTranslate', (_s, translate, byController) => {
  6870. if (!swiper.controller.control || swiper.controller.control.destroyed) return;
  6871. swiper.controller.setTranslate(translate, byController);
  6872. });
  6873. on('setTransition', (_s, duration, byController) => {
  6874. if (!swiper.controller.control || swiper.controller.control.destroyed) return;
  6875. swiper.controller.setTransition(duration, byController);
  6876. });
  6877. Object.assign(swiper.controller, {
  6878. setTranslate,
  6879. setTransition
  6880. });
  6881. }
  6882. function A11y(_ref) {
  6883. let {
  6884. swiper,
  6885. extendParams,
  6886. on
  6887. } = _ref;
  6888. extendParams({
  6889. a11y: {
  6890. enabled: true,
  6891. notificationClass: 'swiper-notification',
  6892. prevSlideMessage: 'Previous slide',
  6893. nextSlideMessage: 'Next slide',
  6894. firstSlideMessage: 'This is the first slide',
  6895. lastSlideMessage: 'This is the last slide',
  6896. paginationBulletMessage: 'Go to slide {{index}}',
  6897. slideLabelMessage: '{{index}} / {{slidesLength}}',
  6898. containerMessage: null,
  6899. containerRoleDescriptionMessage: null,
  6900. itemRoleDescriptionMessage: null,
  6901. slideRole: 'group',
  6902. id: null
  6903. }
  6904. });
  6905. swiper.a11y = {
  6906. clicked: false
  6907. };
  6908. let liveRegion = null;
  6909. function notify(message) {
  6910. const notification = liveRegion;
  6911. if (notification.length === 0) return;
  6912. notification.innerHTML = '';
  6913. notification.innerHTML = message;
  6914. }
  6915. const makeElementsArray = el => (Array.isArray(el) ? el : [el]).filter(e => !!e);
  6916. function getRandomNumber(size) {
  6917. if (size === void 0) {
  6918. size = 16;
  6919. }
  6920. const randomChar = () => Math.round(16 * Math.random()).toString(16);
  6921. return 'x'.repeat(size).replace(/x/g, randomChar);
  6922. }
  6923. function makeElFocusable(el) {
  6924. el = makeElementsArray(el);
  6925. el.forEach(subEl => {
  6926. subEl.setAttribute('tabIndex', '0');
  6927. });
  6928. }
  6929. function makeElNotFocusable(el) {
  6930. el = makeElementsArray(el);
  6931. el.forEach(subEl => {
  6932. subEl.setAttribute('tabIndex', '-1');
  6933. });
  6934. }
  6935. function addElRole(el, role) {
  6936. el = makeElementsArray(el);
  6937. el.forEach(subEl => {
  6938. subEl.setAttribute('role', role);
  6939. });
  6940. }
  6941. function addElRoleDescription(el, description) {
  6942. el = makeElementsArray(el);
  6943. el.forEach(subEl => {
  6944. subEl.setAttribute('aria-roledescription', description);
  6945. });
  6946. }
  6947. function addElControls(el, controls) {
  6948. el = makeElementsArray(el);
  6949. el.forEach(subEl => {
  6950. subEl.setAttribute('aria-controls', controls);
  6951. });
  6952. }
  6953. function addElLabel(el, label) {
  6954. el = makeElementsArray(el);
  6955. el.forEach(subEl => {
  6956. subEl.setAttribute('aria-label', label);
  6957. });
  6958. }
  6959. function addElId(el, id) {
  6960. el = makeElementsArray(el);
  6961. el.forEach(subEl => {
  6962. subEl.setAttribute('id', id);
  6963. });
  6964. }
  6965. function addElLive(el, live) {
  6966. el = makeElementsArray(el);
  6967. el.forEach(subEl => {
  6968. subEl.setAttribute('aria-live', live);
  6969. });
  6970. }
  6971. function disableEl(el) {
  6972. el = makeElementsArray(el);
  6973. el.forEach(subEl => {
  6974. subEl.setAttribute('aria-disabled', true);
  6975. });
  6976. }
  6977. function enableEl(el) {
  6978. el = makeElementsArray(el);
  6979. el.forEach(subEl => {
  6980. subEl.setAttribute('aria-disabled', false);
  6981. });
  6982. }
  6983. function onEnterOrSpaceKey(e) {
  6984. if (e.keyCode !== 13 && e.keyCode !== 32) return;
  6985. const params = swiper.params.a11y;
  6986. const targetEl = e.target;
  6987. if (swiper.pagination && swiper.pagination.el && (targetEl === swiper.pagination.el || swiper.pagination.el.contains(e.target))) {
  6988. if (!e.target.matches(classesToSelector(swiper.params.pagination.bulletClass))) return;
  6989. }
  6990. if (swiper.navigation && swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl) {
  6991. if (!(swiper.isEnd && !swiper.params.loop)) {
  6992. swiper.slideNext();
  6993. }
  6994. if (swiper.isEnd) {
  6995. notify(params.lastSlideMessage);
  6996. } else {
  6997. notify(params.nextSlideMessage);
  6998. }
  6999. }
  7000. if (swiper.navigation && swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl) {
  7001. if (!(swiper.isBeginning && !swiper.params.loop)) {
  7002. swiper.slidePrev();
  7003. }
  7004. if (swiper.isBeginning) {
  7005. notify(params.firstSlideMessage);
  7006. } else {
  7007. notify(params.prevSlideMessage);
  7008. }
  7009. }
  7010. if (swiper.pagination && targetEl.matches(classesToSelector(swiper.params.pagination.bulletClass))) {
  7011. targetEl.click();
  7012. }
  7013. }
  7014. function updateNavigation() {
  7015. if (swiper.params.loop || swiper.params.rewind || !swiper.navigation) return;
  7016. const {
  7017. nextEl,
  7018. prevEl
  7019. } = swiper.navigation;
  7020. if (prevEl) {
  7021. if (swiper.isBeginning) {
  7022. disableEl(prevEl);
  7023. makeElNotFocusable(prevEl);
  7024. } else {
  7025. enableEl(prevEl);
  7026. makeElFocusable(prevEl);
  7027. }
  7028. }
  7029. if (nextEl) {
  7030. if (swiper.isEnd) {
  7031. disableEl(nextEl);
  7032. makeElNotFocusable(nextEl);
  7033. } else {
  7034. enableEl(nextEl);
  7035. makeElFocusable(nextEl);
  7036. }
  7037. }
  7038. }
  7039. function hasPagination() {
  7040. return swiper.pagination && swiper.pagination.bullets && swiper.pagination.bullets.length;
  7041. }
  7042. function hasClickablePagination() {
  7043. return hasPagination() && swiper.params.pagination.clickable;
  7044. }
  7045. function updatePagination() {
  7046. const params = swiper.params.a11y;
  7047. if (!hasPagination()) return;
  7048. swiper.pagination.bullets.forEach(bulletEl => {
  7049. if (swiper.params.pagination.clickable) {
  7050. makeElFocusable(bulletEl);
  7051. if (!swiper.params.pagination.renderBullet) {
  7052. addElRole(bulletEl, 'button');
  7053. addElLabel(bulletEl, params.paginationBulletMessage.replace(/\{\{index\}\}/, elementIndex(bulletEl) + 1));
  7054. }
  7055. }
  7056. if (bulletEl.matches(classesToSelector(swiper.params.pagination.bulletActiveClass))) {
  7057. bulletEl.setAttribute('aria-current', 'true');
  7058. } else {
  7059. bulletEl.removeAttribute('aria-current');
  7060. }
  7061. });
  7062. }
  7063. const initNavEl = (el, wrapperId, message) => {
  7064. makeElFocusable(el);
  7065. if (el.tagName !== 'BUTTON') {
  7066. addElRole(el, 'button');
  7067. el.addEventListener('keydown', onEnterOrSpaceKey);
  7068. }
  7069. addElLabel(el, message);
  7070. addElControls(el, wrapperId);
  7071. };
  7072. const handlePointerDown = () => {
  7073. swiper.a11y.clicked = true;
  7074. };
  7075. const handlePointerUp = () => {
  7076. requestAnimationFrame(() => {
  7077. requestAnimationFrame(() => {
  7078. if (!swiper.destroyed) {
  7079. swiper.a11y.clicked = false;
  7080. }
  7081. });
  7082. });
  7083. };
  7084. const handleFocus = e => {
  7085. if (swiper.a11y.clicked) return;
  7086. const slideEl = e.target.closest(`.${swiper.params.slideClass}, swiper-slide`);
  7087. if (!slideEl || !swiper.slides.includes(slideEl)) return;
  7088. const isActive = swiper.slides.indexOf(slideEl) === swiper.activeIndex;
  7089. const isVisible = swiper.params.watchSlidesProgress && swiper.visibleSlides && swiper.visibleSlides.includes(slideEl);
  7090. if (isActive || isVisible) return;
  7091. if (e.sourceCapabilities && e.sourceCapabilities.firesTouchEvents) return;
  7092. if (swiper.isHorizontal()) {
  7093. swiper.el.scrollLeft = 0;
  7094. } else {
  7095. swiper.el.scrollTop = 0;
  7096. }
  7097. swiper.slideTo(swiper.slides.indexOf(slideEl), 0);
  7098. };
  7099. const initSlides = () => {
  7100. const params = swiper.params.a11y;
  7101. if (params.itemRoleDescriptionMessage) {
  7102. addElRoleDescription(swiper.slides, params.itemRoleDescriptionMessage);
  7103. }
  7104. if (params.slideRole) {
  7105. addElRole(swiper.slides, params.slideRole);
  7106. }
  7107. const slidesLength = swiper.slides.length;
  7108. if (params.slideLabelMessage) {
  7109. swiper.slides.forEach((slideEl, index) => {
  7110. const slideIndex = swiper.params.loop ? parseInt(slideEl.getAttribute('data-swiper-slide-index'), 10) : index;
  7111. const ariaLabelMessage = params.slideLabelMessage.replace(/\{\{index\}\}/, slideIndex + 1).replace(/\{\{slidesLength\}\}/, slidesLength);
  7112. addElLabel(slideEl, ariaLabelMessage);
  7113. });
  7114. }
  7115. };
  7116. const init = () => {
  7117. const params = swiper.params.a11y;
  7118. swiper.el.append(liveRegion);
  7119. // Container
  7120. const containerEl = swiper.el;
  7121. if (params.containerRoleDescriptionMessage) {
  7122. addElRoleDescription(containerEl, params.containerRoleDescriptionMessage);
  7123. }
  7124. if (params.containerMessage) {
  7125. addElLabel(containerEl, params.containerMessage);
  7126. }
  7127. // Wrapper
  7128. const wrapperEl = swiper.wrapperEl;
  7129. const wrapperId = params.id || wrapperEl.getAttribute('id') || `swiper-wrapper-${getRandomNumber(16)}`;
  7130. const live = swiper.params.autoplay && swiper.params.autoplay.enabled ? 'off' : 'polite';
  7131. addElId(wrapperEl, wrapperId);
  7132. addElLive(wrapperEl, live);
  7133. // Slide
  7134. initSlides();
  7135. // Navigation
  7136. let {
  7137. nextEl,
  7138. prevEl
  7139. } = swiper.navigation ? swiper.navigation : {};
  7140. nextEl = makeElementsArray(nextEl);
  7141. prevEl = makeElementsArray(prevEl);
  7142. if (nextEl) {
  7143. nextEl.forEach(el => initNavEl(el, wrapperId, params.nextSlideMessage));
  7144. }
  7145. if (prevEl) {
  7146. prevEl.forEach(el => initNavEl(el, wrapperId, params.prevSlideMessage));
  7147. }
  7148. // Pagination
  7149. if (hasClickablePagination()) {
  7150. const paginationEl = makeElementsArray(swiper.pagination.el);
  7151. paginationEl.forEach(el => {
  7152. el.addEventListener('keydown', onEnterOrSpaceKey);
  7153. });
  7154. }
  7155. // Tab focus
  7156. swiper.el.addEventListener('focus', handleFocus, true);
  7157. swiper.el.addEventListener('pointerdown', handlePointerDown, true);
  7158. swiper.el.addEventListener('pointerup', handlePointerUp, true);
  7159. };
  7160. function destroy() {
  7161. if (liveRegion) liveRegion.remove();
  7162. let {
  7163. nextEl,
  7164. prevEl
  7165. } = swiper.navigation ? swiper.navigation : {};
  7166. nextEl = makeElementsArray(nextEl);
  7167. prevEl = makeElementsArray(prevEl);
  7168. if (nextEl) {
  7169. nextEl.forEach(el => el.removeEventListener('keydown', onEnterOrSpaceKey));
  7170. }
  7171. if (prevEl) {
  7172. prevEl.forEach(el => el.removeEventListener('keydown', onEnterOrSpaceKey));
  7173. }
  7174. // Pagination
  7175. if (hasClickablePagination()) {
  7176. const paginationEl = makeElementsArray(swiper.pagination.el);
  7177. paginationEl.forEach(el => {
  7178. el.removeEventListener('keydown', onEnterOrSpaceKey);
  7179. });
  7180. }
  7181. // Tab focus
  7182. swiper.el.removeEventListener('focus', handleFocus, true);
  7183. swiper.el.removeEventListener('pointerdown', handlePointerDown, true);
  7184. swiper.el.removeEventListener('pointerup', handlePointerUp, true);
  7185. }
  7186. on('beforeInit', () => {
  7187. liveRegion = createElement('span', swiper.params.a11y.notificationClass);
  7188. liveRegion.setAttribute('aria-live', 'assertive');
  7189. liveRegion.setAttribute('aria-atomic', 'true');
  7190. });
  7191. on('afterInit', () => {
  7192. if (!swiper.params.a11y.enabled) return;
  7193. init();
  7194. });
  7195. on('slidesLengthChange snapGridLengthChange slidesGridLengthChange', () => {
  7196. if (!swiper.params.a11y.enabled) return;
  7197. initSlides();
  7198. });
  7199. on('fromEdge toEdge afterInit lock unlock', () => {
  7200. if (!swiper.params.a11y.enabled) return;
  7201. updateNavigation();
  7202. });
  7203. on('paginationUpdate', () => {
  7204. if (!swiper.params.a11y.enabled) return;
  7205. updatePagination();
  7206. });
  7207. on('destroy', () => {
  7208. if (!swiper.params.a11y.enabled) return;
  7209. destroy();
  7210. });
  7211. }
  7212. function History(_ref) {
  7213. let {
  7214. swiper,
  7215. extendParams,
  7216. on
  7217. } = _ref;
  7218. extendParams({
  7219. history: {
  7220. enabled: false,
  7221. root: '',
  7222. replaceState: false,
  7223. key: 'slides',
  7224. keepQuery: false
  7225. }
  7226. });
  7227. let initialized = false;
  7228. let paths = {};
  7229. const slugify = text => {
  7230. return text.toString().replace(/\s+/g, '-').replace(/[^\w-]+/g, '').replace(/--+/g, '-').replace(/^-+/, '').replace(/-+$/, '');
  7231. };
  7232. const getPathValues = urlOverride => {
  7233. const window = getWindow();
  7234. let location;
  7235. if (urlOverride) {
  7236. location = new URL(urlOverride);
  7237. } else {
  7238. location = window.location;
  7239. }
  7240. const pathArray = location.pathname.slice(1).split('/').filter(part => part !== '');
  7241. const total = pathArray.length;
  7242. const key = pathArray[total - 2];
  7243. const value = pathArray[total - 1];
  7244. return {
  7245. key,
  7246. value
  7247. };
  7248. };
  7249. const setHistory = (key, index) => {
  7250. const window = getWindow();
  7251. if (!initialized || !swiper.params.history.enabled) return;
  7252. let location;
  7253. if (swiper.params.url) {
  7254. location = new URL(swiper.params.url);
  7255. } else {
  7256. location = window.location;
  7257. }
  7258. const slide = swiper.slides[index];
  7259. let value = slugify(slide.getAttribute('data-history'));
  7260. if (swiper.params.history.root.length > 0) {
  7261. let root = swiper.params.history.root;
  7262. if (root[root.length - 1] === '/') root = root.slice(0, root.length - 1);
  7263. value = `${root}/${key ? `${key}/` : ''}${value}`;
  7264. } else if (!location.pathname.includes(key)) {
  7265. value = `${key ? `${key}/` : ''}${value}`;
  7266. }
  7267. if (swiper.params.history.keepQuery) {
  7268. value += location.search;
  7269. }
  7270. const currentState = window.history.state;
  7271. if (currentState && currentState.value === value) {
  7272. return;
  7273. }
  7274. if (swiper.params.history.replaceState) {
  7275. window.history.replaceState({
  7276. value
  7277. }, null, value);
  7278. } else {
  7279. window.history.pushState({
  7280. value
  7281. }, null, value);
  7282. }
  7283. };
  7284. const scrollToSlide = (speed, value, runCallbacks) => {
  7285. if (value) {
  7286. for (let i = 0, length = swiper.slides.length; i < length; i += 1) {
  7287. const slide = swiper.slides[i];
  7288. const slideHistory = slugify(slide.getAttribute('data-history'));
  7289. if (slideHistory === value) {
  7290. const index = swiper.getSlideIndex(slide);
  7291. swiper.slideTo(index, speed, runCallbacks);
  7292. }
  7293. }
  7294. } else {
  7295. swiper.slideTo(0, speed, runCallbacks);
  7296. }
  7297. };
  7298. const setHistoryPopState = () => {
  7299. paths = getPathValues(swiper.params.url);
  7300. scrollToSlide(swiper.params.speed, paths.value, false);
  7301. };
  7302. const init = () => {
  7303. const window = getWindow();
  7304. if (!swiper.params.history) return;
  7305. if (!window.history || !window.history.pushState) {
  7306. swiper.params.history.enabled = false;
  7307. swiper.params.hashNavigation.enabled = true;
  7308. return;
  7309. }
  7310. initialized = true;
  7311. paths = getPathValues(swiper.params.url);
  7312. if (!paths.key && !paths.value) {
  7313. if (!swiper.params.history.replaceState) {
  7314. window.addEventListener('popstate', setHistoryPopState);
  7315. }
  7316. return;
  7317. }
  7318. scrollToSlide(0, paths.value, swiper.params.runCallbacksOnInit);
  7319. if (!swiper.params.history.replaceState) {
  7320. window.addEventListener('popstate', setHistoryPopState);
  7321. }
  7322. };
  7323. const destroy = () => {
  7324. const window = getWindow();
  7325. if (!swiper.params.history.replaceState) {
  7326. window.removeEventListener('popstate', setHistoryPopState);
  7327. }
  7328. };
  7329. on('init', () => {
  7330. if (swiper.params.history.enabled) {
  7331. init();
  7332. }
  7333. });
  7334. on('destroy', () => {
  7335. if (swiper.params.history.enabled) {
  7336. destroy();
  7337. }
  7338. });
  7339. on('transitionEnd _freeModeNoMomentumRelease', () => {
  7340. if (initialized) {
  7341. setHistory(swiper.params.history.key, swiper.activeIndex);
  7342. }
  7343. });
  7344. on('slideChange', () => {
  7345. if (initialized && swiper.params.cssMode) {
  7346. setHistory(swiper.params.history.key, swiper.activeIndex);
  7347. }
  7348. });
  7349. }
  7350. function HashNavigation(_ref) {
  7351. let {
  7352. swiper,
  7353. extendParams,
  7354. emit,
  7355. on
  7356. } = _ref;
  7357. let initialized = false;
  7358. const document = getDocument();
  7359. const window = getWindow();
  7360. extendParams({
  7361. hashNavigation: {
  7362. enabled: false,
  7363. replaceState: false,
  7364. watchState: false,
  7365. getSlideIndex(_s, hash) {
  7366. if (swiper.virtual && swiper.params.virtual.enabled) {
  7367. const slideWithHash = swiper.slides.filter(slideEl => slideEl.getAttribute('data-hash') === hash)[0];
  7368. if (!slideWithHash) return 0;
  7369. const index = parseInt(slideWithHash.getAttribute('data-swiper-slide-index'), 10);
  7370. return index;
  7371. }
  7372. return swiper.getSlideIndex(elementChildren(swiper.slidesEl, `.${swiper.params.slideClass}[data-hash="${hash}"], swiper-slide[data-hash="${hash}"]`)[0]);
  7373. }
  7374. }
  7375. });
  7376. const onHashChange = () => {
  7377. emit('hashChange');
  7378. const newHash = document.location.hash.replace('#', '');
  7379. const activeSlideEl = swiper.virtual && swiper.params.virtual.enabled ? swiper.slidesEl.querySelector(`[data-swiper-slide-index="${swiper.activeIndex}"]`) : swiper.slides[swiper.activeIndex];
  7380. const activeSlideHash = activeSlideEl ? activeSlideEl.getAttribute('data-hash') : '';
  7381. if (newHash !== activeSlideHash) {
  7382. const newIndex = swiper.params.hashNavigation.getSlideIndex(swiper, newHash);
  7383. if (typeof newIndex === 'undefined' || Number.isNaN(newIndex)) return;
  7384. swiper.slideTo(newIndex);
  7385. }
  7386. };
  7387. const setHash = () => {
  7388. if (!initialized || !swiper.params.hashNavigation.enabled) return;
  7389. const activeSlideEl = swiper.virtual && swiper.params.virtual.enabled ? swiper.slidesEl.querySelector(`[data-swiper-slide-index="${swiper.activeIndex}"]`) : swiper.slides[swiper.activeIndex];
  7390. const activeSlideHash = activeSlideEl ? activeSlideEl.getAttribute('data-hash') || activeSlideEl.getAttribute('data-history') : '';
  7391. if (swiper.params.hashNavigation.replaceState && window.history && window.history.replaceState) {
  7392. window.history.replaceState(null, null, `#${activeSlideHash}` || '');
  7393. emit('hashSet');
  7394. } else {
  7395. document.location.hash = activeSlideHash || '';
  7396. emit('hashSet');
  7397. }
  7398. };
  7399. const init = () => {
  7400. if (!swiper.params.hashNavigation.enabled || swiper.params.history && swiper.params.history.enabled) return;
  7401. initialized = true;
  7402. const hash = document.location.hash.replace('#', '');
  7403. if (hash) {
  7404. const speed = 0;
  7405. const index = swiper.params.hashNavigation.getSlideIndex(swiper, hash);
  7406. swiper.slideTo(index || 0, speed, swiper.params.runCallbacksOnInit, true);
  7407. }
  7408. if (swiper.params.hashNavigation.watchState) {
  7409. window.addEventListener('hashchange', onHashChange);
  7410. }
  7411. };
  7412. const destroy = () => {
  7413. if (swiper.params.hashNavigation.watchState) {
  7414. window.removeEventListener('hashchange', onHashChange);
  7415. }
  7416. };
  7417. on('init', () => {
  7418. if (swiper.params.hashNavigation.enabled) {
  7419. init();
  7420. }
  7421. });
  7422. on('destroy', () => {
  7423. if (swiper.params.hashNavigation.enabled) {
  7424. destroy();
  7425. }
  7426. });
  7427. on('transitionEnd _freeModeNoMomentumRelease', () => {
  7428. if (initialized) {
  7429. setHash();
  7430. }
  7431. });
  7432. on('slideChange', () => {
  7433. if (initialized && swiper.params.cssMode) {
  7434. setHash();
  7435. }
  7436. });
  7437. }
  7438. /* eslint no-underscore-dangle: "off" */
  7439. /* eslint no-use-before-define: "off" */
  7440. function Autoplay(_ref) {
  7441. let {
  7442. swiper,
  7443. extendParams,
  7444. on,
  7445. emit,
  7446. params
  7447. } = _ref;
  7448. swiper.autoplay = {
  7449. running: false,
  7450. paused: false,
  7451. timeLeft: 0
  7452. };
  7453. extendParams({
  7454. autoplay: {
  7455. enabled: false,
  7456. delay: 3000,
  7457. waitForTransition: true,
  7458. disableOnInteraction: false,
  7459. stopOnLastSlide: false,
  7460. reverseDirection: false,
  7461. pauseOnMouseEnter: false
  7462. }
  7463. });
  7464. let timeout;
  7465. let raf;
  7466. let autoplayDelayTotal = params && params.autoplay ? params.autoplay.delay : 3000;
  7467. let autoplayDelayCurrent = params && params.autoplay ? params.autoplay.delay : 3000;
  7468. let autoplayTimeLeft;
  7469. let autoplayStartTime = new Date().getTime();
  7470. let wasPaused;
  7471. let isTouched;
  7472. let pausedByTouch;
  7473. let touchStartTimeout;
  7474. let slideChanged;
  7475. let pausedByInteraction;
  7476. let pausedByPointerEnter;
  7477. function onTransitionEnd(e) {
  7478. if (!swiper || swiper.destroyed || !swiper.wrapperEl) return;
  7479. if (e.target !== swiper.wrapperEl) return;
  7480. swiper.wrapperEl.removeEventListener('transitionend', onTransitionEnd);
  7481. if (pausedByPointerEnter) {
  7482. return;
  7483. }
  7484. resume();
  7485. }
  7486. const calcTimeLeft = () => {
  7487. if (swiper.destroyed || !swiper.autoplay.running) return;
  7488. if (swiper.autoplay.paused) {
  7489. wasPaused = true;
  7490. } else if (wasPaused) {
  7491. autoplayDelayCurrent = autoplayTimeLeft;
  7492. wasPaused = false;
  7493. }
  7494. const timeLeft = swiper.autoplay.paused ? autoplayTimeLeft : autoplayStartTime + autoplayDelayCurrent - new Date().getTime();
  7495. swiper.autoplay.timeLeft = timeLeft;
  7496. emit('autoplayTimeLeft', timeLeft, timeLeft / autoplayDelayTotal);
  7497. raf = requestAnimationFrame(() => {
  7498. calcTimeLeft();
  7499. });
  7500. };
  7501. const getSlideDelay = () => {
  7502. let activeSlideEl;
  7503. if (swiper.virtual && swiper.params.virtual.enabled) {
  7504. activeSlideEl = swiper.slides.filter(slideEl => slideEl.classList.contains('swiper-slide-active'))[0];
  7505. } else {
  7506. activeSlideEl = swiper.slides[swiper.activeIndex];
  7507. }
  7508. if (!activeSlideEl) return undefined;
  7509. const currentSlideDelay = parseInt(activeSlideEl.getAttribute('data-swiper-autoplay'), 10);
  7510. return currentSlideDelay;
  7511. };
  7512. const run = delayForce => {
  7513. if (swiper.destroyed || !swiper.autoplay.running) return;
  7514. cancelAnimationFrame(raf);
  7515. calcTimeLeft();
  7516. let delay = typeof delayForce === 'undefined' ? swiper.params.autoplay.delay : delayForce;
  7517. autoplayDelayTotal = swiper.params.autoplay.delay;
  7518. autoplayDelayCurrent = swiper.params.autoplay.delay;
  7519. const currentSlideDelay = getSlideDelay();
  7520. if (!Number.isNaN(currentSlideDelay) && currentSlideDelay > 0 && typeof delayForce === 'undefined') {
  7521. delay = currentSlideDelay;
  7522. autoplayDelayTotal = currentSlideDelay;
  7523. autoplayDelayCurrent = currentSlideDelay;
  7524. }
  7525. autoplayTimeLeft = delay;
  7526. const speed = swiper.params.speed;
  7527. const proceed = () => {
  7528. if (!swiper || swiper.destroyed) return;
  7529. if (swiper.params.autoplay.reverseDirection) {
  7530. if (!swiper.isBeginning || swiper.params.loop || swiper.params.rewind) {
  7531. swiper.slidePrev(speed, true, true);
  7532. emit('autoplay');
  7533. } else if (!swiper.params.autoplay.stopOnLastSlide) {
  7534. swiper.slideTo(swiper.slides.length - 1, speed, true, true);
  7535. emit('autoplay');
  7536. }
  7537. } else {
  7538. if (!swiper.isEnd || swiper.params.loop || swiper.params.rewind) {
  7539. swiper.slideNext(speed, true, true);
  7540. emit('autoplay');
  7541. } else if (!swiper.params.autoplay.stopOnLastSlide) {
  7542. swiper.slideTo(0, speed, true, true);
  7543. emit('autoplay');
  7544. }
  7545. }
  7546. if (swiper.params.cssMode) {
  7547. autoplayStartTime = new Date().getTime();
  7548. requestAnimationFrame(() => {
  7549. run();
  7550. });
  7551. }
  7552. };
  7553. if (delay > 0) {
  7554. clearTimeout(timeout);
  7555. timeout = setTimeout(() => {
  7556. proceed();
  7557. }, delay);
  7558. } else {
  7559. requestAnimationFrame(() => {
  7560. proceed();
  7561. });
  7562. }
  7563. // eslint-disable-next-line
  7564. return delay;
  7565. };
  7566. const start = () => {
  7567. autoplayStartTime = new Date().getTime();
  7568. swiper.autoplay.running = true;
  7569. run();
  7570. emit('autoplayStart');
  7571. };
  7572. const stop = () => {
  7573. swiper.autoplay.running = false;
  7574. clearTimeout(timeout);
  7575. cancelAnimationFrame(raf);
  7576. emit('autoplayStop');
  7577. };
  7578. const pause = (internal, reset) => {
  7579. if (swiper.destroyed || !swiper.autoplay.running) return;
  7580. clearTimeout(timeout);
  7581. if (!internal) {
  7582. pausedByInteraction = true;
  7583. }
  7584. const proceed = () => {
  7585. emit('autoplayPause');
  7586. if (swiper.params.autoplay.waitForTransition) {
  7587. swiper.wrapperEl.addEventListener('transitionend', onTransitionEnd);
  7588. } else {
  7589. resume();
  7590. }
  7591. };
  7592. swiper.autoplay.paused = true;
  7593. if (reset) {
  7594. if (slideChanged) {
  7595. autoplayTimeLeft = swiper.params.autoplay.delay;
  7596. }
  7597. slideChanged = false;
  7598. proceed();
  7599. return;
  7600. }
  7601. const delay = autoplayTimeLeft || swiper.params.autoplay.delay;
  7602. autoplayTimeLeft = delay - (new Date().getTime() - autoplayStartTime);
  7603. if (swiper.isEnd && autoplayTimeLeft < 0 && !swiper.params.loop) return;
  7604. if (autoplayTimeLeft < 0) autoplayTimeLeft = 0;
  7605. proceed();
  7606. };
  7607. const resume = () => {
  7608. if (swiper.isEnd && autoplayTimeLeft < 0 && !swiper.params.loop || swiper.destroyed || !swiper.autoplay.running) return;
  7609. autoplayStartTime = new Date().getTime();
  7610. if (pausedByInteraction) {
  7611. pausedByInteraction = false;
  7612. run(autoplayTimeLeft);
  7613. } else {
  7614. run();
  7615. }
  7616. swiper.autoplay.paused = false;
  7617. emit('autoplayResume');
  7618. };
  7619. const onVisibilityChange = () => {
  7620. if (swiper.destroyed || !swiper.autoplay.running) return;
  7621. const document = getDocument();
  7622. if (document.visibilityState === 'hidden') {
  7623. pausedByInteraction = true;
  7624. pause(true);
  7625. }
  7626. if (document.visibilityState === 'visible') {
  7627. resume();
  7628. }
  7629. };
  7630. const onPointerEnter = e => {
  7631. if (e.pointerType !== 'mouse') return;
  7632. pausedByInteraction = true;
  7633. pausedByPointerEnter = true;
  7634. if (swiper.animating || swiper.autoplay.paused) return;
  7635. pause(true);
  7636. };
  7637. const onPointerLeave = e => {
  7638. if (e.pointerType !== 'mouse') return;
  7639. pausedByPointerEnter = false;
  7640. if (swiper.autoplay.paused) {
  7641. resume();
  7642. }
  7643. };
  7644. const attachMouseEvents = () => {
  7645. if (swiper.params.autoplay.pauseOnMouseEnter) {
  7646. swiper.el.addEventListener('pointerenter', onPointerEnter);
  7647. swiper.el.addEventListener('pointerleave', onPointerLeave);
  7648. }
  7649. };
  7650. const detachMouseEvents = () => {
  7651. swiper.el.removeEventListener('pointerenter', onPointerEnter);
  7652. swiper.el.removeEventListener('pointerleave', onPointerLeave);
  7653. };
  7654. const attachDocumentEvents = () => {
  7655. const document = getDocument();
  7656. document.addEventListener('visibilitychange', onVisibilityChange);
  7657. };
  7658. const detachDocumentEvents = () => {
  7659. const document = getDocument();
  7660. document.removeEventListener('visibilitychange', onVisibilityChange);
  7661. };
  7662. on('init', () => {
  7663. if (swiper.params.autoplay.enabled) {
  7664. attachMouseEvents();
  7665. attachDocumentEvents();
  7666. start();
  7667. }
  7668. });
  7669. on('destroy', () => {
  7670. detachMouseEvents();
  7671. detachDocumentEvents();
  7672. if (swiper.autoplay.running) {
  7673. stop();
  7674. }
  7675. });
  7676. on('_freeModeStaticRelease', () => {
  7677. if (pausedByTouch || pausedByInteraction) {
  7678. resume();
  7679. }
  7680. });
  7681. on('_freeModeNoMomentumRelease', () => {
  7682. if (!swiper.params.autoplay.disableOnInteraction) {
  7683. pause(true, true);
  7684. } else {
  7685. stop();
  7686. }
  7687. });
  7688. on('beforeTransitionStart', (_s, speed, internal) => {
  7689. if (swiper.destroyed || !swiper.autoplay.running) return;
  7690. if (internal || !swiper.params.autoplay.disableOnInteraction) {
  7691. pause(true, true);
  7692. } else {
  7693. stop();
  7694. }
  7695. });
  7696. on('sliderFirstMove', () => {
  7697. if (swiper.destroyed || !swiper.autoplay.running) return;
  7698. if (swiper.params.autoplay.disableOnInteraction) {
  7699. stop();
  7700. return;
  7701. }
  7702. isTouched = true;
  7703. pausedByTouch = false;
  7704. pausedByInteraction = false;
  7705. touchStartTimeout = setTimeout(() => {
  7706. pausedByInteraction = true;
  7707. pausedByTouch = true;
  7708. pause(true);
  7709. }, 200);
  7710. });
  7711. on('touchEnd', () => {
  7712. if (swiper.destroyed || !swiper.autoplay.running || !isTouched) return;
  7713. clearTimeout(touchStartTimeout);
  7714. clearTimeout(timeout);
  7715. if (swiper.params.autoplay.disableOnInteraction) {
  7716. pausedByTouch = false;
  7717. isTouched = false;
  7718. return;
  7719. }
  7720. if (pausedByTouch && swiper.params.cssMode) resume();
  7721. pausedByTouch = false;
  7722. isTouched = false;
  7723. });
  7724. on('slideChange', () => {
  7725. if (swiper.destroyed || !swiper.autoplay.running) return;
  7726. slideChanged = true;
  7727. });
  7728. Object.assign(swiper.autoplay, {
  7729. start,
  7730. stop,
  7731. pause,
  7732. resume
  7733. });
  7734. }
  7735. function Thumb(_ref) {
  7736. let {
  7737. swiper,
  7738. extendParams,
  7739. on
  7740. } = _ref;
  7741. extendParams({
  7742. thumbs: {
  7743. swiper: null,
  7744. multipleActiveThumbs: true,
  7745. autoScrollOffset: 0,
  7746. slideThumbActiveClass: 'swiper-slide-thumb-active',
  7747. thumbsContainerClass: 'swiper-thumbs'
  7748. }
  7749. });
  7750. let initialized = false;
  7751. let swiperCreated = false;
  7752. swiper.thumbs = {
  7753. swiper: null
  7754. };
  7755. function onThumbClick() {
  7756. const thumbsSwiper = swiper.thumbs.swiper;
  7757. if (!thumbsSwiper || thumbsSwiper.destroyed) return;
  7758. const clickedIndex = thumbsSwiper.clickedIndex;
  7759. const clickedSlide = thumbsSwiper.clickedSlide;
  7760. if (clickedSlide && clickedSlide.classList.contains(swiper.params.thumbs.slideThumbActiveClass)) return;
  7761. if (typeof clickedIndex === 'undefined' || clickedIndex === null) return;
  7762. let slideToIndex;
  7763. if (thumbsSwiper.params.loop) {
  7764. slideToIndex = parseInt(thumbsSwiper.clickedSlide.getAttribute('data-swiper-slide-index'), 10);
  7765. } else {
  7766. slideToIndex = clickedIndex;
  7767. }
  7768. if (swiper.params.loop) {
  7769. swiper.slideToLoop(slideToIndex);
  7770. } else {
  7771. swiper.slideTo(slideToIndex);
  7772. }
  7773. }
  7774. function init() {
  7775. const {
  7776. thumbs: thumbsParams
  7777. } = swiper.params;
  7778. if (initialized) return false;
  7779. initialized = true;
  7780. const SwiperClass = swiper.constructor;
  7781. if (thumbsParams.swiper instanceof SwiperClass) {
  7782. swiper.thumbs.swiper = thumbsParams.swiper;
  7783. Object.assign(swiper.thumbs.swiper.originalParams, {
  7784. watchSlidesProgress: true,
  7785. slideToClickedSlide: false
  7786. });
  7787. Object.assign(swiper.thumbs.swiper.params, {
  7788. watchSlidesProgress: true,
  7789. slideToClickedSlide: false
  7790. });
  7791. swiper.thumbs.swiper.update();
  7792. } else if (isObject(thumbsParams.swiper)) {
  7793. const thumbsSwiperParams = Object.assign({}, thumbsParams.swiper);
  7794. Object.assign(thumbsSwiperParams, {
  7795. watchSlidesProgress: true,
  7796. slideToClickedSlide: false
  7797. });
  7798. swiper.thumbs.swiper = new SwiperClass(thumbsSwiperParams);
  7799. swiperCreated = true;
  7800. }
  7801. swiper.thumbs.swiper.el.classList.add(swiper.params.thumbs.thumbsContainerClass);
  7802. swiper.thumbs.swiper.on('tap', onThumbClick);
  7803. return true;
  7804. }
  7805. function update(initial) {
  7806. const thumbsSwiper = swiper.thumbs.swiper;
  7807. if (!thumbsSwiper || thumbsSwiper.destroyed) return;
  7808. const slidesPerView = thumbsSwiper.params.slidesPerView === 'auto' ? thumbsSwiper.slidesPerViewDynamic() : thumbsSwiper.params.slidesPerView;
  7809. // Activate thumbs
  7810. let thumbsToActivate = 1;
  7811. const thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass;
  7812. if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) {
  7813. thumbsToActivate = swiper.params.slidesPerView;
  7814. }
  7815. if (!swiper.params.thumbs.multipleActiveThumbs) {
  7816. thumbsToActivate = 1;
  7817. }
  7818. thumbsToActivate = Math.floor(thumbsToActivate);
  7819. thumbsSwiper.slides.forEach(slideEl => slideEl.classList.remove(thumbActiveClass));
  7820. if (thumbsSwiper.params.loop || thumbsSwiper.params.virtual && thumbsSwiper.params.virtual.enabled) {
  7821. for (let i = 0; i < thumbsToActivate; i += 1) {
  7822. elementChildren(thumbsSwiper.slidesEl, `[data-swiper-slide-index="${swiper.realIndex + i}"]`).forEach(slideEl => {
  7823. slideEl.classList.add(thumbActiveClass);
  7824. });
  7825. }
  7826. } else {
  7827. for (let i = 0; i < thumbsToActivate; i += 1) {
  7828. if (thumbsSwiper.slides[swiper.realIndex + i]) {
  7829. thumbsSwiper.slides[swiper.realIndex + i].classList.add(thumbActiveClass);
  7830. }
  7831. }
  7832. }
  7833. const autoScrollOffset = swiper.params.thumbs.autoScrollOffset;
  7834. const useOffset = autoScrollOffset && !thumbsSwiper.params.loop;
  7835. if (swiper.realIndex !== thumbsSwiper.realIndex || useOffset) {
  7836. const currentThumbsIndex = thumbsSwiper.activeIndex;
  7837. let newThumbsIndex;
  7838. let direction;
  7839. if (thumbsSwiper.params.loop) {
  7840. const newThumbsSlide = thumbsSwiper.slides.filter(slideEl => slideEl.getAttribute('data-swiper-slide-index') === `${swiper.realIndex}`)[0];
  7841. newThumbsIndex = thumbsSwiper.slides.indexOf(newThumbsSlide);
  7842. direction = swiper.activeIndex > swiper.previousIndex ? 'next' : 'prev';
  7843. } else {
  7844. newThumbsIndex = swiper.realIndex;
  7845. direction = newThumbsIndex > swiper.previousIndex ? 'next' : 'prev';
  7846. }
  7847. if (useOffset) {
  7848. newThumbsIndex += direction === 'next' ? autoScrollOffset : -1 * autoScrollOffset;
  7849. }
  7850. if (thumbsSwiper.visibleSlidesIndexes && thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0) {
  7851. if (thumbsSwiper.params.centeredSlides) {
  7852. if (newThumbsIndex > currentThumbsIndex) {
  7853. newThumbsIndex = newThumbsIndex - Math.floor(slidesPerView / 2) + 1;
  7854. } else {
  7855. newThumbsIndex = newThumbsIndex + Math.floor(slidesPerView / 2) - 1;
  7856. }
  7857. } else if (newThumbsIndex > currentThumbsIndex && thumbsSwiper.params.slidesPerGroup === 1) ;
  7858. thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined);
  7859. }
  7860. }
  7861. }
  7862. on('beforeInit', () => {
  7863. const {
  7864. thumbs
  7865. } = swiper.params;
  7866. if (!thumbs || !thumbs.swiper) return;
  7867. if (typeof thumbs.swiper === 'string' || thumbs.swiper instanceof HTMLElement) {
  7868. const document = getDocument();
  7869. const getThumbsElementAndInit = () => {
  7870. const thumbsElement = typeof thumbs.swiper === 'string' ? document.querySelector(thumbs.swiper) : thumbs.swiper;
  7871. if (thumbsElement && thumbsElement.swiper) {
  7872. thumbs.swiper = thumbsElement.swiper;
  7873. init();
  7874. update(true);
  7875. } else if (thumbsElement) {
  7876. const onThumbsSwiper = e => {
  7877. thumbs.swiper = e.detail[0];
  7878. thumbsElement.removeEventListener('init', onThumbsSwiper);
  7879. init();
  7880. update(true);
  7881. thumbs.swiper.update();
  7882. swiper.update();
  7883. };
  7884. thumbsElement.addEventListener('init', onThumbsSwiper);
  7885. }
  7886. return thumbsElement;
  7887. };
  7888. const watchForThumbsToAppear = () => {
  7889. if (swiper.destroyed) return;
  7890. const thumbsElement = getThumbsElementAndInit();
  7891. if (!thumbsElement) {
  7892. requestAnimationFrame(watchForThumbsToAppear);
  7893. }
  7894. };
  7895. requestAnimationFrame(watchForThumbsToAppear);
  7896. } else {
  7897. init();
  7898. update(true);
  7899. }
  7900. });
  7901. on('slideChange update resize observerUpdate', () => {
  7902. update();
  7903. });
  7904. on('setTransition', (_s, duration) => {
  7905. const thumbsSwiper = swiper.thumbs.swiper;
  7906. if (!thumbsSwiper || thumbsSwiper.destroyed) return;
  7907. thumbsSwiper.setTransition(duration);
  7908. });
  7909. on('beforeDestroy', () => {
  7910. const thumbsSwiper = swiper.thumbs.swiper;
  7911. if (!thumbsSwiper || thumbsSwiper.destroyed) return;
  7912. if (swiperCreated) {
  7913. thumbsSwiper.destroy();
  7914. }
  7915. });
  7916. Object.assign(swiper.thumbs, {
  7917. init,
  7918. update
  7919. });
  7920. }
  7921. function freeMode(_ref) {
  7922. let {
  7923. swiper,
  7924. extendParams,
  7925. emit,
  7926. once
  7927. } = _ref;
  7928. extendParams({
  7929. freeMode: {
  7930. enabled: false,
  7931. momentum: true,
  7932. momentumRatio: 1,
  7933. momentumBounce: true,
  7934. momentumBounceRatio: 1,
  7935. momentumVelocityRatio: 1,
  7936. sticky: false,
  7937. minimumVelocity: 0.02
  7938. }
  7939. });
  7940. function onTouchStart() {
  7941. if (swiper.params.cssMode) return;
  7942. const translate = swiper.getTranslate();
  7943. swiper.setTranslate(translate);
  7944. swiper.setTransition(0);
  7945. swiper.touchEventsData.velocities.length = 0;
  7946. swiper.freeMode.onTouchEnd({
  7947. currentPos: swiper.rtl ? swiper.translate : -swiper.translate
  7948. });
  7949. }
  7950. function onTouchMove() {
  7951. if (swiper.params.cssMode) return;
  7952. const {
  7953. touchEventsData: data,
  7954. touches
  7955. } = swiper;
  7956. // Velocity
  7957. if (data.velocities.length === 0) {
  7958. data.velocities.push({
  7959. position: touches[swiper.isHorizontal() ? 'startX' : 'startY'],
  7960. time: data.touchStartTime
  7961. });
  7962. }
  7963. data.velocities.push({
  7964. position: touches[swiper.isHorizontal() ? 'currentX' : 'currentY'],
  7965. time: now()
  7966. });
  7967. }
  7968. function onTouchEnd(_ref2) {
  7969. let {
  7970. currentPos
  7971. } = _ref2;
  7972. if (swiper.params.cssMode) return;
  7973. const {
  7974. params,
  7975. wrapperEl,
  7976. rtlTranslate: rtl,
  7977. snapGrid,
  7978. touchEventsData: data
  7979. } = swiper;
  7980. // Time diff
  7981. const touchEndTime = now();
  7982. const timeDiff = touchEndTime - data.touchStartTime;
  7983. if (currentPos < -swiper.minTranslate()) {
  7984. swiper.slideTo(swiper.activeIndex);
  7985. return;
  7986. }
  7987. if (currentPos > -swiper.maxTranslate()) {
  7988. if (swiper.slides.length < snapGrid.length) {
  7989. swiper.slideTo(snapGrid.length - 1);
  7990. } else {
  7991. swiper.slideTo(swiper.slides.length - 1);
  7992. }
  7993. return;
  7994. }
  7995. if (params.freeMode.momentum) {
  7996. if (data.velocities.length > 1) {
  7997. const lastMoveEvent = data.velocities.pop();
  7998. const velocityEvent = data.velocities.pop();
  7999. const distance = lastMoveEvent.position - velocityEvent.position;
  8000. const time = lastMoveEvent.time - velocityEvent.time;
  8001. swiper.velocity = distance / time;
  8002. swiper.velocity /= 2;
  8003. if (Math.abs(swiper.velocity) < params.freeMode.minimumVelocity) {
  8004. swiper.velocity = 0;
  8005. }
  8006. // this implies that the user stopped moving a finger then released.
  8007. // There would be no events with distance zero, so the last event is stale.
  8008. if (time > 150 || now() - lastMoveEvent.time > 300) {
  8009. swiper.velocity = 0;
  8010. }
  8011. } else {
  8012. swiper.velocity = 0;
  8013. }
  8014. swiper.velocity *= params.freeMode.momentumVelocityRatio;
  8015. data.velocities.length = 0;
  8016. let momentumDuration = 1000 * params.freeMode.momentumRatio;
  8017. const momentumDistance = swiper.velocity * momentumDuration;
  8018. let newPosition = swiper.translate + momentumDistance;
  8019. if (rtl) newPosition = -newPosition;
  8020. let doBounce = false;
  8021. let afterBouncePosition;
  8022. const bounceAmount = Math.abs(swiper.velocity) * 20 * params.freeMode.momentumBounceRatio;
  8023. let needsLoopFix;
  8024. if (newPosition < swiper.maxTranslate()) {
  8025. if (params.freeMode.momentumBounce) {
  8026. if (newPosition + swiper.maxTranslate() < -bounceAmount) {
  8027. newPosition = swiper.maxTranslate() - bounceAmount;
  8028. }
  8029. afterBouncePosition = swiper.maxTranslate();
  8030. doBounce = true;
  8031. data.allowMomentumBounce = true;
  8032. } else {
  8033. newPosition = swiper.maxTranslate();
  8034. }
  8035. if (params.loop && params.centeredSlides) needsLoopFix = true;
  8036. } else if (newPosition > swiper.minTranslate()) {
  8037. if (params.freeMode.momentumBounce) {
  8038. if (newPosition - swiper.minTranslate() > bounceAmount) {
  8039. newPosition = swiper.minTranslate() + bounceAmount;
  8040. }
  8041. afterBouncePosition = swiper.minTranslate();
  8042. doBounce = true;
  8043. data.allowMomentumBounce = true;
  8044. } else {
  8045. newPosition = swiper.minTranslate();
  8046. }
  8047. if (params.loop && params.centeredSlides) needsLoopFix = true;
  8048. } else if (params.freeMode.sticky) {
  8049. let nextSlide;
  8050. for (let j = 0; j < snapGrid.length; j += 1) {
  8051. if (snapGrid[j] > -newPosition) {
  8052. nextSlide = j;
  8053. break;
  8054. }
  8055. }
  8056. if (Math.abs(snapGrid[nextSlide] - newPosition) < Math.abs(snapGrid[nextSlide - 1] - newPosition) || swiper.swipeDirection === 'next') {
  8057. newPosition = snapGrid[nextSlide];
  8058. } else {
  8059. newPosition = snapGrid[nextSlide - 1];
  8060. }
  8061. newPosition = -newPosition;
  8062. }
  8063. if (needsLoopFix) {
  8064. once('transitionEnd', () => {
  8065. swiper.loopFix();
  8066. });
  8067. }
  8068. // Fix duration
  8069. if (swiper.velocity !== 0) {
  8070. if (rtl) {
  8071. momentumDuration = Math.abs((-newPosition - swiper.translate) / swiper.velocity);
  8072. } else {
  8073. momentumDuration = Math.abs((newPosition - swiper.translate) / swiper.velocity);
  8074. }
  8075. if (params.freeMode.sticky) {
  8076. // If freeMode.sticky is active and the user ends a swipe with a slow-velocity
  8077. // event, then durations can be 20+ seconds to slide one (or zero!) slides.
  8078. // It's easy to see this when simulating touch with mouse events. To fix this,
  8079. // limit single-slide swipes to the default slide duration. This also has the
  8080. // nice side effect of matching slide speed if the user stopped moving before
  8081. // lifting finger or mouse vs. moving slowly before lifting the finger/mouse.
  8082. // For faster swipes, also apply limits (albeit higher ones).
  8083. const moveDistance = Math.abs((rtl ? -newPosition : newPosition) - swiper.translate);
  8084. const currentSlideSize = swiper.slidesSizesGrid[swiper.activeIndex];
  8085. if (moveDistance < currentSlideSize) {
  8086. momentumDuration = params.speed;
  8087. } else if (moveDistance < 2 * currentSlideSize) {
  8088. momentumDuration = params.speed * 1.5;
  8089. } else {
  8090. momentumDuration = params.speed * 2.5;
  8091. }
  8092. }
  8093. } else if (params.freeMode.sticky) {
  8094. swiper.slideToClosest();
  8095. return;
  8096. }
  8097. if (params.freeMode.momentumBounce && doBounce) {
  8098. swiper.updateProgress(afterBouncePosition);
  8099. swiper.setTransition(momentumDuration);
  8100. swiper.setTranslate(newPosition);
  8101. swiper.transitionStart(true, swiper.swipeDirection);
  8102. swiper.animating = true;
  8103. elementTransitionEnd(wrapperEl, () => {
  8104. if (!swiper || swiper.destroyed || !data.allowMomentumBounce) return;
  8105. emit('momentumBounce');
  8106. swiper.setTransition(params.speed);
  8107. setTimeout(() => {
  8108. swiper.setTranslate(afterBouncePosition);
  8109. elementTransitionEnd(wrapperEl, () => {
  8110. if (!swiper || swiper.destroyed) return;
  8111. swiper.transitionEnd();
  8112. });
  8113. }, 0);
  8114. });
  8115. } else if (swiper.velocity) {
  8116. emit('_freeModeNoMomentumRelease');
  8117. swiper.updateProgress(newPosition);
  8118. swiper.setTransition(momentumDuration);
  8119. swiper.setTranslate(newPosition);
  8120. swiper.transitionStart(true, swiper.swipeDirection);
  8121. if (!swiper.animating) {
  8122. swiper.animating = true;
  8123. elementTransitionEnd(wrapperEl, () => {
  8124. if (!swiper || swiper.destroyed) return;
  8125. swiper.transitionEnd();
  8126. });
  8127. }
  8128. } else {
  8129. swiper.updateProgress(newPosition);
  8130. }
  8131. swiper.updateActiveIndex();
  8132. swiper.updateSlidesClasses();
  8133. } else if (params.freeMode.sticky) {
  8134. swiper.slideToClosest();
  8135. return;
  8136. } else if (params.freeMode) {
  8137. emit('_freeModeNoMomentumRelease');
  8138. }
  8139. if (!params.freeMode.momentum || timeDiff >= params.longSwipesMs) {
  8140. emit('_freeModeStaticRelease');
  8141. swiper.updateProgress();
  8142. swiper.updateActiveIndex();
  8143. swiper.updateSlidesClasses();
  8144. }
  8145. }
  8146. Object.assign(swiper, {
  8147. freeMode: {
  8148. onTouchStart,
  8149. onTouchMove,
  8150. onTouchEnd
  8151. }
  8152. });
  8153. }
  8154. function Grid(_ref) {
  8155. let {
  8156. swiper,
  8157. extendParams,
  8158. on
  8159. } = _ref;
  8160. extendParams({
  8161. grid: {
  8162. rows: 1,
  8163. fill: 'column'
  8164. }
  8165. });
  8166. let slidesNumberEvenToRows;
  8167. let slidesPerRow;
  8168. let numFullColumns;
  8169. let wasMultiRow;
  8170. const getSpaceBetween = () => {
  8171. let spaceBetween = swiper.params.spaceBetween;
  8172. if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {
  8173. spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiper.size;
  8174. } else if (typeof spaceBetween === 'string') {
  8175. spaceBetween = parseFloat(spaceBetween);
  8176. }
  8177. return spaceBetween;
  8178. };
  8179. const initSlides = slides => {
  8180. const {
  8181. slidesPerView
  8182. } = swiper.params;
  8183. const {
  8184. rows,
  8185. fill
  8186. } = swiper.params.grid;
  8187. const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : slides.length;
  8188. numFullColumns = Math.floor(slidesLength / rows);
  8189. if (Math.floor(slidesLength / rows) === slidesLength / rows) {
  8190. slidesNumberEvenToRows = slidesLength;
  8191. } else {
  8192. slidesNumberEvenToRows = Math.ceil(slidesLength / rows) * rows;
  8193. }
  8194. if (slidesPerView !== 'auto' && fill === 'row') {
  8195. slidesNumberEvenToRows = Math.max(slidesNumberEvenToRows, slidesPerView * rows);
  8196. }
  8197. slidesPerRow = slidesNumberEvenToRows / rows;
  8198. };
  8199. const unsetSlides = () => {
  8200. if (swiper.slides) {
  8201. swiper.slides.forEach(slide => {
  8202. if (slide.swiperSlideGridSet) {
  8203. slide.style.height = '';
  8204. slide.style[swiper.getDirectionLabel('margin-top')] = '';
  8205. }
  8206. });
  8207. }
  8208. };
  8209. const updateSlide = (i, slide, slides) => {
  8210. const {
  8211. slidesPerGroup
  8212. } = swiper.params;
  8213. const spaceBetween = getSpaceBetween();
  8214. const {
  8215. rows,
  8216. fill
  8217. } = swiper.params.grid;
  8218. const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : slides.length;
  8219. // Set slides order
  8220. let newSlideOrderIndex;
  8221. let column;
  8222. let row;
  8223. if (fill === 'row' && slidesPerGroup > 1) {
  8224. const groupIndex = Math.floor(i / (slidesPerGroup * rows));
  8225. const slideIndexInGroup = i - rows * slidesPerGroup * groupIndex;
  8226. const columnsInGroup = groupIndex === 0 ? slidesPerGroup : Math.min(Math.ceil((slidesLength - groupIndex * rows * slidesPerGroup) / rows), slidesPerGroup);
  8227. row = Math.floor(slideIndexInGroup / columnsInGroup);
  8228. column = slideIndexInGroup - row * columnsInGroup + groupIndex * slidesPerGroup;
  8229. newSlideOrderIndex = column + row * slidesNumberEvenToRows / rows;
  8230. slide.style.order = newSlideOrderIndex;
  8231. } else if (fill === 'column') {
  8232. column = Math.floor(i / rows);
  8233. row = i - column * rows;
  8234. if (column > numFullColumns || column === numFullColumns && row === rows - 1) {
  8235. row += 1;
  8236. if (row >= rows) {
  8237. row = 0;
  8238. column += 1;
  8239. }
  8240. }
  8241. } else {
  8242. row = Math.floor(i / slidesPerRow);
  8243. column = i - row * slidesPerRow;
  8244. }
  8245. slide.row = row;
  8246. slide.column = column;
  8247. slide.style.height = `calc((100% - ${(rows - 1) * spaceBetween}px) / ${rows})`;
  8248. slide.style[swiper.getDirectionLabel('margin-top')] = row !== 0 ? spaceBetween && `${spaceBetween}px` : '';
  8249. slide.swiperSlideGridSet = true;
  8250. };
  8251. const updateWrapperSize = (slideSize, snapGrid) => {
  8252. const {
  8253. centeredSlides,
  8254. roundLengths
  8255. } = swiper.params;
  8256. const spaceBetween = getSpaceBetween();
  8257. const {
  8258. rows
  8259. } = swiper.params.grid;
  8260. swiper.virtualSize = (slideSize + spaceBetween) * slidesNumberEvenToRows;
  8261. swiper.virtualSize = Math.ceil(swiper.virtualSize / rows) - spaceBetween;
  8262. if (!swiper.params.cssMode) {
  8263. swiper.wrapperEl.style[swiper.getDirectionLabel('width')] = `${swiper.virtualSize + spaceBetween}px`;
  8264. }
  8265. if (centeredSlides) {
  8266. const newSlidesGrid = [];
  8267. for (let i = 0; i < snapGrid.length; i += 1) {
  8268. let slidesGridItem = snapGrid[i];
  8269. if (roundLengths) slidesGridItem = Math.floor(slidesGridItem);
  8270. if (snapGrid[i] < swiper.virtualSize + snapGrid[0]) newSlidesGrid.push(slidesGridItem);
  8271. }
  8272. snapGrid.splice(0, snapGrid.length);
  8273. snapGrid.push(...newSlidesGrid);
  8274. }
  8275. };
  8276. const onInit = () => {
  8277. wasMultiRow = swiper.params.grid && swiper.params.grid.rows > 1;
  8278. };
  8279. const onUpdate = () => {
  8280. const {
  8281. params,
  8282. el
  8283. } = swiper;
  8284. const isMultiRow = params.grid && params.grid.rows > 1;
  8285. if (wasMultiRow && !isMultiRow) {
  8286. el.classList.remove(`${params.containerModifierClass}grid`, `${params.containerModifierClass}grid-column`);
  8287. numFullColumns = 1;
  8288. swiper.emitContainerClasses();
  8289. } else if (!wasMultiRow && isMultiRow) {
  8290. el.classList.add(`${params.containerModifierClass}grid`);
  8291. if (params.grid.fill === 'column') {
  8292. el.classList.add(`${params.containerModifierClass}grid-column`);
  8293. }
  8294. swiper.emitContainerClasses();
  8295. }
  8296. wasMultiRow = isMultiRow;
  8297. };
  8298. on('init', onInit);
  8299. on('update', onUpdate);
  8300. swiper.grid = {
  8301. initSlides,
  8302. unsetSlides,
  8303. updateSlide,
  8304. updateWrapperSize
  8305. };
  8306. }
  8307. function appendSlide(slides) {
  8308. const swiper = this;
  8309. const {
  8310. params,
  8311. slidesEl
  8312. } = swiper;
  8313. if (params.loop) {
  8314. swiper.loopDestroy();
  8315. }
  8316. const appendElement = slideEl => {
  8317. if (typeof slideEl === 'string') {
  8318. const tempDOM = document.createElement('div');
  8319. tempDOM.innerHTML = slideEl;
  8320. slidesEl.append(tempDOM.children[0]);
  8321. tempDOM.innerHTML = '';
  8322. } else {
  8323. slidesEl.append(slideEl);
  8324. }
  8325. };
  8326. if (typeof slides === 'object' && 'length' in slides) {
  8327. for (let i = 0; i < slides.length; i += 1) {
  8328. if (slides[i]) appendElement(slides[i]);
  8329. }
  8330. } else {
  8331. appendElement(slides);
  8332. }
  8333. swiper.recalcSlides();
  8334. if (params.loop) {
  8335. swiper.loopCreate();
  8336. }
  8337. if (!params.observer || swiper.isElement) {
  8338. swiper.update();
  8339. }
  8340. }
  8341. function prependSlide(slides) {
  8342. const swiper = this;
  8343. const {
  8344. params,
  8345. activeIndex,
  8346. slidesEl
  8347. } = swiper;
  8348. if (params.loop) {
  8349. swiper.loopDestroy();
  8350. }
  8351. let newActiveIndex = activeIndex + 1;
  8352. const prependElement = slideEl => {
  8353. if (typeof slideEl === 'string') {
  8354. const tempDOM = document.createElement('div');
  8355. tempDOM.innerHTML = slideEl;
  8356. slidesEl.prepend(tempDOM.children[0]);
  8357. tempDOM.innerHTML = '';
  8358. } else {
  8359. slidesEl.prepend(slideEl);
  8360. }
  8361. };
  8362. if (typeof slides === 'object' && 'length' in slides) {
  8363. for (let i = 0; i < slides.length; i += 1) {
  8364. if (slides[i]) prependElement(slides[i]);
  8365. }
  8366. newActiveIndex = activeIndex + slides.length;
  8367. } else {
  8368. prependElement(slides);
  8369. }
  8370. swiper.recalcSlides();
  8371. if (params.loop) {
  8372. swiper.loopCreate();
  8373. }
  8374. if (!params.observer || swiper.isElement) {
  8375. swiper.update();
  8376. }
  8377. swiper.slideTo(newActiveIndex, 0, false);
  8378. }
  8379. function addSlide(index, slides) {
  8380. const swiper = this;
  8381. const {
  8382. params,
  8383. activeIndex,
  8384. slidesEl
  8385. } = swiper;
  8386. let activeIndexBuffer = activeIndex;
  8387. if (params.loop) {
  8388. activeIndexBuffer -= swiper.loopedSlides;
  8389. swiper.loopDestroy();
  8390. swiper.recalcSlides();
  8391. }
  8392. const baseLength = swiper.slides.length;
  8393. if (index <= 0) {
  8394. swiper.prependSlide(slides);
  8395. return;
  8396. }
  8397. if (index >= baseLength) {
  8398. swiper.appendSlide(slides);
  8399. return;
  8400. }
  8401. let newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + 1 : activeIndexBuffer;
  8402. const slidesBuffer = [];
  8403. for (let i = baseLength - 1; i >= index; i -= 1) {
  8404. const currentSlide = swiper.slides[i];
  8405. currentSlide.remove();
  8406. slidesBuffer.unshift(currentSlide);
  8407. }
  8408. if (typeof slides === 'object' && 'length' in slides) {
  8409. for (let i = 0; i < slides.length; i += 1) {
  8410. if (slides[i]) slidesEl.append(slides[i]);
  8411. }
  8412. newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + slides.length : activeIndexBuffer;
  8413. } else {
  8414. slidesEl.append(slides);
  8415. }
  8416. for (let i = 0; i < slidesBuffer.length; i += 1) {
  8417. slidesEl.append(slidesBuffer[i]);
  8418. }
  8419. swiper.recalcSlides();
  8420. if (params.loop) {
  8421. swiper.loopCreate();
  8422. }
  8423. if (!params.observer || swiper.isElement) {
  8424. swiper.update();
  8425. }
  8426. if (params.loop) {
  8427. swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);
  8428. } else {
  8429. swiper.slideTo(newActiveIndex, 0, false);
  8430. }
  8431. }
  8432. function removeSlide(slidesIndexes) {
  8433. const swiper = this;
  8434. const {
  8435. params,
  8436. activeIndex
  8437. } = swiper;
  8438. let activeIndexBuffer = activeIndex;
  8439. if (params.loop) {
  8440. activeIndexBuffer -= swiper.loopedSlides;
  8441. swiper.loopDestroy();
  8442. }
  8443. let newActiveIndex = activeIndexBuffer;
  8444. let indexToRemove;
  8445. if (typeof slidesIndexes === 'object' && 'length' in slidesIndexes) {
  8446. for (let i = 0; i < slidesIndexes.length; i += 1) {
  8447. indexToRemove = slidesIndexes[i];
  8448. if (swiper.slides[indexToRemove]) swiper.slides[indexToRemove].remove();
  8449. if (indexToRemove < newActiveIndex) newActiveIndex -= 1;
  8450. }
  8451. newActiveIndex = Math.max(newActiveIndex, 0);
  8452. } else {
  8453. indexToRemove = slidesIndexes;
  8454. if (swiper.slides[indexToRemove]) swiper.slides[indexToRemove].remove();
  8455. if (indexToRemove < newActiveIndex) newActiveIndex -= 1;
  8456. newActiveIndex = Math.max(newActiveIndex, 0);
  8457. }
  8458. swiper.recalcSlides();
  8459. if (params.loop) {
  8460. swiper.loopCreate();
  8461. }
  8462. if (!params.observer || swiper.isElement) {
  8463. swiper.update();
  8464. }
  8465. if (params.loop) {
  8466. swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);
  8467. } else {
  8468. swiper.slideTo(newActiveIndex, 0, false);
  8469. }
  8470. }
  8471. function removeAllSlides() {
  8472. const swiper = this;
  8473. const slidesIndexes = [];
  8474. for (let i = 0; i < swiper.slides.length; i += 1) {
  8475. slidesIndexes.push(i);
  8476. }
  8477. swiper.removeSlide(slidesIndexes);
  8478. }
  8479. function Manipulation(_ref) {
  8480. let {
  8481. swiper
  8482. } = _ref;
  8483. Object.assign(swiper, {
  8484. appendSlide: appendSlide.bind(swiper),
  8485. prependSlide: prependSlide.bind(swiper),
  8486. addSlide: addSlide.bind(swiper),
  8487. removeSlide: removeSlide.bind(swiper),
  8488. removeAllSlides: removeAllSlides.bind(swiper)
  8489. });
  8490. }
  8491. function effectInit(params) {
  8492. const {
  8493. effect,
  8494. swiper,
  8495. on,
  8496. setTranslate,
  8497. setTransition,
  8498. overwriteParams,
  8499. perspective,
  8500. recreateShadows,
  8501. getEffectParams
  8502. } = params;
  8503. on('beforeInit', () => {
  8504. if (swiper.params.effect !== effect) return;
  8505. swiper.classNames.push(`${swiper.params.containerModifierClass}${effect}`);
  8506. if (perspective && perspective()) {
  8507. swiper.classNames.push(`${swiper.params.containerModifierClass}3d`);
  8508. }
  8509. const overwriteParamsResult = overwriteParams ? overwriteParams() : {};
  8510. Object.assign(swiper.params, overwriteParamsResult);
  8511. Object.assign(swiper.originalParams, overwriteParamsResult);
  8512. });
  8513. on('setTranslate', () => {
  8514. if (swiper.params.effect !== effect) return;
  8515. setTranslate();
  8516. });
  8517. on('setTransition', (_s, duration) => {
  8518. if (swiper.params.effect !== effect) return;
  8519. setTransition(duration);
  8520. });
  8521. on('transitionEnd', () => {
  8522. if (swiper.params.effect !== effect) return;
  8523. if (recreateShadows) {
  8524. if (!getEffectParams || !getEffectParams().slideShadows) return;
  8525. // remove shadows
  8526. swiper.slides.forEach(slideEl => {
  8527. slideEl.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(shadowEl => shadowEl.remove());
  8528. });
  8529. // create new one
  8530. recreateShadows();
  8531. }
  8532. });
  8533. let requireUpdateOnVirtual;
  8534. on('virtualUpdate', () => {
  8535. if (swiper.params.effect !== effect) return;
  8536. if (!swiper.slides.length) {
  8537. requireUpdateOnVirtual = true;
  8538. }
  8539. requestAnimationFrame(() => {
  8540. if (requireUpdateOnVirtual && swiper.slides && swiper.slides.length) {
  8541. setTranslate();
  8542. requireUpdateOnVirtual = false;
  8543. }
  8544. });
  8545. });
  8546. }
  8547. function effectTarget(effectParams, slideEl) {
  8548. const transformEl = getSlideTransformEl(slideEl);
  8549. if (transformEl !== slideEl) {
  8550. transformEl.style.backfaceVisibility = 'hidden';
  8551. transformEl.style['-webkit-backface-visibility'] = 'hidden';
  8552. }
  8553. return transformEl;
  8554. }
  8555. function effectVirtualTransitionEnd(_ref) {
  8556. let {
  8557. swiper,
  8558. duration,
  8559. transformElements,
  8560. allSlides
  8561. } = _ref;
  8562. const {
  8563. activeIndex
  8564. } = swiper;
  8565. const getSlide = el => {
  8566. if (!el.parentElement) {
  8567. // assume shadow root
  8568. const slide = swiper.slides.filter(slideEl => slideEl.shadowRoot && slideEl.shadowRoot === el.parentNode)[0];
  8569. return slide;
  8570. }
  8571. return el.parentElement;
  8572. };
  8573. if (swiper.params.virtualTranslate && duration !== 0) {
  8574. let eventTriggered = false;
  8575. let transitionEndTarget;
  8576. if (allSlides) {
  8577. transitionEndTarget = transformElements;
  8578. } else {
  8579. transitionEndTarget = transformElements.filter(transformEl => {
  8580. const el = transformEl.classList.contains('swiper-slide-transform') ? getSlide(transformEl) : transformEl;
  8581. return swiper.getSlideIndex(el) === activeIndex;
  8582. });
  8583. }
  8584. transitionEndTarget.forEach(el => {
  8585. elementTransitionEnd(el, () => {
  8586. if (eventTriggered) return;
  8587. if (!swiper || swiper.destroyed) return;
  8588. eventTriggered = true;
  8589. swiper.animating = false;
  8590. const evt = new window.CustomEvent('transitionend', {
  8591. bubbles: true,
  8592. cancelable: true
  8593. });
  8594. swiper.wrapperEl.dispatchEvent(evt);
  8595. });
  8596. });
  8597. }
  8598. }
  8599. function EffectFade(_ref) {
  8600. let {
  8601. swiper,
  8602. extendParams,
  8603. on
  8604. } = _ref;
  8605. extendParams({
  8606. fadeEffect: {
  8607. crossFade: false
  8608. }
  8609. });
  8610. const setTranslate = () => {
  8611. const {
  8612. slides
  8613. } = swiper;
  8614. const params = swiper.params.fadeEffect;
  8615. for (let i = 0; i < slides.length; i += 1) {
  8616. const slideEl = swiper.slides[i];
  8617. const offset = slideEl.swiperSlideOffset;
  8618. let tx = -offset;
  8619. if (!swiper.params.virtualTranslate) tx -= swiper.translate;
  8620. let ty = 0;
  8621. if (!swiper.isHorizontal()) {
  8622. ty = tx;
  8623. tx = 0;
  8624. }
  8625. const slideOpacity = swiper.params.fadeEffect.crossFade ? Math.max(1 - Math.abs(slideEl.progress), 0) : 1 + Math.min(Math.max(slideEl.progress, -1), 0);
  8626. const targetEl = effectTarget(params, slideEl);
  8627. targetEl.style.opacity = slideOpacity;
  8628. targetEl.style.transform = `translate3d(${tx}px, ${ty}px, 0px)`;
  8629. }
  8630. };
  8631. const setTransition = duration => {
  8632. const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));
  8633. transformElements.forEach(el => {
  8634. el.style.transitionDuration = `${duration}ms`;
  8635. });
  8636. effectVirtualTransitionEnd({
  8637. swiper,
  8638. duration,
  8639. transformElements,
  8640. allSlides: true
  8641. });
  8642. };
  8643. effectInit({
  8644. effect: 'fade',
  8645. swiper,
  8646. on,
  8647. setTranslate,
  8648. setTransition,
  8649. overwriteParams: () => ({
  8650. slidesPerView: 1,
  8651. slidesPerGroup: 1,
  8652. watchSlidesProgress: true,
  8653. spaceBetween: 0,
  8654. virtualTranslate: !swiper.params.cssMode
  8655. })
  8656. });
  8657. }
  8658. function EffectCube(_ref) {
  8659. let {
  8660. swiper,
  8661. extendParams,
  8662. on
  8663. } = _ref;
  8664. extendParams({
  8665. cubeEffect: {
  8666. slideShadows: true,
  8667. shadow: true,
  8668. shadowOffset: 20,
  8669. shadowScale: 0.94
  8670. }
  8671. });
  8672. const createSlideShadows = (slideEl, progress, isHorizontal) => {
  8673. let shadowBefore = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-left') : slideEl.querySelector('.swiper-slide-shadow-top');
  8674. let shadowAfter = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-right') : slideEl.querySelector('.swiper-slide-shadow-bottom');
  8675. if (!shadowBefore) {
  8676. shadowBefore = createElement('div', `swiper-slide-shadow-cube swiper-slide-shadow-${isHorizontal ? 'left' : 'top'}`.split(' '));
  8677. slideEl.append(shadowBefore);
  8678. }
  8679. if (!shadowAfter) {
  8680. shadowAfter = createElement('div', `swiper-slide-shadow-cube swiper-slide-shadow-${isHorizontal ? 'right' : 'bottom'}`.split(' '));
  8681. slideEl.append(shadowAfter);
  8682. }
  8683. if (shadowBefore) shadowBefore.style.opacity = Math.max(-progress, 0);
  8684. if (shadowAfter) shadowAfter.style.opacity = Math.max(progress, 0);
  8685. };
  8686. const recreateShadows = () => {
  8687. // create new ones
  8688. const isHorizontal = swiper.isHorizontal();
  8689. swiper.slides.forEach(slideEl => {
  8690. const progress = Math.max(Math.min(slideEl.progress, 1), -1);
  8691. createSlideShadows(slideEl, progress, isHorizontal);
  8692. });
  8693. };
  8694. const setTranslate = () => {
  8695. const {
  8696. el,
  8697. wrapperEl,
  8698. slides,
  8699. width: swiperWidth,
  8700. height: swiperHeight,
  8701. rtlTranslate: rtl,
  8702. size: swiperSize,
  8703. browser
  8704. } = swiper;
  8705. const params = swiper.params.cubeEffect;
  8706. const isHorizontal = swiper.isHorizontal();
  8707. const isVirtual = swiper.virtual && swiper.params.virtual.enabled;
  8708. let wrapperRotate = 0;
  8709. let cubeShadowEl;
  8710. if (params.shadow) {
  8711. if (isHorizontal) {
  8712. cubeShadowEl = swiper.wrapperEl.querySelector('.swiper-cube-shadow');
  8713. if (!cubeShadowEl) {
  8714. cubeShadowEl = createElement('div', 'swiper-cube-shadow');
  8715. swiper.wrapperEl.append(cubeShadowEl);
  8716. }
  8717. cubeShadowEl.style.height = `${swiperWidth}px`;
  8718. } else {
  8719. cubeShadowEl = el.querySelector('.swiper-cube-shadow');
  8720. if (!cubeShadowEl) {
  8721. cubeShadowEl = createElement('div', 'swiper-cube-shadow');
  8722. el.append(cubeShadowEl);
  8723. }
  8724. }
  8725. }
  8726. for (let i = 0; i < slides.length; i += 1) {
  8727. const slideEl = slides[i];
  8728. let slideIndex = i;
  8729. if (isVirtual) {
  8730. slideIndex = parseInt(slideEl.getAttribute('data-swiper-slide-index'), 10);
  8731. }
  8732. let slideAngle = slideIndex * 90;
  8733. let round = Math.floor(slideAngle / 360);
  8734. if (rtl) {
  8735. slideAngle = -slideAngle;
  8736. round = Math.floor(-slideAngle / 360);
  8737. }
  8738. const progress = Math.max(Math.min(slideEl.progress, 1), -1);
  8739. let tx = 0;
  8740. let ty = 0;
  8741. let tz = 0;
  8742. if (slideIndex % 4 === 0) {
  8743. tx = -round * 4 * swiperSize;
  8744. tz = 0;
  8745. } else if ((slideIndex - 1) % 4 === 0) {
  8746. tx = 0;
  8747. tz = -round * 4 * swiperSize;
  8748. } else if ((slideIndex - 2) % 4 === 0) {
  8749. tx = swiperSize + round * 4 * swiperSize;
  8750. tz = swiperSize;
  8751. } else if ((slideIndex - 3) % 4 === 0) {
  8752. tx = -swiperSize;
  8753. tz = 3 * swiperSize + swiperSize * 4 * round;
  8754. }
  8755. if (rtl) {
  8756. tx = -tx;
  8757. }
  8758. if (!isHorizontal) {
  8759. ty = tx;
  8760. tx = 0;
  8761. }
  8762. const transform = `rotateX(${isHorizontal ? 0 : -slideAngle}deg) rotateY(${isHorizontal ? slideAngle : 0}deg) translate3d(${tx}px, ${ty}px, ${tz}px)`;
  8763. if (progress <= 1 && progress > -1) {
  8764. wrapperRotate = slideIndex * 90 + progress * 90;
  8765. if (rtl) wrapperRotate = -slideIndex * 90 - progress * 90;
  8766. if (swiper.browser && swiper.browser.isSafari && Math.abs(wrapperRotate) / 90 % 2 === 1) {
  8767. wrapperRotate += 0.001;
  8768. }
  8769. }
  8770. slideEl.style.transform = transform;
  8771. if (params.slideShadows) {
  8772. createSlideShadows(slideEl, progress, isHorizontal);
  8773. }
  8774. }
  8775. wrapperEl.style.transformOrigin = `50% 50% -${swiperSize / 2}px`;
  8776. wrapperEl.style['-webkit-transform-origin'] = `50% 50% -${swiperSize / 2}px`;
  8777. if (params.shadow) {
  8778. if (isHorizontal) {
  8779. cubeShadowEl.style.transform = `translate3d(0px, ${swiperWidth / 2 + params.shadowOffset}px, ${-swiperWidth / 2}px) rotateX(89.99deg) rotateZ(0deg) scale(${params.shadowScale})`;
  8780. } else {
  8781. const shadowAngle = Math.abs(wrapperRotate) - Math.floor(Math.abs(wrapperRotate) / 90) * 90;
  8782. const multiplier = 1.5 - (Math.sin(shadowAngle * 2 * Math.PI / 360) / 2 + Math.cos(shadowAngle * 2 * Math.PI / 360) / 2);
  8783. const scale1 = params.shadowScale;
  8784. const scale2 = params.shadowScale / multiplier;
  8785. const offset = params.shadowOffset;
  8786. cubeShadowEl.style.transform = `scale3d(${scale1}, 1, ${scale2}) translate3d(0px, ${swiperHeight / 2 + offset}px, ${-swiperHeight / 2 / scale2}px) rotateX(-89.99deg)`;
  8787. }
  8788. }
  8789. const zFactor = (browser.isSafari || browser.isWebView) && browser.needPerspectiveFix ? -swiperSize / 2 : 0;
  8790. wrapperEl.style.transform = `translate3d(0px,0,${zFactor}px) rotateX(${swiper.isHorizontal() ? 0 : wrapperRotate}deg) rotateY(${swiper.isHorizontal() ? -wrapperRotate : 0}deg)`;
  8791. wrapperEl.style.setProperty('--swiper-cube-translate-z', `${zFactor}px`);
  8792. };
  8793. const setTransition = duration => {
  8794. const {
  8795. el,
  8796. slides
  8797. } = swiper;
  8798. slides.forEach(slideEl => {
  8799. slideEl.style.transitionDuration = `${duration}ms`;
  8800. slideEl.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(subEl => {
  8801. subEl.style.transitionDuration = `${duration}ms`;
  8802. });
  8803. });
  8804. if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) {
  8805. const shadowEl = el.querySelector('.swiper-cube-shadow');
  8806. if (shadowEl) shadowEl.style.transitionDuration = `${duration}ms`;
  8807. }
  8808. };
  8809. effectInit({
  8810. effect: 'cube',
  8811. swiper,
  8812. on,
  8813. setTranslate,
  8814. setTransition,
  8815. recreateShadows,
  8816. getEffectParams: () => swiper.params.cubeEffect,
  8817. perspective: () => true,
  8818. overwriteParams: () => ({
  8819. slidesPerView: 1,
  8820. slidesPerGroup: 1,
  8821. watchSlidesProgress: true,
  8822. resistanceRatio: 0,
  8823. spaceBetween: 0,
  8824. centeredSlides: false,
  8825. virtualTranslate: true
  8826. })
  8827. });
  8828. }
  8829. function createShadow(suffix, slideEl, side) {
  8830. const shadowClass = `swiper-slide-shadow${side ? `-${side}` : ''}${suffix ? ` swiper-slide-shadow-${suffix}` : ''}`;
  8831. const shadowContainer = getSlideTransformEl(slideEl);
  8832. let shadowEl = shadowContainer.querySelector(`.${shadowClass.split(' ').join('.')}`);
  8833. if (!shadowEl) {
  8834. shadowEl = createElement('div', shadowClass.split(' '));
  8835. shadowContainer.append(shadowEl);
  8836. }
  8837. return shadowEl;
  8838. }
  8839. function EffectFlip(_ref) {
  8840. let {
  8841. swiper,
  8842. extendParams,
  8843. on
  8844. } = _ref;
  8845. extendParams({
  8846. flipEffect: {
  8847. slideShadows: true,
  8848. limitRotation: true
  8849. }
  8850. });
  8851. const createSlideShadows = (slideEl, progress) => {
  8852. let shadowBefore = swiper.isHorizontal() ? slideEl.querySelector('.swiper-slide-shadow-left') : slideEl.querySelector('.swiper-slide-shadow-top');
  8853. let shadowAfter = swiper.isHorizontal() ? slideEl.querySelector('.swiper-slide-shadow-right') : slideEl.querySelector('.swiper-slide-shadow-bottom');
  8854. if (!shadowBefore) {
  8855. shadowBefore = createShadow('flip', slideEl, swiper.isHorizontal() ? 'left' : 'top');
  8856. }
  8857. if (!shadowAfter) {
  8858. shadowAfter = createShadow('flip', slideEl, swiper.isHorizontal() ? 'right' : 'bottom');
  8859. }
  8860. if (shadowBefore) shadowBefore.style.opacity = Math.max(-progress, 0);
  8861. if (shadowAfter) shadowAfter.style.opacity = Math.max(progress, 0);
  8862. };
  8863. const recreateShadows = () => {
  8864. // Set shadows
  8865. swiper.params.flipEffect;
  8866. swiper.slides.forEach(slideEl => {
  8867. let progress = slideEl.progress;
  8868. if (swiper.params.flipEffect.limitRotation) {
  8869. progress = Math.max(Math.min(slideEl.progress, 1), -1);
  8870. }
  8871. createSlideShadows(slideEl, progress);
  8872. });
  8873. };
  8874. const setTranslate = () => {
  8875. const {
  8876. slides,
  8877. rtlTranslate: rtl
  8878. } = swiper;
  8879. const params = swiper.params.flipEffect;
  8880. for (let i = 0; i < slides.length; i += 1) {
  8881. const slideEl = slides[i];
  8882. let progress = slideEl.progress;
  8883. if (swiper.params.flipEffect.limitRotation) {
  8884. progress = Math.max(Math.min(slideEl.progress, 1), -1);
  8885. }
  8886. const offset = slideEl.swiperSlideOffset;
  8887. const rotate = -180 * progress;
  8888. let rotateY = rotate;
  8889. let rotateX = 0;
  8890. let tx = swiper.params.cssMode ? -offset - swiper.translate : -offset;
  8891. let ty = 0;
  8892. if (!swiper.isHorizontal()) {
  8893. ty = tx;
  8894. tx = 0;
  8895. rotateX = -rotateY;
  8896. rotateY = 0;
  8897. } else if (rtl) {
  8898. rotateY = -rotateY;
  8899. }
  8900. if (swiper.browser && swiper.browser.isSafari) {
  8901. if (Math.abs(rotateY) / 90 % 2 === 1) {
  8902. rotateY += 0.001;
  8903. }
  8904. if (Math.abs(rotateX) / 90 % 2 === 1) {
  8905. rotateX += 0.001;
  8906. }
  8907. }
  8908. slideEl.style.zIndex = -Math.abs(Math.round(progress)) + slides.length;
  8909. if (params.slideShadows) {
  8910. createSlideShadows(slideEl, progress);
  8911. }
  8912. const transform = `translate3d(${tx}px, ${ty}px, 0px) rotateX(${rotateX}deg) rotateY(${rotateY}deg)`;
  8913. const targetEl = effectTarget(params, slideEl);
  8914. targetEl.style.transform = transform;
  8915. }
  8916. };
  8917. const setTransition = duration => {
  8918. const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));
  8919. transformElements.forEach(el => {
  8920. el.style.transitionDuration = `${duration}ms`;
  8921. el.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(shadowEl => {
  8922. shadowEl.style.transitionDuration = `${duration}ms`;
  8923. });
  8924. });
  8925. effectVirtualTransitionEnd({
  8926. swiper,
  8927. duration,
  8928. transformElements
  8929. });
  8930. };
  8931. effectInit({
  8932. effect: 'flip',
  8933. swiper,
  8934. on,
  8935. setTranslate,
  8936. setTransition,
  8937. recreateShadows,
  8938. getEffectParams: () => swiper.params.flipEffect,
  8939. perspective: () => true,
  8940. overwriteParams: () => ({
  8941. slidesPerView: 1,
  8942. slidesPerGroup: 1,
  8943. watchSlidesProgress: true,
  8944. spaceBetween: 0,
  8945. virtualTranslate: !swiper.params.cssMode
  8946. })
  8947. });
  8948. }
  8949. function EffectCoverflow(_ref) {
  8950. let {
  8951. swiper,
  8952. extendParams,
  8953. on
  8954. } = _ref;
  8955. extendParams({
  8956. coverflowEffect: {
  8957. rotate: 50,
  8958. stretch: 0,
  8959. depth: 100,
  8960. scale: 1,
  8961. modifier: 1,
  8962. slideShadows: true
  8963. }
  8964. });
  8965. const setTranslate = () => {
  8966. const {
  8967. width: swiperWidth,
  8968. height: swiperHeight,
  8969. slides,
  8970. slidesSizesGrid
  8971. } = swiper;
  8972. const params = swiper.params.coverflowEffect;
  8973. const isHorizontal = swiper.isHorizontal();
  8974. const transform = swiper.translate;
  8975. const center = isHorizontal ? -transform + swiperWidth / 2 : -transform + swiperHeight / 2;
  8976. const rotate = isHorizontal ? params.rotate : -params.rotate;
  8977. const translate = params.depth;
  8978. // Each slide offset from center
  8979. for (let i = 0, length = slides.length; i < length; i += 1) {
  8980. const slideEl = slides[i];
  8981. const slideSize = slidesSizesGrid[i];
  8982. const slideOffset = slideEl.swiperSlideOffset;
  8983. const centerOffset = (center - slideOffset - slideSize / 2) / slideSize;
  8984. const offsetMultiplier = typeof params.modifier === 'function' ? params.modifier(centerOffset) : centerOffset * params.modifier;
  8985. let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;
  8986. let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier;
  8987. // var rotateZ = 0
  8988. let translateZ = -translate * Math.abs(offsetMultiplier);
  8989. let stretch = params.stretch;
  8990. // Allow percentage to make a relative stretch for responsive sliders
  8991. if (typeof stretch === 'string' && stretch.indexOf('%') !== -1) {
  8992. stretch = parseFloat(params.stretch) / 100 * slideSize;
  8993. }
  8994. let translateY = isHorizontal ? 0 : stretch * offsetMultiplier;
  8995. let translateX = isHorizontal ? stretch * offsetMultiplier : 0;
  8996. let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier);
  8997. // Fix for ultra small values
  8998. if (Math.abs(translateX) < 0.001) translateX = 0;
  8999. if (Math.abs(translateY) < 0.001) translateY = 0;
  9000. if (Math.abs(translateZ) < 0.001) translateZ = 0;
  9001. if (Math.abs(rotateY) < 0.001) rotateY = 0;
  9002. if (Math.abs(rotateX) < 0.001) rotateX = 0;
  9003. if (Math.abs(scale) < 0.001) scale = 0;
  9004. if (swiper.browser && swiper.browser.isSafari) {
  9005. if (Math.abs(rotateY) / 90 % 2 === 1) {
  9006. rotateY += 0.001;
  9007. }
  9008. if (Math.abs(rotateX) / 90 % 2 === 1) {
  9009. rotateX += 0.001;
  9010. }
  9011. }
  9012. const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale(${scale})`;
  9013. const targetEl = effectTarget(params, slideEl);
  9014. targetEl.style.transform = slideTransform;
  9015. slideEl.style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;
  9016. if (params.slideShadows) {
  9017. // Set shadows
  9018. let shadowBeforeEl = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-left') : slideEl.querySelector('.swiper-slide-shadow-top');
  9019. let shadowAfterEl = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-right') : slideEl.querySelector('.swiper-slide-shadow-bottom');
  9020. if (!shadowBeforeEl) {
  9021. shadowBeforeEl = createShadow('coverflow', slideEl, isHorizontal ? 'left' : 'top');
  9022. }
  9023. if (!shadowAfterEl) {
  9024. shadowAfterEl = createShadow('coverflow', slideEl, isHorizontal ? 'right' : 'bottom');
  9025. }
  9026. if (shadowBeforeEl) shadowBeforeEl.style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;
  9027. if (shadowAfterEl) shadowAfterEl.style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;
  9028. }
  9029. }
  9030. };
  9031. const setTransition = duration => {
  9032. const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));
  9033. transformElements.forEach(el => {
  9034. el.style.transitionDuration = `${duration}ms`;
  9035. el.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(shadowEl => {
  9036. shadowEl.style.transitionDuration = `${duration}ms`;
  9037. });
  9038. });
  9039. };
  9040. effectInit({
  9041. effect: 'coverflow',
  9042. swiper,
  9043. on,
  9044. setTranslate,
  9045. setTransition,
  9046. perspective: () => true,
  9047. overwriteParams: () => ({
  9048. watchSlidesProgress: true
  9049. })
  9050. });
  9051. }
  9052. function EffectCreative(_ref) {
  9053. let {
  9054. swiper,
  9055. extendParams,
  9056. on
  9057. } = _ref;
  9058. extendParams({
  9059. creativeEffect: {
  9060. limitProgress: 1,
  9061. shadowPerProgress: false,
  9062. progressMultiplier: 1,
  9063. perspective: true,
  9064. prev: {
  9065. translate: [0, 0, 0],
  9066. rotate: [0, 0, 0],
  9067. opacity: 1,
  9068. scale: 1
  9069. },
  9070. next: {
  9071. translate: [0, 0, 0],
  9072. rotate: [0, 0, 0],
  9073. opacity: 1,
  9074. scale: 1
  9075. }
  9076. }
  9077. });
  9078. const getTranslateValue = value => {
  9079. if (typeof value === 'string') return value;
  9080. return `${value}px`;
  9081. };
  9082. const setTranslate = () => {
  9083. const {
  9084. slides,
  9085. wrapperEl,
  9086. slidesSizesGrid
  9087. } = swiper;
  9088. const params = swiper.params.creativeEffect;
  9089. const {
  9090. progressMultiplier: multiplier
  9091. } = params;
  9092. const isCenteredSlides = swiper.params.centeredSlides;
  9093. if (isCenteredSlides) {
  9094. const margin = slidesSizesGrid[0] / 2 - swiper.params.slidesOffsetBefore || 0;
  9095. wrapperEl.style.transform = `translateX(calc(50% - ${margin}px))`;
  9096. }
  9097. for (let i = 0; i < slides.length; i += 1) {
  9098. const slideEl = slides[i];
  9099. const slideProgress = slideEl.progress;
  9100. const progress = Math.min(Math.max(slideEl.progress, -params.limitProgress), params.limitProgress);
  9101. let originalProgress = progress;
  9102. if (!isCenteredSlides) {
  9103. originalProgress = Math.min(Math.max(slideEl.originalProgress, -params.limitProgress), params.limitProgress);
  9104. }
  9105. const offset = slideEl.swiperSlideOffset;
  9106. const t = [swiper.params.cssMode ? -offset - swiper.translate : -offset, 0, 0];
  9107. const r = [0, 0, 0];
  9108. let custom = false;
  9109. if (!swiper.isHorizontal()) {
  9110. t[1] = t[0];
  9111. t[0] = 0;
  9112. }
  9113. let data = {
  9114. translate: [0, 0, 0],
  9115. rotate: [0, 0, 0],
  9116. scale: 1,
  9117. opacity: 1
  9118. };
  9119. if (progress < 0) {
  9120. data = params.next;
  9121. custom = true;
  9122. } else if (progress > 0) {
  9123. data = params.prev;
  9124. custom = true;
  9125. }
  9126. // set translate
  9127. t.forEach((value, index) => {
  9128. t[index] = `calc(${value}px + (${getTranslateValue(data.translate[index])} * ${Math.abs(progress * multiplier)}))`;
  9129. });
  9130. // set rotates
  9131. r.forEach((value, index) => {
  9132. let val = data.rotate[index] * Math.abs(progress * multiplier);
  9133. if (swiper.browser && swiper.browser.isSafari && Math.abs(val) / 90 % 2 === 1) {
  9134. val += 0.001;
  9135. }
  9136. r[index] = val;
  9137. });
  9138. slideEl.style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;
  9139. const translateString = t.join(', ');
  9140. const rotateString = `rotateX(${r[0]}deg) rotateY(${r[1]}deg) rotateZ(${r[2]}deg)`;
  9141. const scaleString = originalProgress < 0 ? `scale(${1 + (1 - data.scale) * originalProgress * multiplier})` : `scale(${1 - (1 - data.scale) * originalProgress * multiplier})`;
  9142. const opacityString = originalProgress < 0 ? 1 + (1 - data.opacity) * originalProgress * multiplier : 1 - (1 - data.opacity) * originalProgress * multiplier;
  9143. const transform = `translate3d(${translateString}) ${rotateString} ${scaleString}`;
  9144. // Set shadows
  9145. if (custom && data.shadow || !custom) {
  9146. let shadowEl = slideEl.querySelector('.swiper-slide-shadow');
  9147. if (!shadowEl && data.shadow) {
  9148. shadowEl = createShadow('creative', slideEl);
  9149. }
  9150. if (shadowEl) {
  9151. const shadowOpacity = params.shadowPerProgress ? progress * (1 / params.limitProgress) : progress;
  9152. shadowEl.style.opacity = Math.min(Math.max(Math.abs(shadowOpacity), 0), 1);
  9153. }
  9154. }
  9155. const targetEl = effectTarget(params, slideEl);
  9156. targetEl.style.transform = transform;
  9157. targetEl.style.opacity = opacityString;
  9158. if (data.origin) {
  9159. targetEl.style.transformOrigin = data.origin;
  9160. }
  9161. }
  9162. };
  9163. const setTransition = duration => {
  9164. const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));
  9165. transformElements.forEach(el => {
  9166. el.style.transitionDuration = `${duration}ms`;
  9167. el.querySelectorAll('.swiper-slide-shadow').forEach(shadowEl => {
  9168. shadowEl.style.transitionDuration = `${duration}ms`;
  9169. });
  9170. });
  9171. effectVirtualTransitionEnd({
  9172. swiper,
  9173. duration,
  9174. transformElements,
  9175. allSlides: true
  9176. });
  9177. };
  9178. effectInit({
  9179. effect: 'creative',
  9180. swiper,
  9181. on,
  9182. setTranslate,
  9183. setTransition,
  9184. perspective: () => swiper.params.creativeEffect.perspective,
  9185. overwriteParams: () => ({
  9186. watchSlidesProgress: true,
  9187. virtualTranslate: !swiper.params.cssMode
  9188. })
  9189. });
  9190. }
  9191. function EffectCards(_ref) {
  9192. let {
  9193. swiper,
  9194. extendParams,
  9195. on
  9196. } = _ref;
  9197. extendParams({
  9198. cardsEffect: {
  9199. slideShadows: true,
  9200. rotate: true,
  9201. perSlideRotate: 2,
  9202. perSlideOffset: 8
  9203. }
  9204. });
  9205. const setTranslate = () => {
  9206. const {
  9207. slides,
  9208. activeIndex,
  9209. rtlTranslate: rtl
  9210. } = swiper;
  9211. const params = swiper.params.cardsEffect;
  9212. const {
  9213. startTranslate,
  9214. isTouched
  9215. } = swiper.touchEventsData;
  9216. const currentTranslate = rtl ? -swiper.translate : swiper.translate;
  9217. for (let i = 0; i < slides.length; i += 1) {
  9218. const slideEl = slides[i];
  9219. const slideProgress = slideEl.progress;
  9220. const progress = Math.min(Math.max(slideProgress, -4), 4);
  9221. let offset = slideEl.swiperSlideOffset;
  9222. if (swiper.params.centeredSlides && !swiper.params.cssMode) {
  9223. swiper.wrapperEl.style.transform = `translateX(${swiper.minTranslate()}px)`;
  9224. }
  9225. if (swiper.params.centeredSlides && swiper.params.cssMode) {
  9226. offset -= slides[0].swiperSlideOffset;
  9227. }
  9228. let tX = swiper.params.cssMode ? -offset - swiper.translate : -offset;
  9229. let tY = 0;
  9230. const tZ = -100 * Math.abs(progress);
  9231. let scale = 1;
  9232. let rotate = -params.perSlideRotate * progress;
  9233. let tXAdd = params.perSlideOffset - Math.abs(progress) * 0.75;
  9234. const slideIndex = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.from + i : i;
  9235. const isSwipeToNext = (slideIndex === activeIndex || slideIndex === activeIndex - 1) && progress > 0 && progress < 1 && (isTouched || swiper.params.cssMode) && currentTranslate < startTranslate;
  9236. const isSwipeToPrev = (slideIndex === activeIndex || slideIndex === activeIndex + 1) && progress < 0 && progress > -1 && (isTouched || swiper.params.cssMode) && currentTranslate > startTranslate;
  9237. if (isSwipeToNext || isSwipeToPrev) {
  9238. const subProgress = (1 - Math.abs((Math.abs(progress) - 0.5) / 0.5)) ** 0.5;
  9239. rotate += -28 * progress * subProgress;
  9240. scale += -0.5 * subProgress;
  9241. tXAdd += 96 * subProgress;
  9242. tY = `${-25 * subProgress * Math.abs(progress)}%`;
  9243. }
  9244. if (progress < 0) {
  9245. // next
  9246. tX = `calc(${tX}px ${rtl ? '-' : '+'} (${tXAdd * Math.abs(progress)}%))`;
  9247. } else if (progress > 0) {
  9248. // prev
  9249. tX = `calc(${tX}px ${rtl ? '-' : '+'} (-${tXAdd * Math.abs(progress)}%))`;
  9250. } else {
  9251. tX = `${tX}px`;
  9252. }
  9253. if (!swiper.isHorizontal()) {
  9254. const prevY = tY;
  9255. tY = tX;
  9256. tX = prevY;
  9257. }
  9258. const scaleString = progress < 0 ? `${1 + (1 - scale) * progress}` : `${1 - (1 - scale) * progress}`;
  9259. /* eslint-disable */
  9260. const transform = `
  9261. translate3d(${tX}, ${tY}, ${tZ}px)
  9262. rotateZ(${params.rotate ? rtl ? -rotate : rotate : 0}deg)
  9263. scale(${scaleString})
  9264. `;
  9265. /* eslint-enable */
  9266. if (params.slideShadows) {
  9267. // Set shadows
  9268. let shadowEl = slideEl.querySelector('.swiper-slide-shadow');
  9269. if (!shadowEl) {
  9270. shadowEl = createShadow('cards', slideEl);
  9271. }
  9272. if (shadowEl) shadowEl.style.opacity = Math.min(Math.max((Math.abs(progress) - 0.5) / 0.5, 0), 1);
  9273. }
  9274. slideEl.style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;
  9275. const targetEl = effectTarget(params, slideEl);
  9276. targetEl.style.transform = transform;
  9277. }
  9278. };
  9279. const setTransition = duration => {
  9280. const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));
  9281. transformElements.forEach(el => {
  9282. el.style.transitionDuration = `${duration}ms`;
  9283. el.querySelectorAll('.swiper-slide-shadow').forEach(shadowEl => {
  9284. shadowEl.style.transitionDuration = `${duration}ms`;
  9285. });
  9286. });
  9287. effectVirtualTransitionEnd({
  9288. swiper,
  9289. duration,
  9290. transformElements
  9291. });
  9292. };
  9293. effectInit({
  9294. effect: 'cards',
  9295. swiper,
  9296. on,
  9297. setTranslate,
  9298. setTransition,
  9299. perspective: () => true,
  9300. overwriteParams: () => ({
  9301. watchSlidesProgress: true,
  9302. virtualTranslate: !swiper.params.cssMode
  9303. })
  9304. });
  9305. }
  9306. /**
  9307. * Swiper 11.0.5
  9308. * Most modern mobile touch slider and framework with hardware accelerated transitions
  9309. * https://swiperjs.com
  9310. *
  9311. * Copyright 2014-2023 Vladimir Kharlampidi
  9312. *
  9313. * Released under the MIT License
  9314. *
  9315. * Released on: November 22, 2023
  9316. */
  9317. // Swiper Class
  9318. const modules = [Virtual, Keyboard, Mousewheel, Navigation, Pagination, Scrollbar, Parallax, Zoom, Controller, A11y, History, HashNavigation, Autoplay, Thumb, freeMode, Grid, Manipulation, EffectFade, EffectCube, EffectFlip, EffectCoverflow, EffectCreative, EffectCards];
  9319. Swiper.use(modules);
  9320. return Swiper;
  9321. })();