| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381938293839384938593869387938893899390939193929393939493959396939793989399940094019402940394049405940694079408940994109411941294139414941594169417941894199420942194229423942494259426942794289429943094319432943394349435943694379438943994409441944294439444944594469447944894499450945194529453945494559456945794589459946094619462946394649465946694679468946994709471947294739474947594769477947894799480948194829483948494859486948794889489949094919492949394949495949694979498949995009501950295039504950595069507950895099510951195129513951495159516951795189519952095219522952395249525952695279528952995309531953295339534953595369537953895399540954195429543954495459546954795489549955095519552955395549555955695579558955995609561956295639564956595669567956895699570957195729573957495759576957795789579958095819582958395849585958695879588958995909591959295939594959595969597959895999600960196029603960496059606960796089609961096119612961396149615961696179618961996209621962296239624962596269627962896299630963196329633963496359636963796389639964096419642964396449645964696479648964996509651965296539654965596569657965896599660966196629663966496659666966796689669967096719672967396749675967696779678967996809681968296839684968596869687968896899690969196929693969496959696969796989699970097019702970397049705970697079708970997109711971297139714971597169717971897199720972197229723972497259726972797289729973097319732973397349735973697379738973997409741974297439744974597469747974897499750975197529753975497559756975797589759976097619762976397649765976697679768976997709771977297739774977597769777977897799780978197829783978497859786978797889789979097919792979397949795979697979798979998009801980298039804980598069807980898099810981198129813981498159816981798189819982098219822982398249825982698279828982998309831983298339834983598369837983898399840984198429843984498459846984798489849985098519852985398549855985698579858985998609861986298639864986598669867986898699870987198729873987498759876987798789879988098819882988398849885988698879888988998909891989298939894989598969897989898999900990199029903990499059906990799089909991099119912991399149915991699179918991999209921992299239924992599269927992899299930993199329933993499359936993799389939994099419942994399449945994699479948994999509951995299539954995599569957995899599960996199629963996499659966996799689969997099719972997399749975997699779978997999809981998299839984998599869987998899899990999199929993999499959996999799989999100001000110002100031000410005100061000710008100091001010011100121001310014100151001610017100181001910020100211002210023100241002510026100271002810029100301003110032100331003410035100361003710038100391004010041100421004310044100451004610047100481004910050100511005210053100541005510056100571005810059100601006110062100631006410065100661006710068100691007010071100721007310074100751007610077100781007910080100811008210083100841008510086100871008810089100901009110092100931009410095100961009710098100991010010101101021010310104101051010610107101081010910110101111011210113101141011510116101171011810119101201012110122101231012410125101261012710128101291013010131101321013310134101351013610137101381013910140101411014210143101441014510146101471014810149101501015110152101531015410155101561015710158101591016010161101621016310164101651016610167101681016910170101711017210173101741017510176101771017810179101801018110182101831018410185101861018710188101891019010191101921019310194101951019610197101981019910200102011020210203102041020510206102071020810209102101021110212102131021410215102161021710218102191022010221102221022310224102251022610227102281022910230102311023210233102341023510236102371023810239102401024110242102431024410245102461024710248102491025010251102521025310254102551025610257102581025910260102611026210263102641026510266102671026810269102701027110272102731027410275102761027710278102791028010281102821028310284102851028610287102881028910290102911029210293102941029510296102971029810299103001030110302103031030410305103061030710308103091031010311103121031310314103151031610317103181031910320103211032210323103241032510326103271032810329103301033110332103331033410335103361033710338103391034010341103421034310344103451034610347103481034910350103511035210353103541035510356103571035810359103601036110362103631036410365103661036710368103691037010371103721037310374103751037610377103781037910380103811038210383103841038510386103871038810389103901039110392103931039410395103961039710398103991040010401104021040310404104051040610407104081040910410104111041210413104141041510416104171041810419104201042110422104231042410425104261042710428104291043010431104321043310434104351043610437104381043910440104411044210443104441044510446104471044810449104501045110452104531045410455104561045710458104591046010461104621046310464104651046610467104681046910470104711047210473104741047510476104771047810479104801048110482104831048410485104861048710488104891049010491104921049310494104951049610497104981049910500105011050210503105041050510506105071050810509105101051110512105131051410515105161051710518105191052010521105221052310524105251052610527105281052910530105311053210533105341053510536105371053810539105401054110542105431054410545105461054710548105491055010551105521055310554105551055610557105581055910560105611056210563105641056510566105671056810569105701057110572105731057410575105761057710578105791058010581105821058310584105851058610587105881058910590105911059210593105941059510596105971059810599106001060110602106031060410605106061060710608106091061010611106121061310614106151061610617106181061910620106211062210623106241062510626106271062810629106301063110632106331063410635106361063710638106391064010641106421064310644106451064610647106481064910650106511065210653106541065510656106571065810659106601066110662106631066410665106661066710668106691067010671106721067310674106751067610677106781067910680106811068210683106841068510686106871068810689106901069110692106931069410695106961069710698106991070010701107021070310704107051070610707107081070910710107111071210713107141071510716107171071810719107201072110722107231072410725107261072710728107291073010731107321073310734107351073610737107381073910740107411074210743107441074510746107471074810749107501075110752107531075410755107561075710758107591076010761107621076310764107651076610767107681076910770107711077210773107741077510776107771077810779107801078110782107831078410785107861078710788107891079010791107921079310794107951079610797107981079910800108011080210803108041080510806108071080810809108101081110812108131081410815108161081710818108191082010821108221082310824108251082610827108281082910830108311083210833108341083510836108371083810839108401084110842108431084410845108461084710848108491085010851108521085310854108551085610857108581085910860108611086210863108641086510866108671086810869108701087110872108731087410875108761087710878108791088010881108821088310884108851088610887108881088910890108911089210893108941089510896108971089810899109001090110902109031090410905109061090710908109091091010911109121091310914109151091610917109181091910920109211092210923109241092510926109271092810929109301093110932109331093410935109361093710938109391094010941109421094310944109451094610947109481094910950109511095210953109541095510956109571095810959109601096110962109631096410965109661096710968109691097010971109721097310974109751097610977109781097910980109811098210983109841098510986109871098810989109901099110992109931099410995109961099710998109991100011001110021100311004110051100611007110081100911010110111101211013110141101511016110171101811019110201102111022110231102411025110261102711028110291103011031110321103311034110351103611037110381103911040110411104211043110441104511046110471104811049110501105111052110531105411055110561105711058110591106011061110621106311064110651106611067110681106911070110711107211073110741107511076110771107811079110801108111082110831108411085110861108711088110891109011091110921109311094110951109611097110981109911100111011110211103111041110511106111071110811109111101111111112111131111411115111161111711118111191112011121111221112311124111251112611127111281112911130111311113211133111341113511136111371113811139111401114111142111431114411145111461114711148111491115011151111521115311154111551115611157111581115911160111611116211163111641116511166111671116811169111701117111172111731117411175111761117711178111791118011181111821118311184111851118611187111881118911190111911119211193111941119511196111971119811199112001120111202112031120411205112061120711208112091121011211112121121311214112151121611217112181121911220112211122211223112241122511226112271122811229112301123111232112331123411235112361123711238112391124011241112421124311244112451124611247112481124911250112511125211253112541125511256112571125811259112601126111262112631126411265112661126711268112691127011271112721127311274112751127611277112781127911280112811128211283112841128511286112871128811289112901129111292112931129411295112961129711298112991130011301113021130311304113051130611307113081130911310113111131211313113141131511316113171131811319113201132111322113231132411325113261132711328113291133011331113321133311334113351133611337113381133911340113411134211343113441134511346113471134811349113501135111352113531135411355113561135711358113591136011361113621136311364113651136611367113681136911370113711137211373113741137511376113771137811379113801138111382113831138411385113861138711388113891139011391113921139311394113951139611397113981139911400114011140211403114041140511406114071140811409114101141111412114131141411415114161141711418114191142011421114221142311424114251142611427114281142911430114311143211433114341143511436114371143811439114401144111442114431144411445114461144711448114491145011451114521145311454114551145611457114581145911460114611146211463114641146511466114671146811469114701147111472114731147411475114761147711478114791148011481114821148311484114851148611487114881148911490114911149211493114941149511496114971149811499115001150111502115031150411505115061150711508115091151011511115121151311514115151151611517115181151911520115211152211523115241152511526115271152811529115301153111532115331153411535115361153711538115391154011541115421154311544115451154611547115481154911550115511155211553115541155511556115571155811559115601156111562115631156411565115661156711568115691157011571115721157311574115751157611577115781157911580115811158211583115841158511586115871158811589115901159111592115931159411595115961159711598115991160011601116021160311604116051160611607116081160911610116111161211613116141161511616116171161811619116201162111622116231162411625116261162711628116291163011631116321163311634116351163611637116381163911640116411164211643116441164511646116471164811649116501165111652116531165411655116561165711658116591166011661116621166311664116651166611667116681166911670116711167211673116741167511676116771167811679116801168111682116831168411685116861168711688116891169011691116921169311694116951169611697116981169911700117011170211703117041170511706117071170811709117101171111712117131171411715117161171711718117191172011721117221172311724117251172611727117281172911730117311173211733117341173511736117371173811739117401174111742117431174411745117461174711748117491175011751117521175311754117551175611757117581175911760117611176211763117641176511766117671176811769117701177111772117731177411775117761177711778117791178011781117821178311784117851178611787117881178911790117911179211793117941179511796117971179811799118001180111802118031180411805118061180711808118091181011811118121181311814118151181611817118181181911820118211182211823118241182511826118271182811829118301183111832118331183411835118361183711838118391184011841118421184311844118451184611847118481184911850118511185211853118541185511856118571185811859118601186111862118631186411865118661186711868118691187011871118721187311874118751187611877118781187911880118811188211883118841188511886118871188811889118901189111892118931189411895118961189711898118991190011901119021190311904119051190611907119081190911910119111191211913119141191511916119171191811919119201192111922119231192411925119261192711928119291193011931119321193311934119351193611937119381193911940119411194211943119441194511946119471194811949119501195111952119531195411955119561195711958119591196011961119621196311964119651196611967119681196911970119711197211973119741197511976119771197811979119801198111982119831198411985119861198711988119891199011991119921199311994119951199611997119981199912000120011200212003120041200512006120071200812009120101201112012120131201412015120161201712018120191202012021120221202312024120251202612027120281202912030120311203212033120341203512036120371203812039120401204112042120431204412045120461204712048120491205012051120521205312054120551205612057120581205912060120611206212063120641206512066120671206812069120701207112072120731207412075120761207712078120791208012081120821208312084120851208612087120881208912090120911209212093120941209512096120971209812099121001210112102121031210412105121061210712108121091211012111121121211312114121151211612117121181211912120121211212212123121241212512126121271212812129121301213112132121331213412135121361213712138121391214012141121421214312144121451214612147121481214912150121511215212153121541215512156121571215812159121601216112162121631216412165121661216712168121691217012171121721217312174121751217612177121781217912180121811218212183121841218512186121871218812189121901219112192121931219412195121961219712198121991220012201122021220312204122051220612207122081220912210122111221212213122141221512216122171221812219122201222112222122231222412225122261222712228122291223012231122321223312234122351223612237122381223912240122411224212243122441224512246122471224812249122501225112252122531225412255122561225712258122591226012261122621226312264122651226612267122681226912270122711227212273122741227512276122771227812279122801228112282122831228412285122861228712288122891229012291122921229312294122951229612297122981229912300123011230212303123041230512306123071230812309123101231112312123131231412315123161231712318123191232012321123221232312324123251232612327123281232912330123311233212333123341233512336123371233812339123401234112342123431234412345123461234712348123491235012351123521235312354123551235612357123581235912360123611236212363123641236512366123671236812369123701237112372123731237412375123761237712378123791238012381123821238312384123851238612387123881238912390123911239212393123941239512396123971239812399124001240112402124031240412405124061240712408124091241012411124121241312414124151241612417124181241912420124211242212423124241242512426124271242812429124301243112432124331243412435124361243712438124391244012441124421244312444124451244612447124481244912450124511245212453124541245512456124571245812459124601246112462124631246412465124661246712468124691247012471124721247312474124751247612477124781247912480124811248212483124841248512486124871248812489124901249112492124931249412495124961249712498124991250012501125021250312504125051250612507125081250912510125111251212513125141251512516125171251812519125201252112522125231252412525125261252712528125291253012531125321253312534125351253612537125381253912540125411254212543125441254512546125471254812549125501255112552125531255412555125561255712558125591256012561125621256312564125651256612567125681256912570125711257212573125741257512576125771257812579125801258112582125831258412585125861258712588125891259012591125921259312594125951259612597125981259912600126011260212603126041260512606126071260812609126101261112612126131261412615126161261712618126191262012621126221262312624126251262612627126281262912630126311263212633126341263512636126371263812639126401264112642126431264412645126461264712648126491265012651126521265312654126551265612657126581265912660126611266212663126641266512666126671266812669126701267112672126731267412675126761267712678126791268012681126821268312684126851268612687126881268912690126911269212693126941269512696126971269812699127001270112702127031270412705127061270712708127091271012711127121271312714127151271612717127181271912720127211272212723127241272512726127271272812729127301273112732127331273412735127361273712738127391274012741127421274312744127451274612747127481274912750127511275212753127541275512756127571275812759127601276112762127631276412765127661276712768127691277012771127721277312774127751277612777127781277912780127811278212783127841278512786127871278812789127901279112792127931279412795127961279712798127991280012801128021280312804128051280612807128081280912810128111281212813128141281512816128171281812819128201282112822128231282412825128261282712828128291283012831128321283312834128351283612837128381283912840128411284212843128441284512846128471284812849128501285112852128531285412855128561285712858128591286012861128621286312864128651286612867128681286912870128711287212873128741287512876128771287812879128801288112882128831288412885128861288712888128891289012891128921289312894128951289612897128981289912900129011290212903129041290512906129071290812909129101291112912129131291412915129161291712918129191292012921129221292312924129251292612927129281292912930129311293212933129341293512936129371293812939129401294112942129431294412945129461294712948129491295012951129521295312954129551295612957129581295912960129611296212963129641296512966129671296812969129701297112972129731297412975129761297712978129791298012981129821298312984129851298612987129881298912990129911299212993129941299512996129971299812999130001300113002130031300413005130061300713008130091301013011130121301313014130151301613017130181301913020130211302213023130241302513026130271302813029130301303113032130331303413035130361303713038130391304013041130421304313044130451304613047130481304913050130511305213053130541305513056130571305813059130601306113062130631306413065130661306713068130691307013071130721307313074130751307613077130781307913080130811308213083130841308513086130871308813089130901309113092130931309413095130961309713098130991310013101131021310313104131051310613107131081310913110131111311213113131141311513116131171311813119131201312113122131231312413125131261312713128131291313013131131321313313134131351313613137131381313913140131411314213143131441314513146131471314813149131501315113152131531315413155131561315713158131591316013161131621316313164131651316613167131681316913170131711317213173131741317513176131771317813179131801318113182131831318413185131861318713188131891319013191131921319313194131951319613197131981319913200132011320213203132041320513206132071320813209132101321113212132131321413215132161321713218132191322013221132221322313224132251322613227132281322913230132311323213233132341323513236132371323813239132401324113242132431324413245132461324713248132491325013251132521325313254132551325613257132581325913260132611326213263132641326513266132671326813269132701327113272132731327413275132761327713278132791328013281132821328313284132851328613287132881328913290132911329213293132941329513296132971329813299133001330113302133031330413305133061330713308133091331013311133121331313314133151331613317133181331913320133211332213323133241332513326133271332813329133301333113332133331333413335133361333713338133391334013341133421334313344133451334613347133481334913350133511335213353133541335513356133571335813359133601336113362133631336413365133661336713368133691337013371133721337313374133751337613377133781337913380133811338213383133841338513386133871338813389133901339113392133931339413395133961339713398133991340013401134021340313404134051340613407134081340913410134111341213413134141341513416134171341813419134201342113422134231342413425134261342713428134291343013431134321343313434134351343613437134381343913440134411344213443134441344513446134471344813449134501345113452134531345413455134561345713458134591346013461134621346313464134651346613467134681346913470134711347213473134741347513476134771347813479134801348113482134831348413485134861348713488134891349013491134921349313494134951349613497134981349913500135011350213503135041350513506135071350813509135101351113512135131351413515135161351713518135191352013521135221352313524135251352613527135281352913530135311353213533135341353513536135371353813539135401354113542135431354413545135461354713548135491355013551135521355313554135551355613557135581355913560135611356213563135641356513566135671356813569135701357113572135731357413575135761357713578135791358013581135821358313584135851358613587135881358913590135911359213593135941359513596135971359813599136001360113602136031360413605136061360713608136091361013611136121361313614136151361613617136181361913620136211362213623136241362513626136271362813629136301363113632136331363413635136361363713638136391364013641136421364313644136451364613647136481364913650136511365213653136541365513656136571365813659136601366113662136631366413665136661366713668136691367013671136721367313674136751367613677136781367913680136811368213683136841368513686136871368813689136901369113692136931369413695136961369713698136991370013701137021370313704137051370613707137081370913710137111371213713137141371513716137171371813719137201372113722137231372413725137261372713728137291373013731137321373313734137351373613737137381373913740137411374213743137441374513746137471374813749137501375113752137531375413755137561375713758137591376013761137621376313764137651376613767137681376913770137711377213773137741377513776137771377813779137801378113782137831378413785137861378713788137891379013791137921379313794137951379613797137981379913800138011380213803138041380513806138071380813809138101381113812138131381413815138161381713818138191382013821138221382313824138251382613827138281382913830138311383213833138341383513836138371383813839138401384113842138431384413845138461384713848138491385013851138521385313854138551385613857138581385913860138611386213863138641386513866138671386813869138701387113872138731387413875138761387713878138791388013881138821388313884138851388613887138881388913890138911389213893 | /** * @licstart The following is the entire license notice for the * JavaScript code in this page * * Copyright 2023 Mozilla Foundation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * *     http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * @licend The above is the entire license notice for the * JavaScript code in this page *//******/ (() => { // webpackBootstrap/******/ 	"use strict";/******/ 	var __webpack_modules__ = ([/* 0 */,/* 1 *//***/ ((__unused_webpack_module, exports) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.animationStarted = exports.VERTICAL_PADDING = exports.UNKNOWN_SCALE = exports.TextLayerMode = exports.SpreadMode = exports.SidebarView = exports.ScrollMode = exports.SCROLLBAR_PADDING = exports.RenderingStates = exports.RendererType = exports.ProgressBar = exports.PresentationModeState = exports.OutputScale = exports.MIN_SCALE = exports.MAX_SCALE = exports.MAX_AUTO_SCALE = exports.DEFAULT_SCALE_VALUE = exports.DEFAULT_SCALE_DELTA = exports.DEFAULT_SCALE = exports.AutoPrintRegExp = void 0;exports.apiPageLayoutToViewerModes = apiPageLayoutToViewerModes;exports.apiPageModeToSidebarView = apiPageModeToSidebarView;exports.approximateFraction = approximateFraction;exports.backtrackBeforeAllVisibleElements = backtrackBeforeAllVisibleElements;exports.binarySearchFirstItem = binarySearchFirstItem;exports.docStyle = void 0;exports.getActiveOrFocusedElement = getActiveOrFocusedElement;exports.getPageSizeInches = getPageSizeInches;exports.getVisibleElements = getVisibleElements;exports.isPortraitOrientation = isPortraitOrientation;exports.isValidRotation = isValidRotation;exports.isValidScrollMode = isValidScrollMode;exports.isValidSpreadMode = isValidSpreadMode;exports.noContextMenuHandler = noContextMenuHandler;exports.normalizeWheelEventDelta = normalizeWheelEventDelta;exports.normalizeWheelEventDirection = normalizeWheelEventDirection;exports.parseQueryString = parseQueryString;exports.removeNullCharacters = removeNullCharacters;exports.roundToDivide = roundToDivide;exports.scrollIntoView = scrollIntoView;exports.watchScroll = watchScroll;const DEFAULT_SCALE_VALUE = "auto";exports.DEFAULT_SCALE_VALUE = DEFAULT_SCALE_VALUE;const DEFAULT_SCALE = 1.0;exports.DEFAULT_SCALE = DEFAULT_SCALE;const DEFAULT_SCALE_DELTA = 1.1;exports.DEFAULT_SCALE_DELTA = DEFAULT_SCALE_DELTA;const MIN_SCALE = 0.1;exports.MIN_SCALE = MIN_SCALE;const MAX_SCALE = 10.0;exports.MAX_SCALE = MAX_SCALE;const UNKNOWN_SCALE = 0;exports.UNKNOWN_SCALE = UNKNOWN_SCALE;const MAX_AUTO_SCALE = 1.25;exports.MAX_AUTO_SCALE = MAX_AUTO_SCALE;const SCROLLBAR_PADDING = 40;exports.SCROLLBAR_PADDING = SCROLLBAR_PADDING;const VERTICAL_PADDING = 5;exports.VERTICAL_PADDING = VERTICAL_PADDING;const RenderingStates = {  INITIAL: 0,  RUNNING: 1,  PAUSED: 2,  FINISHED: 3};exports.RenderingStates = RenderingStates;const PresentationModeState = {  UNKNOWN: 0,  NORMAL: 1,  CHANGING: 2,  FULLSCREEN: 3};exports.PresentationModeState = PresentationModeState;const SidebarView = {  UNKNOWN: -1,  NONE: 0,  THUMBS: 1,  OUTLINE: 2,  ATTACHMENTS: 3,  LAYERS: 4};exports.SidebarView = SidebarView;const RendererType = {  CANVAS: "canvas",  SVG: "svg"};exports.RendererType = RendererType;const TextLayerMode = {  DISABLE: 0,  ENABLE: 1};exports.TextLayerMode = TextLayerMode;const ScrollMode = {  UNKNOWN: -1,  VERTICAL: 0,  HORIZONTAL: 1,  WRAPPED: 2,  PAGE: 3};exports.ScrollMode = ScrollMode;const SpreadMode = {  UNKNOWN: -1,  NONE: 0,  ODD: 1,  EVEN: 2};exports.SpreadMode = SpreadMode;const AutoPrintRegExp = /\bprint\s*\(/;exports.AutoPrintRegExp = AutoPrintRegExp;class OutputScale {  constructor() {    const pixelRatio = window.devicePixelRatio || 1;    this.sx = pixelRatio;    this.sy = pixelRatio;  }  get scaled() {    return this.sx !== 1 || this.sy !== 1;  }}exports.OutputScale = OutputScale;function scrollIntoView(element, spot, scrollMatches = false) {  let parent = element.offsetParent;  if (!parent) {    console.error("offsetParent is not set -- cannot scroll");    return;  }  let offsetY = element.offsetTop + element.clientTop;  let offsetX = element.offsetLeft + element.clientLeft;  while (parent.clientHeight === parent.scrollHeight && parent.clientWidth === parent.scrollWidth || scrollMatches && (parent.classList.contains("markedContent") || getComputedStyle(parent).overflow === "hidden")) {    offsetY += parent.offsetTop;    offsetX += parent.offsetLeft;    parent = parent.offsetParent;    if (!parent) {      return;    }  }  if (spot) {    if (spot.top !== undefined) {      offsetY += spot.top;    }    if (spot.left !== undefined) {      offsetX += spot.left;      parent.scrollLeft = offsetX;    }  }  parent.scrollTop = offsetY;}function watchScroll(viewAreaElement, callback) {  const debounceScroll = function (evt) {    if (rAF) {      return;    }    rAF = window.requestAnimationFrame(function viewAreaElementScrolled() {      rAF = null;      const currentX = viewAreaElement.scrollLeft;      const lastX = state.lastX;      if (currentX !== lastX) {        state.right = currentX > lastX;      }      state.lastX = currentX;      const currentY = viewAreaElement.scrollTop;      const lastY = state.lastY;      if (currentY !== lastY) {        state.down = currentY > lastY;      }      state.lastY = currentY;      callback(state);    });  };  const state = {    right: true,    down: true,    lastX: viewAreaElement.scrollLeft,    lastY: viewAreaElement.scrollTop,    _eventHandler: debounceScroll  };  let rAF = null;  viewAreaElement.addEventListener("scroll", debounceScroll, true);  return state;}function parseQueryString(query) {  const params = new Map();  for (const [key, value] of new URLSearchParams(query)) {    params.set(key.toLowerCase(), value);  }  return params;}const NullCharactersRegExp = /\x00/g;const InvisibleCharactersRegExp = /[\x01-\x1F]/g;function removeNullCharacters(str, replaceInvisible = false) {  if (typeof str !== "string") {    console.error(`The argument must be a string.`);    return str;  }  if (replaceInvisible) {    str = str.replace(InvisibleCharactersRegExp, " ");  }  return str.replace(NullCharactersRegExp, "");}function binarySearchFirstItem(items, condition, start = 0) {  let minIndex = start;  let maxIndex = items.length - 1;  if (maxIndex < 0 || !condition(items[maxIndex])) {    return items.length;  }  if (condition(items[minIndex])) {    return minIndex;  }  while (minIndex < maxIndex) {    const currentIndex = minIndex + maxIndex >> 1;    const currentItem = items[currentIndex];    if (condition(currentItem)) {      maxIndex = currentIndex;    } else {      minIndex = currentIndex + 1;    }  }  return minIndex;}function approximateFraction(x) {  if (Math.floor(x) === x) {    return [x, 1];  }  const xinv = 1 / x;  const limit = 8;  if (xinv > limit) {    return [1, limit];  } else if (Math.floor(xinv) === xinv) {    return [1, xinv];  }  const x_ = x > 1 ? xinv : x;  let a = 0,    b = 1,    c = 1,    d = 1;  while (true) {    const p = a + c,      q = b + d;    if (q > limit) {      break;    }    if (x_ <= p / q) {      c = p;      d = q;    } else {      a = p;      b = q;    }  }  let result;  if (x_ - a / b < c / d - x_) {    result = x_ === x ? [a, b] : [b, a];  } else {    result = x_ === x ? [c, d] : [d, c];  }  return result;}function roundToDivide(x, div) {  const r = x % div;  return r === 0 ? x : Math.round(x - r + div);}function getPageSizeInches({  view,  userUnit,  rotate}) {  const [x1, y1, x2, y2] = view;  const changeOrientation = rotate % 180 !== 0;  const width = (x2 - x1) / 72 * userUnit;  const height = (y2 - y1) / 72 * userUnit;  return {    width: changeOrientation ? height : width,    height: changeOrientation ? width : height  };}function backtrackBeforeAllVisibleElements(index, views, top) {  if (index < 2) {    return index;  }  let elt = views[index].div;  let pageTop = elt.offsetTop + elt.clientTop;  if (pageTop >= top) {    elt = views[index - 1].div;    pageTop = elt.offsetTop + elt.clientTop;  }  for (let i = index - 2; i >= 0; --i) {    elt = views[i].div;    if (elt.offsetTop + elt.clientTop + elt.clientHeight <= pageTop) {      break;    }    index = i;  }  return index;}function getVisibleElements({  scrollEl,  views,  sortByVisibility = false,  horizontal = false,  rtl = false}) {  const top = scrollEl.scrollTop,    bottom = top + scrollEl.clientHeight;  const left = scrollEl.scrollLeft,    right = left + scrollEl.clientWidth;  function isElementBottomAfterViewTop(view) {    const element = view.div;    const elementBottom = element.offsetTop + element.clientTop + element.clientHeight;    return elementBottom > top;  }  function isElementNextAfterViewHorizontally(view) {    const element = view.div;    const elementLeft = element.offsetLeft + element.clientLeft;    const elementRight = elementLeft + element.clientWidth;    return rtl ? elementLeft < right : elementRight > left;  }  const visible = [],    ids = new Set(),    numViews = views.length;  let firstVisibleElementInd = binarySearchFirstItem(views, horizontal ? isElementNextAfterViewHorizontally : isElementBottomAfterViewTop);  if (firstVisibleElementInd > 0 && firstVisibleElementInd < numViews && !horizontal) {    firstVisibleElementInd = backtrackBeforeAllVisibleElements(firstVisibleElementInd, views, top);  }  let lastEdge = horizontal ? right : -1;  for (let i = firstVisibleElementInd; i < numViews; i++) {    const view = views[i],      element = view.div;    const currentWidth = element.offsetLeft + element.clientLeft;    const currentHeight = element.offsetTop + element.clientTop;    const viewWidth = element.clientWidth,      viewHeight = element.clientHeight;    const viewRight = currentWidth + viewWidth;    const viewBottom = currentHeight + viewHeight;    if (lastEdge === -1) {      if (viewBottom >= bottom) {        lastEdge = viewBottom;      }    } else if ((horizontal ? currentWidth : currentHeight) > lastEdge) {      break;    }    if (viewBottom <= top || currentHeight >= bottom || viewRight <= left || currentWidth >= right) {      continue;    }    const hiddenHeight = Math.max(0, top - currentHeight) + Math.max(0, viewBottom - bottom);    const hiddenWidth = Math.max(0, left - currentWidth) + Math.max(0, viewRight - right);    const fractionHeight = (viewHeight - hiddenHeight) / viewHeight,      fractionWidth = (viewWidth - hiddenWidth) / viewWidth;    const percent = fractionHeight * fractionWidth * 100 | 0;    visible.push({      id: view.id,      x: currentWidth,      y: currentHeight,      view,      percent,      widthPercent: fractionWidth * 100 | 0    });    ids.add(view.id);  }  const first = visible[0],    last = visible.at(-1);  if (sortByVisibility) {    visible.sort(function (a, b) {      const pc = a.percent - b.percent;      if (Math.abs(pc) > 0.001) {        return -pc;      }      return a.id - b.id;    });  }  return {    first,    last,    views: visible,    ids  };}function noContextMenuHandler(evt) {  evt.preventDefault();}function normalizeWheelEventDirection(evt) {  let delta = Math.hypot(evt.deltaX, evt.deltaY);  const angle = Math.atan2(evt.deltaY, evt.deltaX);  if (-0.25 * Math.PI < angle && angle < 0.75 * Math.PI) {    delta = -delta;  }  return delta;}function normalizeWheelEventDelta(evt) {  const deltaMode = evt.deltaMode;  let delta = normalizeWheelEventDirection(evt);  const MOUSE_PIXELS_PER_LINE = 30;  const MOUSE_LINES_PER_PAGE = 30;  if (deltaMode === WheelEvent.DOM_DELTA_PIXEL) {    delta /= MOUSE_PIXELS_PER_LINE * MOUSE_LINES_PER_PAGE;  } else if (deltaMode === WheelEvent.DOM_DELTA_LINE) {    delta /= MOUSE_LINES_PER_PAGE;  }  return delta;}function isValidRotation(angle) {  return Number.isInteger(angle) && angle % 90 === 0;}function isValidScrollMode(mode) {  return Number.isInteger(mode) && Object.values(ScrollMode).includes(mode) && mode !== ScrollMode.UNKNOWN;}function isValidSpreadMode(mode) {  return Number.isInteger(mode) && Object.values(SpreadMode).includes(mode) && mode !== SpreadMode.UNKNOWN;}function isPortraitOrientation(size) {  return size.width <= size.height;}const animationStarted = new Promise(function (resolve) {  window.requestAnimationFrame(resolve);});exports.animationStarted = animationStarted;const docStyle = document.documentElement.style;exports.docStyle = docStyle;function clamp(v, min, max) {  return Math.min(Math.max(v, min), max);}class ProgressBar {  #classList = null;  #disableAutoFetchTimeout = null;  #percent = 0;  #style = null;  #visible = true;  constructor(bar) {    this.#classList = bar.classList;    this.#style = bar.style;  }  get percent() {    return this.#percent;  }  set percent(val) {    this.#percent = clamp(val, 0, 100);    if (isNaN(val)) {      this.#classList.add("indeterminate");      return;    }    this.#classList.remove("indeterminate");    this.#style.setProperty("--progressBar-percent", `${this.#percent}%`);  }  setWidth(viewer) {    if (!viewer) {      return;    }    const container = viewer.parentNode;    const scrollbarWidth = container.offsetWidth - viewer.offsetWidth;    if (scrollbarWidth > 0) {      this.#style.setProperty("--progressBar-end-offset", `${scrollbarWidth}px`);    }  }  setDisableAutoFetch(delay = 5000) {    if (isNaN(this.#percent)) {      return;    }    if (this.#disableAutoFetchTimeout) {      clearTimeout(this.#disableAutoFetchTimeout);    }    this.show();    this.#disableAutoFetchTimeout = setTimeout(() => {      this.#disableAutoFetchTimeout = null;      this.hide();    }, delay);  }  hide() {    if (!this.#visible) {      return;    }    this.#visible = false;    this.#classList.add("hidden");  }  show() {    if (this.#visible) {      return;    }    this.#visible = true;    this.#classList.remove("hidden");  }}exports.ProgressBar = ProgressBar;function getActiveOrFocusedElement() {  let curRoot = document;  let curActiveOrFocused = curRoot.activeElement || curRoot.querySelector(":focus");  while (curActiveOrFocused?.shadowRoot) {    curRoot = curActiveOrFocused.shadowRoot;    curActiveOrFocused = curRoot.activeElement || curRoot.querySelector(":focus");  }  return curActiveOrFocused;}function apiPageLayoutToViewerModes(layout) {  let scrollMode = ScrollMode.VERTICAL,    spreadMode = SpreadMode.NONE;  switch (layout) {    case "SinglePage":      scrollMode = ScrollMode.PAGE;      break;    case "OneColumn":      break;    case "TwoPageLeft":      scrollMode = ScrollMode.PAGE;    case "TwoColumnLeft":      spreadMode = SpreadMode.ODD;      break;    case "TwoPageRight":      scrollMode = ScrollMode.PAGE;    case "TwoColumnRight":      spreadMode = SpreadMode.EVEN;      break;  }  return {    scrollMode,    spreadMode  };}function apiPageModeToSidebarView(mode) {  switch (mode) {    case "UseNone":      return SidebarView.NONE;    case "UseThumbs":      return SidebarView.THUMBS;    case "UseOutlines":      return SidebarView.OUTLINE;    case "UseAttachments":      return SidebarView.ATTACHMENTS;    case "UseOC":      return SidebarView.LAYERS;  }  return SidebarView.NONE;}/***/ }),/* 2 *//***/ ((__unused_webpack_module, exports) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.compatibilityParams = exports.OptionKind = exports.AppOptions = void 0;const compatibilityParams = Object.create(null);exports.compatibilityParams = compatibilityParams;{  const userAgent = navigator.userAgent || "";  const platform = navigator.platform || "";  const maxTouchPoints = navigator.maxTouchPoints || 1;  const isAndroid = /Android/.test(userAgent);  const isIOS = /\b(iPad|iPhone|iPod)(?=;)/.test(userAgent) || platform === "MacIntel" && maxTouchPoints > 1;  (function checkCanvasSizeLimitation() {    if (isIOS || isAndroid) {      compatibilityParams.maxCanvasPixels = 5242880;    }  })();}const OptionKind = {  VIEWER: 0x02,  API: 0x04,  WORKER: 0x08,  PREFERENCE: 0x80};exports.OptionKind = OptionKind;const defaultOptions = {  annotationEditorMode: {    value: 0,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  annotationMode: {    value: 2,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  cursorToolOnLoad: {    value: 0,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  defaultZoomDelay: {    value: 400,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  defaultZoomValue: {    value: "",    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  disableHistory: {    value: false,    kind: OptionKind.VIEWER  },  disablePageLabels: {    value: false,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  enablePermissions: {    value: false,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  enablePrintAutoRotate: {    value: true,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  enableScripting: {    value: true,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  externalLinkRel: {    value: "noopener noreferrer nofollow",    kind: OptionKind.VIEWER  },  externalLinkTarget: {    value: 0,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  historyUpdateUrl: {    value: false,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  ignoreDestinationZoom: {    value: false,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  imageResourcesPath: {    value: "./images/",    kind: OptionKind.VIEWER  },  maxCanvasPixels: {    value: 16777216,    kind: OptionKind.VIEWER  },  forcePageColors: {    value: false,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  pageColorsBackground: {    value: "Canvas",    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  pageColorsForeground: {    value: "CanvasText",    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  pdfBugEnabled: {    value: false,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  printResolution: {    value: 150,    kind: OptionKind.VIEWER  },  sidebarViewOnLoad: {    value: -1,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  scrollModeOnLoad: {    value: -1,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  spreadModeOnLoad: {    value: -1,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  textLayerMode: {    value: 1,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  useOnlyCssZoom: {    value: false,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  viewerCssTheme: {    value: 0,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  viewOnLoad: {    value: 0,    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  },  cMapPacked: {    value: true,    kind: OptionKind.API  },  cMapUrl: {    value: "../web/cmaps/",    kind: OptionKind.API  },  disableAutoFetch: {    value: false,    kind: OptionKind.API + OptionKind.PREFERENCE  },  disableFontFace: {    value: false,    kind: OptionKind.API + OptionKind.PREFERENCE  },  disableRange: {    value: false,    kind: OptionKind.API + OptionKind.PREFERENCE  },  disableStream: {    value: false,    kind: OptionKind.API + OptionKind.PREFERENCE  },  docBaseUrl: {    value: "",    kind: OptionKind.API  },  enableXfa: {    value: true,    kind: OptionKind.API + OptionKind.PREFERENCE  },  fontExtraProperties: {    value: false,    kind: OptionKind.API  },  isEvalSupported: {    value: true,    kind: OptionKind.API  },  isOffscreenCanvasSupported: {    value: true,    kind: OptionKind.API  },  maxImageSize: {    value: -1,    kind: OptionKind.API  },  pdfBug: {    value: false,    kind: OptionKind.API  },  standardFontDataUrl: {    value: "../web/standard_fonts/",    kind: OptionKind.API  },  verbosity: {    value: 1,    kind: OptionKind.API  },  workerPort: {    value: null,    kind: OptionKind.WORKER  },  workerSrc: {    value: "../build/pdf.worker.js",    kind: OptionKind.WORKER  }};{  defaultOptions.defaultUrl = {    value: "compressed.tracemonkey-pldi-09.pdf",    kind: OptionKind.VIEWER  };  defaultOptions.disablePreferences = {    value: false,    kind: OptionKind.VIEWER  };  defaultOptions.locale = {    value: navigator.language || "en-US",    kind: OptionKind.VIEWER  };  defaultOptions.renderer = {    value: "canvas",    kind: OptionKind.VIEWER + OptionKind.PREFERENCE  };  defaultOptions.sandboxBundleSrc = {    value: "../build/pdf.sandbox.js",    kind: OptionKind.VIEWER  };}const userOptions = Object.create(null);class AppOptions {  constructor() {    throw new Error("Cannot initialize AppOptions.");  }  static get(name) {    const userOption = userOptions[name];    if (userOption !== undefined) {      return userOption;    }    const defaultOption = defaultOptions[name];    if (defaultOption !== undefined) {      return compatibilityParams[name] ?? defaultOption.value;    }    return undefined;  }  static getAll(kind = null) {    const options = Object.create(null);    for (const name in defaultOptions) {      const defaultOption = defaultOptions[name];      if (kind) {        if ((kind & defaultOption.kind) === 0) {          continue;        }        if (kind === OptionKind.PREFERENCE) {          const value = defaultOption.value,            valueType = typeof value;          if (valueType === "boolean" || valueType === "string" || valueType === "number" && Number.isInteger(value)) {            options[name] = value;            continue;          }          throw new Error(`Invalid type for preference: ${name}`);        }      }      const userOption = userOptions[name];      options[name] = userOption !== undefined ? userOption : compatibilityParams[name] ?? defaultOption.value;    }    return options;  }  static set(name, value) {    userOptions[name] = value;  }  static setAll(options) {    for (const name in options) {      userOptions[name] = options[name];    }  }  static remove(name) {    delete userOptions[name];  }  static _hasUserOptions() {    return Object.keys(userOptions).length > 0;  }}exports.AppOptions = AppOptions;/***/ }),/* 3 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.SimpleLinkService = exports.PDFLinkService = exports.LinkTarget = void 0;var _ui_utils = __webpack_require__(1);const DEFAULT_LINK_REL = "noopener noreferrer nofollow";const LinkTarget = {  NONE: 0,  SELF: 1,  BLANK: 2,  PARENT: 3,  TOP: 4};exports.LinkTarget = LinkTarget;function addLinkAttributes(link, {  url,  target,  rel,  enabled = true} = {}) {  if (!url || typeof url !== "string") {    throw new Error('A valid "url" parameter must provided.');  }  const urlNullRemoved = (0, _ui_utils.removeNullCharacters)(url);  if (enabled) {    link.href = link.title = urlNullRemoved;  } else {    link.href = "";    link.title = `Disabled: ${urlNullRemoved}`;    link.onclick = () => {      return false;    };  }  let targetStr = "";  switch (target) {    case LinkTarget.NONE:      break;    case LinkTarget.SELF:      targetStr = "_self";      break;    case LinkTarget.BLANK:      targetStr = "_blank";      break;    case LinkTarget.PARENT:      targetStr = "_parent";      break;    case LinkTarget.TOP:      targetStr = "_top";      break;  }  link.target = targetStr;  link.rel = typeof rel === "string" ? rel : DEFAULT_LINK_REL;}class PDFLinkService {  #pagesRefCache = new Map();  constructor({    eventBus,    externalLinkTarget = null,    externalLinkRel = null,    ignoreDestinationZoom = false  } = {}) {    this.eventBus = eventBus;    this.externalLinkTarget = externalLinkTarget;    this.externalLinkRel = externalLinkRel;    this.externalLinkEnabled = true;    this._ignoreDestinationZoom = ignoreDestinationZoom;    this.baseUrl = null;    this.pdfDocument = null;    this.pdfViewer = null;    this.pdfHistory = null;  }  setDocument(pdfDocument, baseUrl = null) {    this.baseUrl = baseUrl;    this.pdfDocument = pdfDocument;    this.#pagesRefCache.clear();  }  setViewer(pdfViewer) {    this.pdfViewer = pdfViewer;  }  setHistory(pdfHistory) {    this.pdfHistory = pdfHistory;  }  get pagesCount() {    return this.pdfDocument ? this.pdfDocument.numPages : 0;  }  get page() {    return this.pdfViewer.currentPageNumber;  }  set page(value) {    this.pdfViewer.currentPageNumber = value;  }  get rotation() {    return this.pdfViewer.pagesRotation;  }  set rotation(value) {    this.pdfViewer.pagesRotation = value;  }  get isInPresentationMode() {    return this.pdfViewer.isInPresentationMode;  }  #goToDestinationHelper(rawDest, namedDest = null, explicitDest) {    const destRef = explicitDest[0];    let pageNumber;    if (typeof destRef === "object" && destRef !== null) {      pageNumber = this._cachedPageNumber(destRef);      if (!pageNumber) {        this.pdfDocument.getPageIndex(destRef).then(pageIndex => {          this.cachePageRef(pageIndex + 1, destRef);          this.#goToDestinationHelper(rawDest, namedDest, explicitDest);        }).catch(() => {          console.error(`PDFLinkService.#goToDestinationHelper: "${destRef}" is not ` + `a valid page reference, for dest="${rawDest}".`);        });        return;      }    } else if (Number.isInteger(destRef)) {      pageNumber = destRef + 1;    } else {      console.error(`PDFLinkService.#goToDestinationHelper: "${destRef}" is not ` + `a valid destination reference, for dest="${rawDest}".`);      return;    }    if (!pageNumber || pageNumber < 1 || pageNumber > this.pagesCount) {      console.error(`PDFLinkService.#goToDestinationHelper: "${pageNumber}" is not ` + `a valid page number, for dest="${rawDest}".`);      return;    }    if (this.pdfHistory) {      this.pdfHistory.pushCurrentPosition();      this.pdfHistory.push({        namedDest,        explicitDest,        pageNumber      });    }    this.pdfViewer.scrollPageIntoView({      pageNumber,      destArray: explicitDest,      ignoreDestinationZoom: this._ignoreDestinationZoom    });  }  async goToDestination(dest) {    if (!this.pdfDocument) {      return;    }    let namedDest, explicitDest;    if (typeof dest === "string") {      namedDest = dest;      explicitDest = await this.pdfDocument.getDestination(dest);    } else {      namedDest = null;      explicitDest = await dest;    }    if (!Array.isArray(explicitDest)) {      console.error(`PDFLinkService.goToDestination: "${explicitDest}" is not ` + `a valid destination array, for dest="${dest}".`);      return;    }    this.#goToDestinationHelper(dest, namedDest, explicitDest);  }  goToPage(val) {    if (!this.pdfDocument) {      return;    }    const pageNumber = typeof val === "string" && this.pdfViewer.pageLabelToPageNumber(val) || val | 0;    if (!(Number.isInteger(pageNumber) && pageNumber > 0 && pageNumber <= this.pagesCount)) {      console.error(`PDFLinkService.goToPage: "${val}" is not a valid page.`);      return;    }    if (this.pdfHistory) {      this.pdfHistory.pushCurrentPosition();      this.pdfHistory.pushPage(pageNumber);    }    this.pdfViewer.scrollPageIntoView({      pageNumber    });  }  addLinkAttributes(link, url, newWindow = false) {    addLinkAttributes(link, {      url,      target: newWindow ? LinkTarget.BLANK : this.externalLinkTarget,      rel: this.externalLinkRel,      enabled: this.externalLinkEnabled    });  }  getDestinationHash(dest) {    if (typeof dest === "string") {      if (dest.length > 0) {        return this.getAnchorUrl("#" + escape(dest));      }    } else if (Array.isArray(dest)) {      const str = JSON.stringify(dest);      if (str.length > 0) {        return this.getAnchorUrl("#" + escape(str));      }    }    return this.getAnchorUrl("");  }  getAnchorUrl(anchor) {    return (this.baseUrl || "") + anchor;  }  setHash(hash) {    if (!this.pdfDocument) {      return;    }    let pageNumber, dest;    if (hash.includes("=")) {      const params = (0, _ui_utils.parseQueryString)(hash);      if (params.has("search")) {        this.eventBus.dispatch("findfromurlhash", {          source: this,          query: params.get("search").replace(/"/g, ""),          phraseSearch: params.get("phrase") === "true"        });      }      if (params.has("page")) {        pageNumber = params.get("page") | 0 || 1;      }      if (params.has("zoom")) {        const zoomArgs = params.get("zoom").split(",");        const zoomArg = zoomArgs[0];        const zoomArgNumber = parseFloat(zoomArg);        if (!zoomArg.includes("Fit")) {          dest = [null, {            name: "XYZ"          }, zoomArgs.length > 1 ? zoomArgs[1] | 0 : null, zoomArgs.length > 2 ? zoomArgs[2] | 0 : null, zoomArgNumber ? zoomArgNumber / 100 : zoomArg];        } else {          if (zoomArg === "Fit" || zoomArg === "FitB") {            dest = [null, {              name: zoomArg            }];          } else if (zoomArg === "FitH" || zoomArg === "FitBH" || zoomArg === "FitV" || zoomArg === "FitBV") {            dest = [null, {              name: zoomArg            }, zoomArgs.length > 1 ? zoomArgs[1] | 0 : null];          } else if (zoomArg === "FitR") {            if (zoomArgs.length !== 5) {              console.error('PDFLinkService.setHash: Not enough parameters for "FitR".');            } else {              dest = [null, {                name: zoomArg              }, zoomArgs[1] | 0, zoomArgs[2] | 0, zoomArgs[3] | 0, zoomArgs[4] | 0];            }          } else {            console.error(`PDFLinkService.setHash: "${zoomArg}" is not a valid zoom value.`);          }        }      }      if (dest) {        this.pdfViewer.scrollPageIntoView({          pageNumber: pageNumber || this.page,          destArray: dest,          allowNegativeOffset: true        });      } else if (pageNumber) {        this.page = pageNumber;      }      if (params.has("pagemode")) {        this.eventBus.dispatch("pagemode", {          source: this,          mode: params.get("pagemode")        });      }      if (params.has("nameddest")) {        this.goToDestination(params.get("nameddest"));      }    } else {      dest = unescape(hash);      try {        dest = JSON.parse(dest);        if (!Array.isArray(dest)) {          dest = dest.toString();        }      } catch (ex) {}      if (typeof dest === "string" || PDFLinkService.#isValidExplicitDestination(dest)) {        this.goToDestination(dest);        return;      }      console.error(`PDFLinkService.setHash: "${unescape(hash)}" is not a valid destination.`);    }  }  executeNamedAction(action) {    switch (action) {      case "GoBack":        this.pdfHistory?.back();        break;      case "GoForward":        this.pdfHistory?.forward();        break;      case "NextPage":        this.pdfViewer.nextPage();        break;      case "PrevPage":        this.pdfViewer.previousPage();        break;      case "LastPage":        this.page = this.pagesCount;        break;      case "FirstPage":        this.page = 1;        break;      default:        break;    }    this.eventBus.dispatch("namedaction", {      source: this,      action    });  }  async executeSetOCGState(action) {    const pdfDocument = this.pdfDocument;    const optionalContentConfig = await this.pdfViewer.optionalContentConfigPromise;    if (pdfDocument !== this.pdfDocument) {      return;    }    let operator;    for (const elem of action.state) {      switch (elem) {        case "ON":        case "OFF":        case "Toggle":          operator = elem;          continue;      }      switch (operator) {        case "ON":          optionalContentConfig.setVisibility(elem, true);          break;        case "OFF":          optionalContentConfig.setVisibility(elem, false);          break;        case "Toggle":          const group = optionalContentConfig.getGroup(elem);          if (group) {            optionalContentConfig.setVisibility(elem, !group.visible);          }          break;      }    }    this.pdfViewer.optionalContentConfigPromise = Promise.resolve(optionalContentConfig);  }  cachePageRef(pageNum, pageRef) {    if (!pageRef) {      return;    }    const refStr = pageRef.gen === 0 ? `${pageRef.num}R` : `${pageRef.num}R${pageRef.gen}`;    this.#pagesRefCache.set(refStr, pageNum);  }  _cachedPageNumber(pageRef) {    if (!pageRef) {      return null;    }    const refStr = pageRef.gen === 0 ? `${pageRef.num}R` : `${pageRef.num}R${pageRef.gen}`;    return this.#pagesRefCache.get(refStr) || null;  }  isPageVisible(pageNumber) {    return this.pdfViewer.isPageVisible(pageNumber);  }  isPageCached(pageNumber) {    return this.pdfViewer.isPageCached(pageNumber);  }  static #isValidExplicitDestination(dest) {    if (!Array.isArray(dest)) {      return false;    }    const destLength = dest.length;    if (destLength < 2) {      return false;    }    const page = dest[0];    if (!(typeof page === "object" && Number.isInteger(page.num) && Number.isInteger(page.gen)) && !(Number.isInteger(page) && page >= 0)) {      return false;    }    const zoom = dest[1];    if (!(typeof zoom === "object" && typeof zoom.name === "string")) {      return false;    }    let allowNull = true;    switch (zoom.name) {      case "XYZ":        if (destLength !== 5) {          return false;        }        break;      case "Fit":      case "FitB":        return destLength === 2;      case "FitH":      case "FitBH":      case "FitV":      case "FitBV":        if (destLength !== 3) {          return false;        }        break;      case "FitR":        if (destLength !== 6) {          return false;        }        allowNull = false;        break;      default:        return false;    }    for (let i = 2; i < destLength; i++) {      const param = dest[i];      if (!(typeof param === "number" || allowNull && param === null)) {        return false;      }    }    return true;  }}exports.PDFLinkService = PDFLinkService;class SimpleLinkService {  constructor() {    this.externalLinkEnabled = true;  }  get pagesCount() {    return 0;  }  get page() {    return 0;  }  set page(value) {}  get rotation() {    return 0;  }  set rotation(value) {}  get isInPresentationMode() {    return false;  }  async goToDestination(dest) {}  goToPage(val) {}  addLinkAttributes(link, url, newWindow = false) {    addLinkAttributes(link, {      url,      enabled: this.externalLinkEnabled    });  }  getDestinationHash(dest) {    return "#";  }  getAnchorUrl(hash) {    return "#";  }  setHash(hash) {}  executeNamedAction(action) {}  executeSetOCGState(action) {}  cachePageRef(pageNum, pageRef) {}  isPageVisible(pageNumber) {    return true;  }  isPageCached(pageNumber) {    return true;  }}exports.SimpleLinkService = SimpleLinkService;/***/ }),/* 4 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFViewerApplication = exports.PDFPrintServiceFactory = exports.DefaultExternalServices = void 0;var _ui_utils = __webpack_require__(1);var _pdfjsLib = __webpack_require__(5);var _app_options = __webpack_require__(2);var _event_utils = __webpack_require__(6);var _pdf_cursor_tools = __webpack_require__(7);var _pdf_link_service = __webpack_require__(3);var _annotation_editor_params = __webpack_require__(9);var _overlay_manager = __webpack_require__(10);var _password_prompt = __webpack_require__(11);var _pdf_attachment_viewer = __webpack_require__(12);var _pdf_document_properties = __webpack_require__(14);var _pdf_find_bar = __webpack_require__(15);var _pdf_find_controller = __webpack_require__(16);var _pdf_history = __webpack_require__(18);var _pdf_layer_viewer = __webpack_require__(19);var _pdf_outline_viewer = __webpack_require__(20);var _pdf_presentation_mode = __webpack_require__(21);var _pdf_rendering_queue = __webpack_require__(22);var _pdf_scripting_manager = __webpack_require__(23);var _pdf_sidebar = __webpack_require__(24);var _pdf_sidebar_resizer = __webpack_require__(25);var _pdf_thumbnail_viewer = __webpack_require__(26);var _pdf_viewer = __webpack_require__(28);var _secondary_toolbar = __webpack_require__(38);var _toolbar = __webpack_require__(39);var _view_history = __webpack_require__(40);const FORCE_PAGES_LOADED_TIMEOUT = 10000;const WHEEL_ZOOM_DISABLED_TIMEOUT = 1000;const ViewOnLoad = {  UNKNOWN: -1,  PREVIOUS: 0,  INITIAL: 1};const ViewerCssTheme = {  AUTOMATIC: 0,  LIGHT: 1,  DARK: 2};class DefaultExternalServices {  constructor() {    throw new Error("Cannot initialize DefaultExternalServices.");  }  static updateFindControlState(data) {}  static updateFindMatchesCount(data) {}  static initPassiveLoading(callbacks) {}  static reportTelemetry(data) {}  static createDownloadManager() {    throw new Error("Not implemented: createDownloadManager");  }  static createPreferences() {    throw new Error("Not implemented: createPreferences");  }  static createL10n(options) {    throw new Error("Not implemented: createL10n");  }  static createScripting(options) {    throw new Error("Not implemented: createScripting");  }  static get supportsPinchToZoom() {    return (0, _pdfjsLib.shadow)(this, "supportsPinchToZoom", true);  }  static get supportsIntegratedFind() {    return (0, _pdfjsLib.shadow)(this, "supportsIntegratedFind", false);  }  static get supportsDocumentFonts() {    return (0, _pdfjsLib.shadow)(this, "supportsDocumentFonts", true);  }  static get supportedMouseWheelZoomModifierKeys() {    return (0, _pdfjsLib.shadow)(this, "supportedMouseWheelZoomModifierKeys", {      ctrlKey: true,      metaKey: true    });  }  static get isInAutomation() {    return (0, _pdfjsLib.shadow)(this, "isInAutomation", false);  }  static updateEditorStates(data) {    throw new Error("Not implemented: updateEditorStates");  }}exports.DefaultExternalServices = DefaultExternalServices;const PDFViewerApplication = {  initialBookmark: document.location.hash.substring(1),  _initializedCapability: (0, _pdfjsLib.createPromiseCapability)(),  appConfig: null,  pdfDocument: null,  pdfLoadingTask: null,  printService: null,  pdfViewer: null,  pdfThumbnailViewer: null,  pdfRenderingQueue: null,  pdfPresentationMode: null,  pdfDocumentProperties: null,  pdfLinkService: null,  pdfHistory: null,  pdfSidebar: null,  pdfSidebarResizer: null,  pdfOutlineViewer: null,  pdfAttachmentViewer: null,  pdfLayerViewer: null,  pdfCursorTools: null,  pdfScriptingManager: null,  store: null,  downloadManager: null,  overlayManager: null,  preferences: null,  toolbar: null,  secondaryToolbar: null,  eventBus: null,  l10n: null,  annotationEditorParams: null,  isInitialViewSet: false,  downloadComplete: false,  isViewerEmbedded: window.parent !== window,  url: "",  baseUrl: "",  _downloadUrl: "",  externalServices: DefaultExternalServices,  _boundEvents: Object.create(null),  documentInfo: null,  metadata: null,  _contentDispositionFilename: null,  _contentLength: null,  _saveInProgress: false,  _wheelUnusedTicks: 0,  _wheelUnusedFactor: 1,  _touchUnusedTicks: 0,  _touchUnusedFactor: 1,  _PDFBug: null,  _hasAnnotationEditors: false,  _title: document.title,  _printAnnotationStoragePromise: null,  _touchInfo: null,  _isCtrlKeyDown: false,  async initialize(appConfig) {    this.preferences = this.externalServices.createPreferences();    this.appConfig = appConfig;    await this._readPreferences();    await this._parseHashParameters();    this._forceCssTheme();    await this._initializeL10n();    if (this.isViewerEmbedded && _app_options.AppOptions.get("externalLinkTarget") === _pdf_link_service.LinkTarget.NONE) {      _app_options.AppOptions.set("externalLinkTarget", _pdf_link_service.LinkTarget.TOP);    }    await this._initializeViewerComponents();    this.bindEvents();    this.bindWindowEvents();    const appContainer = appConfig.appContainer || document.documentElement;    this.l10n.translate(appContainer).then(() => {      this.eventBus.dispatch("localized", {        source: this      });    });    this._initializedCapability.resolve();  },  async _readPreferences() {    if (_app_options.AppOptions.get("disablePreferences")) {      return;    }    if (_app_options.AppOptions._hasUserOptions()) {      console.warn("_readPreferences: The Preferences may override manually set AppOptions; " + 'please use the "disablePreferences"-option in order to prevent that.');    }    try {      _app_options.AppOptions.setAll(await this.preferences.getAll());    } catch (reason) {      console.error(`_readPreferences: "${reason?.message}".`);    }  },  async _parseHashParameters() {    if (!_app_options.AppOptions.get("pdfBugEnabled")) {      return;    }    const hash = document.location.hash.substring(1);    if (!hash) {      return;    }    const {        mainContainer,        viewerContainer      } = this.appConfig,      params = (0, _ui_utils.parseQueryString)(hash);    if (params.get("disableworker") === "true") {      try {        await loadFakeWorker();      } catch (ex) {        console.error(`_parseHashParameters: "${ex.message}".`);      }    }    if (params.has("disablerange")) {      _app_options.AppOptions.set("disableRange", params.get("disablerange") === "true");    }    if (params.has("disablestream")) {      _app_options.AppOptions.set("disableStream", params.get("disablestream") === "true");    }    if (params.has("disableautofetch")) {      _app_options.AppOptions.set("disableAutoFetch", params.get("disableautofetch") === "true");    }    if (params.has("disablefontface")) {      _app_options.AppOptions.set("disableFontFace", params.get("disablefontface") === "true");    }    if (params.has("disablehistory")) {      _app_options.AppOptions.set("disableHistory", params.get("disablehistory") === "true");    }    if (params.has("verbosity")) {      _app_options.AppOptions.set("verbosity", params.get("verbosity") | 0);    }    if (params.has("textlayer")) {      switch (params.get("textlayer")) {        case "off":          _app_options.AppOptions.set("textLayerMode", _ui_utils.TextLayerMode.DISABLE);          break;        case "visible":        case "shadow":        case "hover":          viewerContainer.classList.add(`textLayer-${params.get("textlayer")}`);          try {            await loadPDFBug(this);            this._PDFBug.loadCSS();          } catch (ex) {            console.error(`_parseHashParameters: "${ex.message}".`);          }          break;      }    }    if (params.has("pdfbug")) {      _app_options.AppOptions.set("pdfBug", true);      _app_options.AppOptions.set("fontExtraProperties", true);      const enabled = params.get("pdfbug").split(",");      try {        await loadPDFBug(this);        this._PDFBug.init({          OPS: _pdfjsLib.OPS        }, mainContainer, enabled);      } catch (ex) {        console.error(`_parseHashParameters: "${ex.message}".`);      }    }    if (params.has("locale")) {      _app_options.AppOptions.set("locale", params.get("locale"));    }  },  async _initializeL10n() {    this.l10n = this.externalServices.createL10n({      locale: _app_options.AppOptions.get("locale")    });    const dir = await this.l10n.getDirection();    document.getElementsByTagName("html")[0].dir = dir;  },  _forceCssTheme() {    const cssTheme = _app_options.AppOptions.get("viewerCssTheme");    if (cssTheme === ViewerCssTheme.AUTOMATIC || !Object.values(ViewerCssTheme).includes(cssTheme)) {      return;    }    try {      const styleSheet = document.styleSheets[0];      const cssRules = styleSheet?.cssRules || [];      for (let i = 0, ii = cssRules.length; i < ii; i++) {        const rule = cssRules[i];        if (rule instanceof CSSMediaRule && rule.media?.[0] === "(prefers-color-scheme: dark)") {          if (cssTheme === ViewerCssTheme.LIGHT) {            styleSheet.deleteRule(i);            return;          }          const darkRules = /^@media \(prefers-color-scheme: dark\) {\n\s*([\w\s-.,:;/\\{}()]+)\n}$/.exec(rule.cssText);          if (darkRules?.[1]) {            styleSheet.deleteRule(i);            styleSheet.insertRule(darkRules[1], i);          }          return;        }      }    } catch (reason) {      console.error(`_forceCssTheme: "${reason?.message}".`);    }  },  async _initializeViewerComponents() {    const {      appConfig,      externalServices    } = this;    const eventBus = externalServices.isInAutomation ? new _event_utils.AutomationEventBus() : new _event_utils.EventBus();    this.eventBus = eventBus;    this.overlayManager = new _overlay_manager.OverlayManager();    const pdfRenderingQueue = new _pdf_rendering_queue.PDFRenderingQueue();    pdfRenderingQueue.onIdle = this._cleanup.bind(this);    this.pdfRenderingQueue = pdfRenderingQueue;    const pdfLinkService = new _pdf_link_service.PDFLinkService({      eventBus,      externalLinkTarget: _app_options.AppOptions.get("externalLinkTarget"),      externalLinkRel: _app_options.AppOptions.get("externalLinkRel"),      ignoreDestinationZoom: _app_options.AppOptions.get("ignoreDestinationZoom")    });    this.pdfLinkService = pdfLinkService;    const downloadManager = externalServices.createDownloadManager();    this.downloadManager = downloadManager;    const findController = new _pdf_find_controller.PDFFindController({      linkService: pdfLinkService,      eventBus,      updateMatchesCountOnProgress: true    });    this.findController = findController;    const pdfScriptingManager = new _pdf_scripting_manager.PDFScriptingManager({      eventBus,      sandboxBundleSrc: _app_options.AppOptions.get("sandboxBundleSrc"),      scriptingFactory: externalServices,      docPropertiesLookup: this._scriptingDocProperties.bind(this)    });    this.pdfScriptingManager = pdfScriptingManager;    const container = appConfig.mainContainer,      viewer = appConfig.viewerContainer;    const annotationEditorMode = _app_options.AppOptions.get("annotationEditorMode");    const pageColors = _app_options.AppOptions.get("forcePageColors") || window.matchMedia("(forced-colors: active)").matches ? {      background: _app_options.AppOptions.get("pageColorsBackground"),      foreground: _app_options.AppOptions.get("pageColorsForeground")    } : null;    this.pdfViewer = new _pdf_viewer.PDFViewer({      container,      viewer,      eventBus,      renderingQueue: pdfRenderingQueue,      linkService: pdfLinkService,      downloadManager,      findController,      scriptingManager: _app_options.AppOptions.get("enableScripting") && pdfScriptingManager,      renderer: _app_options.AppOptions.get("renderer"),      l10n: this.l10n,      textLayerMode: _app_options.AppOptions.get("textLayerMode"),      annotationMode: _app_options.AppOptions.get("annotationMode"),      annotationEditorMode,      imageResourcesPath: _app_options.AppOptions.get("imageResourcesPath"),      enablePrintAutoRotate: _app_options.AppOptions.get("enablePrintAutoRotate"),      useOnlyCssZoom: _app_options.AppOptions.get("useOnlyCssZoom"),      isOffscreenCanvasSupported: _app_options.AppOptions.get("isOffscreenCanvasSupported"),      maxCanvasPixels: _app_options.AppOptions.get("maxCanvasPixels"),      enablePermissions: _app_options.AppOptions.get("enablePermissions"),      pageColors    });    pdfRenderingQueue.setViewer(this.pdfViewer);    pdfLinkService.setViewer(this.pdfViewer);    pdfScriptingManager.setViewer(this.pdfViewer);    if (appConfig.sidebar?.thumbnailView) {      this.pdfThumbnailViewer = new _pdf_thumbnail_viewer.PDFThumbnailViewer({        container: appConfig.sidebar.thumbnailView,        eventBus,        renderingQueue: pdfRenderingQueue,        linkService: pdfLinkService,        l10n: this.l10n,        pageColors      });      pdfRenderingQueue.setThumbnailViewer(this.pdfThumbnailViewer);    }    if (!this.isViewerEmbedded && !_app_options.AppOptions.get("disableHistory")) {      this.pdfHistory = new _pdf_history.PDFHistory({        linkService: pdfLinkService,        eventBus      });      pdfLinkService.setHistory(this.pdfHistory);    }    if (!this.supportsIntegratedFind && appConfig.findBar) {      this.findBar = new _pdf_find_bar.PDFFindBar(appConfig.findBar, eventBus, this.l10n);    }    if (appConfig.annotationEditorParams) {      if (annotationEditorMode !== _pdfjsLib.AnnotationEditorType.DISABLE) {        this.annotationEditorParams = new _annotation_editor_params.AnnotationEditorParams(appConfig.annotationEditorParams, eventBus);      } else {        for (const id of ["editorModeButtons", "editorModeSeparator"]) {          document.getElementById(id)?.classList.add("hidden");        }      }    }    if (appConfig.documentProperties) {      this.pdfDocumentProperties = new _pdf_document_properties.PDFDocumentProperties(appConfig.documentProperties, this.overlayManager, eventBus, this.l10n, () => {        return this._docFilename;      });    }    this.pdfCursorTools = new _pdf_cursor_tools.PDFCursorTools({      container,      eventBus,      cursorToolOnLoad: _app_options.AppOptions.get("cursorToolOnLoad")    });    if (appConfig.toolbar) {      this.toolbar = new _toolbar.Toolbar(appConfig.toolbar, eventBus, this.l10n);    }    if (appConfig.secondaryToolbar) {      this.secondaryToolbar = new _secondary_toolbar.SecondaryToolbar(appConfig.secondaryToolbar, eventBus, this.externalServices);    }    if (this.supportsFullscreen) {      this.pdfPresentationMode = new _pdf_presentation_mode.PDFPresentationMode({        container,        pdfViewer: this.pdfViewer,        eventBus      });    }    if (appConfig.passwordOverlay) {      this.passwordPrompt = new _password_prompt.PasswordPrompt(appConfig.passwordOverlay, this.overlayManager, this.l10n, this.isViewerEmbedded);    }    if (appConfig.sidebar?.outlineView) {      this.pdfOutlineViewer = new _pdf_outline_viewer.PDFOutlineViewer({        container: appConfig.sidebar.outlineView,        eventBus,        linkService: pdfLinkService,        downloadManager      });    }    if (appConfig.sidebar?.attachmentsView) {      this.pdfAttachmentViewer = new _pdf_attachment_viewer.PDFAttachmentViewer({        container: appConfig.sidebar.attachmentsView,        eventBus,        downloadManager      });    }    if (appConfig.sidebar?.layersView) {      this.pdfLayerViewer = new _pdf_layer_viewer.PDFLayerViewer({        container: appConfig.sidebar.layersView,        eventBus,        l10n: this.l10n      });    }    if (appConfig.sidebar) {      this.pdfSidebar = new _pdf_sidebar.PDFSidebar({        elements: appConfig.sidebar,        pdfViewer: this.pdfViewer,        pdfThumbnailViewer: this.pdfThumbnailViewer,        eventBus,        l10n: this.l10n      });      this.pdfSidebar.onToggled = this.forceRendering.bind(this);      this.pdfSidebarResizer = new _pdf_sidebar_resizer.PDFSidebarResizer(appConfig.sidebarResizer, eventBus, this.l10n);    }  },  run(config) {    this.initialize(config).then(webViewerInitialized);  },  get initialized() {    return this._initializedCapability.settled;  },  get initializedPromise() {    return this._initializedCapability.promise;  },  zoomIn(steps, scaleFactor) {    if (this.pdfViewer.isInPresentationMode) {      return;    }    this.pdfViewer.increaseScale({      drawingDelay: _app_options.AppOptions.get("defaultZoomDelay"),      steps,      scaleFactor    });  },  zoomOut(steps, scaleFactor) {    if (this.pdfViewer.isInPresentationMode) {      return;    }    this.pdfViewer.decreaseScale({      drawingDelay: _app_options.AppOptions.get("defaultZoomDelay"),      steps,      scaleFactor    });  },  zoomReset() {    if (this.pdfViewer.isInPresentationMode) {      return;    }    this.pdfViewer.currentScaleValue = _ui_utils.DEFAULT_SCALE_VALUE;  },  get pagesCount() {    return this.pdfDocument ? this.pdfDocument.numPages : 0;  },  get page() {    return this.pdfViewer.currentPageNumber;  },  set page(val) {    this.pdfViewer.currentPageNumber = val;  },  get supportsPrinting() {    return PDFPrintServiceFactory.instance.supportsPrinting;  },  get supportsFullscreen() {    return (0, _pdfjsLib.shadow)(this, "supportsFullscreen", document.fullscreenEnabled);  },  get supportsPinchToZoom() {    return this.externalServices.supportsPinchToZoom;  },  get supportsIntegratedFind() {    return this.externalServices.supportsIntegratedFind;  },  get supportsDocumentFonts() {    return this.externalServices.supportsDocumentFonts;  },  get loadingBar() {    const barElement = document.getElementById("loadingBar");    const bar = barElement ? new _ui_utils.ProgressBar(barElement) : null;    return (0, _pdfjsLib.shadow)(this, "loadingBar", bar);  },  get supportedMouseWheelZoomModifierKeys() {    return this.externalServices.supportedMouseWheelZoomModifierKeys;  },  initPassiveLoading() {    throw new Error("Not implemented: initPassiveLoading");  },  setTitleUsingUrl(url = "", downloadUrl = null) {    this.url = url;    this.baseUrl = url.split("#")[0];    if (downloadUrl) {      this._downloadUrl = downloadUrl === url ? this.baseUrl : downloadUrl.split("#")[0];    }    if ((0, _pdfjsLib.isDataScheme)(url)) {      this._hideViewBookmark();    }    let title = (0, _pdfjsLib.getPdfFilenameFromUrl)(url, "");    if (!title) {      try {        title = decodeURIComponent((0, _pdfjsLib.getFilenameFromUrl)(url)) || url;      } catch (ex) {        title = url;      }    }    this.setTitle(title);  },  setTitle(title = this._title) {    this._title = title;    if (this.isViewerEmbedded) {      return;    }    const editorIndicator = this._hasAnnotationEditors && !this.pdfRenderingQueue.printing;    document.title = `${editorIndicator ? "* " : ""}${title}`;  },  get _docFilename() {    return this._contentDispositionFilename || (0, _pdfjsLib.getPdfFilenameFromUrl)(this.url);  },  _hideViewBookmark() {    const {      secondaryToolbar    } = this.appConfig;    secondaryToolbar?.viewBookmarkButton.classList.add("hidden");    if (secondaryToolbar?.presentationModeButton.classList.contains("hidden")) {      document.getElementById("viewBookmarkSeparator")?.classList.add("hidden");    }  },  async close() {    this._unblockDocumentLoadEvent();    this._hideViewBookmark();    if (!this.pdfLoadingTask) {      return;    }    if (this.pdfDocument?.annotationStorage.size > 0 && this._annotationStorageModified) {      try {        await this.save();      } catch (reason) {}    }    const promises = [];    promises.push(this.pdfLoadingTask.destroy());    this.pdfLoadingTask = null;    if (this.pdfDocument) {      this.pdfDocument = null;      this.pdfThumbnailViewer?.setDocument(null);      this.pdfViewer.setDocument(null);      this.pdfLinkService.setDocument(null);      this.pdfDocumentProperties?.setDocument(null);    }    this.pdfLinkService.externalLinkEnabled = true;    this.store = null;    this.isInitialViewSet = false;    this.downloadComplete = false;    this.url = "";    this.baseUrl = "";    this._downloadUrl = "";    this.documentInfo = null;    this.metadata = null;    this._contentDispositionFilename = null;    this._contentLength = null;    this._saveInProgress = false;    this._hasAnnotationEditors = false;    promises.push(this.pdfScriptingManager.destroyPromise);    this.setTitle();    this.pdfSidebar?.reset();    this.pdfOutlineViewer?.reset();    this.pdfAttachmentViewer?.reset();    this.pdfLayerViewer?.reset();    this.pdfHistory?.reset();    this.findBar?.reset();    this.toolbar?.reset();    this.secondaryToolbar?.reset();    this._PDFBug?.cleanup();    await Promise.all(promises);  },  async open(args) {    let deprecatedArgs = false;    if (typeof args === "string") {      args = {        url: args      };      deprecatedArgs = true;    } else if (args?.byteLength) {      args = {        data: args      };      deprecatedArgs = true;    }    if (deprecatedArgs) {      console.error("The `PDFViewerApplication.open` signature was updated, please use an object instead.");    }    if (this.pdfLoadingTask) {      await this.close();    }    const workerParameters = _app_options.AppOptions.getAll(_app_options.OptionKind.WORKER);    for (const key in workerParameters) {      _pdfjsLib.GlobalWorkerOptions[key] = workerParameters[key];    }    const parameters = Object.create(null);    if (args.url) {      if (args.originalUrl) {        this.setTitleUsingUrl(args.originalUrl, args.url);        delete args.originalUrl;      } else {        this.setTitleUsingUrl(args.url, args.url);      }    }    const apiParameters = _app_options.AppOptions.getAll(_app_options.OptionKind.API);    for (const key in apiParameters) {      let value = apiParameters[key];      if (key === "docBaseUrl") {}      parameters[key] = value;    }    for (const key in args) {      parameters[key] = args[key];    }    const loadingTask = (0, _pdfjsLib.getDocument)(parameters);    this.pdfLoadingTask = loadingTask;    loadingTask.onPassword = (updateCallback, reason) => {      if (this.isViewerEmbedded) {        this._unblockDocumentLoadEvent();      }      this.pdfLinkService.externalLinkEnabled = false;      this.passwordPrompt.setUpdateCallback(updateCallback, reason);      this.passwordPrompt.open();    };    loadingTask.onProgress = ({      loaded,      total    }) => {      this.progress(loaded / total);    };    return loadingTask.promise.then(pdfDocument => {      this.load(pdfDocument);    }, reason => {      if (loadingTask !== this.pdfLoadingTask) {        return undefined;      }      let key = "loading_error";      if (reason instanceof _pdfjsLib.InvalidPDFException) {        key = "invalid_file_error";      } else if (reason instanceof _pdfjsLib.MissingPDFException) {        key = "missing_file_error";      } else if (reason instanceof _pdfjsLib.UnexpectedResponseException) {        key = "unexpected_response_error";      }      return this.l10n.get(key).then(msg => {        this._documentError(msg, {          message: reason?.message        });        throw reason;      });    });  },  _ensureDownloadComplete() {    if (this.pdfDocument && this.downloadComplete) {      return;    }    throw new Error("PDF document not downloaded.");  },  async download() {    const url = this._downloadUrl,      filename = this._docFilename;    try {      this._ensureDownloadComplete();      const data = await this.pdfDocument.getData();      const blob = new Blob([data], {        type: "application/pdf"      });      await this.downloadManager.download(blob, url, filename);    } catch (reason) {      await this.downloadManager.downloadUrl(url, filename);    }  },  async save() {    if (this._saveInProgress) {      return;    }    this._saveInProgress = true;    await this.pdfScriptingManager.dispatchWillSave();    const url = this._downloadUrl,      filename = this._docFilename;    try {      this._ensureDownloadComplete();      const data = await this.pdfDocument.saveDocument();      const blob = new Blob([data], {        type: "application/pdf"      });      await this.downloadManager.download(blob, url, filename);    } catch (reason) {      console.error(`Error when saving the document: ${reason.message}`);      await this.download();    } finally {      await this.pdfScriptingManager.dispatchDidSave();      this._saveInProgress = false;    }    if (this._hasAnnotationEditors) {      this.externalServices.reportTelemetry({        type: "editing",        data: {          type: "save"        }      });    }  },  downloadOrSave() {    if (this.pdfDocument?.annotationStorage.size > 0) {      this.save();    } else {      this.download();    }  },  _documentError(message, moreInfo = null) {    this._unblockDocumentLoadEvent();    this._otherError(message, moreInfo);    this.eventBus.dispatch("documenterror", {      source: this,      message,      reason: moreInfo?.message ?? null    });  },  _otherError(message, moreInfo = null) {    const moreInfoText = [`PDF.js v${_pdfjsLib.version || "?"} (build: ${_pdfjsLib.build || "?"})`];    if (moreInfo) {      moreInfoText.push(`Message: ${moreInfo.message}`);      if (moreInfo.stack) {        moreInfoText.push(`Stack: ${moreInfo.stack}`);      } else {        if (moreInfo.filename) {          moreInfoText.push(`File: ${moreInfo.filename}`);        }        if (moreInfo.lineNumber) {          moreInfoText.push(`Line: ${moreInfo.lineNumber}`);        }      }    }    console.error(`${message}\n\n${moreInfoText.join("\n")}`);  },  progress(level) {    if (!this.loadingBar || this.downloadComplete) {      return;    }    const percent = Math.round(level * 100);    if (percent <= this.loadingBar.percent) {      return;    }    this.loadingBar.percent = percent;    if (this.pdfDocument?.loadingParams.disableAutoFetch ?? _app_options.AppOptions.get("disableAutoFetch")) {      this.loadingBar.setDisableAutoFetch();    }  },  load(pdfDocument) {    this.pdfDocument = pdfDocument;    pdfDocument.getDownloadInfo().then(({      length    }) => {      this._contentLength = length;      this.downloadComplete = true;      this.loadingBar?.hide();      firstPagePromise.then(() => {        this.eventBus.dispatch("documentloaded", {          source: this        });      });    });    const pageLayoutPromise = pdfDocument.getPageLayout().catch(function () {});    const pageModePromise = pdfDocument.getPageMode().catch(function () {});    const openActionPromise = pdfDocument.getOpenAction().catch(function () {});    this.toolbar?.setPagesCount(pdfDocument.numPages, false);    this.secondaryToolbar?.setPagesCount(pdfDocument.numPages);    let baseDocumentUrl;    baseDocumentUrl = null;    if (baseDocumentUrl && (0, _pdfjsLib.isDataScheme)(baseDocumentUrl)) {      baseDocumentUrl = null;    }    this.pdfLinkService.setDocument(pdfDocument, baseDocumentUrl);    this.pdfDocumentProperties?.setDocument(pdfDocument);    const pdfViewer = this.pdfViewer;    pdfViewer.setDocument(pdfDocument);    const {      firstPagePromise,      onePageRendered,      pagesPromise    } = pdfViewer;    this.pdfThumbnailViewer?.setDocument(pdfDocument);    const storedPromise = (this.store = new _view_history.ViewHistory(pdfDocument.fingerprints[0])).getMultiple({      page: null,      zoom: _ui_utils.DEFAULT_SCALE_VALUE,      scrollLeft: "0",      scrollTop: "0",      rotation: null,      sidebarView: _ui_utils.SidebarView.UNKNOWN,      scrollMode: _ui_utils.ScrollMode.UNKNOWN,      spreadMode: _ui_utils.SpreadMode.UNKNOWN    }).catch(() => {      return Object.create(null);    });    firstPagePromise.then(pdfPage => {      this.loadingBar?.setWidth(this.appConfig.viewerContainer);      this._initializeAnnotationStorageCallbacks(pdfDocument);      Promise.all([_ui_utils.animationStarted, storedPromise, pageLayoutPromise, pageModePromise, openActionPromise]).then(async ([timeStamp, stored, pageLayout, pageMode, openAction]) => {        const viewOnLoad = _app_options.AppOptions.get("viewOnLoad");        this._initializePdfHistory({          fingerprint: pdfDocument.fingerprints[0],          viewOnLoad,          initialDest: openAction?.dest        });        const initialBookmark = this.initialBookmark;        const zoom = _app_options.AppOptions.get("defaultZoomValue");        let hash = zoom ? `zoom=${zoom}` : null;        let rotation = null;        let sidebarView = _app_options.AppOptions.get("sidebarViewOnLoad");        let scrollMode = _app_options.AppOptions.get("scrollModeOnLoad");        let spreadMode = _app_options.AppOptions.get("spreadModeOnLoad");        if (stored.page && viewOnLoad !== ViewOnLoad.INITIAL) {          hash = `page=${stored.page}&zoom=${zoom || stored.zoom},` + `${stored.scrollLeft},${stored.scrollTop}`;          rotation = parseInt(stored.rotation, 10);          if (sidebarView === _ui_utils.SidebarView.UNKNOWN) {            sidebarView = stored.sidebarView | 0;          }          if (scrollMode === _ui_utils.ScrollMode.UNKNOWN) {            scrollMode = stored.scrollMode | 0;          }          if (spreadMode === _ui_utils.SpreadMode.UNKNOWN) {            spreadMode = stored.spreadMode | 0;          }        }        if (pageMode && sidebarView === _ui_utils.SidebarView.UNKNOWN) {          sidebarView = (0, _ui_utils.apiPageModeToSidebarView)(pageMode);        }        if (pageLayout && scrollMode === _ui_utils.ScrollMode.UNKNOWN && spreadMode === _ui_utils.SpreadMode.UNKNOWN) {          const modes = (0, _ui_utils.apiPageLayoutToViewerModes)(pageLayout);          spreadMode = modes.spreadMode;        }        this.setInitialView(hash, {          rotation,          sidebarView,          scrollMode,          spreadMode        });        this.eventBus.dispatch("documentinit", {          source: this        });        if (!this.isViewerEmbedded) {          pdfViewer.focus();        }        await Promise.race([pagesPromise, new Promise(resolve => {          setTimeout(resolve, FORCE_PAGES_LOADED_TIMEOUT);        })]);        if (!initialBookmark && !hash) {          return;        }        if (pdfViewer.hasEqualPageSizes) {          return;        }        this.initialBookmark = initialBookmark;        pdfViewer.currentScaleValue = pdfViewer.currentScaleValue;        this.setInitialView(hash);      }).catch(() => {        this.setInitialView();      }).then(function () {        pdfViewer.update();      });    });    pagesPromise.then(() => {      this._unblockDocumentLoadEvent();      this._initializeAutoPrint(pdfDocument, openActionPromise);    }, reason => {      this.l10n.get("loading_error").then(msg => {        this._documentError(msg, {          message: reason?.message        });      });    });    onePageRendered.then(data => {      this.externalServices.reportTelemetry({        type: "pageInfo",        timestamp: data.timestamp      });      pdfDocument.getOutline().then(outline => {        if (pdfDocument !== this.pdfDocument) {          return;        }        this.pdfOutlineViewer?.render({          outline,          pdfDocument        });      });      pdfDocument.getAttachments().then(attachments => {        if (pdfDocument !== this.pdfDocument) {          return;        }        this.pdfAttachmentViewer?.render({          attachments        });      });      pdfViewer.optionalContentConfigPromise.then(optionalContentConfig => {        if (pdfDocument !== this.pdfDocument) {          return;        }        this.pdfLayerViewer?.render({          optionalContentConfig,          pdfDocument        });      });    });    this._initializePageLabels(pdfDocument);    this._initializeMetadata(pdfDocument);  },  async _scriptingDocProperties(pdfDocument) {    if (!this.documentInfo) {      await new Promise(resolve => {        this.eventBus._on("metadataloaded", resolve, {          once: true        });      });      if (pdfDocument !== this.pdfDocument) {        return null;      }    }    if (!this._contentLength) {      await new Promise(resolve => {        this.eventBus._on("documentloaded", resolve, {          once: true        });      });      if (pdfDocument !== this.pdfDocument) {        return null;      }    }    return {      ...this.documentInfo,      baseURL: this.baseUrl,      filesize: this._contentLength,      filename: this._docFilename,      metadata: this.metadata?.getRaw(),      authors: this.metadata?.get("dc:creator"),      numPages: this.pagesCount,      URL: this.url    };  },  async _initializeAutoPrint(pdfDocument, openActionPromise) {    const [openAction, javaScript] = await Promise.all([openActionPromise, !this.pdfViewer.enableScripting ? pdfDocument.getJavaScript() : null]);    if (pdfDocument !== this.pdfDocument) {      return;    }    let triggerAutoPrint = false;    if (openAction?.action === "Print") {      triggerAutoPrint = true;    }    if (javaScript) {      javaScript.some(js => {        if (!js) {          return false;        }        console.warn("Warning: JavaScript support is not enabled");        return true;      });      if (!triggerAutoPrint) {        for (const js of javaScript) {          if (js && _ui_utils.AutoPrintRegExp.test(js)) {            triggerAutoPrint = true;            break;          }        }      }    }    if (triggerAutoPrint) {      this.triggerPrinting();    }  },  async _initializeMetadata(pdfDocument) {    const {      info,      metadata,      contentDispositionFilename,      contentLength    } = await pdfDocument.getMetadata();    if (pdfDocument !== this.pdfDocument) {      return;    }    this.documentInfo = info;    this.metadata = metadata;    this._contentDispositionFilename ??= contentDispositionFilename;    this._contentLength ??= contentLength;    console.log(`PDF ${pdfDocument.fingerprints[0]} [${info.PDFFormatVersion} ` + `${(info.Producer || "-").trim()} / ${(info.Creator || "-").trim()}] ` + `(PDF.js: ${_pdfjsLib.version || "?"} [${_pdfjsLib.build || "?"}])`);    let pdfTitle = info.Title;    const metadataTitle = metadata?.get("dc:title");    if (metadataTitle) {      if (metadataTitle !== "Untitled" && !/[\uFFF0-\uFFFF]/g.test(metadataTitle)) {        pdfTitle = metadataTitle;      }    }    if (pdfTitle) {      this.setTitle(`${pdfTitle} - ${this._contentDispositionFilename || this._title}`);    } else if (this._contentDispositionFilename) {      this.setTitle(this._contentDispositionFilename);    }    if (info.IsXFAPresent && !info.IsAcroFormPresent && !pdfDocument.isPureXfa) {      if (pdfDocument.loadingParams.enableXfa) {        console.warn("Warning: XFA Foreground documents are not supported");      } else {        console.warn("Warning: XFA support is not enabled");      }    } else if ((info.IsAcroFormPresent || info.IsXFAPresent) && !this.pdfViewer.renderForms) {      console.warn("Warning: Interactive form support is not enabled");    }    if (info.IsSignaturesPresent) {      console.warn("Warning: Digital signatures validation is not supported");    }    this.eventBus.dispatch("metadataloaded", {      source: this    });  },  async _initializePageLabels(pdfDocument) {    const labels = await pdfDocument.getPageLabels();    if (pdfDocument !== this.pdfDocument) {      return;    }    if (!labels || _app_options.AppOptions.get("disablePageLabels")) {      return;    }    const numLabels = labels.length;    let standardLabels = 0,      emptyLabels = 0;    for (let i = 0; i < numLabels; i++) {      const label = labels[i];      if (label === (i + 1).toString()) {        standardLabels++;      } else if (label === "") {        emptyLabels++;      } else {        break;      }    }    if (standardLabels >= numLabels || emptyLabels >= numLabels) {      return;    }    const {      pdfViewer,      pdfThumbnailViewer,      toolbar    } = this;    pdfViewer.setPageLabels(labels);    pdfThumbnailViewer?.setPageLabels(labels);    toolbar?.setPagesCount(numLabels, true);    toolbar?.setPageNumber(pdfViewer.currentPageNumber, pdfViewer.currentPageLabel);  },  _initializePdfHistory({    fingerprint,    viewOnLoad,    initialDest = null  }) {    if (!this.pdfHistory) {      return;    }    this.pdfHistory.initialize({      fingerprint,      resetHistory: viewOnLoad === ViewOnLoad.INITIAL,      updateUrl: _app_options.AppOptions.get("historyUpdateUrl")    });    if (this.pdfHistory.initialBookmark) {      this.initialBookmark = this.pdfHistory.initialBookmark;      this.initialRotation = this.pdfHistory.initialRotation;    }    if (initialDest && !this.initialBookmark && viewOnLoad === ViewOnLoad.UNKNOWN) {      this.initialBookmark = JSON.stringify(initialDest);      this.pdfHistory.push({        explicitDest: initialDest,        pageNumber: null      });    }  },  _initializeAnnotationStorageCallbacks(pdfDocument) {    if (pdfDocument !== this.pdfDocument) {      return;    }    const {      annotationStorage    } = pdfDocument;    annotationStorage.onSetModified = () => {      window.addEventListener("beforeunload", beforeUnload);      this._annotationStorageModified = true;    };    annotationStorage.onResetModified = () => {      window.removeEventListener("beforeunload", beforeUnload);      delete this._annotationStorageModified;    };    annotationStorage.onAnnotationEditor = typeStr => {      this._hasAnnotationEditors = !!typeStr;      this.setTitle();      if (typeStr) {        this.externalServices.reportTelemetry({          type: "editing",          data: {            type: typeStr          }        });      }    };  },  setInitialView(storedHash, {    rotation,    sidebarView,    scrollMode,    spreadMode  } = {}) {    const setRotation = angle => {      if ((0, _ui_utils.isValidRotation)(angle)) {        this.pdfViewer.pagesRotation = angle;      }    };    const setViewerModes = (scroll, spread) => {      if ((0, _ui_utils.isValidScrollMode)(scroll)) {        this.pdfViewer.scrollMode = scroll;      }      if ((0, _ui_utils.isValidSpreadMode)(spread)) {        this.pdfViewer.spreadMode = spread;      }    };    this.isInitialViewSet = true;    this.pdfSidebar?.setInitialView(sidebarView);    setViewerModes(scrollMode, spreadMode);    if (this.initialBookmark) {      setRotation(this.initialRotation);      delete this.initialRotation;      this.pdfLinkService.setHash(this.initialBookmark);      this.initialBookmark = null;    } else if (storedHash) {      setRotation(rotation);      this.pdfLinkService.setHash(storedHash);    }    this.toolbar?.setPageNumber(this.pdfViewer.currentPageNumber, this.pdfViewer.currentPageLabel);    this.secondaryToolbar?.setPageNumber(this.pdfViewer.currentPageNumber);    if (!this.pdfViewer.currentScaleValue) {      this.pdfViewer.currentScaleValue = _ui_utils.DEFAULT_SCALE_VALUE;    }  },  _cleanup() {    if (!this.pdfDocument) {      return;    }    this.pdfViewer.cleanup();    this.pdfThumbnailViewer?.cleanup();    this.pdfDocument.cleanup(this.pdfViewer.renderer === _ui_utils.RendererType.SVG);  },  forceRendering() {    this.pdfRenderingQueue.printing = !!this.printService;    this.pdfRenderingQueue.isThumbnailViewEnabled = this.pdfSidebar?.visibleView === _ui_utils.SidebarView.THUMBS;    this.pdfRenderingQueue.renderHighestPriority();  },  beforePrint() {    this._printAnnotationStoragePromise = this.pdfScriptingManager.dispatchWillPrint().catch(() => {}).then(() => {      return this.pdfDocument?.annotationStorage.print;    });    if (this.printService) {      return;    }    if (!this.supportsPrinting) {      this.l10n.get("printing_not_supported").then(msg => {        this._otherError(msg);      });      return;    }    if (!this.pdfViewer.pageViewsReady) {      this.l10n.get("printing_not_ready").then(msg => {        window.alert(msg);      });      return;    }    const pagesOverview = this.pdfViewer.getPagesOverview();    const printContainer = this.appConfig.printContainer;    const printResolution = _app_options.AppOptions.get("printResolution");    const optionalContentConfigPromise = this.pdfViewer.optionalContentConfigPromise;    const printService = PDFPrintServiceFactory.instance.createPrintService(this.pdfDocument, pagesOverview, printContainer, printResolution, optionalContentConfigPromise, this._printAnnotationStoragePromise, this.l10n);    this.printService = printService;    this.forceRendering();    this.setTitle();    printService.layout();    if (this._hasAnnotationEditors) {      this.externalServices.reportTelemetry({        type: "editing",        data: {          type: "print"        }      });    }  },  afterPrint() {    if (this._printAnnotationStoragePromise) {      this._printAnnotationStoragePromise.then(() => {        this.pdfScriptingManager.dispatchDidPrint();      });      this._printAnnotationStoragePromise = null;    }    if (this.printService) {      this.printService.destroy();      this.printService = null;      this.pdfDocument?.annotationStorage.resetModified();    }    this.forceRendering();    this.setTitle();  },  rotatePages(delta) {    this.pdfViewer.pagesRotation += delta;  },  requestPresentationMode() {    this.pdfPresentationMode?.request();  },  triggerPrinting() {    if (!this.supportsPrinting) {      return;    }    window.print();  },  bindEvents() {    const {      eventBus,      _boundEvents    } = this;    _boundEvents.beforePrint = this.beforePrint.bind(this);    _boundEvents.afterPrint = this.afterPrint.bind(this);    eventBus._on("resize", webViewerResize);    eventBus._on("hashchange", webViewerHashchange);    eventBus._on("beforeprint", _boundEvents.beforePrint);    eventBus._on("afterprint", _boundEvents.afterPrint);    eventBus._on("pagerender", webViewerPageRender);    eventBus._on("pagerendered", webViewerPageRendered);    eventBus._on("updateviewarea", webViewerUpdateViewarea);    eventBus._on("pagechanging", webViewerPageChanging);    eventBus._on("scalechanging", webViewerScaleChanging);    eventBus._on("rotationchanging", webViewerRotationChanging);    eventBus._on("sidebarviewchanged", webViewerSidebarViewChanged);    eventBus._on("pagemode", webViewerPageMode);    eventBus._on("namedaction", webViewerNamedAction);    eventBus._on("presentationmodechanged", webViewerPresentationModeChanged);    eventBus._on("presentationmode", webViewerPresentationMode);    eventBus._on("switchannotationeditormode", webViewerSwitchAnnotationEditorMode);    eventBus._on("switchannotationeditorparams", webViewerSwitchAnnotationEditorParams);    eventBus._on("print", webViewerPrint);    eventBus._on("download", webViewerDownload);    eventBus._on("firstpage", webViewerFirstPage);    eventBus._on("lastpage", webViewerLastPage);    eventBus._on("nextpage", webViewerNextPage);    eventBus._on("previouspage", webViewerPreviousPage);    eventBus._on("zoomin", webViewerZoomIn);    eventBus._on("zoomout", webViewerZoomOut);    eventBus._on("zoomreset", webViewerZoomReset);    eventBus._on("pagenumberchanged", webViewerPageNumberChanged);    eventBus._on("scalechanged", webViewerScaleChanged);    eventBus._on("rotatecw", webViewerRotateCw);    eventBus._on("rotateccw", webViewerRotateCcw);    eventBus._on("optionalcontentconfig", webViewerOptionalContentConfig);    eventBus._on("switchscrollmode", webViewerSwitchScrollMode);    eventBus._on("scrollmodechanged", webViewerScrollModeChanged);    eventBus._on("switchspreadmode", webViewerSwitchSpreadMode);    eventBus._on("spreadmodechanged", webViewerSpreadModeChanged);    eventBus._on("documentproperties", webViewerDocumentProperties);    eventBus._on("findfromurlhash", webViewerFindFromUrlHash);    eventBus._on("updatefindmatchescount", webViewerUpdateFindMatchesCount);    eventBus._on("updatefindcontrolstate", webViewerUpdateFindControlState);    if (_app_options.AppOptions.get("pdfBug")) {      _boundEvents.reportPageStatsPDFBug = reportPageStatsPDFBug;      eventBus._on("pagerendered", _boundEvents.reportPageStatsPDFBug);      eventBus._on("pagechanging", _boundEvents.reportPageStatsPDFBug);    }    eventBus._on("fileinputchange", webViewerFileInputChange);    eventBus._on("openfile", webViewerOpenFile);  },  bindWindowEvents() {    const {      eventBus,      _boundEvents    } = this;    function addWindowResolutionChange(evt = null) {      if (evt) {        webViewerResolutionChange(evt);      }      const mediaQueryList = window.matchMedia(`(resolution: ${window.devicePixelRatio || 1}dppx)`);      mediaQueryList.addEventListener("change", addWindowResolutionChange, {        once: true      });      _boundEvents.removeWindowResolutionChange ||= function () {        mediaQueryList.removeEventListener("change", addWindowResolutionChange);        _boundEvents.removeWindowResolutionChange = null;      };    }    addWindowResolutionChange();    _boundEvents.windowResize = () => {      eventBus.dispatch("resize", {        source: window      });    };    _boundEvents.windowHashChange = () => {      eventBus.dispatch("hashchange", {        source: window,        hash: document.location.hash.substring(1)      });    };    _boundEvents.windowBeforePrint = () => {      eventBus.dispatch("beforeprint", {        source: window      });    };    _boundEvents.windowAfterPrint = () => {      eventBus.dispatch("afterprint", {        source: window      });    };    _boundEvents.windowUpdateFromSandbox = event => {      eventBus.dispatch("updatefromsandbox", {        source: window,        detail: event.detail      });    };    window.addEventListener("visibilitychange", webViewerVisibilityChange);    window.addEventListener("wheel", webViewerWheel, {      passive: false    });    window.addEventListener("touchstart", webViewerTouchStart, {      passive: false    });    window.addEventListener("touchmove", webViewerTouchMove, {      passive: false    });    window.addEventListener("touchend", webViewerTouchEnd, {      passive: false    });    window.addEventListener("click", webViewerClick);    window.addEventListener("keydown", webViewerKeyDown);    window.addEventListener("keyup", webViewerKeyUp);    window.addEventListener("resize", _boundEvents.windowResize);    window.addEventListener("hashchange", _boundEvents.windowHashChange);    window.addEventListener("beforeprint", _boundEvents.windowBeforePrint);    window.addEventListener("afterprint", _boundEvents.windowAfterPrint);    window.addEventListener("updatefromsandbox", _boundEvents.windowUpdateFromSandbox);  },  unbindEvents() {    const {      eventBus,      _boundEvents    } = this;    eventBus._off("resize", webViewerResize);    eventBus._off("hashchange", webViewerHashchange);    eventBus._off("beforeprint", _boundEvents.beforePrint);    eventBus._off("afterprint", _boundEvents.afterPrint);    eventBus._off("pagerender", webViewerPageRender);    eventBus._off("pagerendered", webViewerPageRendered);    eventBus._off("updateviewarea", webViewerUpdateViewarea);    eventBus._off("pagechanging", webViewerPageChanging);    eventBus._off("scalechanging", webViewerScaleChanging);    eventBus._off("rotationchanging", webViewerRotationChanging);    eventBus._off("sidebarviewchanged", webViewerSidebarViewChanged);    eventBus._off("pagemode", webViewerPageMode);    eventBus._off("namedaction", webViewerNamedAction);    eventBus._off("presentationmodechanged", webViewerPresentationModeChanged);    eventBus._off("presentationmode", webViewerPresentationMode);    eventBus._off("print", webViewerPrint);    eventBus._off("download", webViewerDownload);    eventBus._off("firstpage", webViewerFirstPage);    eventBus._off("lastpage", webViewerLastPage);    eventBus._off("nextpage", webViewerNextPage);    eventBus._off("previouspage", webViewerPreviousPage);    eventBus._off("zoomin", webViewerZoomIn);    eventBus._off("zoomout", webViewerZoomOut);    eventBus._off("zoomreset", webViewerZoomReset);    eventBus._off("pagenumberchanged", webViewerPageNumberChanged);    eventBus._off("scalechanged", webViewerScaleChanged);    eventBus._off("rotatecw", webViewerRotateCw);    eventBus._off("rotateccw", webViewerRotateCcw);    eventBus._off("optionalcontentconfig", webViewerOptionalContentConfig);    eventBus._off("switchscrollmode", webViewerSwitchScrollMode);    eventBus._off("scrollmodechanged", webViewerScrollModeChanged);    eventBus._off("switchspreadmode", webViewerSwitchSpreadMode);    eventBus._off("spreadmodechanged", webViewerSpreadModeChanged);    eventBus._off("documentproperties", webViewerDocumentProperties);    eventBus._off("findfromurlhash", webViewerFindFromUrlHash);    eventBus._off("updatefindmatchescount", webViewerUpdateFindMatchesCount);    eventBus._off("updatefindcontrolstate", webViewerUpdateFindControlState);    if (_boundEvents.reportPageStatsPDFBug) {      eventBus._off("pagerendered", _boundEvents.reportPageStatsPDFBug);      eventBus._off("pagechanging", _boundEvents.reportPageStatsPDFBug);      _boundEvents.reportPageStatsPDFBug = null;    }    eventBus._off("fileinputchange", webViewerFileInputChange);    eventBus._off("openfile", webViewerOpenFile);    _boundEvents.beforePrint = null;    _boundEvents.afterPrint = null;  },  unbindWindowEvents() {    const {      _boundEvents    } = this;    window.removeEventListener("visibilitychange", webViewerVisibilityChange);    window.removeEventListener("wheel", webViewerWheel, {      passive: false    });    window.removeEventListener("touchstart", webViewerTouchStart, {      passive: false    });    window.removeEventListener("touchmove", webViewerTouchMove, {      passive: false    });    window.removeEventListener("touchend", webViewerTouchEnd, {      passive: false    });    window.removeEventListener("click", webViewerClick);    window.removeEventListener("keydown", webViewerKeyDown);    window.removeEventListener("keyup", webViewerKeyUp);    window.removeEventListener("resize", _boundEvents.windowResize);    window.removeEventListener("hashchange", _boundEvents.windowHashChange);    window.removeEventListener("beforeprint", _boundEvents.windowBeforePrint);    window.removeEventListener("afterprint", _boundEvents.windowAfterPrint);    window.removeEventListener("updatefromsandbox", _boundEvents.windowUpdateFromSandbox);    _boundEvents.removeWindowResolutionChange?.();    _boundEvents.windowResize = null;    _boundEvents.windowHashChange = null;    _boundEvents.windowBeforePrint = null;    _boundEvents.windowAfterPrint = null;    _boundEvents.windowUpdateFromSandbox = null;  },  _accumulateTicks(ticks, prop) {    if (this[prop] > 0 && ticks < 0 || this[prop] < 0 && ticks > 0) {      this[prop] = 0;    }    this[prop] += ticks;    const wholeTicks = Math.trunc(this[prop]);    this[prop] -= wholeTicks;    return wholeTicks;  },  _accumulateFactor(previousScale, factor, prop) {    if (factor === 1) {      return 1;    }    if (this[prop] > 1 && factor < 1 || this[prop] < 1 && factor > 1) {      this[prop] = 1;    }    const newFactor = Math.floor(previousScale * factor * this[prop] * 100) / (100 * previousScale);    this[prop] = factor / newFactor;    return newFactor;  },  _centerAtPos(previousScale, x, y) {    const {      pdfViewer    } = this;    const scaleDiff = pdfViewer.currentScale / previousScale - 1;    if (scaleDiff !== 0) {      const [top, left] = pdfViewer.containerTopLeft;      pdfViewer.container.scrollLeft += (x - left) * scaleDiff;      pdfViewer.container.scrollTop += (y - top) * scaleDiff;    }  },  _unblockDocumentLoadEvent() {    document.blockUnblockOnload?.(false);    this._unblockDocumentLoadEvent = () => {};  },  get scriptingReady() {    return this.pdfScriptingManager.ready;  }};exports.PDFViewerApplication = PDFViewerApplication;{  const HOSTED_VIEWER_ORIGINS = ["null", "http://mozilla.github.io", "https://mozilla.github.io"];  var validateFileURL = function (file) {    if (!file) {      return;    }    try {      const viewerOrigin = new URL(window.location.href).origin || "null";      if (HOSTED_VIEWER_ORIGINS.includes(viewerOrigin)) {        return;      }      // const fileOrigin = new URL(file, window.location.href).origin;      // if (fileOrigin !== viewerOrigin) {      //   throw new Error("file origin does not match viewer's");      // }    } catch (ex) {      PDFViewerApplication.l10n.get("loading_error").then(msg => {        PDFViewerApplication._documentError(msg, {          message: ex?.message        });      });      throw ex;    }  };}async function loadFakeWorker() {  _pdfjsLib.GlobalWorkerOptions.workerSrc ||= _app_options.AppOptions.get("workerSrc");  await (0, _pdfjsLib.loadScript)(_pdfjsLib.PDFWorker.workerSrc);}async function loadPDFBug(self) {  const {    debuggerScriptPath  } = self.appConfig;  const {    PDFBug  } = await import(debuggerScriptPath);  self._PDFBug = PDFBug;}function reportPageStatsPDFBug({  pageNumber}) {  if (!globalThis.Stats?.enabled) {    return;  }  const pageView = PDFViewerApplication.pdfViewer.getPageView(pageNumber - 1);  globalThis.Stats.add(pageNumber, pageView?.pdfPage?.stats);}function webViewerInitialized() {  const {    appConfig,    eventBus  } = PDFViewerApplication;  let file;  const queryString = document.location.search.substring(1);  const params = (0, _ui_utils.parseQueryString)(queryString);  file = params.get("file") ?? _app_options.AppOptions.get("defaultUrl");  validateFileURL(file);  const fileInput = appConfig.openFileInput;  fileInput.value = null;  fileInput.addEventListener("change", function (evt) {    const {      files    } = evt.target;    if (!files || files.length === 0) {      return;    }    eventBus.dispatch("fileinputchange", {      source: this,      fileInput: evt.target    });  });  appConfig.mainContainer.addEventListener("dragover", function (evt) {    evt.preventDefault();    evt.dataTransfer.dropEffect = evt.dataTransfer.effectAllowed === "copy" ? "copy" : "move";  });  appConfig.mainContainer.addEventListener("drop", function (evt) {    evt.preventDefault();    const {      files    } = evt.dataTransfer;    if (!files || files.length === 0) {      return;    }    eventBus.dispatch("fileinputchange", {      source: this,      fileInput: evt.dataTransfer    });  });  if (!PDFViewerApplication.supportsDocumentFonts) {    _app_options.AppOptions.set("disableFontFace", true);    PDFViewerApplication.l10n.get("web_fonts_disabled").then(msg => {      console.warn(msg);    });  }  if (!PDFViewerApplication.supportsPrinting) {    appConfig.toolbar?.print.classList.add("hidden");    appConfig.secondaryToolbar?.printButton.classList.add("hidden");  }  if (!PDFViewerApplication.supportsFullscreen) {    appConfig.secondaryToolbar?.presentationModeButton.classList.add("hidden");  }  if (PDFViewerApplication.supportsIntegratedFind) {    appConfig.toolbar?.viewFind.classList.add("hidden");  }  appConfig.mainContainer.addEventListener("transitionend", function (evt) {    if (evt.target === this) {      eventBus.dispatch("resize", {        source: this      });    }  }, true);  try {    if (file) {      PDFViewerApplication.open({        url: file      });    } else {      PDFViewerApplication._hideViewBookmark();    }  } catch (reason) {    PDFViewerApplication.l10n.get("loading_error").then(msg => {      PDFViewerApplication._documentError(msg, reason);    });  }}function webViewerPageRender({  pageNumber}) {  if (pageNumber === PDFViewerApplication.page) {    PDFViewerApplication.toolbar?.updateLoadingIndicatorState(true);  }}function webViewerPageRendered({  pageNumber,  error}) {  if (pageNumber === PDFViewerApplication.page) {    PDFViewerApplication.toolbar?.updateLoadingIndicatorState(false);  }  if (PDFViewerApplication.pdfSidebar?.visibleView === _ui_utils.SidebarView.THUMBS) {    const pageView = PDFViewerApplication.pdfViewer.getPageView(pageNumber - 1);    const thumbnailView = PDFViewerApplication.pdfThumbnailViewer?.getThumbnail(pageNumber - 1);    if (pageView && thumbnailView) {      thumbnailView.setImage(pageView);    }  }  if (error) {    PDFViewerApplication.l10n.get("rendering_error").then(msg => {      PDFViewerApplication._otherError(msg, error);    });  }}function webViewerPageMode({  mode}) {  let view;  switch (mode) {    case "thumbs":      view = _ui_utils.SidebarView.THUMBS;      break;    case "bookmarks":    case "outline":      view = _ui_utils.SidebarView.OUTLINE;      break;    case "attachments":      view = _ui_utils.SidebarView.ATTACHMENTS;      break;    case "layers":      view = _ui_utils.SidebarView.LAYERS;      break;    case "none":      view = _ui_utils.SidebarView.NONE;      break;    default:      console.error('Invalid "pagemode" hash parameter: ' + mode);      return;  }  PDFViewerApplication.pdfSidebar?.switchView(view, true);}function webViewerNamedAction(evt) {  switch (evt.action) {    case "GoToPage":      PDFViewerApplication.appConfig.toolbar?.pageNumber.select();      break;    case "Find":      if (!PDFViewerApplication.supportsIntegratedFind) {        PDFViewerApplication?.findBar.toggle();      }      break;    case "Print":      PDFViewerApplication.triggerPrinting();      break;    case "SaveAs":      PDFViewerApplication.downloadOrSave();      break;  }}function webViewerPresentationModeChanged(evt) {  PDFViewerApplication.pdfViewer.presentationModeState = evt.state;}function webViewerSidebarViewChanged({  view}) {  PDFViewerApplication.pdfRenderingQueue.isThumbnailViewEnabled = view === _ui_utils.SidebarView.THUMBS;  if (PDFViewerApplication.isInitialViewSet) {    PDFViewerApplication.store?.set("sidebarView", view).catch(() => {});  }}function webViewerUpdateViewarea({  location}) {  if (PDFViewerApplication.isInitialViewSet) {    PDFViewerApplication.store?.setMultiple({      page: location.pageNumber,      zoom: location.scale,      scrollLeft: location.left,      scrollTop: location.top,      rotation: location.rotation    }).catch(() => {});  }  if (PDFViewerApplication.appConfig.secondaryToolbar) {    const href = PDFViewerApplication.pdfLinkService.getAnchorUrl(location.pdfOpenParams);    PDFViewerApplication.appConfig.secondaryToolbar.viewBookmarkButton.href = href;  }}function webViewerScrollModeChanged(evt) {  if (PDFViewerApplication.isInitialViewSet && !PDFViewerApplication.pdfViewer.isInPresentationMode) {    PDFViewerApplication.store?.set("scrollMode", evt.mode).catch(() => {});  }}function webViewerSpreadModeChanged(evt) {  if (PDFViewerApplication.isInitialViewSet && !PDFViewerApplication.pdfViewer.isInPresentationMode) {    PDFViewerApplication.store?.set("spreadMode", evt.mode).catch(() => {});  }}function webViewerResize() {  const {    pdfDocument,    pdfViewer,    pdfRenderingQueue  } = PDFViewerApplication;  if (pdfRenderingQueue.printing && window.matchMedia("print").matches) {    return;  }  if (!pdfDocument) {    return;  }  const currentScaleValue = pdfViewer.currentScaleValue;  if (currentScaleValue === "auto" || currentScaleValue === "page-fit" || currentScaleValue === "page-width") {    pdfViewer.currentScaleValue = currentScaleValue;  }  pdfViewer.update();}function webViewerHashchange(evt) {  const hash = evt.hash;  if (!hash) {    return;  }  if (!PDFViewerApplication.isInitialViewSet) {    PDFViewerApplication.initialBookmark = hash;  } else if (!PDFViewerApplication.pdfHistory?.popStateInProgress) {    PDFViewerApplication.pdfLinkService.setHash(hash);  }}{  var webViewerFileInputChange = function (evt) {    if (PDFViewerApplication.pdfViewer?.isInPresentationMode) {      return;    }    const file = evt.fileInput.files[0];    PDFViewerApplication.open({      url: URL.createObjectURL(file),      originalUrl: file.name    });  };  var webViewerOpenFile = function (evt) {    const fileInput = PDFViewerApplication.appConfig.openFileInput;    fileInput.click();  };}function webViewerPresentationMode() {  PDFViewerApplication.requestPresentationMode();}function webViewerSwitchAnnotationEditorMode(evt) {  PDFViewerApplication.pdfViewer.annotationEditorMode = evt.mode;}function webViewerSwitchAnnotationEditorParams(evt) {  PDFViewerApplication.pdfViewer.annotationEditorParams = evt;}function webViewerPrint() {  PDFViewerApplication.triggerPrinting();}function webViewerDownload() {  PDFViewerApplication.downloadOrSave();}function webViewerFirstPage() {  if (PDFViewerApplication.pdfDocument) {    PDFViewerApplication.page = 1;  }}function webViewerLastPage() {  if (PDFViewerApplication.pdfDocument) {    PDFViewerApplication.page = PDFViewerApplication.pagesCount;  }}function webViewerNextPage() {  PDFViewerApplication.pdfViewer.nextPage();}function webViewerPreviousPage() {  PDFViewerApplication.pdfViewer.previousPage();}function webViewerZoomIn() {  PDFViewerApplication.zoomIn();}function webViewerZoomOut() {  PDFViewerApplication.zoomOut();}function webViewerZoomReset() {  PDFViewerApplication.zoomReset();}function webViewerPageNumberChanged(evt) {  const pdfViewer = PDFViewerApplication.pdfViewer;  if (evt.value !== "") {    PDFViewerApplication.pdfLinkService.goToPage(evt.value);  }  if (evt.value !== pdfViewer.currentPageNumber.toString() && evt.value !== pdfViewer.currentPageLabel) {    PDFViewerApplication.toolbar?.setPageNumber(pdfViewer.currentPageNumber, pdfViewer.currentPageLabel);  }}function webViewerScaleChanged(evt) {  PDFViewerApplication.pdfViewer.currentScaleValue = evt.value;}function webViewerRotateCw() {  PDFViewerApplication.rotatePages(90);}function webViewerRotateCcw() {  PDFViewerApplication.rotatePages(-90);}function webViewerOptionalContentConfig(evt) {  PDFViewerApplication.pdfViewer.optionalContentConfigPromise = evt.promise;}function webViewerSwitchScrollMode(evt) {  PDFViewerApplication.pdfViewer.scrollMode = evt.mode;}function webViewerSwitchSpreadMode(evt) {  PDFViewerApplication.pdfViewer.spreadMode = evt.mode;}function webViewerDocumentProperties() {  PDFViewerApplication.pdfDocumentProperties?.open();}function webViewerFindFromUrlHash(evt) {  PDFViewerApplication.eventBus.dispatch("find", {    source: evt.source,    type: "",    query: evt.query,    phraseSearch: evt.phraseSearch,    caseSensitive: false,    entireWord: false,    highlightAll: true,    findPrevious: false,    matchDiacritics: true  });}function webViewerUpdateFindMatchesCount({  matchesCount}) {  if (PDFViewerApplication.supportsIntegratedFind) {    PDFViewerApplication.externalServices.updateFindMatchesCount(matchesCount);  } else {    PDFViewerApplication.findBar.updateResultsCount(matchesCount);  }}function webViewerUpdateFindControlState({  state,  previous,  matchesCount,  rawQuery}) {  if (PDFViewerApplication.supportsIntegratedFind) {    PDFViewerApplication.externalServices.updateFindControlState({      result: state,      findPrevious: previous,      matchesCount,      rawQuery    });  } else {    PDFViewerApplication.findBar?.updateUIState(state, previous, matchesCount);  }}function webViewerScaleChanging(evt) {  PDFViewerApplication.toolbar?.setPageScale(evt.presetValue, evt.scale);  PDFViewerApplication.pdfViewer.update();}function webViewerRotationChanging(evt) {  if (PDFViewerApplication.pdfThumbnailViewer) {    PDFViewerApplication.pdfThumbnailViewer.pagesRotation = evt.pagesRotation;  }  PDFViewerApplication.forceRendering();  PDFViewerApplication.pdfViewer.currentPageNumber = evt.pageNumber;}function webViewerPageChanging({  pageNumber,  pageLabel}) {  PDFViewerApplication.toolbar?.setPageNumber(pageNumber, pageLabel);  PDFViewerApplication.secondaryToolbar?.setPageNumber(pageNumber);  if (PDFViewerApplication.pdfSidebar?.visibleView === _ui_utils.SidebarView.THUMBS) {    PDFViewerApplication.pdfThumbnailViewer?.scrollThumbnailIntoView(pageNumber);  }  const currentPage = PDFViewerApplication.pdfViewer.getPageView(pageNumber - 1);  PDFViewerApplication.toolbar?.updateLoadingIndicatorState(currentPage?.renderingState === _ui_utils.RenderingStates.RUNNING);}function webViewerResolutionChange(evt) {  PDFViewerApplication.pdfViewer.refresh();}function webViewerVisibilityChange(evt) {  if (document.visibilityState === "visible") {    setZoomDisabledTimeout();  }}let zoomDisabledTimeout = null;function setZoomDisabledTimeout() {  if (zoomDisabledTimeout) {    clearTimeout(zoomDisabledTimeout);  }  zoomDisabledTimeout = setTimeout(function () {    zoomDisabledTimeout = null;  }, WHEEL_ZOOM_DISABLED_TIMEOUT);}function webViewerWheel(evt) {  const {    pdfViewer,    supportedMouseWheelZoomModifierKeys,    supportsPinchToZoom  } = PDFViewerApplication;  if (pdfViewer.isInPresentationMode) {    return;  }  const deltaMode = evt.deltaMode;  let scaleFactor = Math.exp(-evt.deltaY / 100);  const isPinchToZoom = evt.ctrlKey && !PDFViewerApplication._isCtrlKeyDown && deltaMode === WheelEvent.DOM_DELTA_PIXEL && evt.deltaX === 0 && Math.abs(scaleFactor - 1) < 0.05 && evt.deltaZ === 0;  if (isPinchToZoom || evt.ctrlKey && supportedMouseWheelZoomModifierKeys.ctrlKey || evt.metaKey && supportedMouseWheelZoomModifierKeys.metaKey) {    evt.preventDefault();    if (zoomDisabledTimeout || document.visibilityState === "hidden") {      return;    }    const previousScale = pdfViewer.currentScale;    if (isPinchToZoom && supportsPinchToZoom) {      scaleFactor = PDFViewerApplication._accumulateFactor(previousScale, scaleFactor, "_wheelUnusedFactor");      if (scaleFactor < 1) {        PDFViewerApplication.zoomOut(null, scaleFactor);      } else if (scaleFactor > 1) {        PDFViewerApplication.zoomIn(null, scaleFactor);      } else {        return;      }    } else {      const delta = (0, _ui_utils.normalizeWheelEventDirection)(evt);      let ticks = 0;      if (deltaMode === WheelEvent.DOM_DELTA_LINE || deltaMode === WheelEvent.DOM_DELTA_PAGE) {        if (Math.abs(delta) >= 1) {          ticks = Math.sign(delta);        } else {          ticks = PDFViewerApplication._accumulateTicks(delta, "_wheelUnusedTicks");        }      } else {        const PIXELS_PER_LINE_SCALE = 30;        ticks = PDFViewerApplication._accumulateTicks(delta / PIXELS_PER_LINE_SCALE, "_wheelUnusedTicks");      }      if (ticks < 0) {        PDFViewerApplication.zoomOut(-ticks);      } else if (ticks > 0) {        PDFViewerApplication.zoomIn(ticks);      } else {        return;      }    }    PDFViewerApplication._centerAtPos(previousScale, evt.clientX, evt.clientY);  } else {    setZoomDisabledTimeout();  }}function webViewerTouchStart(evt) {  if (PDFViewerApplication.pdfViewer.isInPresentationMode || evt.touches.length < 2) {    return;  }  evt.preventDefault();  if (evt.touches.length !== 2) {    PDFViewerApplication._touchInfo = null;    return;  }  let [touch0, touch1] = evt.touches;  if (touch0.identifier > touch1.identifier) {    [touch0, touch1] = [touch1, touch0];  }  PDFViewerApplication._touchInfo = {    touch0X: touch0.pageX,    touch0Y: touch0.pageY,    touch1X: touch1.pageX,    touch1Y: touch1.pageY  };}function webViewerTouchMove(evt) {  if (!PDFViewerApplication._touchInfo || evt.touches.length !== 2) {    return;  }  const {    pdfViewer,    _touchInfo,    supportsPinchToZoom  } = PDFViewerApplication;  let [touch0, touch1] = evt.touches;  if (touch0.identifier > touch1.identifier) {    [touch0, touch1] = [touch1, touch0];  }  const {    pageX: page0X,    pageY: page0Y  } = touch0;  const {    pageX: page1X,    pageY: page1Y  } = touch1;  const {    touch0X: pTouch0X,    touch0Y: pTouch0Y,    touch1X: pTouch1X,    touch1Y: pTouch1Y  } = _touchInfo;  if (Math.abs(pTouch0X - page0X) <= 1 && Math.abs(pTouch0Y - page0Y) <= 1 && Math.abs(pTouch1X - page1X) <= 1 && Math.abs(pTouch1Y - page1Y) <= 1) {    return;  }  _touchInfo.touch0X = page0X;  _touchInfo.touch0Y = page0Y;  _touchInfo.touch1X = page1X;  _touchInfo.touch1Y = page1Y;  if (pTouch0X === page0X && pTouch0Y === page0Y) {    const v1X = pTouch1X - page0X;    const v1Y = pTouch1Y - page0Y;    const v2X = page1X - page0X;    const v2Y = page1Y - page0Y;    const det = v1X * v2Y - v1Y * v2X;    if (Math.abs(det) > 0.02 * Math.hypot(v1X, v1Y) * Math.hypot(v2X, v2Y)) {      return;    }  } else if (pTouch1X === page1X && pTouch1Y === page1Y) {    const v1X = pTouch0X - page1X;    const v1Y = pTouch0Y - page1Y;    const v2X = page0X - page1X;    const v2Y = page0Y - page1Y;    const det = v1X * v2Y - v1Y * v2X;    if (Math.abs(det) > 0.02 * Math.hypot(v1X, v1Y) * Math.hypot(v2X, v2Y)) {      return;    }  } else {    const diff0X = page0X - pTouch0X;    const diff1X = page1X - pTouch1X;    const diff0Y = page0Y - pTouch0Y;    const diff1Y = page1Y - pTouch1Y;    const dotProduct = diff0X * diff1X + diff0Y * diff1Y;    if (dotProduct >= 0) {      return;    }  }  evt.preventDefault();  const distance = Math.hypot(page0X - page1X, page0Y - page1Y) || 1;  const pDistance = Math.hypot(pTouch0X - pTouch1X, pTouch0Y - pTouch1Y) || 1;  const previousScale = pdfViewer.currentScale;  if (supportsPinchToZoom) {    const newScaleFactor = PDFViewerApplication._accumulateFactor(previousScale, distance / pDistance, "_touchUnusedFactor");    if (newScaleFactor < 1) {      PDFViewerApplication.zoomOut(null, newScaleFactor);    } else if (newScaleFactor > 1) {      PDFViewerApplication.zoomIn(null, newScaleFactor);    } else {      return;    }  } else {    const PIXELS_PER_LINE_SCALE = 30;    const ticks = PDFViewerApplication._accumulateTicks((distance - pDistance) / PIXELS_PER_LINE_SCALE, "_touchUnusedTicks");    if (ticks < 0) {      PDFViewerApplication.zoomOut(-ticks);    } else if (ticks > 0) {      PDFViewerApplication.zoomIn(ticks);    } else {      return;    }  }  PDFViewerApplication._centerAtPos(previousScale, (page0X + page1X) / 2, (page0Y + page1Y) / 2);}function webViewerTouchEnd(evt) {  if (!PDFViewerApplication._touchInfo) {    return;  }  evt.preventDefault();  PDFViewerApplication._touchInfo = null;  PDFViewerApplication._touchUnusedTicks = 0;  PDFViewerApplication._touchUnusedFactor = 1;}function webViewerClick(evt) {  if (!PDFViewerApplication.secondaryToolbar?.isOpen) {    return;  }  const appConfig = PDFViewerApplication.appConfig;  if (PDFViewerApplication.pdfViewer.containsElement(evt.target) || appConfig.toolbar?.container.contains(evt.target) && evt.target !== appConfig.secondaryToolbar?.toggleButton) {    PDFViewerApplication.secondaryToolbar.close();  }}function webViewerKeyUp(evt) {  if (evt.key === "Control") {    PDFViewerApplication._isCtrlKeyDown = false;  }}function webViewerKeyDown(evt) {  PDFViewerApplication._isCtrlKeyDown = evt.key === "Control";  if (PDFViewerApplication.overlayManager.active) {    return;  }  const {    eventBus,    pdfViewer  } = PDFViewerApplication;  const isViewerInPresentationMode = pdfViewer.isInPresentationMode;  let handled = false,    ensureViewerFocused = false;  const cmd = (evt.ctrlKey ? 1 : 0) | (evt.altKey ? 2 : 0) | (evt.shiftKey ? 4 : 0) | (evt.metaKey ? 8 : 0);  if (cmd === 1 || cmd === 8 || cmd === 5 || cmd === 12) {    switch (evt.keyCode) {      case 70:        if (!PDFViewerApplication.supportsIntegratedFind && !evt.shiftKey) {          PDFViewerApplication.findBar?.open();          handled = true;        }        break;      case 71:        if (!PDFViewerApplication.supportsIntegratedFind) {          const {            state          } = PDFViewerApplication.findController;          if (state) {            const eventState = Object.assign(Object.create(null), state, {              source: window,              type: "again",              findPrevious: cmd === 5 || cmd === 12            });            eventBus.dispatch("find", eventState);          }          handled = true;        }        break;      case 61:      case 107:      case 187:      case 171:        if (!isViewerInPresentationMode) {          PDFViewerApplication.zoomIn();        }        handled = true;        break;      case 173:      case 109:      case 189:        if (!isViewerInPresentationMode) {          PDFViewerApplication.zoomOut();        }        handled = true;        break;      case 48:      case 96:        if (!isViewerInPresentationMode) {          setTimeout(function () {            PDFViewerApplication.zoomReset();          });          handled = false;        }        break;      case 38:        if (isViewerInPresentationMode || PDFViewerApplication.page > 1) {          PDFViewerApplication.page = 1;          handled = true;          ensureViewerFocused = true;        }        break;      case 40:        if (isViewerInPresentationMode || PDFViewerApplication.page < PDFViewerApplication.pagesCount) {          PDFViewerApplication.page = PDFViewerApplication.pagesCount;          handled = true;          ensureViewerFocused = true;        }        break;    }  }  if (cmd === 1 || cmd === 8) {    switch (evt.keyCode) {      case 83:        eventBus.dispatch("download", {          source: window        });        handled = true;        break;      case 79:        {          eventBus.dispatch("openfile", {            source: window          });          handled = true;        }        break;    }  }  if (cmd === 3 || cmd === 10) {    switch (evt.keyCode) {      case 80:        PDFViewerApplication.requestPresentationMode();        handled = true;        PDFViewerApplication.externalServices.reportTelemetry({          type: "buttons",          data: {            id: "presentationModeKeyboard"          }        });        break;      case 71:        if (PDFViewerApplication.appConfig.toolbar) {          PDFViewerApplication.appConfig.toolbar.pageNumber.select();          handled = true;        }        break;    }  }  if (handled) {    if (ensureViewerFocused && !isViewerInPresentationMode) {      pdfViewer.focus();    }    evt.preventDefault();    return;  }  const curElement = (0, _ui_utils.getActiveOrFocusedElement)();  const curElementTagName = curElement?.tagName.toUpperCase();  if (curElementTagName === "INPUT" || curElementTagName === "TEXTAREA" || curElementTagName === "SELECT" || curElement?.isContentEditable) {    if (evt.keyCode !== 27) {      return;    }  }  if (cmd === 0) {    let turnPage = 0,      turnOnlyIfPageFit = false;    switch (evt.keyCode) {      case 38:      case 33:        if (pdfViewer.isVerticalScrollbarEnabled) {          turnOnlyIfPageFit = true;        }        turnPage = -1;        break;      case 8:        if (!isViewerInPresentationMode) {          turnOnlyIfPageFit = true;        }        turnPage = -1;        break;      case 37:        if (pdfViewer.isHorizontalScrollbarEnabled) {          turnOnlyIfPageFit = true;        }      case 75:      case 80:        turnPage = -1;        break;      case 27:        if (PDFViewerApplication.secondaryToolbar?.isOpen) {          PDFViewerApplication.secondaryToolbar.close();          handled = true;        }        if (!PDFViewerApplication.supportsIntegratedFind && PDFViewerApplication.findBar?.opened) {          PDFViewerApplication.findBar.close();          handled = true;        }        break;      case 40:      case 34:        if (pdfViewer.isVerticalScrollbarEnabled) {          turnOnlyIfPageFit = true;        }        turnPage = 1;        break;      case 13:      case 32:        if (!isViewerInPresentationMode) {          turnOnlyIfPageFit = true;        }        turnPage = 1;        break;      case 39:        if (pdfViewer.isHorizontalScrollbarEnabled) {          turnOnlyIfPageFit = true;        }      case 74:      case 78:        turnPage = 1;        break;      case 36:        if (isViewerInPresentationMode || PDFViewerApplication.page > 1) {          PDFViewerApplication.page = 1;          handled = true;          ensureViewerFocused = true;        }        break;      case 35:        if (isViewerInPresentationMode || PDFViewerApplication.page < PDFViewerApplication.pagesCount) {          PDFViewerApplication.page = PDFViewerApplication.pagesCount;          handled = true;          ensureViewerFocused = true;        }        break;      case 83:        PDFViewerApplication.pdfCursorTools?.switchTool(_pdf_cursor_tools.CursorTool.SELECT);        break;      case 72:        PDFViewerApplication.pdfCursorTools?.switchTool(_pdf_cursor_tools.CursorTool.HAND);        break;      case 82:        PDFViewerApplication.rotatePages(90);        break;      case 115:        PDFViewerApplication.pdfSidebar?.toggle();        break;    }    if (turnPage !== 0 && (!turnOnlyIfPageFit || pdfViewer.currentScaleValue === "page-fit")) {      if (turnPage > 0) {        pdfViewer.nextPage();      } else {        pdfViewer.previousPage();      }      handled = true;    }  }  if (cmd === 4) {    switch (evt.keyCode) {      case 13:      case 32:        if (!isViewerInPresentationMode && pdfViewer.currentScaleValue !== "page-fit") {          break;        }        pdfViewer.previousPage();        handled = true;        break;      case 82:        PDFViewerApplication.rotatePages(-90);        break;    }  }  if (!handled && !isViewerInPresentationMode) {    if (evt.keyCode >= 33 && evt.keyCode <= 40 || evt.keyCode === 32 && curElementTagName !== "BUTTON") {      ensureViewerFocused = true;    }  }  if (ensureViewerFocused && !pdfViewer.containsElement(curElement)) {    pdfViewer.focus();  }  if (handled) {    evt.preventDefault();  }}function beforeUnload(evt) {  evt.preventDefault();  evt.returnValue = "";  return false;}function webViewerAnnotationEditorStatesChanged(data) {  PDFViewerApplication.externalServices.updateEditorStates(data);}const PDFPrintServiceFactory = {  instance: {    supportsPrinting: false,    createPrintService() {      throw new Error("Not implemented: createPrintService");    }  }};exports.PDFPrintServiceFactory = PDFPrintServiceFactory;/***/ }),/* 5 *//***/ ((module) => {let pdfjsLib;if (typeof window !== "undefined" && window["pdfjs-dist/build/pdf"]) {  pdfjsLib = window["pdfjs-dist/build/pdf"];} else {  pdfjsLib = require("../build/pdf.js");}module.exports = pdfjsLib;/***/ }),/* 6 *//***/ ((__unused_webpack_module, exports) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.WaitOnType = exports.EventBus = exports.AutomationEventBus = void 0;exports.waitOnEventOrTimeout = waitOnEventOrTimeout;const WaitOnType = {  EVENT: "event",  TIMEOUT: "timeout"};exports.WaitOnType = WaitOnType;function waitOnEventOrTimeout({  target,  name,  delay = 0}) {  return new Promise(function (resolve, reject) {    if (typeof target !== "object" || !(name && typeof name === "string") || !(Number.isInteger(delay) && delay >= 0)) {      throw new Error("waitOnEventOrTimeout - invalid parameters.");    }    function handler(type) {      if (target instanceof EventBus) {        target._off(name, eventHandler);      } else {        target.removeEventListener(name, eventHandler);      }      if (timeout) {        clearTimeout(timeout);      }      resolve(type);    }    const eventHandler = handler.bind(null, WaitOnType.EVENT);    if (target instanceof EventBus) {      target._on(name, eventHandler);    } else {      target.addEventListener(name, eventHandler);    }    const timeoutHandler = handler.bind(null, WaitOnType.TIMEOUT);    const timeout = setTimeout(timeoutHandler, delay);  });}class EventBus {  #listeners = Object.create(null);  on(eventName, listener, options = null) {    this._on(eventName, listener, {      external: true,      once: options?.once    });  }  off(eventName, listener, options = null) {    this._off(eventName, listener, {      external: true,      once: options?.once    });  }  dispatch(eventName, data) {    const eventListeners = this.#listeners[eventName];    if (!eventListeners || eventListeners.length === 0) {      return;    }    let externalListeners;    for (const {      listener,      external,      once    } of eventListeners.slice(0)) {      if (once) {        this._off(eventName, listener);      }      if (external) {        (externalListeners ||= []).push(listener);        continue;      }      listener(data);    }    if (externalListeners) {      for (const listener of externalListeners) {        listener(data);      }      externalListeners = null;    }  }  _on(eventName, listener, options = null) {    const eventListeners = this.#listeners[eventName] ||= [];    eventListeners.push({      listener,      external: options?.external === true,      once: options?.once === true    });  }  _off(eventName, listener, options = null) {    const eventListeners = this.#listeners[eventName];    if (!eventListeners) {      return;    }    for (let i = 0, ii = eventListeners.length; i < ii; i++) {      if (eventListeners[i].listener === listener) {        eventListeners.splice(i, 1);        return;      }    }  }}exports.EventBus = EventBus;class AutomationEventBus extends EventBus {  dispatch(eventName, data) {    throw new Error("Not implemented: AutomationEventBus.dispatch");  }}exports.AutomationEventBus = AutomationEventBus;/***/ }),/* 7 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFCursorTools = exports.CursorTool = void 0;var _pdfjsLib = __webpack_require__(5);var _grab_to_pan = __webpack_require__(8);var _ui_utils = __webpack_require__(1);const CursorTool = {  SELECT: 0,  HAND: 1,  ZOOM: 2};exports.CursorTool = CursorTool;class PDFCursorTools {  constructor({    container,    eventBus,    cursorToolOnLoad = CursorTool.SELECT  }) {    this.container = container;    this.eventBus = eventBus;    this.active = CursorTool.SELECT;    this.previouslyActive = null;    this.handTool = new _grab_to_pan.GrabToPan({      element: this.container    });    this.#addEventListeners();    Promise.resolve().then(() => {      this.switchTool(cursorToolOnLoad);    });  }  get activeTool() {    return this.active;  }  switchTool(tool) {    if (this.previouslyActive !== null) {      return;    }    if (tool === this.active) {      return;    }    const disableActiveTool = () => {      switch (this.active) {        case CursorTool.SELECT:          break;        case CursorTool.HAND:          this.handTool.deactivate();          break;        case CursorTool.ZOOM:      }    };    switch (tool) {      case CursorTool.SELECT:        disableActiveTool();        break;      case CursorTool.HAND:        disableActiveTool();        this.handTool.activate();        break;      case CursorTool.ZOOM:      default:        console.error(`switchTool: "${tool}" is an unsupported value.`);        return;    }    this.active = tool;    this.#dispatchEvent();  }  #dispatchEvent() {    this.eventBus.dispatch("cursortoolchanged", {      source: this,      tool: this.active    });  }  #addEventListeners() {    this.eventBus._on("switchcursortool", evt => {      this.switchTool(evt.tool);    });    let annotationEditorMode = _pdfjsLib.AnnotationEditorType.NONE,      presentationModeState = _ui_utils.PresentationModeState.NORMAL;    const disableActive = () => {      const previouslyActive = this.active;      this.switchTool(CursorTool.SELECT);      this.previouslyActive ??= previouslyActive;    };    const enableActive = () => {      const previouslyActive = this.previouslyActive;      if (previouslyActive !== null && annotationEditorMode === _pdfjsLib.AnnotationEditorType.NONE && presentationModeState === _ui_utils.PresentationModeState.NORMAL) {        this.previouslyActive = null;        this.switchTool(previouslyActive);      }    };    this.eventBus._on("secondarytoolbarreset", evt => {      if (this.previouslyActive !== null) {        annotationEditorMode = _pdfjsLib.AnnotationEditorType.NONE;        presentationModeState = _ui_utils.PresentationModeState.NORMAL;        enableActive();      }    });    this.eventBus._on("annotationeditormodechanged", ({      mode    }) => {      annotationEditorMode = mode;      if (mode === _pdfjsLib.AnnotationEditorType.NONE) {        enableActive();      } else {        disableActive();      }    });    this.eventBus._on("presentationmodechanged", ({      state    }) => {      presentationModeState = state;      if (state === _ui_utils.PresentationModeState.NORMAL) {        enableActive();      } else if (state === _ui_utils.PresentationModeState.FULLSCREEN) {        disableActive();      }    });  }}exports.PDFCursorTools = PDFCursorTools;/***/ }),/* 8 *//***/ ((__unused_webpack_module, exports) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.GrabToPan = void 0;const CSS_CLASS_GRAB = "grab-to-pan-grab";class GrabToPan {  constructor(options) {    this.element = options.element;    this.document = options.element.ownerDocument;    if (typeof options.ignoreTarget === "function") {      this.ignoreTarget = options.ignoreTarget;    }    this.onActiveChanged = options.onActiveChanged;    this.activate = this.activate.bind(this);    this.deactivate = this.deactivate.bind(this);    this.toggle = this.toggle.bind(this);    this._onMouseDown = this.#onMouseDown.bind(this);    this._onMouseMove = this.#onMouseMove.bind(this);    this._endPan = this.#endPan.bind(this);    const overlay = this.overlay = document.createElement("div");    overlay.className = "grab-to-pan-grabbing";  }  activate() {    if (!this.active) {      this.active = true;      this.element.addEventListener("mousedown", this._onMouseDown, true);      this.element.classList.add(CSS_CLASS_GRAB);      this.onActiveChanged?.(true);    }  }  deactivate() {    if (this.active) {      this.active = false;      this.element.removeEventListener("mousedown", this._onMouseDown, true);      this._endPan();      this.element.classList.remove(CSS_CLASS_GRAB);      this.onActiveChanged?.(false);    }  }  toggle() {    if (this.active) {      this.deactivate();    } else {      this.activate();    }  }  ignoreTarget(node) {    return node.matches("a[href], a[href] *, input, textarea, button, button *, select, option");  }  #onMouseDown(event) {    if (event.button !== 0 || this.ignoreTarget(event.target)) {      return;    }    if (event.originalTarget) {      try {        event.originalTarget.tagName;      } catch (e) {        return;      }    }    this.scrollLeftStart = this.element.scrollLeft;    this.scrollTopStart = this.element.scrollTop;    this.clientXStart = event.clientX;    this.clientYStart = event.clientY;    this.document.addEventListener("mousemove", this._onMouseMove, true);    this.document.addEventListener("mouseup", this._endPan, true);    this.element.addEventListener("scroll", this._endPan, true);    event.preventDefault();    event.stopPropagation();    const focusedElement = document.activeElement;    if (focusedElement && !focusedElement.contains(event.target)) {      focusedElement.blur();    }  }  #onMouseMove(event) {    this.element.removeEventListener("scroll", this._endPan, true);    if (!(event.buttons & 1)) {      this._endPan();      return;    }    const xDiff = event.clientX - this.clientXStart;    const yDiff = event.clientY - this.clientYStart;    const scrollTop = this.scrollTopStart - yDiff;    const scrollLeft = this.scrollLeftStart - xDiff;    if (this.element.scrollTo) {      this.element.scrollTo({        top: scrollTop,        left: scrollLeft,        behavior: "instant"      });    } else {      this.element.scrollTop = scrollTop;      this.element.scrollLeft = scrollLeft;    }    if (!this.overlay.parentNode) {      document.body.append(this.overlay);    }  }  #endPan() {    this.element.removeEventListener("scroll", this._endPan, true);    this.document.removeEventListener("mousemove", this._onMouseMove, true);    this.document.removeEventListener("mouseup", this._endPan, true);    this.overlay.remove();  }}exports.GrabToPan = GrabToPan;/***/ }),/* 9 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.AnnotationEditorParams = void 0;var _pdfjsLib = __webpack_require__(5);class AnnotationEditorParams {  constructor(options, eventBus) {    this.eventBus = eventBus;    this.#bindListeners(options);  }  #bindListeners({    editorFreeTextFontSize,    editorFreeTextColor,    editorInkColor,    editorInkThickness,    editorInkOpacity  }) {    editorFreeTextFontSize.addEventListener("input", evt => {      this.eventBus.dispatch("switchannotationeditorparams", {        source: this,        type: _pdfjsLib.AnnotationEditorParamsType.FREETEXT_SIZE,        value: editorFreeTextFontSize.valueAsNumber      });    });    editorFreeTextColor.addEventListener("input", evt => {      this.eventBus.dispatch("switchannotationeditorparams", {        source: this,        type: _pdfjsLib.AnnotationEditorParamsType.FREETEXT_COLOR,        value: editorFreeTextColor.value      });    });    editorInkColor.addEventListener("input", evt => {      this.eventBus.dispatch("switchannotationeditorparams", {        source: this,        type: _pdfjsLib.AnnotationEditorParamsType.INK_COLOR,        value: editorInkColor.value      });    });    editorInkThickness.addEventListener("input", evt => {      this.eventBus.dispatch("switchannotationeditorparams", {        source: this,        type: _pdfjsLib.AnnotationEditorParamsType.INK_THICKNESS,        value: editorInkThickness.valueAsNumber      });    });    editorInkOpacity.addEventListener("input", evt => {      this.eventBus.dispatch("switchannotationeditorparams", {        source: this,        type: _pdfjsLib.AnnotationEditorParamsType.INK_OPACITY,        value: editorInkOpacity.valueAsNumber      });    });    this.eventBus._on("annotationeditorparamschanged", evt => {      for (const [type, value] of evt.details) {        switch (type) {          case _pdfjsLib.AnnotationEditorParamsType.FREETEXT_SIZE:            editorFreeTextFontSize.value = value;            break;          case _pdfjsLib.AnnotationEditorParamsType.FREETEXT_COLOR:            editorFreeTextColor.value = value;            break;          case _pdfjsLib.AnnotationEditorParamsType.INK_COLOR:            editorInkColor.value = value;            break;          case _pdfjsLib.AnnotationEditorParamsType.INK_THICKNESS:            editorInkThickness.value = value;            break;          case _pdfjsLib.AnnotationEditorParamsType.INK_OPACITY:            editorInkOpacity.value = value;            break;        }      }    });  }}exports.AnnotationEditorParams = AnnotationEditorParams;/***/ }),/* 10 *//***/ ((__unused_webpack_module, exports) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.OverlayManager = void 0;class OverlayManager {  #overlays = new WeakMap();  #active = null;  get active() {    return this.#active;  }  async register(dialog, canForceClose = false) {    if (typeof dialog !== "object") {      throw new Error("Not enough parameters.");    } else if (this.#overlays.has(dialog)) {      throw new Error("The overlay is already registered.");    }    this.#overlays.set(dialog, {      canForceClose    });    dialog.addEventListener("cancel", evt => {      this.#active = null;    });  }  async unregister(dialog) {    if (!this.#overlays.has(dialog)) {      throw new Error("The overlay does not exist.");    } else if (this.#active === dialog) {      throw new Error("The overlay cannot be removed while it is active.");    }    this.#overlays.delete(dialog);  }  async open(dialog) {    if (!this.#overlays.has(dialog)) {      throw new Error("The overlay does not exist.");    } else if (this.#active) {      if (this.#active === dialog) {        throw new Error("The overlay is already active.");      } else if (this.#overlays.get(dialog).canForceClose) {        await this.close();      } else {        throw new Error("Another overlay is currently active.");      }    }    this.#active = dialog;    dialog.showModal();  }  async close(dialog = this.#active) {    if (!this.#overlays.has(dialog)) {      throw new Error("The overlay does not exist.");    } else if (!this.#active) {      throw new Error("The overlay is currently not active.");    } else if (this.#active !== dialog) {      throw new Error("Another overlay is currently active.");    }    dialog.close();    this.#active = null;  }}exports.OverlayManager = OverlayManager;/***/ }),/* 11 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PasswordPrompt = void 0;var _pdfjsLib = __webpack_require__(5);class PasswordPrompt {  #activeCapability = null;  #updateCallback = null;  #reason = null;  constructor(options, overlayManager, l10n, isViewerEmbedded = false) {    this.dialog = options.dialog;    this.label = options.label;    this.input = options.input;    this.submitButton = options.submitButton;    this.cancelButton = options.cancelButton;    this.overlayManager = overlayManager;    this.l10n = l10n;    this._isViewerEmbedded = isViewerEmbedded;    this.submitButton.addEventListener("click", this.#verify.bind(this));    this.cancelButton.addEventListener("click", this.close.bind(this));    this.input.addEventListener("keydown", e => {      if (e.keyCode === 13) {        this.#verify();      }    });    this.overlayManager.register(this.dialog, true);    this.dialog.addEventListener("close", this.#cancel.bind(this));  }  async open() {    if (this.#activeCapability) {      await this.#activeCapability.promise;    }    this.#activeCapability = (0, _pdfjsLib.createPromiseCapability)();    try {      await this.overlayManager.open(this.dialog);    } catch (ex) {      this.#activeCapability = null;      throw ex;    }    const passwordIncorrect = this.#reason === _pdfjsLib.PasswordResponses.INCORRECT_PASSWORD;    if (!this._isViewerEmbedded || passwordIncorrect) {      this.input.focus();    }    this.label.textContent = await this.l10n.get(`password_${passwordIncorrect ? "invalid" : "label"}`);  }  async close() {    if (this.overlayManager.active === this.dialog) {      this.overlayManager.close(this.dialog);    }  }  #verify() {    const password = this.input.value;    if (password?.length > 0) {      this.#invokeCallback(password);    }  }  #cancel() {    this.#invokeCallback(new Error("PasswordPrompt cancelled."));    this.#activeCapability.resolve();  }  #invokeCallback(password) {    if (!this.#updateCallback) {      return;    }    this.close();    this.input.value = "";    this.#updateCallback(password);    this.#updateCallback = null;  }  async setUpdateCallback(updateCallback, reason) {    if (this.#activeCapability) {      await this.#activeCapability.promise;    }    this.#updateCallback = updateCallback;    this.#reason = reason;  }}exports.PasswordPrompt = PasswordPrompt;/***/ }),/* 12 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFAttachmentViewer = void 0;var _pdfjsLib = __webpack_require__(5);var _base_tree_viewer = __webpack_require__(13);var _event_utils = __webpack_require__(6);class PDFAttachmentViewer extends _base_tree_viewer.BaseTreeViewer {  constructor(options) {    super(options);    this.downloadManager = options.downloadManager;    this.eventBus._on("fileattachmentannotation", this.#appendAttachment.bind(this));  }  reset(keepRenderedCapability = false) {    super.reset();    this._attachments = null;    if (!keepRenderedCapability) {      this._renderedCapability = (0, _pdfjsLib.createPromiseCapability)();    }    this._pendingDispatchEvent = false;  }  async _dispatchEvent(attachmentsCount) {    this._renderedCapability.resolve();    if (attachmentsCount === 0 && !this._pendingDispatchEvent) {      this._pendingDispatchEvent = true;      await (0, _event_utils.waitOnEventOrTimeout)({        target: this.eventBus,        name: "annotationlayerrendered",        delay: 1000      });      if (!this._pendingDispatchEvent) {        return;      }    }    this._pendingDispatchEvent = false;    this.eventBus.dispatch("attachmentsloaded", {      source: this,      attachmentsCount    });  }  _bindLink(element, {    content,    filename  }) {    element.onclick = () => {      this.downloadManager.openOrDownloadData(element, content, filename);      return false;    };  }  render({    attachments,    keepRenderedCapability = false  }) {    if (this._attachments) {      this.reset(keepRenderedCapability);    }    this._attachments = attachments || null;    if (!attachments) {      this._dispatchEvent(0);      return;    }    const names = Object.keys(attachments).sort(function (a, b) {      return a.toLowerCase().localeCompare(b.toLowerCase());    });    const fragment = document.createDocumentFragment();    let attachmentsCount = 0;    for (const name of names) {      const item = attachments[name];      const content = item.content,        filename = (0, _pdfjsLib.getFilenameFromUrl)(item.filename, true);      const div = document.createElement("div");      div.className = "treeItem";      const element = document.createElement("a");      this._bindLink(element, {        content,        filename      });      element.textContent = this._normalizeTextContent(filename);      div.append(element);      fragment.append(div);      attachmentsCount++;    }    this._finishRendering(fragment, attachmentsCount);  }  #appendAttachment({    filename,    content  }) {    const renderedPromise = this._renderedCapability.promise;    renderedPromise.then(() => {      if (renderedPromise !== this._renderedCapability.promise) {        return;      }      const attachments = this._attachments || Object.create(null);      for (const name in attachments) {        if (filename === name) {          return;        }      }      attachments[filename] = {        filename,        content      };      this.render({        attachments,        keepRenderedCapability: true      });    });  }}exports.PDFAttachmentViewer = PDFAttachmentViewer;/***/ }),/* 13 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.BaseTreeViewer = void 0;var _ui_utils = __webpack_require__(1);const TREEITEM_OFFSET_TOP = -100;const TREEITEM_SELECTED_CLASS = "selected";class BaseTreeViewer {  constructor(options) {    if (this.constructor === BaseTreeViewer) {      throw new Error("Cannot initialize BaseTreeViewer.");    }    this.container = options.container;    this.eventBus = options.eventBus;    this.reset();  }  reset() {    this._pdfDocument = null;    this._lastToggleIsShow = true;    this._currentTreeItem = null;    this.container.textContent = "";    this.container.classList.remove("treeWithDeepNesting");  }  _dispatchEvent(count) {    throw new Error("Not implemented: _dispatchEvent");  }  _bindLink(element, params) {    throw new Error("Not implemented: _bindLink");  }  _normalizeTextContent(str) {    return (0, _ui_utils.removeNullCharacters)(str, true) || "\u2013";  }  _addToggleButton(div, hidden = false) {    const toggler = document.createElement("div");    toggler.className = "treeItemToggler";    if (hidden) {      toggler.classList.add("treeItemsHidden");    }    toggler.onclick = evt => {      evt.stopPropagation();      toggler.classList.toggle("treeItemsHidden");      if (evt.shiftKey) {        const shouldShowAll = !toggler.classList.contains("treeItemsHidden");        this._toggleTreeItem(div, shouldShowAll);      }    };    div.prepend(toggler);  }  _toggleTreeItem(root, show = false) {    this._lastToggleIsShow = show;    for (const toggler of root.querySelectorAll(".treeItemToggler")) {      toggler.classList.toggle("treeItemsHidden", !show);    }  }  _toggleAllTreeItems() {    this._toggleTreeItem(this.container, !this._lastToggleIsShow);  }  _finishRendering(fragment, count, hasAnyNesting = false) {    if (hasAnyNesting) {      this.container.classList.add("treeWithDeepNesting");      this._lastToggleIsShow = !fragment.querySelector(".treeItemsHidden");    }    this.container.append(fragment);    this._dispatchEvent(count);  }  render(params) {    throw new Error("Not implemented: render");  }  _updateCurrentTreeItem(treeItem = null) {    if (this._currentTreeItem) {      this._currentTreeItem.classList.remove(TREEITEM_SELECTED_CLASS);      this._currentTreeItem = null;    }    if (treeItem) {      treeItem.classList.add(TREEITEM_SELECTED_CLASS);      this._currentTreeItem = treeItem;    }  }  _scrollToCurrentTreeItem(treeItem) {    if (!treeItem) {      return;    }    let currentNode = treeItem.parentNode;    while (currentNode && currentNode !== this.container) {      if (currentNode.classList.contains("treeItem")) {        const toggler = currentNode.firstElementChild;        toggler?.classList.remove("treeItemsHidden");      }      currentNode = currentNode.parentNode;    }    this._updateCurrentTreeItem(treeItem);    this.container.scrollTo(treeItem.offsetLeft, treeItem.offsetTop + TREEITEM_OFFSET_TOP);  }}exports.BaseTreeViewer = BaseTreeViewer;/***/ }),/* 14 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFDocumentProperties = void 0;var _pdfjsLib = __webpack_require__(5);var _ui_utils = __webpack_require__(1);const DEFAULT_FIELD_CONTENT = "-";const NON_METRIC_LOCALES = ["en-us", "en-lr", "my"];const US_PAGE_NAMES = {  "8.5x11": "Letter",  "8.5x14": "Legal"};const METRIC_PAGE_NAMES = {  "297x420": "A3",  "210x297": "A4"};function getPageName(size, isPortrait, pageNames) {  const width = isPortrait ? size.width : size.height;  const height = isPortrait ? size.height : size.width;  return pageNames[`${width}x${height}`];}class PDFDocumentProperties {  #fieldData = null;  constructor({    dialog,    fields,    closeButton  }, overlayManager, eventBus, l10n, fileNameLookup) {    this.dialog = dialog;    this.fields = fields;    this.overlayManager = overlayManager;    this.l10n = l10n;    this._fileNameLookup = fileNameLookup;    this.#reset();    closeButton.addEventListener("click", this.close.bind(this));    this.overlayManager.register(this.dialog);    eventBus._on("pagechanging", evt => {      this._currentPageNumber = evt.pageNumber;    });    eventBus._on("rotationchanging", evt => {      this._pagesRotation = evt.pagesRotation;    });    this._isNonMetricLocale = true;    l10n.getLanguage().then(locale => {      this._isNonMetricLocale = NON_METRIC_LOCALES.includes(locale);    });  }  async open() {    await Promise.all([this.overlayManager.open(this.dialog), this._dataAvailableCapability.promise]);    const currentPageNumber = this._currentPageNumber;    const pagesRotation = this._pagesRotation;    if (this.#fieldData && currentPageNumber === this.#fieldData._currentPageNumber && pagesRotation === this.#fieldData._pagesRotation) {      this.#updateUI();      return;    }    const {      info,      contentLength    } = await this.pdfDocument.getMetadata();    const [fileName, fileSize, creationDate, modificationDate, pageSize, isLinearized] = await Promise.all([this._fileNameLookup(), this.#parseFileSize(contentLength), this.#parseDate(info.CreationDate), this.#parseDate(info.ModDate), this.pdfDocument.getPage(currentPageNumber).then(pdfPage => {      return this.#parsePageSize((0, _ui_utils.getPageSizeInches)(pdfPage), pagesRotation);    }), this.#parseLinearization(info.IsLinearized)]);    this.#fieldData = Object.freeze({      fileName,      fileSize,      title: info.Title,      author: info.Author,      subject: info.Subject,      keywords: info.Keywords,      creationDate,      modificationDate,      creator: info.Creator,      producer: info.Producer,      version: info.PDFFormatVersion,      pageCount: this.pdfDocument.numPages,      pageSize,      linearized: isLinearized,      _currentPageNumber: currentPageNumber,      _pagesRotation: pagesRotation    });    this.#updateUI();    const {      length    } = await this.pdfDocument.getDownloadInfo();    if (contentLength === length) {      return;    }    const data = Object.assign(Object.create(null), this.#fieldData);    data.fileSize = await this.#parseFileSize(length);    this.#fieldData = Object.freeze(data);    this.#updateUI();  }  async close() {    this.overlayManager.close(this.dialog);  }  setDocument(pdfDocument) {    if (this.pdfDocument) {      this.#reset();      this.#updateUI(true);    }    if (!pdfDocument) {      return;    }    this.pdfDocument = pdfDocument;    this._dataAvailableCapability.resolve();  }  #reset() {    this.pdfDocument = null;    this.#fieldData = null;    this._dataAvailableCapability = (0, _pdfjsLib.createPromiseCapability)();    this._currentPageNumber = 1;    this._pagesRotation = 0;  }  #updateUI(reset = false) {    if (reset || !this.#fieldData) {      for (const id in this.fields) {        this.fields[id].textContent = DEFAULT_FIELD_CONTENT;      }      return;    }    if (this.overlayManager.active !== this.dialog) {      return;    }    for (const id in this.fields) {      const content = this.#fieldData[id];      this.fields[id].textContent = content || content === 0 ? content : DEFAULT_FIELD_CONTENT;    }  }  async #parseFileSize(fileSize = 0) {    const kb = fileSize / 1024,      mb = kb / 1024;    if (!kb) {      return undefined;    }    return this.l10n.get(`document_properties_${mb >= 1 ? "mb" : "kb"}`, {      size_mb: mb >= 1 && (+mb.toPrecision(3)).toLocaleString(),      size_kb: mb < 1 && (+kb.toPrecision(3)).toLocaleString(),      size_b: fileSize.toLocaleString()    });  }  async #parsePageSize(pageSizeInches, pagesRotation) {    if (!pageSizeInches) {      return undefined;    }    if (pagesRotation % 180 !== 0) {      pageSizeInches = {        width: pageSizeInches.height,        height: pageSizeInches.width      };    }    const isPortrait = (0, _ui_utils.isPortraitOrientation)(pageSizeInches);    let sizeInches = {      width: Math.round(pageSizeInches.width * 100) / 100,      height: Math.round(pageSizeInches.height * 100) / 100    };    let sizeMillimeters = {      width: Math.round(pageSizeInches.width * 25.4 * 10) / 10,      height: Math.round(pageSizeInches.height * 25.4 * 10) / 10    };    let rawName = getPageName(sizeInches, isPortrait, US_PAGE_NAMES) || getPageName(sizeMillimeters, isPortrait, METRIC_PAGE_NAMES);    if (!rawName && !(Number.isInteger(sizeMillimeters.width) && Number.isInteger(sizeMillimeters.height))) {      const exactMillimeters = {        width: pageSizeInches.width * 25.4,        height: pageSizeInches.height * 25.4      };      const intMillimeters = {        width: Math.round(sizeMillimeters.width),        height: Math.round(sizeMillimeters.height)      };      if (Math.abs(exactMillimeters.width - intMillimeters.width) < 0.1 && Math.abs(exactMillimeters.height - intMillimeters.height) < 0.1) {        rawName = getPageName(intMillimeters, isPortrait, METRIC_PAGE_NAMES);        if (rawName) {          sizeInches = {            width: Math.round(intMillimeters.width / 25.4 * 100) / 100,            height: Math.round(intMillimeters.height / 25.4 * 100) / 100          };          sizeMillimeters = intMillimeters;        }      }    }    const [{      width,      height    }, unit, name, orientation] = await Promise.all([this._isNonMetricLocale ? sizeInches : sizeMillimeters, this.l10n.get(`document_properties_page_size_unit_${this._isNonMetricLocale ? "inches" : "millimeters"}`), rawName && this.l10n.get(`document_properties_page_size_name_${rawName.toLowerCase()}`), this.l10n.get(`document_properties_page_size_orientation_${isPortrait ? "portrait" : "landscape"}`)]);    return this.l10n.get(`document_properties_page_size_dimension_${name ? "name_" : ""}string`, {      width: width.toLocaleString(),      height: height.toLocaleString(),      unit,      name,      orientation    });  }  async #parseDate(inputDate) {    const dateObject = _pdfjsLib.PDFDateString.toDateObject(inputDate);    if (!dateObject) {      return undefined;    }    return this.l10n.get("document_properties_date_string", {      date: dateObject.toLocaleDateString(),      time: dateObject.toLocaleTimeString()    });  }  #parseLinearization(isLinearized) {    return this.l10n.get(`document_properties_linearized_${isLinearized ? "yes" : "no"}`);  }}exports.PDFDocumentProperties = PDFDocumentProperties;/***/ }),/* 15 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFFindBar = void 0;var _pdf_find_controller = __webpack_require__(16);const MATCHES_COUNT_LIMIT = 1000;class PDFFindBar {  constructor(options, eventBus, l10n) {    this.opened = false;    this.bar = options.bar;    this.toggleButton = options.toggleButton;    this.findField = options.findField;    this.highlightAll = options.highlightAllCheckbox;    this.caseSensitive = options.caseSensitiveCheckbox;    this.matchDiacritics = options.matchDiacriticsCheckbox;    this.entireWord = options.entireWordCheckbox;    this.findMsg = options.findMsg;    this.findResultsCount = options.findResultsCount;    this.findPreviousButton = options.findPreviousButton;    this.findNextButton = options.findNextButton;    this.eventBus = eventBus;    this.l10n = l10n;    this.toggleButton.addEventListener("click", () => {      this.toggle();    });    this.findField.addEventListener("input", () => {      this.dispatchEvent("");    });    this.bar.addEventListener("keydown", e => {      switch (e.keyCode) {        case 13:          if (e.target === this.findField) {            this.dispatchEvent("again", e.shiftKey);          }          break;        case 27:          this.close();          break;      }    });    this.findPreviousButton.addEventListener("click", () => {      this.dispatchEvent("again", true);    });    this.findNextButton.addEventListener("click", () => {      this.dispatchEvent("again", false);    });    this.highlightAll.addEventListener("click", () => {      this.dispatchEvent("highlightallchange");    });    this.caseSensitive.addEventListener("click", () => {      this.dispatchEvent("casesensitivitychange");    });    this.entireWord.addEventListener("click", () => {      this.dispatchEvent("entirewordchange");    });    this.matchDiacritics.addEventListener("click", () => {      this.dispatchEvent("diacriticmatchingchange");    });    this.eventBus._on("resize", this.#adjustWidth.bind(this));  }  reset() {    this.updateUIState();  }  dispatchEvent(type, findPrev = false) {    this.eventBus.dispatch("find", {      source: this,      type,      query: this.findField.value,      phraseSearch: true,      caseSensitive: this.caseSensitive.checked,      entireWord: this.entireWord.checked,      highlightAll: this.highlightAll.checked,      findPrevious: findPrev,      matchDiacritics: this.matchDiacritics.checked    });  }  updateUIState(state, previous, matchesCount) {    let findMsg = Promise.resolve("");    let status = "";    switch (state) {      case _pdf_find_controller.FindState.FOUND:        break;      case _pdf_find_controller.FindState.PENDING:        status = "pending";        break;      case _pdf_find_controller.FindState.NOT_FOUND:        findMsg = this.l10n.get("find_not_found");        status = "notFound";        break;      case _pdf_find_controller.FindState.WRAPPED:        findMsg = this.l10n.get(`find_reached_${previous ? "top" : "bottom"}`);        break;    }    this.findField.setAttribute("data-status", status);    this.findField.setAttribute("aria-invalid", state === _pdf_find_controller.FindState.NOT_FOUND);    findMsg.then(msg => {      this.findMsg.textContent = msg;      this.#adjustWidth();    });    this.updateResultsCount(matchesCount);  }  updateResultsCount({    current = 0,    total = 0  } = {}) {    const limit = MATCHES_COUNT_LIMIT;    let matchCountMsg = Promise.resolve("");    if (total > 0) {      if (total > limit) {        let key = "find_match_count_limit";        matchCountMsg = this.l10n.get(key, {          limit        });      } else {        let key = "find_match_count";        matchCountMsg = this.l10n.get(key, {          current,          total        });      }    }    matchCountMsg.then(msg => {      this.findResultsCount.textContent = msg;      this.#adjustWidth();    });  }  open() {    if (!this.opened) {      this.opened = true;      this.toggleButton.classList.add("toggled");      this.toggleButton.setAttribute("aria-expanded", "true");      this.bar.classList.remove("hidden");    }    this.findField.select();    this.findField.focus();    this.#adjustWidth();  }  close() {    if (!this.opened) {      return;    }    this.opened = false;    this.toggleButton.classList.remove("toggled");    this.toggleButton.setAttribute("aria-expanded", "false");    this.bar.classList.add("hidden");    this.eventBus.dispatch("findbarclose", {      source: this    });  }  toggle() {    if (this.opened) {      this.close();    } else {      this.open();    }  }  #adjustWidth() {    if (!this.opened) {      return;    }    this.bar.classList.remove("wrapContainers");    const findbarHeight = this.bar.clientHeight;    const inputContainerHeight = this.bar.firstElementChild.clientHeight;    if (findbarHeight > inputContainerHeight) {      this.bar.classList.add("wrapContainers");    }  }}exports.PDFFindBar = PDFFindBar;/***/ }),/* 16 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFFindController = exports.FindState = void 0;var _ui_utils = __webpack_require__(1);var _pdfjsLib = __webpack_require__(5);var _pdf_find_utils = __webpack_require__(17);const FindState = {  FOUND: 0,  NOT_FOUND: 1,  WRAPPED: 2,  PENDING: 3};exports.FindState = FindState;const FIND_TIMEOUT = 250;const MATCH_SCROLL_OFFSET_TOP = -50;const MATCH_SCROLL_OFFSET_LEFT = -400;const CHARACTERS_TO_NORMALIZE = {  "\u2010": "-",  "\u2018": "'",  "\u2019": "'",  "\u201A": "'",  "\u201B": "'",  "\u201C": '"',  "\u201D": '"',  "\u201E": '"',  "\u201F": '"',  "\u00BC": "1/4",  "\u00BD": "1/2",  "\u00BE": "3/4"};const DIACRITICS_EXCEPTION = new Set([0x3099, 0x309a, 0x094d, 0x09cd, 0x0a4d, 0x0acd, 0x0b4d, 0x0bcd, 0x0c4d, 0x0ccd, 0x0d3b, 0x0d3c, 0x0d4d, 0x0dca, 0x0e3a, 0x0eba, 0x0f84, 0x1039, 0x103a, 0x1714, 0x1734, 0x17d2, 0x1a60, 0x1b44, 0x1baa, 0x1bab, 0x1bf2, 0x1bf3, 0x2d7f, 0xa806, 0xa82c, 0xa8c4, 0xa953, 0xa9c0, 0xaaf6, 0xabed, 0x0c56, 0x0f71, 0x0f72, 0x0f7a, 0x0f7b, 0x0f7c, 0x0f7d, 0x0f80, 0x0f74]);let DIACRITICS_EXCEPTION_STR;const DIACRITICS_REG_EXP = /\p{M}+/gu;const SPECIAL_CHARS_REG_EXP = /([.*+?^${}()|[\]\\])|(\p{P})|(\s+)|(\p{M})|(\p{L})/gu;const NOT_DIACRITIC_FROM_END_REG_EXP = /([^\p{M}])\p{M}*$/u;const NOT_DIACRITIC_FROM_START_REG_EXP = /^\p{M}*([^\p{M}])/u;const SYLLABLES_REG_EXP = /[\uAC00-\uD7AF\uFA6C\uFACF-\uFAD1\uFAD5-\uFAD7]+/g;const SYLLABLES_LENGTHS = new Map();const FIRST_CHAR_SYLLABLES_REG_EXP = "[\\u1100-\\u1112\\ud7a4-\\ud7af\\ud84a\\ud84c\\ud850\\ud854\\ud857\\ud85f]";const NFKC_CHARS_TO_NORMALIZE = new Map();let noSyllablesRegExp = null;let withSyllablesRegExp = null;function normalize(text) {  const syllablePositions = [];  let m;  while ((m = SYLLABLES_REG_EXP.exec(text)) !== null) {    let {      index    } = m;    for (const char of m[0]) {      let len = SYLLABLES_LENGTHS.get(char);      if (!len) {        len = char.normalize("NFD").length;        SYLLABLES_LENGTHS.set(char, len);      }      syllablePositions.push([len, index++]);    }  }  let normalizationRegex;  if (syllablePositions.length === 0 && noSyllablesRegExp) {    normalizationRegex = noSyllablesRegExp;  } else if (syllablePositions.length > 0 && withSyllablesRegExp) {    normalizationRegex = withSyllablesRegExp;  } else {    const replace = Object.keys(CHARACTERS_TO_NORMALIZE).join("");    const toNormalizeWithNFKC = "\u2460-\u2473" + "\u24b6-\u24ff" + "\u3244-\u32bf" + "\u32d0-\u32fe" + "\uff00-\uffef";    const CJK = "(?:\\p{Ideographic}|[\u3040-\u30FF])";    const regexp = `([${replace}])|([${toNormalizeWithNFKC}])|(\\p{M}+(?:-\\n)?)|(\\S-\\n)|(${CJK}\\n)|(\\n)`;    if (syllablePositions.length === 0) {      normalizationRegex = noSyllablesRegExp = new RegExp(regexp + "|(\\u0000)", "gum");    } else {      normalizationRegex = withSyllablesRegExp = new RegExp(regexp + `|(${FIRST_CHAR_SYLLABLES_REG_EXP})`, "gum");    }  }  const rawDiacriticsPositions = [];  while ((m = DIACRITICS_REG_EXP.exec(text)) !== null) {    rawDiacriticsPositions.push([m[0].length, m.index]);  }  let normalized = text.normalize("NFD");  const positions = [[0, 0]];  let rawDiacriticsIndex = 0;  let syllableIndex = 0;  let shift = 0;  let shiftOrigin = 0;  let eol = 0;  let hasDiacritics = false;  normalized = normalized.replace(normalizationRegex, (match, p1, p2, p3, p4, p5, p6, p7, i) => {    i -= shiftOrigin;    if (p1) {      const replacement = CHARACTERS_TO_NORMALIZE[p1];      const jj = replacement.length;      for (let j = 1; j < jj; j++) {        positions.push([i - shift + j, shift - j]);      }      shift -= jj - 1;      return replacement;    }    if (p2) {      let replacement = NFKC_CHARS_TO_NORMALIZE.get(p2);      if (!replacement) {        replacement = p2.normalize("NFKC");        NFKC_CHARS_TO_NORMALIZE.set(p2, replacement);      }      const jj = replacement.length;      for (let j = 1; j < jj; j++) {        positions.push([i - shift + j, shift - j]);      }      shift -= jj - 1;      return replacement;    }    if (p3) {      const hasTrailingDashEOL = p3.endsWith("\n");      const len = hasTrailingDashEOL ? p3.length - 2 : p3.length;      hasDiacritics = true;      let jj = len;      if (i + eol === rawDiacriticsPositions[rawDiacriticsIndex]?.[1]) {        jj -= rawDiacriticsPositions[rawDiacriticsIndex][0];        ++rawDiacriticsIndex;      }      for (let j = 1; j <= jj; j++) {        positions.push([i - 1 - shift + j, shift - j]);      }      shift -= jj;      shiftOrigin += jj;      if (hasTrailingDashEOL) {        i += len - 1;        positions.push([i - shift + 1, 1 + shift]);        shift += 1;        shiftOrigin += 1;        eol += 1;        return p3.slice(0, len);      }      return p3;    }    if (p4) {      positions.push([i - shift + 1, 1 + shift]);      shift += 1;      shiftOrigin += 1;      eol += 1;      return p4.charAt(0);    }    if (p5) {      positions.push([i - shift + 1, shift]);      shiftOrigin += 1;      eol += 1;      return p5.charAt(0);    }    if (p6) {      positions.push([i - shift + 1, shift - 1]);      shift -= 1;      shiftOrigin += 1;      eol += 1;      return " ";    }    if (i + eol === syllablePositions[syllableIndex]?.[1]) {      const newCharLen = syllablePositions[syllableIndex][0] - 1;      ++syllableIndex;      for (let j = 1; j <= newCharLen; j++) {        positions.push([i - (shift - j), shift - j]);      }      shift -= newCharLen;      shiftOrigin += newCharLen;    }    return p7;  });  positions.push([normalized.length, shift]);  return [normalized, positions, hasDiacritics];}function getOriginalIndex(diffs, pos, len) {  if (!diffs) {    return [pos, len];  }  const start = pos;  const end = pos + len;  let i = (0, _ui_utils.binarySearchFirstItem)(diffs, x => x[0] >= start);  if (diffs[i][0] > start) {    --i;  }  let j = (0, _ui_utils.binarySearchFirstItem)(diffs, x => x[0] >= end, i);  if (diffs[j][0] > end) {    --j;  }  return [start + diffs[i][1], len + diffs[j][1] - diffs[i][1]];}class PDFFindController {  #updateMatchesCountOnProgress = true;  #visitedPagesCount = 0;  constructor({    linkService,    eventBus,    updateMatchesCountOnProgress = true  }) {    this._linkService = linkService;    this._eventBus = eventBus;    this.#updateMatchesCountOnProgress = updateMatchesCountOnProgress;    this.#reset();    eventBus._on("find", this.#onFind.bind(this));    eventBus._on("findbarclose", this.#onFindBarClose.bind(this));  }  get highlightMatches() {    return this._highlightMatches;  }  get pageMatches() {    return this._pageMatches;  }  get pageMatchesLength() {    return this._pageMatchesLength;  }  get selected() {    return this._selected;  }  get state() {    return this._state;  }  setDocument(pdfDocument) {    if (this._pdfDocument) {      this.#reset();    }    if (!pdfDocument) {      return;    }    this._pdfDocument = pdfDocument;    this._firstPageCapability.resolve();  }  #onFind(state) {    if (!state) {      return;    }    const pdfDocument = this._pdfDocument;    const {      type    } = state;    if (this._state === null || this.#shouldDirtyMatch(state)) {      this._dirtyMatch = true;    }    this._state = state;    if (type !== "highlightallchange") {      this.#updateUIState(FindState.PENDING);    }    this._firstPageCapability.promise.then(() => {      if (!this._pdfDocument || pdfDocument && this._pdfDocument !== pdfDocument) {        return;      }      this.#extractText();      const findbarClosed = !this._highlightMatches;      const pendingTimeout = !!this._findTimeout;      if (this._findTimeout) {        clearTimeout(this._findTimeout);        this._findTimeout = null;      }      if (!type) {        this._findTimeout = setTimeout(() => {          this.#nextMatch();          this._findTimeout = null;        }, FIND_TIMEOUT);      } else if (this._dirtyMatch) {        this.#nextMatch();      } else if (type === "again") {        this.#nextMatch();        if (findbarClosed && this._state.highlightAll) {          this.#updateAllPages();        }      } else if (type === "highlightallchange") {        if (pendingTimeout) {          this.#nextMatch();        } else {          this._highlightMatches = true;        }        this.#updateAllPages();      } else {        this.#nextMatch();      }    });  }  scrollMatchIntoView({    element = null,    selectedLeft = 0,    pageIndex = -1,    matchIndex = -1  }) {    if (!this._scrollMatches || !element) {      return;    } else if (matchIndex === -1 || matchIndex !== this._selected.matchIdx) {      return;    } else if (pageIndex === -1 || pageIndex !== this._selected.pageIdx) {      return;    }    this._scrollMatches = false;    const spot = {      top: MATCH_SCROLL_OFFSET_TOP,      left: selectedLeft + MATCH_SCROLL_OFFSET_LEFT    };    (0, _ui_utils.scrollIntoView)(element, spot, true);  }  #reset() {    this._highlightMatches = false;    this._scrollMatches = false;    this._pdfDocument = null;    this._pageMatches = [];    this._pageMatchesLength = [];    this.#visitedPagesCount = 0;    this._state = null;    this._selected = {      pageIdx: -1,      matchIdx: -1    };    this._offset = {      pageIdx: null,      matchIdx: null,      wrapped: false    };    this._extractTextPromises = [];    this._pageContents = [];    this._pageDiffs = [];    this._hasDiacritics = [];    this._matchesCountTotal = 0;    this._pagesToSearch = null;    this._pendingFindMatches = new Set();    this._resumePageIdx = null;    this._dirtyMatch = false;    clearTimeout(this._findTimeout);    this._findTimeout = null;    this._firstPageCapability = (0, _pdfjsLib.createPromiseCapability)();  }  get #query() {    if (this._state.query !== this._rawQuery) {      this._rawQuery = this._state.query;      [this._normalizedQuery] = normalize(this._state.query);    }    return this._normalizedQuery;  }  #shouldDirtyMatch(state) {    if (state.query !== this._state.query) {      return true;    }    switch (state.type) {      case "again":        const pageNumber = this._selected.pageIdx + 1;        const linkService = this._linkService;        if (pageNumber >= 1 && pageNumber <= linkService.pagesCount && pageNumber !== linkService.page && !linkService.isPageVisible(pageNumber)) {          return true;        }        return false;      case "highlightallchange":        return false;    }    return true;  }  #isEntireWord(content, startIdx, length) {    let match = content.slice(0, startIdx).match(NOT_DIACRITIC_FROM_END_REG_EXP);    if (match) {      const first = content.charCodeAt(startIdx);      const limit = match[1].charCodeAt(0);      if ((0, _pdf_find_utils.getCharacterType)(first) === (0, _pdf_find_utils.getCharacterType)(limit)) {        return false;      }    }    match = content.slice(startIdx + length).match(NOT_DIACRITIC_FROM_START_REG_EXP);    if (match) {      const last = content.charCodeAt(startIdx + length - 1);      const limit = match[1].charCodeAt(0);      if ((0, _pdf_find_utils.getCharacterType)(last) === (0, _pdf_find_utils.getCharacterType)(limit)) {        return false;      }    }    return true;  }  #calculateRegExpMatch(query, entireWord, pageIndex, pageContent) {    const matches = this._pageMatches[pageIndex] = [];    const matchesLength = this._pageMatchesLength[pageIndex] = [];    if (!query) {      return;    }    const diffs = this._pageDiffs[pageIndex];    let match;    while ((match = query.exec(pageContent)) !== null) {      if (entireWord && !this.#isEntireWord(pageContent, match.index, match[0].length)) {        continue;      }      const [matchPos, matchLen] = getOriginalIndex(diffs, match.index, match[0].length);      if (matchLen) {        matches.push(matchPos);        matchesLength.push(matchLen);      }    }  }  #convertToRegExpString(query, hasDiacritics) {    const {      matchDiacritics    } = this._state;    let isUnicode = false;    query = query.replace(SPECIAL_CHARS_REG_EXP, (match, p1, p2, p3, p4, p5) => {      if (p1) {        return `[ ]*\\${p1}[ ]*`;      }      if (p2) {        return `[ ]*${p2}[ ]*`;      }      if (p3) {        return "[ ]+";      }      if (matchDiacritics) {        return p4 || p5;      }      if (p4) {        return DIACRITICS_EXCEPTION.has(p4.charCodeAt(0)) ? p4 : "";      }      if (hasDiacritics) {        isUnicode = true;        return `${p5}\\p{M}*`;      }      return p5;    });    const trailingSpaces = "[ ]*";    if (query.endsWith(trailingSpaces)) {      query = query.slice(0, query.length - trailingSpaces.length);    }    if (matchDiacritics) {      if (hasDiacritics) {        DIACRITICS_EXCEPTION_STR ||= String.fromCharCode(...DIACRITICS_EXCEPTION);        isUnicode = true;        query = `${query}(?=[${DIACRITICS_EXCEPTION_STR}]|[^\\p{M}]|$)`;      }    }    return [isUnicode, query];  }  #calculateMatch(pageIndex) {    let query = this.#query;    if (!query) {      return;    }    const {      caseSensitive,      entireWord,      phraseSearch    } = this._state;    const pageContent = this._pageContents[pageIndex];    const hasDiacritics = this._hasDiacritics[pageIndex];    let isUnicode = false;    if (phraseSearch) {      [isUnicode, query] = this.#convertToRegExpString(query, hasDiacritics);    } else {      const match = query.match(/\S+/g);      if (match) {        query = match.sort().reverse().map(q => {          const [isUnicodePart, queryPart] = this.#convertToRegExpString(q, hasDiacritics);          isUnicode ||= isUnicodePart;          return `(${queryPart})`;        }).join("|");      }    }    const flags = `g${isUnicode ? "u" : ""}${caseSensitive ? "" : "i"}`;    query = query ? new RegExp(query, flags) : null;    this.#calculateRegExpMatch(query, entireWord, pageIndex, pageContent);    if (this._state.highlightAll) {      this.#updatePage(pageIndex);    }    if (this._resumePageIdx === pageIndex) {      this._resumePageIdx = null;      this.#nextPageMatch();    }    const pageMatchesCount = this._pageMatches[pageIndex].length;    this._matchesCountTotal += pageMatchesCount;    if (this.#updateMatchesCountOnProgress) {      if (pageMatchesCount > 0) {        this.#updateUIResultsCount();      }    } else if (++this.#visitedPagesCount === this._linkService.pagesCount) {      this.#updateUIResultsCount();    }  }  #extractText() {    if (this._extractTextPromises.length > 0) {      return;    }    let promise = Promise.resolve();    for (let i = 0, ii = this._linkService.pagesCount; i < ii; i++) {      const extractTextCapability = (0, _pdfjsLib.createPromiseCapability)();      this._extractTextPromises[i] = extractTextCapability.promise;      promise = promise.then(() => {        return this._pdfDocument.getPage(i + 1).then(pdfPage => {          return pdfPage.getTextContent();        }).then(textContent => {          const strBuf = [];          for (const textItem of textContent.items) {            strBuf.push(textItem.str);            if (textItem.hasEOL) {              strBuf.push("\n");            }          }          [this._pageContents[i], this._pageDiffs[i], this._hasDiacritics[i]] = normalize(strBuf.join(""));          extractTextCapability.resolve();        }, reason => {          console.error(`Unable to get text content for page ${i + 1}`, reason);          this._pageContents[i] = "";          this._pageDiffs[i] = null;          this._hasDiacritics[i] = false;          extractTextCapability.resolve();        });      });    }  }  #updatePage(index) {    if (this._scrollMatches && this._selected.pageIdx === index) {      this._linkService.page = index + 1;    }    this._eventBus.dispatch("updatetextlayermatches", {      source: this,      pageIndex: index    });  }  #updateAllPages() {    this._eventBus.dispatch("updatetextlayermatches", {      source: this,      pageIndex: -1    });  }  #nextMatch() {    const previous = this._state.findPrevious;    const currentPageIndex = this._linkService.page - 1;    const numPages = this._linkService.pagesCount;    this._highlightMatches = true;    if (this._dirtyMatch) {      this._dirtyMatch = false;      this._selected.pageIdx = this._selected.matchIdx = -1;      this._offset.pageIdx = currentPageIndex;      this._offset.matchIdx = null;      this._offset.wrapped = false;      this._resumePageIdx = null;      this._pageMatches.length = 0;      this._pageMatchesLength.length = 0;      this.#visitedPagesCount = 0;      this._matchesCountTotal = 0;      this.#updateAllPages();      for (let i = 0; i < numPages; i++) {        if (this._pendingFindMatches.has(i)) {          continue;        }        this._pendingFindMatches.add(i);        this._extractTextPromises[i].then(() => {          this._pendingFindMatches.delete(i);          this.#calculateMatch(i);        });      }    }    if (!this.#query) {      this.#updateUIState(FindState.FOUND);      return;    }    if (this._resumePageIdx) {      return;    }    const offset = this._offset;    this._pagesToSearch = numPages;    if (offset.matchIdx !== null) {      const numPageMatches = this._pageMatches[offset.pageIdx].length;      if (!previous && offset.matchIdx + 1 < numPageMatches || previous && offset.matchIdx > 0) {        offset.matchIdx = previous ? offset.matchIdx - 1 : offset.matchIdx + 1;        this.#updateMatch(true);        return;      }      this.#advanceOffsetPage(previous);    }    this.#nextPageMatch();  }  #matchesReady(matches) {    const offset = this._offset;    const numMatches = matches.length;    const previous = this._state.findPrevious;    if (numMatches) {      offset.matchIdx = previous ? numMatches - 1 : 0;      this.#updateMatch(true);      return true;    }    this.#advanceOffsetPage(previous);    if (offset.wrapped) {      offset.matchIdx = null;      if (this._pagesToSearch < 0) {        this.#updateMatch(false);        return true;      }    }    return false;  }  #nextPageMatch() {    if (this._resumePageIdx !== null) {      console.error("There can only be one pending page.");    }    let matches = null;    do {      const pageIdx = this._offset.pageIdx;      matches = this._pageMatches[pageIdx];      if (!matches) {        this._resumePageIdx = pageIdx;        break;      }    } while (!this.#matchesReady(matches));  }  #advanceOffsetPage(previous) {    const offset = this._offset;    const numPages = this._linkService.pagesCount;    offset.pageIdx = previous ? offset.pageIdx - 1 : offset.pageIdx + 1;    offset.matchIdx = null;    this._pagesToSearch--;    if (offset.pageIdx >= numPages || offset.pageIdx < 0) {      offset.pageIdx = previous ? numPages - 1 : 0;      offset.wrapped = true;    }  }  #updateMatch(found = false) {    let state = FindState.NOT_FOUND;    const wrapped = this._offset.wrapped;    this._offset.wrapped = false;    if (found) {      const previousPage = this._selected.pageIdx;      this._selected.pageIdx = this._offset.pageIdx;      this._selected.matchIdx = this._offset.matchIdx;      state = wrapped ? FindState.WRAPPED : FindState.FOUND;      if (previousPage !== -1 && previousPage !== this._selected.pageIdx) {        this.#updatePage(previousPage);      }    }    this.#updateUIState(state, this._state.findPrevious);    if (this._selected.pageIdx !== -1) {      this._scrollMatches = true;      this.#updatePage(this._selected.pageIdx);    }  }  #onFindBarClose(evt) {    const pdfDocument = this._pdfDocument;    this._firstPageCapability.promise.then(() => {      if (!this._pdfDocument || pdfDocument && this._pdfDocument !== pdfDocument) {        return;      }      if (this._findTimeout) {        clearTimeout(this._findTimeout);        this._findTimeout = null;      }      if (this._resumePageIdx) {        this._resumePageIdx = null;        this._dirtyMatch = true;      }      this.#updateUIState(FindState.FOUND);      this._highlightMatches = false;      this.#updateAllPages();    });  }  #requestMatchesCount() {    const {      pageIdx,      matchIdx    } = this._selected;    let current = 0,      total = this._matchesCountTotal;    if (matchIdx !== -1) {      for (let i = 0; i < pageIdx; i++) {        current += this._pageMatches[i]?.length || 0;      }      current += matchIdx + 1;    }    if (current < 1 || current > total) {      current = total = 0;    }    return {      current,      total    };  }  #updateUIResultsCount() {    this._eventBus.dispatch("updatefindmatchescount", {      source: this,      matchesCount: this.#requestMatchesCount()    });  }  #updateUIState(state, previous = false) {    if (!this.#updateMatchesCountOnProgress && (this.#visitedPagesCount !== this._linkService.pagesCount || state === FindState.PENDING)) {      return;    }    this._eventBus.dispatch("updatefindcontrolstate", {      source: this,      state,      previous,      matchesCount: this.#requestMatchesCount(),      rawQuery: this._state?.query ?? null    });  }}exports.PDFFindController = PDFFindController;/***/ }),/* 17 *//***/ ((__unused_webpack_module, exports) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.CharacterType = void 0;exports.getCharacterType = getCharacterType;const CharacterType = {  SPACE: 0,  ALPHA_LETTER: 1,  PUNCT: 2,  HAN_LETTER: 3,  KATAKANA_LETTER: 4,  HIRAGANA_LETTER: 5,  HALFWIDTH_KATAKANA_LETTER: 6,  THAI_LETTER: 7};exports.CharacterType = CharacterType;function isAlphabeticalScript(charCode) {  return charCode < 0x2e80;}function isAscii(charCode) {  return (charCode & 0xff80) === 0;}function isAsciiAlpha(charCode) {  return charCode >= 0x61 && charCode <= 0x7a || charCode >= 0x41 && charCode <= 0x5a;}function isAsciiDigit(charCode) {  return charCode >= 0x30 && charCode <= 0x39;}function isAsciiSpace(charCode) {  return charCode === 0x20 || charCode === 0x09 || charCode === 0x0d || charCode === 0x0a;}function isHan(charCode) {  return charCode >= 0x3400 && charCode <= 0x9fff || charCode >= 0xf900 && charCode <= 0xfaff;}function isKatakana(charCode) {  return charCode >= 0x30a0 && charCode <= 0x30ff;}function isHiragana(charCode) {  return charCode >= 0x3040 && charCode <= 0x309f;}function isHalfwidthKatakana(charCode) {  return charCode >= 0xff60 && charCode <= 0xff9f;}function isThai(charCode) {  return (charCode & 0xff80) === 0x0e00;}function getCharacterType(charCode) {  if (isAlphabeticalScript(charCode)) {    if (isAscii(charCode)) {      if (isAsciiSpace(charCode)) {        return CharacterType.SPACE;      } else if (isAsciiAlpha(charCode) || isAsciiDigit(charCode) || charCode === 0x5f) {        return CharacterType.ALPHA_LETTER;      }      return CharacterType.PUNCT;    } else if (isThai(charCode)) {      return CharacterType.THAI_LETTER;    } else if (charCode === 0xa0) {      return CharacterType.SPACE;    }    return CharacterType.ALPHA_LETTER;  }  if (isHan(charCode)) {    return CharacterType.HAN_LETTER;  } else if (isKatakana(charCode)) {    return CharacterType.KATAKANA_LETTER;  } else if (isHiragana(charCode)) {    return CharacterType.HIRAGANA_LETTER;  } else if (isHalfwidthKatakana(charCode)) {    return CharacterType.HALFWIDTH_KATAKANA_LETTER;  }  return CharacterType.ALPHA_LETTER;}/***/ }),/* 18 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFHistory = void 0;exports.isDestArraysEqual = isDestArraysEqual;exports.isDestHashesEqual = isDestHashesEqual;var _ui_utils = __webpack_require__(1);var _event_utils = __webpack_require__(6);const HASH_CHANGE_TIMEOUT = 1000;const POSITION_UPDATED_THRESHOLD = 50;const UPDATE_VIEWAREA_TIMEOUT = 1000;function getCurrentHash() {  return document.location.hash;}class PDFHistory {  constructor({    linkService,    eventBus  }) {    this.linkService = linkService;    this.eventBus = eventBus;    this._initialized = false;    this._fingerprint = "";    this.reset();    this._boundEvents = null;    this.eventBus._on("pagesinit", () => {      this._isPagesLoaded = false;      this.eventBus._on("pagesloaded", evt => {        this._isPagesLoaded = !!evt.pagesCount;      }, {        once: true      });    });  }  initialize({    fingerprint,    resetHistory = false,    updateUrl = false  }) {    if (!fingerprint || typeof fingerprint !== "string") {      console.error('PDFHistory.initialize: The "fingerprint" must be a non-empty string.');      return;    }    if (this._initialized) {      this.reset();    }    const reInitialized = this._fingerprint !== "" && this._fingerprint !== fingerprint;    this._fingerprint = fingerprint;    this._updateUrl = updateUrl === true;    this._initialized = true;    this._bindEvents();    const state = window.history.state;    this._popStateInProgress = false;    this._blockHashChange = 0;    this._currentHash = getCurrentHash();    this._numPositionUpdates = 0;    this._uid = this._maxUid = 0;    this._destination = null;    this._position = null;    if (!this._isValidState(state, true) || resetHistory) {      const {        hash,        page,        rotation      } = this._parseCurrentHash(true);      if (!hash || reInitialized || resetHistory) {        this._pushOrReplaceState(null, true);        return;      }      this._pushOrReplaceState({        hash,        page,        rotation      }, true);      return;    }    const destination = state.destination;    this._updateInternalState(destination, state.uid, true);    if (destination.rotation !== undefined) {      this._initialRotation = destination.rotation;    }    if (destination.dest) {      this._initialBookmark = JSON.stringify(destination.dest);      this._destination.page = null;    } else if (destination.hash) {      this._initialBookmark = destination.hash;    } else if (destination.page) {      this._initialBookmark = `page=${destination.page}`;    }  }  reset() {    if (this._initialized) {      this._pageHide();      this._initialized = false;      this._unbindEvents();    }    if (this._updateViewareaTimeout) {      clearTimeout(this._updateViewareaTimeout);      this._updateViewareaTimeout = null;    }    this._initialBookmark = null;    this._initialRotation = null;  }  push({    namedDest = null,    explicitDest,    pageNumber  }) {    if (!this._initialized) {      return;    }    if (namedDest && typeof namedDest !== "string") {      console.error("PDFHistory.push: " + `"${namedDest}" is not a valid namedDest parameter.`);      return;    } else if (!Array.isArray(explicitDest)) {      console.error("PDFHistory.push: " + `"${explicitDest}" is not a valid explicitDest parameter.`);      return;    } else if (!this._isValidPage(pageNumber)) {      if (pageNumber !== null || this._destination) {        console.error("PDFHistory.push: " + `"${pageNumber}" is not a valid pageNumber parameter.`);        return;      }    }    const hash = namedDest || JSON.stringify(explicitDest);    if (!hash) {      return;    }    let forceReplace = false;    if (this._destination && (isDestHashesEqual(this._destination.hash, hash) || isDestArraysEqual(this._destination.dest, explicitDest))) {      if (this._destination.page) {        return;      }      forceReplace = true;    }    if (this._popStateInProgress && !forceReplace) {      return;    }    this._pushOrReplaceState({      dest: explicitDest,      hash,      page: pageNumber,      rotation: this.linkService.rotation    }, forceReplace);    if (!this._popStateInProgress) {      this._popStateInProgress = true;      Promise.resolve().then(() => {        this._popStateInProgress = false;      });    }  }  pushPage(pageNumber) {    if (!this._initialized) {      return;    }    if (!this._isValidPage(pageNumber)) {      console.error(`PDFHistory.pushPage: "${pageNumber}" is not a valid page number.`);      return;    }    if (this._destination?.page === pageNumber) {      return;    }    if (this._popStateInProgress) {      return;    }    this._pushOrReplaceState({      dest: null,      hash: `page=${pageNumber}`,      page: pageNumber,      rotation: this.linkService.rotation    });    if (!this._popStateInProgress) {      this._popStateInProgress = true;      Promise.resolve().then(() => {        this._popStateInProgress = false;      });    }  }  pushCurrentPosition() {    if (!this._initialized || this._popStateInProgress) {      return;    }    this._tryPushCurrentPosition();  }  back() {    if (!this._initialized || this._popStateInProgress) {      return;    }    const state = window.history.state;    if (this._isValidState(state) && state.uid > 0) {      window.history.back();    }  }  forward() {    if (!this._initialized || this._popStateInProgress) {      return;    }    const state = window.history.state;    if (this._isValidState(state) && state.uid < this._maxUid) {      window.history.forward();    }  }  get popStateInProgress() {    return this._initialized && (this._popStateInProgress || this._blockHashChange > 0);  }  get initialBookmark() {    return this._initialized ? this._initialBookmark : null;  }  get initialRotation() {    return this._initialized ? this._initialRotation : null;  }  _pushOrReplaceState(destination, forceReplace = false) {    const shouldReplace = forceReplace || !this._destination;    const newState = {      fingerprint: this._fingerprint,      uid: shouldReplace ? this._uid : this._uid + 1,      destination    };    this._updateInternalState(destination, newState.uid);    let newUrl;    if (this._updateUrl && destination?.hash) {      const baseUrl = document.location.href.split("#")[0];      if (!baseUrl.startsWith("file://")) {        newUrl = `${baseUrl}#${destination.hash}`;      }    }    if (shouldReplace) {      window.history.replaceState(newState, "", newUrl);    } else {      window.history.pushState(newState, "", newUrl);    }  }  _tryPushCurrentPosition(temporary = false) {    if (!this._position) {      return;    }    let position = this._position;    if (temporary) {      position = Object.assign(Object.create(null), this._position);      position.temporary = true;    }    if (!this._destination) {      this._pushOrReplaceState(position);      return;    }    if (this._destination.temporary) {      this._pushOrReplaceState(position, true);      return;    }    if (this._destination.hash === position.hash) {      return;    }    if (!this._destination.page && (POSITION_UPDATED_THRESHOLD <= 0 || this._numPositionUpdates <= POSITION_UPDATED_THRESHOLD)) {      return;    }    let forceReplace = false;    if (this._destination.page >= position.first && this._destination.page <= position.page) {      if (this._destination.dest !== undefined || !this._destination.first) {        return;      }      forceReplace = true;    }    this._pushOrReplaceState(position, forceReplace);  }  _isValidPage(val) {    return Number.isInteger(val) && val > 0 && val <= this.linkService.pagesCount;  }  _isValidState(state, checkReload = false) {    if (!state) {      return false;    }    if (state.fingerprint !== this._fingerprint) {      if (checkReload) {        if (typeof state.fingerprint !== "string" || state.fingerprint.length !== this._fingerprint.length) {          return false;        }        const [perfEntry] = performance.getEntriesByType("navigation");        if (perfEntry?.type !== "reload") {          return false;        }      } else {        return false;      }    }    if (!Number.isInteger(state.uid) || state.uid < 0) {      return false;    }    if (state.destination === null || typeof state.destination !== "object") {      return false;    }    return true;  }  _updateInternalState(destination, uid, removeTemporary = false) {    if (this._updateViewareaTimeout) {      clearTimeout(this._updateViewareaTimeout);      this._updateViewareaTimeout = null;    }    if (removeTemporary && destination?.temporary) {      delete destination.temporary;    }    this._destination = destination;    this._uid = uid;    this._maxUid = Math.max(this._maxUid, uid);    this._numPositionUpdates = 0;  }  _parseCurrentHash(checkNameddest = false) {    const hash = unescape(getCurrentHash()).substring(1);    const params = (0, _ui_utils.parseQueryString)(hash);    const nameddest = params.get("nameddest") || "";    let page = params.get("page") | 0;    if (!this._isValidPage(page) || checkNameddest && nameddest.length > 0) {      page = null;    }    return {      hash,      page,      rotation: this.linkService.rotation    };  }  _updateViewarea({    location  }) {    if (this._updateViewareaTimeout) {      clearTimeout(this._updateViewareaTimeout);      this._updateViewareaTimeout = null;    }    this._position = {      hash: location.pdfOpenParams.substring(1),      page: this.linkService.page,      first: location.pageNumber,      rotation: location.rotation    };    if (this._popStateInProgress) {      return;    }    if (POSITION_UPDATED_THRESHOLD > 0 && this._isPagesLoaded && this._destination && !this._destination.page) {      this._numPositionUpdates++;    }    if (UPDATE_VIEWAREA_TIMEOUT > 0) {      this._updateViewareaTimeout = setTimeout(() => {        if (!this._popStateInProgress) {          this._tryPushCurrentPosition(true);        }        this._updateViewareaTimeout = null;      }, UPDATE_VIEWAREA_TIMEOUT);    }  }  _popState({    state  }) {    const newHash = getCurrentHash(),      hashChanged = this._currentHash !== newHash;    this._currentHash = newHash;    if (!state) {      this._uid++;      const {        hash,        page,        rotation      } = this._parseCurrentHash();      this._pushOrReplaceState({        hash,        page,        rotation      }, true);      return;    }    if (!this._isValidState(state)) {      return;    }    this._popStateInProgress = true;    if (hashChanged) {      this._blockHashChange++;      (0, _event_utils.waitOnEventOrTimeout)({        target: window,        name: "hashchange",        delay: HASH_CHANGE_TIMEOUT      }).then(() => {        this._blockHashChange--;      });    }    const destination = state.destination;    this._updateInternalState(destination, state.uid, true);    if ((0, _ui_utils.isValidRotation)(destination.rotation)) {      this.linkService.rotation = destination.rotation;    }    if (destination.dest) {      this.linkService.goToDestination(destination.dest);    } else if (destination.hash) {      this.linkService.setHash(destination.hash);    } else if (destination.page) {      this.linkService.page = destination.page;    }    Promise.resolve().then(() => {      this._popStateInProgress = false;    });  }  _pageHide() {    if (!this._destination || this._destination.temporary) {      this._tryPushCurrentPosition();    }  }  _bindEvents() {    if (this._boundEvents) {      return;    }    this._boundEvents = {      updateViewarea: this._updateViewarea.bind(this),      popState: this._popState.bind(this),      pageHide: this._pageHide.bind(this)    };    this.eventBus._on("updateviewarea", this._boundEvents.updateViewarea);    window.addEventListener("popstate", this._boundEvents.popState);    window.addEventListener("pagehide", this._boundEvents.pageHide);  }  _unbindEvents() {    if (!this._boundEvents) {      return;    }    this.eventBus._off("updateviewarea", this._boundEvents.updateViewarea);    window.removeEventListener("popstate", this._boundEvents.popState);    window.removeEventListener("pagehide", this._boundEvents.pageHide);    this._boundEvents = null;  }}exports.PDFHistory = PDFHistory;function isDestHashesEqual(destHash, pushHash) {  if (typeof destHash !== "string" || typeof pushHash !== "string") {    return false;  }  if (destHash === pushHash) {    return true;  }  const nameddest = (0, _ui_utils.parseQueryString)(destHash).get("nameddest");  if (nameddest === pushHash) {    return true;  }  return false;}function isDestArraysEqual(firstDest, secondDest) {  function isEntryEqual(first, second) {    if (typeof first !== typeof second) {      return false;    }    if (Array.isArray(first) || Array.isArray(second)) {      return false;    }    if (first !== null && typeof first === "object" && second !== null) {      if (Object.keys(first).length !== Object.keys(second).length) {        return false;      }      for (const key in first) {        if (!isEntryEqual(first[key], second[key])) {          return false;        }      }      return true;    }    return first === second || Number.isNaN(first) && Number.isNaN(second);  }  if (!(Array.isArray(firstDest) && Array.isArray(secondDest))) {    return false;  }  if (firstDest.length !== secondDest.length) {    return false;  }  for (let i = 0, ii = firstDest.length; i < ii; i++) {    if (!isEntryEqual(firstDest[i], secondDest[i])) {      return false;    }  }  return true;}/***/ }),/* 19 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFLayerViewer = void 0;var _base_tree_viewer = __webpack_require__(13);class PDFLayerViewer extends _base_tree_viewer.BaseTreeViewer {  constructor(options) {    super(options);    this.l10n = options.l10n;    this.eventBus._on("optionalcontentconfigchanged", evt => {      this.#updateLayers(evt.promise);    });    this.eventBus._on("resetlayers", () => {      this.#updateLayers();    });    this.eventBus._on("togglelayerstree", this._toggleAllTreeItems.bind(this));  }  reset() {    super.reset();    this._optionalContentConfig = null;    this._optionalContentHash = null;  }  _dispatchEvent(layersCount) {    this.eventBus.dispatch("layersloaded", {      source: this,      layersCount    });  }  _bindLink(element, {    groupId,    input  }) {    const setVisibility = () => {      this._optionalContentConfig.setVisibility(groupId, input.checked);      this._optionalContentHash = this._optionalContentConfig.getHash();      this.eventBus.dispatch("optionalcontentconfig", {        source: this,        promise: Promise.resolve(this._optionalContentConfig)      });    };    element.onclick = evt => {      if (evt.target === input) {        setVisibility();        return true;      } else if (evt.target !== element) {        return true;      }      input.checked = !input.checked;      setVisibility();      return false;    };  }  async _setNestedName(element, {    name = null  }) {    if (typeof name === "string") {      element.textContent = this._normalizeTextContent(name);      return;    }    element.textContent = await this.l10n.get("additional_layers");    element.style.fontStyle = "italic";  }  _addToggleButton(div, {    name = null  }) {    super._addToggleButton(div, name === null);  }  _toggleAllTreeItems() {    if (!this._optionalContentConfig) {      return;    }    super._toggleAllTreeItems();  }  render({    optionalContentConfig,    pdfDocument  }) {    if (this._optionalContentConfig) {      this.reset();    }    this._optionalContentConfig = optionalContentConfig || null;    this._pdfDocument = pdfDocument || null;    const groups = optionalContentConfig?.getOrder();    if (!groups) {      this._dispatchEvent(0);      return;    }    this._optionalContentHash = optionalContentConfig.getHash();    const fragment = document.createDocumentFragment(),      queue = [{        parent: fragment,        groups      }];    let layersCount = 0,      hasAnyNesting = false;    while (queue.length > 0) {      const levelData = queue.shift();      for (const groupId of levelData.groups) {        const div = document.createElement("div");        div.className = "treeItem";        const element = document.createElement("a");        div.append(element);        if (typeof groupId === "object") {          hasAnyNesting = true;          this._addToggleButton(div, groupId);          this._setNestedName(element, groupId);          const itemsDiv = document.createElement("div");          itemsDiv.className = "treeItems";          div.append(itemsDiv);          queue.push({            parent: itemsDiv,            groups: groupId.order          });        } else {          const group = optionalContentConfig.getGroup(groupId);          const input = document.createElement("input");          this._bindLink(element, {            groupId,            input          });          input.type = "checkbox";          input.checked = group.visible;          const label = document.createElement("label");          label.textContent = this._normalizeTextContent(group.name);          label.append(input);          element.append(label);          layersCount++;        }        levelData.parent.append(div);      }    }    this._finishRendering(fragment, layersCount, hasAnyNesting);  }  async #updateLayers(promise = null) {    if (!this._optionalContentConfig) {      return;    }    const pdfDocument = this._pdfDocument;    const optionalContentConfig = await (promise || pdfDocument.getOptionalContentConfig());    if (pdfDocument !== this._pdfDocument) {      return;    }    if (promise) {      if (optionalContentConfig.getHash() === this._optionalContentHash) {        return;      }    } else {      this.eventBus.dispatch("optionalcontentconfig", {        source: this,        promise: Promise.resolve(optionalContentConfig)      });    }    this.render({      optionalContentConfig,      pdfDocument: this._pdfDocument    });  }}exports.PDFLayerViewer = PDFLayerViewer;/***/ }),/* 20 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFOutlineViewer = void 0;var _base_tree_viewer = __webpack_require__(13);var _pdfjsLib = __webpack_require__(5);var _ui_utils = __webpack_require__(1);class PDFOutlineViewer extends _base_tree_viewer.BaseTreeViewer {  constructor(options) {    super(options);    this.linkService = options.linkService;    this.downloadManager = options.downloadManager;    this.eventBus._on("toggleoutlinetree", this._toggleAllTreeItems.bind(this));    this.eventBus._on("currentoutlineitem", this._currentOutlineItem.bind(this));    this.eventBus._on("pagechanging", evt => {      this._currentPageNumber = evt.pageNumber;    });    this.eventBus._on("pagesloaded", evt => {      this._isPagesLoaded = !!evt.pagesCount;      if (this._currentOutlineItemCapability && !this._currentOutlineItemCapability.settled) {        this._currentOutlineItemCapability.resolve(this._isPagesLoaded);      }    });    this.eventBus._on("sidebarviewchanged", evt => {      this._sidebarView = evt.view;    });  }  reset() {    super.reset();    this._outline = null;    this._pageNumberToDestHashCapability = null;    this._currentPageNumber = 1;    this._isPagesLoaded = null;    if (this._currentOutlineItemCapability && !this._currentOutlineItemCapability.settled) {      this._currentOutlineItemCapability.resolve(false);    }    this._currentOutlineItemCapability = null;  }  _dispatchEvent(outlineCount) {    this._currentOutlineItemCapability = (0, _pdfjsLib.createPromiseCapability)();    if (outlineCount === 0 || this._pdfDocument?.loadingParams.disableAutoFetch) {      this._currentOutlineItemCapability.resolve(false);    } else if (this._isPagesLoaded !== null) {      this._currentOutlineItemCapability.resolve(this._isPagesLoaded);    }    this.eventBus.dispatch("outlineloaded", {      source: this,      outlineCount,      currentOutlineItemPromise: this._currentOutlineItemCapability.promise    });  }  _bindLink(element, {    url,    newWindow,    action,    attachment,    dest,    setOCGState  }) {    const {      linkService    } = this;    if (url) {      linkService.addLinkAttributes(element, url, newWindow);      return;    }    if (action) {      element.href = linkService.getAnchorUrl("");      element.onclick = () => {        linkService.executeNamedAction(action);        return false;      };      return;    }    if (attachment) {      element.href = linkService.getAnchorUrl("");      element.onclick = () => {        this.downloadManager.openOrDownloadData(element, attachment.content, attachment.filename);        return false;      };      return;    }    if (setOCGState) {      element.href = linkService.getAnchorUrl("");      element.onclick = () => {        linkService.executeSetOCGState(setOCGState);        return false;      };      return;    }    element.href = linkService.getDestinationHash(dest);    element.onclick = evt => {      this._updateCurrentTreeItem(evt.target.parentNode);      if (dest) {        linkService.goToDestination(dest);      }      return false;    };  }  _setStyles(element, {    bold,    italic  }) {    if (bold) {      element.style.fontWeight = "bold";    }    if (italic) {      element.style.fontStyle = "italic";    }  }  _addToggleButton(div, {    count,    items  }) {    let hidden = false;    if (count < 0) {      let totalCount = items.length;      if (totalCount > 0) {        const queue = [...items];        while (queue.length > 0) {          const {            count: nestedCount,            items: nestedItems          } = queue.shift();          if (nestedCount > 0 && nestedItems.length > 0) {            totalCount += nestedItems.length;            queue.push(...nestedItems);          }        }      }      if (Math.abs(count) === totalCount) {        hidden = true;      }    }    super._addToggleButton(div, hidden);  }  _toggleAllTreeItems() {    if (!this._outline) {      return;    }    super._toggleAllTreeItems();  }  render({    outline,    pdfDocument  }) {    if (this._outline) {      this.reset();    }    this._outline = outline || null;    this._pdfDocument = pdfDocument || null;    if (!outline) {      this._dispatchEvent(0);      return;    }    const fragment = document.createDocumentFragment();    const queue = [{      parent: fragment,      items: outline    }];    let outlineCount = 0,      hasAnyNesting = false;    while (queue.length > 0) {      const levelData = queue.shift();      for (const item of levelData.items) {        const div = document.createElement("div");        div.className = "treeItem";        const element = document.createElement("a");        this._bindLink(element, item);        this._setStyles(element, item);        element.textContent = this._normalizeTextContent(item.title);        div.append(element);        if (item.items.length > 0) {          hasAnyNesting = true;          this._addToggleButton(div, item);          const itemsDiv = document.createElement("div");          itemsDiv.className = "treeItems";          div.append(itemsDiv);          queue.push({            parent: itemsDiv,            items: item.items          });        }        levelData.parent.append(div);        outlineCount++;      }    }    this._finishRendering(fragment, outlineCount, hasAnyNesting);  }  async _currentOutlineItem() {    if (!this._isPagesLoaded) {      throw new Error("_currentOutlineItem: All pages have not been loaded.");    }    if (!this._outline || !this._pdfDocument) {      return;    }    const pageNumberToDestHash = await this._getPageNumberToDestHash(this._pdfDocument);    if (!pageNumberToDestHash) {      return;    }    this._updateCurrentTreeItem(null);    if (this._sidebarView !== _ui_utils.SidebarView.OUTLINE) {      return;    }    for (let i = this._currentPageNumber; i > 0; i--) {      const destHash = pageNumberToDestHash.get(i);      if (!destHash) {        continue;      }      const linkElement = this.container.querySelector(`a[href="${destHash}"]`);      if (!linkElement) {        continue;      }      this._scrollToCurrentTreeItem(linkElement.parentNode);      break;    }  }  async _getPageNumberToDestHash(pdfDocument) {    if (this._pageNumberToDestHashCapability) {      return this._pageNumberToDestHashCapability.promise;    }    this._pageNumberToDestHashCapability = (0, _pdfjsLib.createPromiseCapability)();    const pageNumberToDestHash = new Map(),      pageNumberNesting = new Map();    const queue = [{      nesting: 0,      items: this._outline    }];    while (queue.length > 0) {      const levelData = queue.shift(),        currentNesting = levelData.nesting;      for (const {        dest,        items      } of levelData.items) {        let explicitDest, pageNumber;        if (typeof dest === "string") {          explicitDest = await pdfDocument.getDestination(dest);          if (pdfDocument !== this._pdfDocument) {            return null;          }        } else {          explicitDest = dest;        }        if (Array.isArray(explicitDest)) {          const [destRef] = explicitDest;          if (typeof destRef === "object" && destRef !== null) {            pageNumber = this.linkService._cachedPageNumber(destRef);            if (!pageNumber) {              try {                pageNumber = (await pdfDocument.getPageIndex(destRef)) + 1;                if (pdfDocument !== this._pdfDocument) {                  return null;                }                this.linkService.cachePageRef(pageNumber, destRef);              } catch (ex) {}            }          } else if (Number.isInteger(destRef)) {            pageNumber = destRef + 1;          }          if (Number.isInteger(pageNumber) && (!pageNumberToDestHash.has(pageNumber) || currentNesting > pageNumberNesting.get(pageNumber))) {            const destHash = this.linkService.getDestinationHash(dest);            pageNumberToDestHash.set(pageNumber, destHash);            pageNumberNesting.set(pageNumber, currentNesting);          }        }        if (items.length > 0) {          queue.push({            nesting: currentNesting + 1,            items          });        }      }    }    this._pageNumberToDestHashCapability.resolve(pageNumberToDestHash.size > 0 ? pageNumberToDestHash : null);    return this._pageNumberToDestHashCapability.promise;  }}exports.PDFOutlineViewer = PDFOutlineViewer;/***/ }),/* 21 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFPresentationMode = void 0;var _ui_utils = __webpack_require__(1);var _pdfjsLib = __webpack_require__(5);const DELAY_BEFORE_HIDING_CONTROLS = 3000;const ACTIVE_SELECTOR = "pdfPresentationMode";const CONTROLS_SELECTOR = "pdfPresentationModeControls";const MOUSE_SCROLL_COOLDOWN_TIME = 50;const PAGE_SWITCH_THRESHOLD = 0.1;const SWIPE_MIN_DISTANCE_THRESHOLD = 50;const SWIPE_ANGLE_THRESHOLD = Math.PI / 6;class PDFPresentationMode {  #state = _ui_utils.PresentationModeState.UNKNOWN;  #args = null;  constructor({    container,    pdfViewer,    eventBus  }) {    this.container = container;    this.pdfViewer = pdfViewer;    this.eventBus = eventBus;    this.contextMenuOpen = false;    this.mouseScrollTimeStamp = 0;    this.mouseScrollDelta = 0;    this.touchSwipeState = null;  }  async request() {    const {      container,      pdfViewer    } = this;    if (this.active || !pdfViewer.pagesCount || !container.requestFullscreen) {      return false;    }    this.#addFullscreenChangeListeners();    this.#notifyStateChange(_ui_utils.PresentationModeState.CHANGING);    const promise = container.requestFullscreen();    this.#args = {      pageNumber: pdfViewer.currentPageNumber,      scaleValue: pdfViewer.currentScaleValue,      scrollMode: pdfViewer.scrollMode,      spreadMode: null,      annotationEditorMode: null    };    if (pdfViewer.spreadMode !== _ui_utils.SpreadMode.NONE && !(pdfViewer.pageViewsReady && pdfViewer.hasEqualPageSizes)) {      console.warn("Ignoring Spread modes when entering PresentationMode, " + "since the document may contain varying page sizes.");      this.#args.spreadMode = pdfViewer.spreadMode;    }    if (pdfViewer.annotationEditorMode !== _pdfjsLib.AnnotationEditorType.DISABLE) {      this.#args.annotationEditorMode = pdfViewer.annotationEditorMode;    }    try {      await promise;      pdfViewer.focus();      return true;    } catch (reason) {      this.#removeFullscreenChangeListeners();      this.#notifyStateChange(_ui_utils.PresentationModeState.NORMAL);    }    return false;  }  get active() {    return this.#state === _ui_utils.PresentationModeState.CHANGING || this.#state === _ui_utils.PresentationModeState.FULLSCREEN;  }  #mouseWheel(evt) {    if (!this.active) {      return;    }    evt.preventDefault();    const delta = (0, _ui_utils.normalizeWheelEventDelta)(evt);    const currentTime = Date.now();    const storedTime = this.mouseScrollTimeStamp;    if (currentTime > storedTime && currentTime - storedTime < MOUSE_SCROLL_COOLDOWN_TIME) {      return;    }    if (this.mouseScrollDelta > 0 && delta < 0 || this.mouseScrollDelta < 0 && delta > 0) {      this.#resetMouseScrollState();    }    this.mouseScrollDelta += delta;    if (Math.abs(this.mouseScrollDelta) >= PAGE_SWITCH_THRESHOLD) {      const totalDelta = this.mouseScrollDelta;      this.#resetMouseScrollState();      const success = totalDelta > 0 ? this.pdfViewer.previousPage() : this.pdfViewer.nextPage();      if (success) {        this.mouseScrollTimeStamp = currentTime;      }    }  }  #notifyStateChange(state) {    this.#state = state;    this.eventBus.dispatch("presentationmodechanged", {      source: this,      state    });  }  #enter() {    this.#notifyStateChange(_ui_utils.PresentationModeState.FULLSCREEN);    this.container.classList.add(ACTIVE_SELECTOR);    setTimeout(() => {      this.pdfViewer.scrollMode = _ui_utils.ScrollMode.PAGE;      if (this.#args.spreadMode !== null) {        this.pdfViewer.spreadMode = _ui_utils.SpreadMode.NONE;      }      this.pdfViewer.currentPageNumber = this.#args.pageNumber;      this.pdfViewer.currentScaleValue = "page-fit";      if (this.#args.annotationEditorMode !== null) {        this.pdfViewer.annotationEditorMode = _pdfjsLib.AnnotationEditorType.NONE;      }    }, 0);    this.#addWindowListeners();    this.#showControls();    this.contextMenuOpen = false;    window.getSelection().removeAllRanges();  }  #exit() {    const pageNumber = this.pdfViewer.currentPageNumber;    this.container.classList.remove(ACTIVE_SELECTOR);    setTimeout(() => {      this.#removeFullscreenChangeListeners();      this.#notifyStateChange(_ui_utils.PresentationModeState.NORMAL);      this.pdfViewer.scrollMode = this.#args.scrollMode;      if (this.#args.spreadMode !== null) {        this.pdfViewer.spreadMode = this.#args.spreadMode;      }      this.pdfViewer.currentScaleValue = this.#args.scaleValue;      this.pdfViewer.currentPageNumber = pageNumber;      if (this.#args.annotationEditorMode !== null) {        this.pdfViewer.annotationEditorMode = this.#args.annotationEditorMode;      }      this.#args = null;    }, 0);    this.#removeWindowListeners();    this.#hideControls();    this.#resetMouseScrollState();    this.contextMenuOpen = false;  }  #mouseDown(evt) {    if (this.contextMenuOpen) {      this.contextMenuOpen = false;      evt.preventDefault();      return;    }    if (evt.button !== 0) {      return;    }    if (evt.target.href && evt.target.parentNode?.hasAttribute("data-internal-link")) {      return;    }    evt.preventDefault();    if (evt.shiftKey) {      this.pdfViewer.previousPage();    } else {      this.pdfViewer.nextPage();    }  }  #contextMenu() {    this.contextMenuOpen = true;  }  #showControls() {    if (this.controlsTimeout) {      clearTimeout(this.controlsTimeout);    } else {      this.container.classList.add(CONTROLS_SELECTOR);    }    this.controlsTimeout = setTimeout(() => {      this.container.classList.remove(CONTROLS_SELECTOR);      delete this.controlsTimeout;    }, DELAY_BEFORE_HIDING_CONTROLS);  }  #hideControls() {    if (!this.controlsTimeout) {      return;    }    clearTimeout(this.controlsTimeout);    this.container.classList.remove(CONTROLS_SELECTOR);    delete this.controlsTimeout;  }  #resetMouseScrollState() {    this.mouseScrollTimeStamp = 0;    this.mouseScrollDelta = 0;  }  #touchSwipe(evt) {    if (!this.active) {      return;    }    if (evt.touches.length > 1) {      this.touchSwipeState = null;      return;    }    switch (evt.type) {      case "touchstart":        this.touchSwipeState = {          startX: evt.touches[0].pageX,          startY: evt.touches[0].pageY,          endX: evt.touches[0].pageX,          endY: evt.touches[0].pageY        };        break;      case "touchmove":        if (this.touchSwipeState === null) {          return;        }        this.touchSwipeState.endX = evt.touches[0].pageX;        this.touchSwipeState.endY = evt.touches[0].pageY;        evt.preventDefault();        break;      case "touchend":        if (this.touchSwipeState === null) {          return;        }        let delta = 0;        const dx = this.touchSwipeState.endX - this.touchSwipeState.startX;        const dy = this.touchSwipeState.endY - this.touchSwipeState.startY;        const absAngle = Math.abs(Math.atan2(dy, dx));        if (Math.abs(dx) > SWIPE_MIN_DISTANCE_THRESHOLD && (absAngle <= SWIPE_ANGLE_THRESHOLD || absAngle >= Math.PI - SWIPE_ANGLE_THRESHOLD)) {          delta = dx;        } else if (Math.abs(dy) > SWIPE_MIN_DISTANCE_THRESHOLD && Math.abs(absAngle - Math.PI / 2) <= SWIPE_ANGLE_THRESHOLD) {          delta = dy;        }        if (delta > 0) {          this.pdfViewer.previousPage();        } else if (delta < 0) {          this.pdfViewer.nextPage();        }        break;    }  }  #addWindowListeners() {    this.showControlsBind = this.#showControls.bind(this);    this.mouseDownBind = this.#mouseDown.bind(this);    this.mouseWheelBind = this.#mouseWheel.bind(this);    this.resetMouseScrollStateBind = this.#resetMouseScrollState.bind(this);    this.contextMenuBind = this.#contextMenu.bind(this);    this.touchSwipeBind = this.#touchSwipe.bind(this);    window.addEventListener("mousemove", this.showControlsBind);    window.addEventListener("mousedown", this.mouseDownBind);    window.addEventListener("wheel", this.mouseWheelBind, {      passive: false    });    window.addEventListener("keydown", this.resetMouseScrollStateBind);    window.addEventListener("contextmenu", this.contextMenuBind);    window.addEventListener("touchstart", this.touchSwipeBind);    window.addEventListener("touchmove", this.touchSwipeBind);    window.addEventListener("touchend", this.touchSwipeBind);  }  #removeWindowListeners() {    window.removeEventListener("mousemove", this.showControlsBind);    window.removeEventListener("mousedown", this.mouseDownBind);    window.removeEventListener("wheel", this.mouseWheelBind, {      passive: false    });    window.removeEventListener("keydown", this.resetMouseScrollStateBind);    window.removeEventListener("contextmenu", this.contextMenuBind);    window.removeEventListener("touchstart", this.touchSwipeBind);    window.removeEventListener("touchmove", this.touchSwipeBind);    window.removeEventListener("touchend", this.touchSwipeBind);    delete this.showControlsBind;    delete this.mouseDownBind;    delete this.mouseWheelBind;    delete this.resetMouseScrollStateBind;    delete this.contextMenuBind;    delete this.touchSwipeBind;  }  #fullscreenChange() {    if (document.fullscreenElement) {      this.#enter();    } else {      this.#exit();    }  }  #addFullscreenChangeListeners() {    this.fullscreenChangeBind = this.#fullscreenChange.bind(this);    window.addEventListener("fullscreenchange", this.fullscreenChangeBind);  }  #removeFullscreenChangeListeners() {    window.removeEventListener("fullscreenchange", this.fullscreenChangeBind);    delete this.fullscreenChangeBind;  }}exports.PDFPresentationMode = PDFPresentationMode;/***/ }),/* 22 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFRenderingQueue = void 0;var _pdfjsLib = __webpack_require__(5);var _ui_utils = __webpack_require__(1);const CLEANUP_TIMEOUT = 30000;class PDFRenderingQueue {  constructor() {    this.pdfViewer = null;    this.pdfThumbnailViewer = null;    this.onIdle = null;    this.highestPriorityPage = null;    this.idleTimeout = null;    this.printing = false;    this.isThumbnailViewEnabled = false;  }  setViewer(pdfViewer) {    this.pdfViewer = pdfViewer;  }  setThumbnailViewer(pdfThumbnailViewer) {    this.pdfThumbnailViewer = pdfThumbnailViewer;  }  isHighestPriority(view) {    return this.highestPriorityPage === view.renderingId;  }  hasViewer() {    return !!this.pdfViewer;  }  renderHighestPriority(currentlyVisiblePages) {    if (this.idleTimeout) {      clearTimeout(this.idleTimeout);      this.idleTimeout = null;    }    if (this.pdfViewer.forceRendering(currentlyVisiblePages)) {      return;    }    if (this.isThumbnailViewEnabled && this.pdfThumbnailViewer?.forceRendering()) {      return;    }    if (this.printing) {      return;    }    if (this.onIdle) {      this.idleTimeout = setTimeout(this.onIdle.bind(this), CLEANUP_TIMEOUT);    }  }  getHighestPriority(visible, views, scrolledDown, preRenderExtra = false) {    const visibleViews = visible.views,      numVisible = visibleViews.length;    if (numVisible === 0) {      return null;    }    for (let i = 0; i < numVisible; i++) {      const view = visibleViews[i].view;      if (!this.isViewFinished(view)) {        return view;      }    }    const firstId = visible.first.id,      lastId = visible.last.id;    if (lastId - firstId + 1 > numVisible) {      const visibleIds = visible.ids;      for (let i = 1, ii = lastId - firstId; i < ii; i++) {        const holeId = scrolledDown ? firstId + i : lastId - i;        if (visibleIds.has(holeId)) {          continue;        }        const holeView = views[holeId - 1];        if (!this.isViewFinished(holeView)) {          return holeView;        }      }    }    let preRenderIndex = scrolledDown ? lastId : firstId - 2;    let preRenderView = views[preRenderIndex];    if (preRenderView && !this.isViewFinished(preRenderView)) {      return preRenderView;    }    if (preRenderExtra) {      preRenderIndex += scrolledDown ? 1 : -1;      preRenderView = views[preRenderIndex];      if (preRenderView && !this.isViewFinished(preRenderView)) {        return preRenderView;      }    }    return null;  }  isViewFinished(view) {    return view.renderingState === _ui_utils.RenderingStates.FINISHED;  }  renderView(view) {    switch (view.renderingState) {      case _ui_utils.RenderingStates.FINISHED:        return false;      case _ui_utils.RenderingStates.PAUSED:        this.highestPriorityPage = view.renderingId;        view.resume();        break;      case _ui_utils.RenderingStates.RUNNING:        this.highestPriorityPage = view.renderingId;        break;      case _ui_utils.RenderingStates.INITIAL:        this.highestPriorityPage = view.renderingId;        view.draw().finally(() => {          this.renderHighestPriority();        }).catch(reason => {          if (reason instanceof _pdfjsLib.RenderingCancelledException) {            return;          }          console.error(`renderView: "${reason}"`);        });        break;    }    return true;  }}exports.PDFRenderingQueue = PDFRenderingQueue;/***/ }),/* 23 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFScriptingManager = void 0;var _ui_utils = __webpack_require__(1);var _pdfjsLib = __webpack_require__(5);class PDFScriptingManager {  constructor({    eventBus,    sandboxBundleSrc = null,    scriptingFactory = null,    docPropertiesLookup = null  }) {    this._pdfDocument = null;    this._pdfViewer = null;    this._closeCapability = null;    this._destroyCapability = null;    this._scripting = null;    this._ready = false;    this._eventBus = eventBus;    this._sandboxBundleSrc = sandboxBundleSrc;    this._scriptingFactory = scriptingFactory;    this._docPropertiesLookup = docPropertiesLookup;  }  setViewer(pdfViewer) {    this._pdfViewer = pdfViewer;  }  async setDocument(pdfDocument) {    if (this._pdfDocument) {      await this._destroyScripting();    }    this._pdfDocument = pdfDocument;    if (!pdfDocument) {      return;    }    const [objects, calculationOrder, docActions] = await Promise.all([pdfDocument.getFieldObjects(), pdfDocument.getCalculationOrderIds(), pdfDocument.getJSActions()]);    if (!objects && !docActions) {      await this._destroyScripting();      return;    }    if (pdfDocument !== this._pdfDocument) {      return;    }    try {      this._scripting = this._createScripting();    } catch (error) {      console.error(`PDFScriptingManager.setDocument: "${error?.message}".`);      await this._destroyScripting();      return;    }    this._internalEvents.set("updatefromsandbox", event => {      if (event?.source !== window) {        return;      }      this._updateFromSandbox(event.detail);    });    this._internalEvents.set("dispatcheventinsandbox", event => {      this._scripting?.dispatchEventInSandbox(event.detail);    });    this._internalEvents.set("pagechanging", ({      pageNumber,      previous    }) => {      if (pageNumber === previous) {        return;      }      this._dispatchPageClose(previous);      this._dispatchPageOpen(pageNumber);    });    this._internalEvents.set("pagerendered", ({      pageNumber    }) => {      if (!this._pageOpenPending.has(pageNumber)) {        return;      }      if (pageNumber !== this._pdfViewer.currentPageNumber) {        return;      }      this._dispatchPageOpen(pageNumber);    });    this._internalEvents.set("pagesdestroy", async event => {      await this._dispatchPageClose(this._pdfViewer.currentPageNumber);      await this._scripting?.dispatchEventInSandbox({        id: "doc",        name: "WillClose"      });      this._closeCapability?.resolve();    });    for (const [name, listener] of this._internalEvents) {      this._eventBus._on(name, listener);    }    try {      const docProperties = await this._getDocProperties();      if (pdfDocument !== this._pdfDocument) {        return;      }      await this._scripting.createSandbox({        objects,        calculationOrder,        appInfo: {          platform: navigator.platform,          language: navigator.language        },        docInfo: {          ...docProperties,          actions: docActions        }      });      this._eventBus.dispatch("sandboxcreated", {        source: this      });    } catch (error) {      console.error(`PDFScriptingManager.setDocument: "${error?.message}".`);      await this._destroyScripting();      return;    }    await this._scripting?.dispatchEventInSandbox({      id: "doc",      name: "Open"    });    await this._dispatchPageOpen(this._pdfViewer.currentPageNumber, true);    Promise.resolve().then(() => {      if (pdfDocument === this._pdfDocument) {        this._ready = true;      }    });  }  async dispatchWillSave(detail) {    return this._scripting?.dispatchEventInSandbox({      id: "doc",      name: "WillSave"    });  }  async dispatchDidSave(detail) {    return this._scripting?.dispatchEventInSandbox({      id: "doc",      name: "DidSave"    });  }  async dispatchWillPrint(detail) {    return this._scripting?.dispatchEventInSandbox({      id: "doc",      name: "WillPrint"    });  }  async dispatchDidPrint(detail) {    return this._scripting?.dispatchEventInSandbox({      id: "doc",      name: "DidPrint"    });  }  get destroyPromise() {    return this._destroyCapability?.promise || null;  }  get ready() {    return this._ready;  }  get _internalEvents() {    return (0, _pdfjsLib.shadow)(this, "_internalEvents", new Map());  }  get _pageOpenPending() {    return (0, _pdfjsLib.shadow)(this, "_pageOpenPending", new Set());  }  get _visitedPages() {    return (0, _pdfjsLib.shadow)(this, "_visitedPages", new Map());  }  async _updateFromSandbox(detail) {    const isInPresentationMode = this._pdfViewer.isInPresentationMode || this._pdfViewer.isChangingPresentationMode;    const {      id,      siblings,      command,      value    } = detail;    if (!id) {      switch (command) {        case "clear":          console.clear();          break;        case "error":          console.error(value);          break;        case "layout":          {            if (isInPresentationMode) {              return;            }            const modes = (0, _ui_utils.apiPageLayoutToViewerModes)(value);            this._pdfViewer.spreadMode = modes.spreadMode;            break;          }        case "page-num":          this._pdfViewer.currentPageNumber = value + 1;          break;        case "print":          await this._pdfViewer.pagesPromise;          this._eventBus.dispatch("print", {            source: this          });          break;        case "println":          console.log(value);          break;        case "zoom":          if (isInPresentationMode) {            return;          }          this._pdfViewer.currentScaleValue = value;          break;        case "SaveAs":          this._eventBus.dispatch("download", {            source: this          });          break;        case "FirstPage":          this._pdfViewer.currentPageNumber = 1;          break;        case "LastPage":          this._pdfViewer.currentPageNumber = this._pdfViewer.pagesCount;          break;        case "NextPage":          this._pdfViewer.nextPage();          break;        case "PrevPage":          this._pdfViewer.previousPage();          break;        case "ZoomViewIn":          if (isInPresentationMode) {            return;          }          this._pdfViewer.increaseScale();          break;        case "ZoomViewOut":          if (isInPresentationMode) {            return;          }          this._pdfViewer.decreaseScale();          break;      }      return;    }    if (isInPresentationMode) {      if (detail.focus) {        return;      }    }    delete detail.id;    delete detail.siblings;    const ids = siblings ? [id, ...siblings] : [id];    for (const elementId of ids) {      const element = document.querySelector(`[data-element-id="${elementId}"]`);      if (element) {        element.dispatchEvent(new CustomEvent("updatefromsandbox", {          detail        }));      } else {        this._pdfDocument?.annotationStorage.setValue(elementId, detail);      }    }  }  async _dispatchPageOpen(pageNumber, initialize = false) {    const pdfDocument = this._pdfDocument,      visitedPages = this._visitedPages;    if (initialize) {      this._closeCapability = (0, _pdfjsLib.createPromiseCapability)();    }    if (!this._closeCapability) {      return;    }    const pageView = this._pdfViewer.getPageView(pageNumber - 1);    if (pageView?.renderingState !== _ui_utils.RenderingStates.FINISHED) {      this._pageOpenPending.add(pageNumber);      return;    }    this._pageOpenPending.delete(pageNumber);    const actionsPromise = (async () => {      const actions = await (!visitedPages.has(pageNumber) ? pageView.pdfPage?.getJSActions() : null);      if (pdfDocument !== this._pdfDocument) {        return;      }      await this._scripting?.dispatchEventInSandbox({        id: "page",        name: "PageOpen",        pageNumber,        actions      });    })();    visitedPages.set(pageNumber, actionsPromise);  }  async _dispatchPageClose(pageNumber) {    const pdfDocument = this._pdfDocument,      visitedPages = this._visitedPages;    if (!this._closeCapability) {      return;    }    if (this._pageOpenPending.has(pageNumber)) {      return;    }    const actionsPromise = visitedPages.get(pageNumber);    if (!actionsPromise) {      return;    }    visitedPages.set(pageNumber, null);    await actionsPromise;    if (pdfDocument !== this._pdfDocument) {      return;    }    await this._scripting?.dispatchEventInSandbox({      id: "page",      name: "PageClose",      pageNumber    });  }  async _getDocProperties() {    if (this._docPropertiesLookup) {      return this._docPropertiesLookup(this._pdfDocument);    }    throw new Error("_getDocProperties: Unable to lookup properties.");  }  _createScripting() {    this._destroyCapability = (0, _pdfjsLib.createPromiseCapability)();    if (this._scripting) {      throw new Error("_createScripting: Scripting already exists.");    }    if (this._scriptingFactory) {      return this._scriptingFactory.createScripting({        sandboxBundleSrc: this._sandboxBundleSrc      });    }    throw new Error("_createScripting: Cannot create scripting.");  }  async _destroyScripting() {    if (!this._scripting) {      this._pdfDocument = null;      this._destroyCapability?.resolve();      return;    }    if (this._closeCapability) {      await Promise.race([this._closeCapability.promise, new Promise(resolve => {        setTimeout(resolve, 1000);      })]).catch(reason => {});      this._closeCapability = null;    }    this._pdfDocument = null;    try {      await this._scripting.destroySandbox();    } catch (ex) {}    for (const [name, listener] of this._internalEvents) {      this._eventBus._off(name, listener);    }    this._internalEvents.clear();    this._pageOpenPending.clear();    this._visitedPages.clear();    this._scripting = null;    this._ready = false;    this._destroyCapability?.resolve();  }}exports.PDFScriptingManager = PDFScriptingManager;/***/ }),/* 24 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFSidebar = void 0;var _ui_utils = __webpack_require__(1);const UI_NOTIFICATION_CLASS = "pdfSidebarNotification";class PDFSidebar {  constructor({    elements,    pdfViewer,    pdfThumbnailViewer,    eventBus,    l10n  }) {    this.isOpen = false;    this.active = _ui_utils.SidebarView.THUMBS;    this.isInitialViewSet = false;    this.isInitialEventDispatched = false;    this.onToggled = null;    this.pdfViewer = pdfViewer;    this.pdfThumbnailViewer = pdfThumbnailViewer;    this.outerContainer = elements.outerContainer;    this.sidebarContainer = elements.sidebarContainer;    this.toggleButton = elements.toggleButton;    this.thumbnailButton = elements.thumbnailButton;    this.outlineButton = elements.outlineButton;    this.attachmentsButton = elements.attachmentsButton;    this.layersButton = elements.layersButton;    this.thumbnailView = elements.thumbnailView;    this.outlineView = elements.outlineView;    this.attachmentsView = elements.attachmentsView;    this.layersView = elements.layersView;    this._outlineOptionsContainer = elements.outlineOptionsContainer;    this._currentOutlineItemButton = elements.currentOutlineItemButton;    this.eventBus = eventBus;    this.l10n = l10n;    this.#addEventListeners();  }  reset() {    this.isInitialViewSet = false;    this.isInitialEventDispatched = false;    this.#hideUINotification(true);    this.switchView(_ui_utils.SidebarView.THUMBS);    this.outlineButton.disabled = false;    this.attachmentsButton.disabled = false;    this.layersButton.disabled = false;    this._currentOutlineItemButton.disabled = true;  }  get visibleView() {    return this.isOpen ? this.active : _ui_utils.SidebarView.NONE;  }  setInitialView(view = _ui_utils.SidebarView.NONE) {    if (this.isInitialViewSet) {      return;    }    this.isInitialViewSet = true;    if (view === _ui_utils.SidebarView.NONE || view === _ui_utils.SidebarView.UNKNOWN) {      this.#dispatchEvent();      return;    }    this.switchView(view, true);    if (!this.isInitialEventDispatched) {      this.#dispatchEvent();    }  }  switchView(view, forceOpen = false) {    const isViewChanged = view !== this.active;    let shouldForceRendering = false;    switch (view) {      case _ui_utils.SidebarView.NONE:        if (this.isOpen) {          this.close();        }        return;      case _ui_utils.SidebarView.THUMBS:        if (this.isOpen && isViewChanged) {          shouldForceRendering = true;        }        break;      case _ui_utils.SidebarView.OUTLINE:        if (this.outlineButton.disabled) {          return;        }        break;      case _ui_utils.SidebarView.ATTACHMENTS:        if (this.attachmentsButton.disabled) {          return;        }        break;      case _ui_utils.SidebarView.LAYERS:        if (this.layersButton.disabled) {          return;        }        break;      default:        console.error(`PDFSidebar.switchView: "${view}" is not a valid view.`);        return;    }    this.active = view;    const isThumbs = view === _ui_utils.SidebarView.THUMBS,      isOutline = view === _ui_utils.SidebarView.OUTLINE,      isAttachments = view === _ui_utils.SidebarView.ATTACHMENTS,      isLayers = view === _ui_utils.SidebarView.LAYERS;    this.thumbnailButton.classList.toggle("toggled", isThumbs);    this.outlineButton.classList.toggle("toggled", isOutline);    this.attachmentsButton.classList.toggle("toggled", isAttachments);    this.layersButton.classList.toggle("toggled", isLayers);    this.thumbnailButton.setAttribute("aria-checked", isThumbs);    this.outlineButton.setAttribute("aria-checked", isOutline);    this.attachmentsButton.setAttribute("aria-checked", isAttachments);    this.layersButton.setAttribute("aria-checked", isLayers);    this.thumbnailView.classList.toggle("hidden", !isThumbs);    this.outlineView.classList.toggle("hidden", !isOutline);    this.attachmentsView.classList.toggle("hidden", !isAttachments);    this.layersView.classList.toggle("hidden", !isLayers);    this._outlineOptionsContainer.classList.toggle("hidden", !isOutline);    if (forceOpen && !this.isOpen) {      this.open();      return;    }    if (shouldForceRendering) {      this.#updateThumbnailViewer();      this.#forceRendering();    }    if (isViewChanged) {      this.#dispatchEvent();    }  }  open() {    if (this.isOpen) {      return;    }    this.isOpen = true;    this.toggleButton.classList.add("toggled");    this.toggleButton.setAttribute("aria-expanded", "true");    this.outerContainer.classList.add("sidebarMoving", "sidebarOpen");    if (this.active === _ui_utils.SidebarView.THUMBS) {      this.#updateThumbnailViewer();    }    this.#forceRendering();    this.#dispatchEvent();    this.#hideUINotification();  }  close() {    if (!this.isOpen) {      return;    }    this.isOpen = false;    this.toggleButton.classList.remove("toggled");    this.toggleButton.setAttribute("aria-expanded", "false");    this.outerContainer.classList.add("sidebarMoving");    this.outerContainer.classList.remove("sidebarOpen");    this.#forceRendering();    this.#dispatchEvent();  }  toggle() {    if (this.isOpen) {      this.close();    } else {      this.open();    }  }  #dispatchEvent() {    if (this.isInitialViewSet && !this.isInitialEventDispatched) {      this.isInitialEventDispatched = true;    }    this.eventBus.dispatch("sidebarviewchanged", {      source: this,      view: this.visibleView    });  }  #forceRendering() {    if (this.onToggled) {      this.onToggled();    } else {      this.pdfViewer.forceRendering();      this.pdfThumbnailViewer.forceRendering();    }  }  #updateThumbnailViewer() {    const {      pdfViewer,      pdfThumbnailViewer    } = this;    const pagesCount = pdfViewer.pagesCount;    for (let pageIndex = 0; pageIndex < pagesCount; pageIndex++) {      const pageView = pdfViewer.getPageView(pageIndex);      if (pageView?.renderingState === _ui_utils.RenderingStates.FINISHED) {        const thumbnailView = pdfThumbnailViewer.getThumbnail(pageIndex);        thumbnailView.setImage(pageView);      }    }    pdfThumbnailViewer.scrollThumbnailIntoView(pdfViewer.currentPageNumber);  }  #showUINotification() {    this.toggleButton.setAttribute("data-l10n-id", "toggle_sidebar_notification2");    this.l10n.translate(this.toggleButton);    if (!this.isOpen) {      this.toggleButton.classList.add(UI_NOTIFICATION_CLASS);    }  }  #hideUINotification(reset = false) {    if (this.isOpen || reset) {      this.toggleButton.classList.remove(UI_NOTIFICATION_CLASS);    }    if (reset) {      this.toggleButton.setAttribute("data-l10n-id", "toggle_sidebar");      this.l10n.translate(this.toggleButton);    }  }  #addEventListeners() {    this.sidebarContainer.addEventListener("transitionend", evt => {      if (evt.target === this.sidebarContainer) {        this.outerContainer.classList.remove("sidebarMoving");      }    });    this.toggleButton.addEventListener("click", () => {      this.toggle();    });    this.thumbnailButton.addEventListener("click", () => {      this.switchView(_ui_utils.SidebarView.THUMBS);    });    this.outlineButton.addEventListener("click", () => {      this.switchView(_ui_utils.SidebarView.OUTLINE);    });    this.outlineButton.addEventListener("dblclick", () => {      this.eventBus.dispatch("toggleoutlinetree", {        source: this      });    });    this.attachmentsButton.addEventListener("click", () => {      this.switchView(_ui_utils.SidebarView.ATTACHMENTS);    });    this.layersButton.addEventListener("click", () => {      this.switchView(_ui_utils.SidebarView.LAYERS);    });    this.layersButton.addEventListener("dblclick", () => {      this.eventBus.dispatch("resetlayers", {        source: this      });    });    this._currentOutlineItemButton.addEventListener("click", () => {      this.eventBus.dispatch("currentoutlineitem", {        source: this      });    });    const onTreeLoaded = (count, button, view) => {      button.disabled = !count;      if (count) {        this.#showUINotification();      } else if (this.active === view) {        this.switchView(_ui_utils.SidebarView.THUMBS);      }    };    this.eventBus._on("outlineloaded", evt => {      onTreeLoaded(evt.outlineCount, this.outlineButton, _ui_utils.SidebarView.OUTLINE);      evt.currentOutlineItemPromise.then(enabled => {        if (!this.isInitialViewSet) {          return;        }        this._currentOutlineItemButton.disabled = !enabled;      });    });    this.eventBus._on("attachmentsloaded", evt => {      onTreeLoaded(evt.attachmentsCount, this.attachmentsButton, _ui_utils.SidebarView.ATTACHMENTS);    });    this.eventBus._on("layersloaded", evt => {      onTreeLoaded(evt.layersCount, this.layersButton, _ui_utils.SidebarView.LAYERS);    });    this.eventBus._on("presentationmodechanged", evt => {      if (evt.state === _ui_utils.PresentationModeState.NORMAL && this.visibleView === _ui_utils.SidebarView.THUMBS) {        this.#updateThumbnailViewer();      }    });  }}exports.PDFSidebar = PDFSidebar;/***/ }),/* 25 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFSidebarResizer = void 0;var _ui_utils = __webpack_require__(1);const SIDEBAR_WIDTH_VAR = "--sidebar-width";const SIDEBAR_MIN_WIDTH = 200;const SIDEBAR_RESIZING_CLASS = "sidebarResizing";class PDFSidebarResizer {  constructor(options, eventBus, l10n) {    this.isRTL = false;    this.sidebarOpen = false;    this._width = null;    this._outerContainerWidth = null;    this._boundEvents = Object.create(null);    this.outerContainer = options.outerContainer;    this.resizer = options.resizer;    this.eventBus = eventBus;    l10n.getDirection().then(dir => {      this.isRTL = dir === "rtl";    });    this._addEventListeners();  }  get outerContainerWidth() {    return this._outerContainerWidth ||= this.outerContainer.clientWidth;  }  _updateWidth(width = 0) {    const maxWidth = Math.floor(this.outerContainerWidth / 2);    if (width > maxWidth) {      width = maxWidth;    }    if (width < SIDEBAR_MIN_WIDTH) {      width = SIDEBAR_MIN_WIDTH;    }    if (width === this._width) {      return false;    }    this._width = width;    _ui_utils.docStyle.setProperty(SIDEBAR_WIDTH_VAR, `${width}px`);    return true;  }  _mouseMove(evt) {    let width = evt.clientX;    if (this.isRTL) {      width = this.outerContainerWidth - width;    }    this._updateWidth(width);  }  _mouseUp(evt) {    this.outerContainer.classList.remove(SIDEBAR_RESIZING_CLASS);    this.eventBus.dispatch("resize", {      source: this    });    const _boundEvents = this._boundEvents;    window.removeEventListener("mousemove", _boundEvents.mouseMove);    window.removeEventListener("mouseup", _boundEvents.mouseUp);  }  _addEventListeners() {    const _boundEvents = this._boundEvents;    _boundEvents.mouseMove = this._mouseMove.bind(this);    _boundEvents.mouseUp = this._mouseUp.bind(this);    this.resizer.addEventListener("mousedown", evt => {      if (evt.button !== 0) {        return;      }      this.outerContainer.classList.add(SIDEBAR_RESIZING_CLASS);      window.addEventListener("mousemove", _boundEvents.mouseMove);      window.addEventListener("mouseup", _boundEvents.mouseUp);    });    this.eventBus._on("sidebarviewchanged", evt => {      this.sidebarOpen = !!evt?.view;    });    this.eventBus._on("resize", evt => {      if (evt?.source !== window) {        return;      }      this._outerContainerWidth = null;      if (!this._width) {        return;      }      if (!this.sidebarOpen) {        this._updateWidth(this._width);        return;      }      this.outerContainer.classList.add(SIDEBAR_RESIZING_CLASS);      const updated = this._updateWidth(this._width);      Promise.resolve().then(() => {        this.outerContainer.classList.remove(SIDEBAR_RESIZING_CLASS);        if (updated) {          this.eventBus.dispatch("resize", {            source: this          });        }      });    });  }}exports.PDFSidebarResizer = PDFSidebarResizer;/***/ }),/* 26 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFThumbnailViewer = void 0;var _ui_utils = __webpack_require__(1);var _pdf_thumbnail_view = __webpack_require__(27);const THUMBNAIL_SCROLL_MARGIN = -19;const THUMBNAIL_SELECTED_CLASS = "selected";class PDFThumbnailViewer {  constructor({    container,    eventBus,    linkService,    renderingQueue,    l10n,    pageColors  }) {    this.container = container;    this.linkService = linkService;    this.renderingQueue = renderingQueue;    this.l10n = l10n;    this.pageColors = pageColors || null;    if (this.pageColors && !(CSS.supports("color", this.pageColors.background) && CSS.supports("color", this.pageColors.foreground))) {      if (this.pageColors.background || this.pageColors.foreground) {        console.warn("PDFThumbnailViewer: Ignoring `pageColors`-option, since the browser doesn't support the values used.");      }      this.pageColors = null;    }    this.scroll = (0, _ui_utils.watchScroll)(this.container, this._scrollUpdated.bind(this));    this._resetView();  }  _scrollUpdated() {    this.renderingQueue.renderHighestPriority();  }  getThumbnail(index) {    return this._thumbnails[index];  }  _getVisibleThumbs() {    return (0, _ui_utils.getVisibleElements)({      scrollEl: this.container,      views: this._thumbnails    });  }  scrollThumbnailIntoView(pageNumber) {    if (!this.pdfDocument) {      return;    }    const thumbnailView = this._thumbnails[pageNumber - 1];    if (!thumbnailView) {      console.error('scrollThumbnailIntoView: Invalid "pageNumber" parameter.');      return;    }    if (pageNumber !== this._currentPageNumber) {      const prevThumbnailView = this._thumbnails[this._currentPageNumber - 1];      prevThumbnailView.div.classList.remove(THUMBNAIL_SELECTED_CLASS);      thumbnailView.div.classList.add(THUMBNAIL_SELECTED_CLASS);    }    const {      first,      last,      views    } = this._getVisibleThumbs();    if (views.length > 0) {      let shouldScroll = false;      if (pageNumber <= first.id || pageNumber >= last.id) {        shouldScroll = true;      } else {        for (const {          id,          percent        } of views) {          if (id !== pageNumber) {            continue;          }          shouldScroll = percent < 100;          break;        }      }      if (shouldScroll) {        (0, _ui_utils.scrollIntoView)(thumbnailView.div, {          top: THUMBNAIL_SCROLL_MARGIN        });      }    }    this._currentPageNumber = pageNumber;  }  get pagesRotation() {    return this._pagesRotation;  }  set pagesRotation(rotation) {    if (!(0, _ui_utils.isValidRotation)(rotation)) {      throw new Error("Invalid thumbnails rotation angle.");    }    if (!this.pdfDocument) {      return;    }    if (this._pagesRotation === rotation) {      return;    }    this._pagesRotation = rotation;    const updateArgs = {      rotation    };    for (const thumbnail of this._thumbnails) {      thumbnail.update(updateArgs);    }  }  cleanup() {    for (const thumbnail of this._thumbnails) {      if (thumbnail.renderingState !== _ui_utils.RenderingStates.FINISHED) {        thumbnail.reset();      }    }    _pdf_thumbnail_view.TempImageFactory.destroyCanvas();  }  _resetView() {    this._thumbnails = [];    this._currentPageNumber = 1;    this._pageLabels = null;    this._pagesRotation = 0;    this.container.textContent = "";  }  setDocument(pdfDocument) {    if (this.pdfDocument) {      this._cancelRendering();      this._resetView();    }    this.pdfDocument = pdfDocument;    if (!pdfDocument) {      return;    }    const firstPagePromise = pdfDocument.getPage(1);    const optionalContentConfigPromise = pdfDocument.getOptionalContentConfig();    firstPagePromise.then(firstPdfPage => {      const pagesCount = pdfDocument.numPages;      const viewport = firstPdfPage.getViewport({        scale: 1      });      for (let pageNum = 1; pageNum <= pagesCount; ++pageNum) {        const thumbnail = new _pdf_thumbnail_view.PDFThumbnailView({          container: this.container,          id: pageNum,          defaultViewport: viewport.clone(),          optionalContentConfigPromise,          linkService: this.linkService,          renderingQueue: this.renderingQueue,          l10n: this.l10n,          pageColors: this.pageColors        });        this._thumbnails.push(thumbnail);      }      this._thumbnails[0]?.setPdfPage(firstPdfPage);      const thumbnailView = this._thumbnails[this._currentPageNumber - 1];      thumbnailView.div.classList.add(THUMBNAIL_SELECTED_CLASS);    }).catch(reason => {      console.error("Unable to initialize thumbnail viewer", reason);    });  }  _cancelRendering() {    for (const thumbnail of this._thumbnails) {      thumbnail.cancelRendering();    }  }  setPageLabels(labels) {    if (!this.pdfDocument) {      return;    }    if (!labels) {      this._pageLabels = null;    } else if (!(Array.isArray(labels) && this.pdfDocument.numPages === labels.length)) {      this._pageLabels = null;      console.error("PDFThumbnailViewer_setPageLabels: Invalid page labels.");    } else {      this._pageLabels = labels;    }    for (let i = 0, ii = this._thumbnails.length; i < ii; i++) {      this._thumbnails[i].setPageLabel(this._pageLabels?.[i] ?? null);    }  }  async #ensurePdfPageLoaded(thumbView) {    if (thumbView.pdfPage) {      return thumbView.pdfPage;    }    try {      const pdfPage = await this.pdfDocument.getPage(thumbView.id);      if (!thumbView.pdfPage) {        thumbView.setPdfPage(pdfPage);      }      return pdfPage;    } catch (reason) {      console.error("Unable to get page for thumb view", reason);      return null;    }  }  #getScrollAhead(visible) {    if (visible.first?.id === 1) {      return true;    } else if (visible.last?.id === this._thumbnails.length) {      return false;    }    return this.scroll.down;  }  forceRendering() {    const visibleThumbs = this._getVisibleThumbs();    const scrollAhead = this.#getScrollAhead(visibleThumbs);    const thumbView = this.renderingQueue.getHighestPriority(visibleThumbs, this._thumbnails, scrollAhead);    if (thumbView) {      this.#ensurePdfPageLoaded(thumbView).then(() => {        this.renderingQueue.renderView(thumbView);      });      return true;    }    return false;  }}exports.PDFThumbnailViewer = PDFThumbnailViewer;/***/ }),/* 27 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.TempImageFactory = exports.PDFThumbnailView = void 0;var _ui_utils = __webpack_require__(1);var _pdfjsLib = __webpack_require__(5);const DRAW_UPSCALE_FACTOR = 2;const MAX_NUM_SCALING_STEPS = 3;const THUMBNAIL_CANVAS_BORDER_WIDTH = 1;const THUMBNAIL_WIDTH = 98;class TempImageFactory {  static #tempCanvas = null;  static getCanvas(width, height) {    const tempCanvas = this.#tempCanvas ||= document.createElement("canvas");    tempCanvas.width = width;    tempCanvas.height = height;    const ctx = tempCanvas.getContext("2d", {      alpha: false    });    ctx.save();    ctx.fillStyle = "rgb(255, 255, 255)";    ctx.fillRect(0, 0, width, height);    ctx.restore();    return [tempCanvas, tempCanvas.getContext("2d")];  }  static destroyCanvas() {    const tempCanvas = this.#tempCanvas;    if (tempCanvas) {      tempCanvas.width = 0;      tempCanvas.height = 0;    }    this.#tempCanvas = null;  }}exports.TempImageFactory = TempImageFactory;class PDFThumbnailView {  constructor({    container,    id,    defaultViewport,    optionalContentConfigPromise,    linkService,    renderingQueue,    l10n,    pageColors  }) {    this.id = id;    this.renderingId = "thumbnail" + id;    this.pageLabel = null;    this.pdfPage = null;    this.rotation = 0;    this.viewport = defaultViewport;    this.pdfPageRotate = defaultViewport.rotation;    this._optionalContentConfigPromise = optionalContentConfigPromise || null;    this.pageColors = pageColors || null;    this.linkService = linkService;    this.renderingQueue = renderingQueue;    this.renderTask = null;    this.renderingState = _ui_utils.RenderingStates.INITIAL;    this.resume = null;    const pageWidth = this.viewport.width,      pageHeight = this.viewport.height,      pageRatio = pageWidth / pageHeight;    this.canvasWidth = THUMBNAIL_WIDTH;    this.canvasHeight = this.canvasWidth / pageRatio | 0;    this.scale = this.canvasWidth / pageWidth;    this.l10n = l10n;    const anchor = document.createElement("a");    anchor.href = linkService.getAnchorUrl("#page=" + id);    this._thumbPageTitle.then(msg => {      anchor.title = msg;    });    anchor.onclick = function () {      linkService.goToPage(id);      return false;    };    this.anchor = anchor;    const div = document.createElement("div");    div.className = "thumbnail";    div.setAttribute("data-page-number", this.id);    this.div = div;    const ring = document.createElement("div");    ring.className = "thumbnailSelectionRing";    const borderAdjustment = 2 * THUMBNAIL_CANVAS_BORDER_WIDTH;    ring.style.width = this.canvasWidth + borderAdjustment + "px";    ring.style.height = this.canvasHeight + borderAdjustment + "px";    this.ring = ring;    div.append(ring);    anchor.append(div);    container.append(anchor);  }  setPdfPage(pdfPage) {    this.pdfPage = pdfPage;    this.pdfPageRotate = pdfPage.rotate;    const totalRotation = (this.rotation + this.pdfPageRotate) % 360;    this.viewport = pdfPage.getViewport({      scale: 1,      rotation: totalRotation    });    this.reset();  }  reset() {    this.cancelRendering();    this.renderingState = _ui_utils.RenderingStates.INITIAL;    const pageWidth = this.viewport.width,      pageHeight = this.viewport.height,      pageRatio = pageWidth / pageHeight;    this.canvasHeight = this.canvasWidth / pageRatio | 0;    this.scale = this.canvasWidth / pageWidth;    this.div.removeAttribute("data-loaded");    const ring = this.ring;    ring.textContent = "";    const borderAdjustment = 2 * THUMBNAIL_CANVAS_BORDER_WIDTH;    ring.style.width = this.canvasWidth + borderAdjustment + "px";    ring.style.height = this.canvasHeight + borderAdjustment + "px";    if (this.canvas) {      this.canvas.width = 0;      this.canvas.height = 0;      delete this.canvas;    }    if (this.image) {      this.image.removeAttribute("src");      delete this.image;    }  }  update({    rotation = null  }) {    if (typeof rotation === "number") {      this.rotation = rotation;    }    const totalRotation = (this.rotation + this.pdfPageRotate) % 360;    this.viewport = this.viewport.clone({      scale: 1,      rotation: totalRotation    });    this.reset();  }  cancelRendering() {    if (this.renderTask) {      this.renderTask.cancel();      this.renderTask = null;    }    this.resume = null;  }  _getPageDrawContext(upscaleFactor = 1) {    const canvas = document.createElement("canvas");    const ctx = canvas.getContext("2d", {      alpha: false    });    const outputScale = new _ui_utils.OutputScale();    canvas.width = upscaleFactor * this.canvasWidth * outputScale.sx | 0;    canvas.height = upscaleFactor * this.canvasHeight * outputScale.sy | 0;    const transform = outputScale.scaled ? [outputScale.sx, 0, 0, outputScale.sy, 0, 0] : null;    return {      ctx,      canvas,      transform    };  }  _convertCanvasToImage(canvas) {    if (this.renderingState !== _ui_utils.RenderingStates.FINISHED) {      throw new Error("_convertCanvasToImage: Rendering has not finished.");    }    const reducedCanvas = this._reduceImage(canvas);    const image = document.createElement("img");    image.className = "thumbnailImage";    this._thumbPageCanvas.then(msg => {      image.setAttribute("aria-label", msg);    });    image.style.width = this.canvasWidth + "px";    image.style.height = this.canvasHeight + "px";    image.src = reducedCanvas.toDataURL();    this.image = image;    this.div.setAttribute("data-loaded", true);    this.ring.append(image);    reducedCanvas.width = 0;    reducedCanvas.height = 0;  }  draw() {    if (this.renderingState !== _ui_utils.RenderingStates.INITIAL) {      console.error("Must be in new state before drawing");      return Promise.resolve();    }    const {      pdfPage    } = this;    if (!pdfPage) {      this.renderingState = _ui_utils.RenderingStates.FINISHED;      return Promise.reject(new Error("pdfPage is not loaded"));    }    this.renderingState = _ui_utils.RenderingStates.RUNNING;    const finishRenderTask = async (error = null) => {      if (renderTask === this.renderTask) {        this.renderTask = null;      }      if (error instanceof _pdfjsLib.RenderingCancelledException) {        return;      }      this.renderingState = _ui_utils.RenderingStates.FINISHED;      this._convertCanvasToImage(canvas);      if (error) {        throw error;      }    };    const {      ctx,      canvas,      transform    } = this._getPageDrawContext(DRAW_UPSCALE_FACTOR);    const drawViewport = this.viewport.clone({      scale: DRAW_UPSCALE_FACTOR * this.scale    });    const renderContinueCallback = cont => {      if (!this.renderingQueue.isHighestPriority(this)) {        this.renderingState = _ui_utils.RenderingStates.PAUSED;        this.resume = () => {          this.renderingState = _ui_utils.RenderingStates.RUNNING;          cont();        };        return;      }      cont();    };    const renderContext = {      canvasContext: ctx,      transform,      viewport: drawViewport,      optionalContentConfigPromise: this._optionalContentConfigPromise,      pageColors: this.pageColors    };    const renderTask = this.renderTask = pdfPage.render(renderContext);    renderTask.onContinue = renderContinueCallback;    const resultPromise = renderTask.promise.then(function () {      return finishRenderTask(null);    }, function (error) {      return finishRenderTask(error);    });    resultPromise.finally(() => {      canvas.width = 0;      canvas.height = 0;      const pageCached = this.linkService.isPageCached(this.id);      if (!pageCached) {        this.pdfPage?.cleanup();      }    });    return resultPromise;  }  setImage(pageView) {    if (this.renderingState !== _ui_utils.RenderingStates.INITIAL) {      return;    }    const {      thumbnailCanvas: canvas,      pdfPage,      scale    } = pageView;    if (!canvas) {      return;    }    if (!this.pdfPage) {      this.setPdfPage(pdfPage);    }    if (scale < this.scale) {      return;    }    this.renderingState = _ui_utils.RenderingStates.FINISHED;    this._convertCanvasToImage(canvas);  }  _reduceImage(img) {    const {      ctx,      canvas    } = this._getPageDrawContext();    if (img.width <= 2 * canvas.width) {      ctx.drawImage(img, 0, 0, img.width, img.height, 0, 0, canvas.width, canvas.height);      return canvas;    }    let reducedWidth = canvas.width << MAX_NUM_SCALING_STEPS;    let reducedHeight = canvas.height << MAX_NUM_SCALING_STEPS;    const [reducedImage, reducedImageCtx] = TempImageFactory.getCanvas(reducedWidth, reducedHeight);    while (reducedWidth > img.width || reducedHeight > img.height) {      reducedWidth >>= 1;      reducedHeight >>= 1;    }    reducedImageCtx.drawImage(img, 0, 0, img.width, img.height, 0, 0, reducedWidth, reducedHeight);    while (reducedWidth > 2 * canvas.width) {      reducedImageCtx.drawImage(reducedImage, 0, 0, reducedWidth, reducedHeight, 0, 0, reducedWidth >> 1, reducedHeight >> 1);      reducedWidth >>= 1;      reducedHeight >>= 1;    }    ctx.drawImage(reducedImage, 0, 0, reducedWidth, reducedHeight, 0, 0, canvas.width, canvas.height);    return canvas;  }  get _thumbPageTitle() {    return this.l10n.get("thumb_page_title", {      page: this.pageLabel ?? this.id    });  }  get _thumbPageCanvas() {    return this.l10n.get("thumb_page_canvas", {      page: this.pageLabel ?? this.id    });  }  setPageLabel(label) {    this.pageLabel = typeof label === "string" ? label : null;    this._thumbPageTitle.then(msg => {      this.anchor.title = msg;    });    if (this.renderingState !== _ui_utils.RenderingStates.FINISHED) {      return;    }    this._thumbPageCanvas.then(msg => {      this.image?.setAttribute("aria-label", msg);    });  }}exports.PDFThumbnailView = PDFThumbnailView;/***/ }),/* 28 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PagesCountLimit = exports.PDFViewer = exports.PDFPageViewBuffer = void 0;var _pdfjsLib = __webpack_require__(5);var _ui_utils = __webpack_require__(1);var _l10n_utils = __webpack_require__(29);var _pdf_page_view = __webpack_require__(30);var _pdf_rendering_queue = __webpack_require__(22);var _pdf_link_service = __webpack_require__(3);const DEFAULT_CACHE_SIZE = 10;const ENABLE_PERMISSIONS_CLASS = "enablePermissions";const PagesCountLimit = {  FORCE_SCROLL_MODE_PAGE: 15000,  FORCE_LAZY_PAGE_INIT: 7500,  PAUSE_EAGER_PAGE_INIT: 250};exports.PagesCountLimit = PagesCountLimit;function isValidAnnotationEditorMode(mode) {  return Object.values(_pdfjsLib.AnnotationEditorType).includes(mode) && mode !== _pdfjsLib.AnnotationEditorType.DISABLE;}class PDFPageViewBuffer {  #buf = new Set();  #size = 0;  constructor(size) {    this.#size = size;  }  push(view) {    const buf = this.#buf;    if (buf.has(view)) {      buf.delete(view);    }    buf.add(view);    if (buf.size > this.#size) {      this.#destroyFirstView();    }  }  resize(newSize, idsToKeep = null) {    this.#size = newSize;    const buf = this.#buf;    if (idsToKeep) {      const ii = buf.size;      let i = 1;      for (const view of buf) {        if (idsToKeep.has(view.id)) {          buf.delete(view);          buf.add(view);        }        if (++i > ii) {          break;        }      }    }    while (buf.size > this.#size) {      this.#destroyFirstView();    }  }  has(view) {    return this.#buf.has(view);  }  [Symbol.iterator]() {    return this.#buf.keys();  }  #destroyFirstView() {    const firstView = this.#buf.keys().next().value;    firstView?.destroy();    this.#buf.delete(firstView);  }}exports.PDFPageViewBuffer = PDFPageViewBuffer;class PDFViewer {  #buffer = null;  #annotationEditorMode = _pdfjsLib.AnnotationEditorType.NONE;  #annotationEditorUIManager = null;  #annotationMode = _pdfjsLib.AnnotationMode.ENABLE_FORMS;  #containerTopLeft = null;  #enablePermissions = false;  #previousContainerHeight = 0;  #resizeObserver = new ResizeObserver(this.#resizeObserverCallback.bind(this));  #scrollModePageState = null;  #onVisibilityChange = null;  #scaleTimeoutId = null;  constructor(options) {    const viewerVersion = '3.3.122';    if (_pdfjsLib.version !== viewerVersion) {      throw new Error(`The API version "${_pdfjsLib.version}" does not match the Viewer version "${viewerVersion}".`);    }    this.container = options.container;    this.viewer = options.viewer || options.container.firstElementChild;    if (this.container?.tagName !== "DIV" || this.viewer?.tagName !== "DIV") {      throw new Error("Invalid `container` and/or `viewer` option.");    }    if (this.container.offsetParent && getComputedStyle(this.container).position !== "absolute") {      throw new Error("The `container` must be absolutely positioned.");    }    this.#resizeObserver.observe(this.container);    this.eventBus = options.eventBus;    this.linkService = options.linkService || new _pdf_link_service.SimpleLinkService();    this.downloadManager = options.downloadManager || null;    this.findController = options.findController || null;    this._scriptingManager = options.scriptingManager || null;    this.removePageBorders = options.removePageBorders || false;    this.textLayerMode = options.textLayerMode ?? _ui_utils.TextLayerMode.ENABLE;    this.#annotationMode = options.annotationMode ?? _pdfjsLib.AnnotationMode.ENABLE_FORMS;    this.#annotationEditorMode = options.annotationEditorMode ?? _pdfjsLib.AnnotationEditorType.NONE;    this.imageResourcesPath = options.imageResourcesPath || "";    this.enablePrintAutoRotate = options.enablePrintAutoRotate || false;    this.renderer = options.renderer || _ui_utils.RendererType.CANVAS;    this.useOnlyCssZoom = options.useOnlyCssZoom || false;    this.isOffscreenCanvasSupported = options.isOffscreenCanvasSupported ?? true;    this.maxCanvasPixels = options.maxCanvasPixels;    this.l10n = options.l10n || _l10n_utils.NullL10n;    this.#enablePermissions = options.enablePermissions || false;    this.pageColors = options.pageColors || null;    if (this.pageColors && !(CSS.supports("color", this.pageColors.background) && CSS.supports("color", this.pageColors.foreground))) {      if (this.pageColors.background || this.pageColors.foreground) {        console.warn("PDFViewer: Ignoring `pageColors`-option, since the browser doesn't support the values used.");      }      this.pageColors = null;    }    this.defaultRenderingQueue = !options.renderingQueue;    if (this.defaultRenderingQueue) {      this.renderingQueue = new _pdf_rendering_queue.PDFRenderingQueue();      this.renderingQueue.setViewer(this);    } else {      this.renderingQueue = options.renderingQueue;    }    this.scroll = (0, _ui_utils.watchScroll)(this.container, this._scrollUpdate.bind(this));    this.presentationModeState = _ui_utils.PresentationModeState.UNKNOWN;    this._onBeforeDraw = this._onAfterDraw = null;    this._resetView();    if (this.removePageBorders) {      this.viewer.classList.add("removePageBorders");    }    this.#updateContainerHeightCss();  }  get pagesCount() {    return this._pages.length;  }  getPageView(index) {    return this._pages[index];  }  get pageViewsReady() {    if (!this._pagesCapability.settled) {      return false;    }    return this._pages.every(function (pageView) {      return pageView?.pdfPage;    });  }  get renderForms() {    return this.#annotationMode === _pdfjsLib.AnnotationMode.ENABLE_FORMS;  }  get enableScripting() {    return !!this._scriptingManager;  }  get currentPageNumber() {    return this._currentPageNumber;  }  set currentPageNumber(val) {    if (!Number.isInteger(val)) {      throw new Error("Invalid page number.");    }    if (!this.pdfDocument) {      return;    }    if (!this._setCurrentPageNumber(val, true)) {      console.error(`currentPageNumber: "${val}" is not a valid page.`);    }  }  _setCurrentPageNumber(val, resetCurrentPageView = false) {    if (this._currentPageNumber === val) {      if (resetCurrentPageView) {        this.#resetCurrentPageView();      }      return true;    }    if (!(0 < val && val <= this.pagesCount)) {      return false;    }    const previous = this._currentPageNumber;    this._currentPageNumber = val;    this.eventBus.dispatch("pagechanging", {      source: this,      pageNumber: val,      pageLabel: this._pageLabels?.[val - 1] ?? null,      previous    });    if (resetCurrentPageView) {      this.#resetCurrentPageView();    }    return true;  }  get currentPageLabel() {    return this._pageLabels?.[this._currentPageNumber - 1] ?? null;  }  set currentPageLabel(val) {    if (!this.pdfDocument) {      return;    }    let page = val | 0;    if (this._pageLabels) {      const i = this._pageLabels.indexOf(val);      if (i >= 0) {        page = i + 1;      }    }    if (!this._setCurrentPageNumber(page, true)) {      console.error(`currentPageLabel: "${val}" is not a valid page.`);    }  }  get currentScale() {    return this._currentScale !== _ui_utils.UNKNOWN_SCALE ? this._currentScale : _ui_utils.DEFAULT_SCALE;  }  set currentScale(val) {    if (isNaN(val)) {      throw new Error("Invalid numeric scale.");    }    if (!this.pdfDocument) {      return;    }    this._setScale(val, {      noScroll: false    });  }  get currentScaleValue() {    return this._currentScaleValue;  }  set currentScaleValue(val) {    if (!this.pdfDocument) {      return;    }    this._setScale(val, {      noScroll: false    });  }  get pagesRotation() {    return this._pagesRotation;  }  set pagesRotation(rotation) {    if (!(0, _ui_utils.isValidRotation)(rotation)) {      throw new Error("Invalid pages rotation angle.");    }    if (!this.pdfDocument) {      return;    }    rotation %= 360;    if (rotation < 0) {      rotation += 360;    }    if (this._pagesRotation === rotation) {      return;    }    this._pagesRotation = rotation;    const pageNumber = this._currentPageNumber;    this.refresh(true, {      rotation    });    if (this._currentScaleValue) {      this._setScale(this._currentScaleValue, {        noScroll: true      });    }    this.eventBus.dispatch("rotationchanging", {      source: this,      pagesRotation: rotation,      pageNumber    });    if (this.defaultRenderingQueue) {      this.update();    }  }  get firstPagePromise() {    return this.pdfDocument ? this._firstPageCapability.promise : null;  }  get onePageRendered() {    return this.pdfDocument ? this._onePageRenderedCapability.promise : null;  }  get pagesPromise() {    return this.pdfDocument ? this._pagesCapability.promise : null;  }  #layerProperties() {    const self = this;    return {      get annotationEditorUIManager() {        return self.#annotationEditorUIManager;      },      get annotationStorage() {        return self.pdfDocument?.annotationStorage;      },      get downloadManager() {        return self.downloadManager;      },      get enableScripting() {        return !!self._scriptingManager;      },      get fieldObjectsPromise() {        return self.pdfDocument?.getFieldObjects();      },      get findController() {        return self.findController;      },      get hasJSActionsPromise() {        return self.pdfDocument?.hasJSActions();      },      get linkService() {        return self.linkService;      }    };  }  #initializePermissions(permissions) {    const params = {      annotationEditorMode: this.#annotationEditorMode,      annotationMode: this.#annotationMode,      textLayerMode: this.textLayerMode    };    if (!permissions) {      return params;    }    if (!permissions.includes(_pdfjsLib.PermissionFlag.COPY)) {      this.viewer.classList.add(ENABLE_PERMISSIONS_CLASS);    }    if (!permissions.includes(_pdfjsLib.PermissionFlag.MODIFY_CONTENTS)) {      params.annotationEditorMode = _pdfjsLib.AnnotationEditorType.DISABLE;    }    if (!permissions.includes(_pdfjsLib.PermissionFlag.MODIFY_ANNOTATIONS) && !permissions.includes(_pdfjsLib.PermissionFlag.FILL_INTERACTIVE_FORMS) && this.#annotationMode === _pdfjsLib.AnnotationMode.ENABLE_FORMS) {      params.annotationMode = _pdfjsLib.AnnotationMode.ENABLE;    }    return params;  }  #onePageRenderedOrForceFetch() {    if (document.visibilityState === "hidden" || !this.container.offsetParent || this._getVisiblePages().views.length === 0) {      return Promise.resolve();    }    const visibilityChangePromise = new Promise(resolve => {      this.#onVisibilityChange = () => {        if (document.visibilityState !== "hidden") {          return;        }        resolve();        document.removeEventListener("visibilitychange", this.#onVisibilityChange);        this.#onVisibilityChange = null;      };      document.addEventListener("visibilitychange", this.#onVisibilityChange);    });    return Promise.race([this._onePageRenderedCapability.promise, visibilityChangePromise]);  }  setDocument(pdfDocument) {    if (this.pdfDocument) {      this.eventBus.dispatch("pagesdestroy", {        source: this      });      this._cancelRendering();      this._resetView();      this.findController?.setDocument(null);      this._scriptingManager?.setDocument(null);      if (this.#annotationEditorUIManager) {        this.#annotationEditorUIManager.destroy();        this.#annotationEditorUIManager = null;      }    }    this.pdfDocument = pdfDocument;    if (!pdfDocument) {      return;    }    const pagesCount = pdfDocument.numPages;    const firstPagePromise = pdfDocument.getPage(1);    const optionalContentConfigPromise = pdfDocument.getOptionalContentConfig();    const permissionsPromise = this.#enablePermissions ? pdfDocument.getPermissions() : Promise.resolve();    if (pagesCount > PagesCountLimit.FORCE_SCROLL_MODE_PAGE) {      console.warn("Forcing PAGE-scrolling for performance reasons, given the length of the document.");      const mode = this._scrollMode = _ui_utils.ScrollMode.PAGE;      this.eventBus.dispatch("scrollmodechanged", {        source: this,        mode      });    }    this._pagesCapability.promise.then(() => {      this.eventBus.dispatch("pagesloaded", {        source: this,        pagesCount      });    }, () => {});    this._onBeforeDraw = evt => {      const pageView = this._pages[evt.pageNumber - 1];      if (!pageView) {        return;      }      this.#buffer.push(pageView);    };    this.eventBus._on("pagerender", this._onBeforeDraw);    this._onAfterDraw = evt => {      if (evt.cssTransform || this._onePageRenderedCapability.settled) {        return;      }      this._onePageRenderedCapability.resolve({        timestamp: evt.timestamp      });      this.eventBus._off("pagerendered", this._onAfterDraw);      this._onAfterDraw = null;      if (this.#onVisibilityChange) {        document.removeEventListener("visibilitychange", this.#onVisibilityChange);        this.#onVisibilityChange = null;      }    };    this.eventBus._on("pagerendered", this._onAfterDraw);    Promise.all([firstPagePromise, permissionsPromise]).then(([firstPdfPage, permissions]) => {      if (pdfDocument !== this.pdfDocument) {        return;      }      this._firstPageCapability.resolve(firstPdfPage);      this._optionalContentConfigPromise = optionalContentConfigPromise;      const {        annotationEditorMode,        annotationMode,        textLayerMode      } = this.#initializePermissions(permissions);      if (annotationEditorMode !== _pdfjsLib.AnnotationEditorType.DISABLE) {        const mode = annotationEditorMode;        if (pdfDocument.isPureXfa) {          console.warn("Warning: XFA-editing is not implemented.");        } else if (isValidAnnotationEditorMode(mode)) {          this.#annotationEditorUIManager = new _pdfjsLib.AnnotationEditorUIManager(this.container, this.eventBus, pdfDocument?.annotationStorage);          if (mode !== _pdfjsLib.AnnotationEditorType.NONE) {            this.#annotationEditorUIManager.updateMode(mode);          }        } else {          console.error(`Invalid AnnotationEditor mode: ${mode}`);        }      }      const layerProperties = this.#layerProperties.bind(this);      const viewerElement = this._scrollMode === _ui_utils.ScrollMode.PAGE ? null : this.viewer;      const scale = this.currentScale;      const viewport = firstPdfPage.getViewport({        scale: scale * _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS      });      this.viewer.style.setProperty("--scale-factor", viewport.scale);      for (let pageNum = 1; pageNum <= pagesCount; ++pageNum) {        const pageView = new _pdf_page_view.PDFPageView({          container: viewerElement,          eventBus: this.eventBus,          id: pageNum,          scale,          defaultViewport: viewport.clone(),          optionalContentConfigPromise,          renderingQueue: this.renderingQueue,          textLayerMode,          annotationMode,          imageResourcesPath: this.imageResourcesPath,          renderer: this.renderer,          useOnlyCssZoom: this.useOnlyCssZoom,          isOffscreenCanvasSupported: this.isOffscreenCanvasSupported,          maxCanvasPixels: this.maxCanvasPixels,          pageColors: this.pageColors,          l10n: this.l10n,          layerProperties        });        this._pages.push(pageView);      }      const firstPageView = this._pages[0];      if (firstPageView) {        firstPageView.setPdfPage(firstPdfPage);        this.linkService.cachePageRef(1, firstPdfPage.ref);      }      if (this._scrollMode === _ui_utils.ScrollMode.PAGE) {        this.#ensurePageViewVisible();      } else if (this._spreadMode !== _ui_utils.SpreadMode.NONE) {        this._updateSpreadMode();      }      this.#onePageRenderedOrForceFetch().then(async () => {        this.findController?.setDocument(pdfDocument);        this._scriptingManager?.setDocument(pdfDocument);        if (this.#annotationEditorUIManager) {          this.eventBus.dispatch("annotationeditormodechanged", {            source: this,            mode: this.#annotationEditorMode          });        }        if (pdfDocument.loadingParams.disableAutoFetch || pagesCount > PagesCountLimit.FORCE_LAZY_PAGE_INIT) {          this._pagesCapability.resolve();          return;        }        let getPagesLeft = pagesCount - 1;        if (getPagesLeft <= 0) {          this._pagesCapability.resolve();          return;        }        for (let pageNum = 2; pageNum <= pagesCount; ++pageNum) {          const promise = pdfDocument.getPage(pageNum).then(pdfPage => {            const pageView = this._pages[pageNum - 1];            if (!pageView.pdfPage) {              pageView.setPdfPage(pdfPage);            }            this.linkService.cachePageRef(pageNum, pdfPage.ref);            if (--getPagesLeft === 0) {              this._pagesCapability.resolve();            }          }, reason => {            console.error(`Unable to get page ${pageNum} to initialize viewer`, reason);            if (--getPagesLeft === 0) {              this._pagesCapability.resolve();            }          });          if (pageNum % PagesCountLimit.PAUSE_EAGER_PAGE_INIT === 0) {            await promise;          }        }      });      this.eventBus.dispatch("pagesinit", {        source: this      });      pdfDocument.getMetadata().then(({        info      }) => {        if (pdfDocument !== this.pdfDocument) {          return;        }        if (info.Language) {          this.viewer.lang = info.Language;        }      });      if (this.defaultRenderingQueue) {        this.update();      }    }).catch(reason => {      console.error("Unable to initialize viewer", reason);      this._pagesCapability.reject(reason);    });  }  setPageLabels(labels) {    if (!this.pdfDocument) {      return;    }    if (!labels) {      this._pageLabels = null;    } else if (!(Array.isArray(labels) && this.pdfDocument.numPages === labels.length)) {      this._pageLabels = null;      console.error(`setPageLabels: Invalid page labels.`);    } else {      this._pageLabels = labels;    }    for (let i = 0, ii = this._pages.length; i < ii; i++) {      this._pages[i].setPageLabel(this._pageLabels?.[i] ?? null);    }  }  _resetView() {    this._pages = [];    this._currentPageNumber = 1;    this._currentScale = _ui_utils.UNKNOWN_SCALE;    this._currentScaleValue = null;    this._pageLabels = null;    this.#buffer = new PDFPageViewBuffer(DEFAULT_CACHE_SIZE);    this._location = null;    this._pagesRotation = 0;    this._optionalContentConfigPromise = null;    this._firstPageCapability = (0, _pdfjsLib.createPromiseCapability)();    this._onePageRenderedCapability = (0, _pdfjsLib.createPromiseCapability)();    this._pagesCapability = (0, _pdfjsLib.createPromiseCapability)();    this._scrollMode = _ui_utils.ScrollMode.VERTICAL;    this._previousScrollMode = _ui_utils.ScrollMode.UNKNOWN;    this._spreadMode = _ui_utils.SpreadMode.NONE;    this.#scrollModePageState = {      previousPageNumber: 1,      scrollDown: true,      pages: []    };    if (this._onBeforeDraw) {      this.eventBus._off("pagerender", this._onBeforeDraw);      this._onBeforeDraw = null;    }    if (this._onAfterDraw) {      this.eventBus._off("pagerendered", this._onAfterDraw);      this._onAfterDraw = null;    }    if (this.#onVisibilityChange) {      document.removeEventListener("visibilitychange", this.#onVisibilityChange);      this.#onVisibilityChange = null;    }    this.viewer.textContent = "";    this._updateScrollMode();    this.viewer.removeAttribute("lang");    this.viewer.classList.remove(ENABLE_PERMISSIONS_CLASS);  }  #ensurePageViewVisible() {    if (this._scrollMode !== _ui_utils.ScrollMode.PAGE) {      throw new Error("#ensurePageViewVisible: Invalid scrollMode value.");    }    const pageNumber = this._currentPageNumber,      state = this.#scrollModePageState,      viewer = this.viewer;    viewer.textContent = "";    state.pages.length = 0;    if (this._spreadMode === _ui_utils.SpreadMode.NONE && !this.isInPresentationMode) {      const pageView = this._pages[pageNumber - 1];      viewer.append(pageView.div);      state.pages.push(pageView);    } else {      const pageIndexSet = new Set(),        parity = this._spreadMode - 1;      if (parity === -1) {        pageIndexSet.add(pageNumber - 1);      } else if (pageNumber % 2 !== parity) {        pageIndexSet.add(pageNumber - 1);        pageIndexSet.add(pageNumber);      } else {        pageIndexSet.add(pageNumber - 2);        pageIndexSet.add(pageNumber - 1);      }      const spread = document.createElement("div");      spread.className = "spread";      if (this.isInPresentationMode) {        const dummyPage = document.createElement("div");        dummyPage.className = "dummyPage";        spread.append(dummyPage);      }      for (const i of pageIndexSet) {        const pageView = this._pages[i];        if (!pageView) {          continue;        }        spread.append(pageView.div);        state.pages.push(pageView);      }      viewer.append(spread);    }    state.scrollDown = pageNumber >= state.previousPageNumber;    state.previousPageNumber = pageNumber;  }  _scrollUpdate() {    if (this.pagesCount === 0) {      return;    }    this.update();  }  #scrollIntoView(pageView, pageSpot = null) {    const {      div,      id    } = pageView;    if (this._currentPageNumber !== id) {      this._setCurrentPageNumber(id);    }    if (this._scrollMode === _ui_utils.ScrollMode.PAGE) {      this.#ensurePageViewVisible();      this.update();    }    if (!pageSpot && !this.isInPresentationMode) {      const left = div.offsetLeft + div.clientLeft,        right = left + div.clientWidth;      const {        scrollLeft,        clientWidth      } = this.container;      if (this._scrollMode === _ui_utils.ScrollMode.HORIZONTAL || left < scrollLeft || right > scrollLeft + clientWidth) {        pageSpot = {          left: 0,          top: 0        };      }    }    (0, _ui_utils.scrollIntoView)(div, pageSpot);    if (!this._currentScaleValue && this._location) {      this._location = null;    }  }  #isSameScale(newScale) {    return newScale === this._currentScale || Math.abs(newScale - this._currentScale) < 1e-15;  }  _setScaleUpdatePages(newScale, newValue, {    noScroll = false,    preset = false,    drawingDelay = -1  }) {    this._currentScaleValue = newValue.toString();    if (this.#isSameScale(newScale)) {      if (preset) {        this.eventBus.dispatch("scalechanging", {          source: this,          scale: newScale,          presetValue: newValue        });      }      return;    }    this.viewer.style.setProperty("--scale-factor", newScale * _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS);    const postponeDrawing = drawingDelay >= 0 && drawingDelay < 1000;    this.refresh(true, {      scale: newScale,      drawingDelay: postponeDrawing ? drawingDelay : -1    });    if (postponeDrawing) {      this.#scaleTimeoutId = setTimeout(() => {        this.#scaleTimeoutId = null;        this.refresh();      }, drawingDelay);    }    this._currentScale = newScale;    if (!noScroll) {      let page = this._currentPageNumber,        dest;      if (this._location && !(this.isInPresentationMode || this.isChangingPresentationMode)) {        page = this._location.pageNumber;        dest = [null, {          name: "XYZ"        }, this._location.left, this._location.top, null];      }      this.scrollPageIntoView({        pageNumber: page,        destArray: dest,        allowNegativeOffset: true      });    }    this.eventBus.dispatch("scalechanging", {      source: this,      scale: newScale,      presetValue: preset ? newValue : undefined    });    if (this.defaultRenderingQueue) {      this.update();    }  }  get _pageWidthScaleFactor() {    if (this._spreadMode !== _ui_utils.SpreadMode.NONE && this._scrollMode !== _ui_utils.ScrollMode.HORIZONTAL) {      return 2;    }    return 1;  }  _setScale(value, options) {    let scale = parseFloat(value);    if (scale > 0) {      options.preset = false;      this._setScaleUpdatePages(scale, value, options);    } else {      const currentPage = this._pages[this._currentPageNumber - 1];      if (!currentPage) {        return;      }      let hPadding = _ui_utils.SCROLLBAR_PADDING,        vPadding = _ui_utils.VERTICAL_PADDING;      if (this.isInPresentationMode) {        hPadding = vPadding = 4;        if (this._spreadMode !== _ui_utils.SpreadMode.NONE) {          hPadding *= 2;        }      } else if (this.removePageBorders) {        hPadding = vPadding = 0;      } else if (this._scrollMode === _ui_utils.ScrollMode.HORIZONTAL) {        [hPadding, vPadding] = [vPadding, hPadding];      }      const pageWidthScale = (this.container.clientWidth - hPadding) / currentPage.width * currentPage.scale / this._pageWidthScaleFactor;      const pageHeightScale = (this.container.clientHeight - vPadding) / currentPage.height * currentPage.scale;      switch (value) {        case "page-actual":          scale = 1;          break;        case "page-width":          scale = pageWidthScale;          break;        case "page-height":          scale = pageHeightScale;          break;        case "page-fit":          scale = Math.min(pageWidthScale, pageHeightScale);          break;        case "auto":          const horizontalScale = (0, _ui_utils.isPortraitOrientation)(currentPage) ? pageWidthScale : Math.min(pageHeightScale, pageWidthScale);          scale = Math.min(_ui_utils.MAX_AUTO_SCALE, horizontalScale);          break;        default:          console.error(`_setScale: "${value}" is an unknown zoom value.`);          return;      }      options.preset = true;      this._setScaleUpdatePages(scale, value, options);    }  }  #resetCurrentPageView() {    const pageView = this._pages[this._currentPageNumber - 1];    if (this.isInPresentationMode) {      this._setScale(this._currentScaleValue, {        noScroll: true      });    }    this.#scrollIntoView(pageView);  }  pageLabelToPageNumber(label) {    if (!this._pageLabels) {      return null;    }    const i = this._pageLabels.indexOf(label);    if (i < 0) {      return null;    }    return i + 1;  }  scrollPageIntoView({    pageNumber,    destArray = null,    allowNegativeOffset = false,    ignoreDestinationZoom = false  }) {    if (!this.pdfDocument) {      return;    }    const pageView = Number.isInteger(pageNumber) && this._pages[pageNumber - 1];    if (!pageView) {      console.error(`scrollPageIntoView: "${pageNumber}" is not a valid pageNumber parameter.`);      return;    }    if (this.isInPresentationMode || !destArray) {      this._setCurrentPageNumber(pageNumber, true);      return;    }    let x = 0,      y = 0;    let width = 0,      height = 0,      widthScale,      heightScale;    const changeOrientation = pageView.rotation % 180 !== 0;    const pageWidth = (changeOrientation ? pageView.height : pageView.width) / pageView.scale / _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS;    const pageHeight = (changeOrientation ? pageView.width : pageView.height) / pageView.scale / _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS;    let scale = 0;    switch (destArray[1].name) {      case "XYZ":        x = destArray[2];        y = destArray[3];        scale = destArray[4];        x = x !== null ? x : 0;        y = y !== null ? y : pageHeight;        break;      case "Fit":      case "FitB":        scale = "page-fit";        break;      case "FitH":      case "FitBH":        y = destArray[2];        scale = "page-width";        if (y === null && this._location) {          x = this._location.left;          y = this._location.top;        } else if (typeof y !== "number" || y < 0) {          y = pageHeight;        }        break;      case "FitV":      case "FitBV":        x = destArray[2];        width = pageWidth;        height = pageHeight;        scale = "page-height";        break;      case "FitR":        x = destArray[2];        y = destArray[3];        width = destArray[4] - x;        height = destArray[5] - y;        const hPadding = this.removePageBorders ? 0 : _ui_utils.SCROLLBAR_PADDING;        const vPadding = this.removePageBorders ? 0 : _ui_utils.VERTICAL_PADDING;        widthScale = (this.container.clientWidth - hPadding) / width / _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS;        heightScale = (this.container.clientHeight - vPadding) / height / _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS;        scale = Math.min(Math.abs(widthScale), Math.abs(heightScale));        break;      default:        console.error(`scrollPageIntoView: "${destArray[1].name}" is not a valid destination type.`);        return;    }    if (!ignoreDestinationZoom) {      if (scale && scale !== this._currentScale) {        this.currentScaleValue = scale;      } else if (this._currentScale === _ui_utils.UNKNOWN_SCALE) {        this.currentScaleValue = _ui_utils.DEFAULT_SCALE_VALUE;      }    }    if (scale === "page-fit" && !destArray[4]) {      this.#scrollIntoView(pageView);      return;    }    const boundingRect = [pageView.viewport.convertToViewportPoint(x, y), pageView.viewport.convertToViewportPoint(x + width, y + height)];    let left = Math.min(boundingRect[0][0], boundingRect[1][0]);    let top = Math.min(boundingRect[0][1], boundingRect[1][1]);    if (!allowNegativeOffset) {      left = Math.max(left, 0);      top = Math.max(top, 0);    }    this.#scrollIntoView(pageView, {      left,      top    });  }  _updateLocation(firstPage) {    const currentScale = this._currentScale;    const currentScaleValue = this._currentScaleValue;    const normalizedScaleValue = parseFloat(currentScaleValue) === currentScale ? Math.round(currentScale * 10000) / 100 : currentScaleValue;    const pageNumber = firstPage.id;    const currentPageView = this._pages[pageNumber - 1];    const container = this.container;    const topLeft = currentPageView.getPagePoint(container.scrollLeft - firstPage.x, container.scrollTop - firstPage.y);    const intLeft = Math.round(topLeft[0]);    const intTop = Math.round(topLeft[1]);    let pdfOpenParams = `#page=${pageNumber}`;    if (!this.isInPresentationMode) {      pdfOpenParams += `&zoom=${normalizedScaleValue},${intLeft},${intTop}`;    }    this._location = {      pageNumber,      scale: normalizedScaleValue,      top: intTop,      left: intLeft,      rotation: this._pagesRotation,      pdfOpenParams    };  }  update() {    const visible = this._getVisiblePages();    const visiblePages = visible.views,      numVisiblePages = visiblePages.length;    if (numVisiblePages === 0) {      return;    }    const newCacheSize = Math.max(DEFAULT_CACHE_SIZE, 2 * numVisiblePages + 1);    this.#buffer.resize(newCacheSize, visible.ids);    this.renderingQueue.renderHighestPriority(visible);    const isSimpleLayout = this._spreadMode === _ui_utils.SpreadMode.NONE && (this._scrollMode === _ui_utils.ScrollMode.PAGE || this._scrollMode === _ui_utils.ScrollMode.VERTICAL);    const currentId = this._currentPageNumber;    let stillFullyVisible = false;    for (const page of visiblePages) {      if (page.percent < 100) {        break;      }      if (page.id === currentId && isSimpleLayout) {        stillFullyVisible = true;        break;      }    }    this._setCurrentPageNumber(stillFullyVisible ? currentId : visiblePages[0].id);    this._updateLocation(visible.first);    this.eventBus.dispatch("updateviewarea", {      source: this,      location: this._location    });  }  containsElement(element) {    return this.container.contains(element);  }  focus() {    this.container.focus();  }  get _isContainerRtl() {    return getComputedStyle(this.container).direction === "rtl";  }  get isInPresentationMode() {    return this.presentationModeState === _ui_utils.PresentationModeState.FULLSCREEN;  }  get isChangingPresentationMode() {    return this.presentationModeState === _ui_utils.PresentationModeState.CHANGING;  }  get isHorizontalScrollbarEnabled() {    return this.isInPresentationMode ? false : this.container.scrollWidth > this.container.clientWidth;  }  get isVerticalScrollbarEnabled() {    return this.isInPresentationMode ? false : this.container.scrollHeight > this.container.clientHeight;  }  _getVisiblePages() {    const views = this._scrollMode === _ui_utils.ScrollMode.PAGE ? this.#scrollModePageState.pages : this._pages,      horizontal = this._scrollMode === _ui_utils.ScrollMode.HORIZONTAL,      rtl = horizontal && this._isContainerRtl;    return (0, _ui_utils.getVisibleElements)({      scrollEl: this.container,      views,      sortByVisibility: true,      horizontal,      rtl    });  }  isPageVisible(pageNumber) {    if (!this.pdfDocument) {      return false;    }    if (!(Number.isInteger(pageNumber) && pageNumber > 0 && pageNumber <= this.pagesCount)) {      console.error(`isPageVisible: "${pageNumber}" is not a valid page.`);      return false;    }    return this._getVisiblePages().ids.has(pageNumber);  }  isPageCached(pageNumber) {    if (!this.pdfDocument) {      return false;    }    if (!(Number.isInteger(pageNumber) && pageNumber > 0 && pageNumber <= this.pagesCount)) {      console.error(`isPageCached: "${pageNumber}" is not a valid page.`);      return false;    }    const pageView = this._pages[pageNumber - 1];    return this.#buffer.has(pageView);  }  cleanup() {    for (const pageView of this._pages) {      if (pageView.renderingState !== _ui_utils.RenderingStates.FINISHED) {        pageView.reset();      }    }  }  _cancelRendering() {    for (const pageView of this._pages) {      pageView.cancelRendering();    }  }  async #ensurePdfPageLoaded(pageView) {    if (pageView.pdfPage) {      return pageView.pdfPage;    }    try {      const pdfPage = await this.pdfDocument.getPage(pageView.id);      if (!pageView.pdfPage) {        pageView.setPdfPage(pdfPage);      }      if (!this.linkService._cachedPageNumber?.(pdfPage.ref)) {        this.linkService.cachePageRef(pageView.id, pdfPage.ref);      }      return pdfPage;    } catch (reason) {      console.error("Unable to get page for page view", reason);      return null;    }  }  #getScrollAhead(visible) {    if (visible.first?.id === 1) {      return true;    } else if (visible.last?.id === this.pagesCount) {      return false;    }    switch (this._scrollMode) {      case _ui_utils.ScrollMode.PAGE:        return this.#scrollModePageState.scrollDown;      case _ui_utils.ScrollMode.HORIZONTAL:        return this.scroll.right;    }    return this.scroll.down;  }  forceRendering(currentlyVisiblePages) {    const visiblePages = currentlyVisiblePages || this._getVisiblePages();    const scrollAhead = this.#getScrollAhead(visiblePages);    const preRenderExtra = this._spreadMode !== _ui_utils.SpreadMode.NONE && this._scrollMode !== _ui_utils.ScrollMode.HORIZONTAL;    const pageView = this.renderingQueue.getHighestPriority(visiblePages, this._pages, scrollAhead, preRenderExtra);    if (pageView) {      this.#ensurePdfPageLoaded(pageView).then(() => {        this.renderingQueue.renderView(pageView);      });      return true;    }    return false;  }  get hasEqualPageSizes() {    const firstPageView = this._pages[0];    for (let i = 1, ii = this._pages.length; i < ii; ++i) {      const pageView = this._pages[i];      if (pageView.width !== firstPageView.width || pageView.height !== firstPageView.height) {        return false;      }    }    return true;  }  getPagesOverview() {    return this._pages.map(pageView => {      const viewport = pageView.pdfPage.getViewport({        scale: 1      });      if (!this.enablePrintAutoRotate || (0, _ui_utils.isPortraitOrientation)(viewport)) {        return {          width: viewport.width,          height: viewport.height,          rotation: viewport.rotation        };      }      return {        width: viewport.height,        height: viewport.width,        rotation: (viewport.rotation - 90) % 360      };    });  }  get optionalContentConfigPromise() {    if (!this.pdfDocument) {      return Promise.resolve(null);    }    if (!this._optionalContentConfigPromise) {      console.error("optionalContentConfigPromise: Not initialized yet.");      return this.pdfDocument.getOptionalContentConfig();    }    return this._optionalContentConfigPromise;  }  set optionalContentConfigPromise(promise) {    if (!(promise instanceof Promise)) {      throw new Error(`Invalid optionalContentConfigPromise: ${promise}`);    }    if (!this.pdfDocument) {      return;    }    if (!this._optionalContentConfigPromise) {      return;    }    this._optionalContentConfigPromise = promise;    this.refresh(false, {      optionalContentConfigPromise: promise    });    this.eventBus.dispatch("optionalcontentconfigchanged", {      source: this,      promise    });  }  get scrollMode() {    return this._scrollMode;  }  set scrollMode(mode) {    if (this._scrollMode === mode) {      return;    }    if (!(0, _ui_utils.isValidScrollMode)(mode)) {      throw new Error(`Invalid scroll mode: ${mode}`);    }    if (this.pagesCount > PagesCountLimit.FORCE_SCROLL_MODE_PAGE) {      return;    }    this._previousScrollMode = this._scrollMode;    this._scrollMode = mode;    this.eventBus.dispatch("scrollmodechanged", {      source: this,      mode    });    this._updateScrollMode(this._currentPageNumber);  }  _updateScrollMode(pageNumber = null) {    const scrollMode = this._scrollMode,      viewer = this.viewer;    viewer.classList.toggle("scrollHorizontal", scrollMode === _ui_utils.ScrollMode.HORIZONTAL);    viewer.classList.toggle("scrollWrapped", scrollMode === _ui_utils.ScrollMode.WRAPPED);    if (!this.pdfDocument || !pageNumber) {      return;    }    if (scrollMode === _ui_utils.ScrollMode.PAGE) {      this.#ensurePageViewVisible();    } else if (this._previousScrollMode === _ui_utils.ScrollMode.PAGE) {      this._updateSpreadMode();    }    if (this._currentScaleValue && isNaN(this._currentScaleValue)) {      this._setScale(this._currentScaleValue, {        noScroll: true      });    }    this._setCurrentPageNumber(pageNumber, true);    this.update();  }  get spreadMode() {    return this._spreadMode;  }  set spreadMode(mode) {    if (this._spreadMode === mode) {      return;    }    if (!(0, _ui_utils.isValidSpreadMode)(mode)) {      throw new Error(`Invalid spread mode: ${mode}`);    }    this._spreadMode = mode;    this.eventBus.dispatch("spreadmodechanged", {      source: this,      mode    });    this._updateSpreadMode(this._currentPageNumber);  }  _updateSpreadMode(pageNumber = null) {    if (!this.pdfDocument) {      return;    }    const viewer = this.viewer,      pages = this._pages;    if (this._scrollMode === _ui_utils.ScrollMode.PAGE) {      this.#ensurePageViewVisible();    } else {      viewer.textContent = "";      if (this._spreadMode === _ui_utils.SpreadMode.NONE) {        for (const pageView of this._pages) {          viewer.append(pageView.div);        }      } else {        const parity = this._spreadMode - 1;        let spread = null;        for (let i = 0, ii = pages.length; i < ii; ++i) {          if (spread === null) {            spread = document.createElement("div");            spread.className = "spread";            viewer.append(spread);          } else if (i % 2 === parity) {            spread = spread.cloneNode(false);            viewer.append(spread);          }          spread.append(pages[i].div);        }      }    }    if (!pageNumber) {      return;    }    if (this._currentScaleValue && isNaN(this._currentScaleValue)) {      this._setScale(this._currentScaleValue, {        noScroll: true      });    }    this._setCurrentPageNumber(pageNumber, true);    this.update();  }  _getPageAdvance(currentPageNumber, previous = false) {    switch (this._scrollMode) {      case _ui_utils.ScrollMode.WRAPPED:        {          const {              views            } = this._getVisiblePages(),            pageLayout = new Map();          for (const {            id,            y,            percent,            widthPercent          } of views) {            if (percent === 0 || widthPercent < 100) {              continue;            }            let yArray = pageLayout.get(y);            if (!yArray) {              pageLayout.set(y, yArray ||= []);            }            yArray.push(id);          }          for (const yArray of pageLayout.values()) {            const currentIndex = yArray.indexOf(currentPageNumber);            if (currentIndex === -1) {              continue;            }            const numPages = yArray.length;            if (numPages === 1) {              break;            }            if (previous) {              for (let i = currentIndex - 1, ii = 0; i >= ii; i--) {                const currentId = yArray[i],                  expectedId = yArray[i + 1] - 1;                if (currentId < expectedId) {                  return currentPageNumber - expectedId;                }              }            } else {              for (let i = currentIndex + 1, ii = numPages; i < ii; i++) {                const currentId = yArray[i],                  expectedId = yArray[i - 1] + 1;                if (currentId > expectedId) {                  return expectedId - currentPageNumber;                }              }            }            if (previous) {              const firstId = yArray[0];              if (firstId < currentPageNumber) {                return currentPageNumber - firstId + 1;              }            } else {              const lastId = yArray[numPages - 1];              if (lastId > currentPageNumber) {                return lastId - currentPageNumber + 1;              }            }            break;          }          break;        }      case _ui_utils.ScrollMode.HORIZONTAL:        {          break;        }      case _ui_utils.ScrollMode.PAGE:      case _ui_utils.ScrollMode.VERTICAL:        {          if (this._spreadMode === _ui_utils.SpreadMode.NONE) {            break;          }          const parity = this._spreadMode - 1;          if (previous && currentPageNumber % 2 !== parity) {            break;          } else if (!previous && currentPageNumber % 2 === parity) {            break;          }          const {              views            } = this._getVisiblePages(),            expectedId = previous ? currentPageNumber - 1 : currentPageNumber + 1;          for (const {            id,            percent,            widthPercent          } of views) {            if (id !== expectedId) {              continue;            }            if (percent > 0 && widthPercent === 100) {              return 2;            }            break;          }          break;        }    }    return 1;  }  nextPage() {    const currentPageNumber = this._currentPageNumber,      pagesCount = this.pagesCount;    if (currentPageNumber >= pagesCount) {      return false;    }    const advance = this._getPageAdvance(currentPageNumber, false) || 1;    this.currentPageNumber = Math.min(currentPageNumber + advance, pagesCount);    return true;  }  previousPage() {    const currentPageNumber = this._currentPageNumber;    if (currentPageNumber <= 1) {      return false;    }    const advance = this._getPageAdvance(currentPageNumber, true) || 1;    this.currentPageNumber = Math.max(currentPageNumber - advance, 1);    return true;  }  increaseScale(options = null) {    if (typeof options === "number") {      console.error("The `increaseScale` method-signature was updated, please use an object instead.");      options = {        steps: options      };    }    if (!this.pdfDocument) {      return;    }    options ||= Object.create(null);    let newScale = this._currentScale;    if (options.scaleFactor > 1) {      newScale = Math.min(_ui_utils.MAX_SCALE, Math.round(newScale * options.scaleFactor * 100) / 100);    } else {      let steps = options.steps ?? 1;      do {        newScale = (newScale * _ui_utils.DEFAULT_SCALE_DELTA).toFixed(2);        newScale = Math.ceil(newScale * 10) / 10;        newScale = Math.min(_ui_utils.MAX_SCALE, newScale);      } while (--steps > 0 && newScale < _ui_utils.MAX_SCALE);    }    options.noScroll = false;    this._setScale(newScale, options);  }  decreaseScale(options = null) {    if (typeof options === "number") {      console.error("The `decreaseScale` method-signature was updated, please use an object instead.");      options = {        steps: options      };    }    if (!this.pdfDocument) {      return;    }    options ||= Object.create(null);    let newScale = this._currentScale;    if (options.scaleFactor > 0 && options.scaleFactor < 1) {      newScale = Math.max(_ui_utils.MIN_SCALE, Math.round(newScale * options.scaleFactor * 100) / 100);    } else {      let steps = options.steps ?? 1;      do {        newScale = (newScale / _ui_utils.DEFAULT_SCALE_DELTA).toFixed(2);        newScale = Math.floor(newScale * 10) / 10;        newScale = Math.max(_ui_utils.MIN_SCALE, newScale);      } while (--steps > 0 && newScale > _ui_utils.MIN_SCALE);    }    options.noScroll = false;    this._setScale(newScale, options);  }  #updateContainerHeightCss(height = this.container.clientHeight) {    if (height !== this.#previousContainerHeight) {      this.#previousContainerHeight = height;      _ui_utils.docStyle.setProperty("--viewer-container-height", `${height}px`);    }  }  #resizeObserverCallback(entries) {    for (const entry of entries) {      if (entry.target === this.container) {        this.#updateContainerHeightCss(Math.floor(entry.borderBoxSize[0].blockSize));        this.#containerTopLeft = null;        break;      }    }  }  get containerTopLeft() {    return this.#containerTopLeft ||= [this.container.offsetTop, this.container.offsetLeft];  }  get annotationEditorMode() {    return this.#annotationEditorUIManager ? this.#annotationEditorMode : _pdfjsLib.AnnotationEditorType.DISABLE;  }  set annotationEditorMode(mode) {    if (!this.#annotationEditorUIManager) {      throw new Error(`The AnnotationEditor is not enabled.`);    }    if (this.#annotationEditorMode === mode) {      return;    }    if (!isValidAnnotationEditorMode(mode)) {      throw new Error(`Invalid AnnotationEditor mode: ${mode}`);    }    if (!this.pdfDocument) {      return;    }    this.#annotationEditorMode = mode;    this.eventBus.dispatch("annotationeditormodechanged", {      source: this,      mode    });    this.#annotationEditorUIManager.updateMode(mode);  }  set annotationEditorParams({    type,    value  }) {    if (!this.#annotationEditorUIManager) {      throw new Error(`The AnnotationEditor is not enabled.`);    }    this.#annotationEditorUIManager.updateParams(type, value);  }  refresh(noUpdate = false, updateArgs = Object.create(null)) {    if (!this.pdfDocument) {      return;    }    for (const pageView of this._pages) {      pageView.update(updateArgs);    }    if (this.#scaleTimeoutId !== null) {      clearTimeout(this.#scaleTimeoutId);      this.#scaleTimeoutId = null;    }    if (!noUpdate) {      this.update();    }  }}exports.PDFViewer = PDFViewer;/***/ }),/* 29 *//***/ ((__unused_webpack_module, exports) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.NullL10n = void 0;exports.fixupLangCode = fixupLangCode;exports.getL10nFallback = getL10nFallback;const DEFAULT_L10N_STRINGS = {  of_pages: "of {{pagesCount}}",  page_of_pages: "({{pageNumber}} of {{pagesCount}})",  document_properties_kb: "{{size_kb}} KB ({{size_b}} bytes)",  document_properties_mb: "{{size_mb}} MB ({{size_b}} bytes)",  document_properties_date_string: "{{date}}, {{time}}",  document_properties_page_size_unit_inches: "in",  document_properties_page_size_unit_millimeters: "mm",  document_properties_page_size_orientation_portrait: "portrait",  document_properties_page_size_orientation_landscape: "landscape",  document_properties_page_size_name_a3: "A3",  document_properties_page_size_name_a4: "A4",  document_properties_page_size_name_letter: "Letter",  document_properties_page_size_name_legal: "Legal",  document_properties_page_size_dimension_string: "{{width}} × {{height}} {{unit}} ({{orientation}})",  document_properties_page_size_dimension_name_string: "{{width}} × {{height}} {{unit}} ({{name}}, {{orientation}})",  document_properties_linearized_yes: "Yes",  document_properties_linearized_no: "No",  additional_layers: "Additional Layers",  page_landmark: "Page {{page}}",  thumb_page_title: "Page {{page}}",  thumb_page_canvas: "Thumbnail of Page {{page}}",  find_reached_top: "Reached top of document, continued from bottom",  find_reached_bottom: "Reached end of document, continued from top",  "find_match_count[one]": "{{current}} of {{total}} match",  "find_match_count[other]": "{{current}} of {{total}} matches",  "find_match_count_limit[one]": "More than {{limit}} match",  "find_match_count_limit[other]": "More than {{limit}} matches",  find_not_found: "Phrase not found",  page_scale_width: "Page Width",  page_scale_fit: "Page Fit",  page_scale_auto: "Automatic Zoom",  page_scale_actual: "Actual Size",  page_scale_percent: "{{scale}}%",  loading: "Loading…",  loading_error: "An error occurred while loading the PDF.",  invalid_file_error: "Invalid or corrupted PDF file.",  missing_file_error: "Missing PDF file.",  unexpected_response_error: "Unexpected server response.",  rendering_error: "An error occurred while rendering the page.",  printing_not_supported: "Warning: Printing is not fully supported by this browser.",  printing_not_ready: "Warning: The PDF is not fully loaded for printing.",  web_fonts_disabled: "Web fonts are disabled: unable to use embedded PDF fonts.",  free_text2_default_content: "Start typing…",  editor_free_text2_aria_label: "Text Editor",  editor_ink2_aria_label: "Draw Editor",  editor_ink_canvas_aria_label: "User-created image"};{  DEFAULT_L10N_STRINGS.print_progress_percent = "{{progress}}%";}function getL10nFallback(key, args) {  switch (key) {    case "find_match_count":      key = `find_match_count[${args.total === 1 ? "one" : "other"}]`;      break;    case "find_match_count_limit":      key = `find_match_count_limit[${args.limit === 1 ? "one" : "other"}]`;      break;  }  return DEFAULT_L10N_STRINGS[key] || "";}const PARTIAL_LANG_CODES = {  en: "en-US",  es: "es-ES",  fy: "fy-NL",  ga: "ga-IE",  gu: "gu-IN",  hi: "hi-IN",  hy: "hy-AM",  nb: "nb-NO",  ne: "ne-NP",  nn: "nn-NO",  pa: "pa-IN",  pt: "pt-PT",  sv: "sv-SE",  zh: "zh-CN"};function fixupLangCode(langCode) {  return PARTIAL_LANG_CODES[langCode?.toLowerCase()] || langCode;}function formatL10nValue(text, args) {  if (!args) {    return text;  }  return text.replace(/\{\{\s*(\w+)\s*\}\}/g, (all, name) => {    return name in args ? args[name] : "{{" + name + "}}";  });}const NullL10n = {  async getLanguage() {    return "en-us";  },  async getDirection() {    return "ltr";  },  async get(key, args = null, fallback = getL10nFallback(key, args)) {    return formatL10nValue(fallback, args);  },  async translate(element) {}};exports.NullL10n = NullL10n;/***/ }),/* 30 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFPageView = void 0;var _pdfjsLib = __webpack_require__(5);var _ui_utils = __webpack_require__(1);var _annotation_editor_layer_builder = __webpack_require__(31);var _annotation_layer_builder = __webpack_require__(32);var _app_options = __webpack_require__(2);var _l10n_utils = __webpack_require__(29);var _struct_tree_layer_builder = __webpack_require__(33);var _text_accessibility = __webpack_require__(34);var _text_highlighter = __webpack_require__(35);var _text_layer_builder = __webpack_require__(36);var _xfa_layer_builder = __webpack_require__(37);const MAX_CANVAS_PIXELS = _app_options.compatibilityParams.maxCanvasPixels || 16777216;const DEFAULT_LAYER_PROPERTIES = () => {  return null;};class PDFPageView {  #annotationMode = _pdfjsLib.AnnotationMode.ENABLE_FORMS;  #layerProperties = null;  #previousRotation = null;  #renderingState = _ui_utils.RenderingStates.INITIAL;  #useThumbnailCanvas = {    initialOptionalContent: true,    regularAnnotations: true  };  constructor(options) {    const container = options.container;    const defaultViewport = options.defaultViewport;    this.id = options.id;    this.renderingId = "page" + this.id;    this.#layerProperties = options.layerProperties || DEFAULT_LAYER_PROPERTIES;    this.pdfPage = null;    this.pageLabel = null;    this.rotation = 0;    this.scale = options.scale || _ui_utils.DEFAULT_SCALE;    this.viewport = defaultViewport;    this.pdfPageRotate = defaultViewport.rotation;    this._optionalContentConfigPromise = options.optionalContentConfigPromise || null;    this.hasRestrictedScaling = false;    this.textLayerMode = options.textLayerMode ?? _ui_utils.TextLayerMode.ENABLE;    this.#annotationMode = options.annotationMode ?? _pdfjsLib.AnnotationMode.ENABLE_FORMS;    this.imageResourcesPath = options.imageResourcesPath || "";    this.useOnlyCssZoom = options.useOnlyCssZoom || false;    this.isOffscreenCanvasSupported = options.isOffscreenCanvasSupported ?? true;    this.maxCanvasPixels = options.maxCanvasPixels || MAX_CANVAS_PIXELS;    this.pageColors = options.pageColors || null;    this.eventBus = options.eventBus;    this.renderingQueue = options.renderingQueue;    this.renderer = options.renderer || _ui_utils.RendererType.CANVAS;    this.l10n = options.l10n || _l10n_utils.NullL10n;    this.paintTask = null;    this.paintedViewportMap = new WeakMap();    this.resume = null;    this._renderError = null;    this._isStandalone = !this.renderingQueue?.hasViewer();    this._annotationCanvasMap = null;    this.annotationLayer = null;    this.annotationEditorLayer = null;    this.textLayer = null;    this.zoomLayer = null;    this.xfaLayer = null;    this.structTreeLayer = null;    const div = document.createElement("div");    div.className = "page";    div.setAttribute("data-page-number", this.id);    div.setAttribute("role", "region");    this.l10n.get("page_landmark", {      page: this.id    }).then(msg => {      div.setAttribute("aria-label", msg);    });    this.div = div;    this.#setDimensions();    container?.append(div);    if (this._isStandalone) {      container?.style.setProperty("--scale-factor", this.scale * _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS);      const {        optionalContentConfigPromise      } = options;      if (optionalContentConfigPromise) {        optionalContentConfigPromise.then(optionalContentConfig => {          if (optionalContentConfigPromise !== this._optionalContentConfigPromise) {            return;          }          this.#useThumbnailCanvas.initialOptionalContent = optionalContentConfig.hasInitialVisibility;        });      }    }  }  get renderingState() {    return this.#renderingState;  }  set renderingState(state) {    this.#renderingState = state;    switch (state) {      case _ui_utils.RenderingStates.INITIAL:      case _ui_utils.RenderingStates.PAUSED:        this.loadingIconDiv?.classList.add("notVisible");        break;      case _ui_utils.RenderingStates.RUNNING:        this.loadingIconDiv?.classList.remove("notVisible");        break;      case _ui_utils.RenderingStates.FINISHED:        if (this.loadingIconDiv) {          this.loadingIconDiv.remove();          delete this.loadingIconDiv;        }        break;    }  }  #setDimensions() {    const {      viewport    } = this;    if (this.pdfPage) {      if (this.#previousRotation === viewport.rotation) {        return;      }      this.#previousRotation = viewport.rotation;    }    (0, _pdfjsLib.setLayerDimensions)(this.div, viewport, true, false);  }  setPdfPage(pdfPage) {    this.pdfPage = pdfPage;    this.pdfPageRotate = pdfPage.rotate;    const totalRotation = (this.rotation + this.pdfPageRotate) % 360;    this.viewport = pdfPage.getViewport({      scale: this.scale * _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS,      rotation: totalRotation    });    this.#setDimensions();    this.reset();  }  destroy() {    this.reset();    this.pdfPage?.cleanup();  }  get _textHighlighter() {    return (0, _pdfjsLib.shadow)(this, "_textHighlighter", new _text_highlighter.TextHighlighter({      pageIndex: this.id - 1,      eventBus: this.eventBus,      findController: this.#layerProperties().findController    }));  }  async #renderAnnotationLayer() {    let error = null;    try {      await this.annotationLayer.render(this.viewport, "display");    } catch (ex) {      console.error(`#renderAnnotationLayer: "${ex}".`);      error = ex;    } finally {      this.eventBus.dispatch("annotationlayerrendered", {        source: this,        pageNumber: this.id,        error      });    }  }  async #renderAnnotationEditorLayer() {    let error = null;    try {      await this.annotationEditorLayer.render(this.viewport, "display");    } catch (ex) {      console.error(`#renderAnnotationEditorLayer: "${ex}".`);      error = ex;    } finally {      this.eventBus.dispatch("annotationeditorlayerrendered", {        source: this,        pageNumber: this.id,        error      });    }  }  async #renderXfaLayer() {    let error = null;    try {      const result = await this.xfaLayer.render(this.viewport, "display");      if (result?.textDivs && this._textHighlighter) {        this.#buildXfaTextContentItems(result.textDivs);      }    } catch (ex) {      console.error(`#renderXfaLayer: "${ex}".`);      error = ex;    } finally {      this.eventBus.dispatch("xfalayerrendered", {        source: this,        pageNumber: this.id,        error      });    }  }  async #renderTextLayer() {    const {      pdfPage,      textLayer,      viewport    } = this;    if (!textLayer) {      return;    }    let error = null;    try {      if (!textLayer.renderingDone) {        const readableStream = pdfPage.streamTextContent({          includeMarkedContent: true        });        textLayer.setTextContentSource(readableStream);      }      await textLayer.render(viewport);    } catch (ex) {      if (ex instanceof _pdfjsLib.AbortException) {        return;      }      console.error(`#renderTextLayer: "${ex}".`);      error = ex;    }    this.eventBus.dispatch("textlayerrendered", {      source: this,      pageNumber: this.id,      numTextDivs: textLayer.numTextDivs,      error    });    this.#renderStructTreeLayer();  }  async #renderStructTreeLayer() {    if (!this.textLayer) {      return;    }    this.structTreeLayer ||= new _struct_tree_layer_builder.StructTreeLayerBuilder();    const tree = await (!this.structTreeLayer.renderingDone ? this.pdfPage.getStructTree() : null);    const treeDom = this.structTreeLayer?.render(tree);    if (treeDom) {      this.canvas?.append(treeDom);    }  }  async #buildXfaTextContentItems(textDivs) {    const text = await this.pdfPage.getTextContent();    const items = [];    for (const item of text.items) {      items.push(item.str);    }    this._textHighlighter.setTextMapping(textDivs, items);    this._textHighlighter.enable();  }  _resetZoomLayer(removeFromDOM = false) {    if (!this.zoomLayer) {      return;    }    const zoomLayerCanvas = this.zoomLayer.firstChild;    this.paintedViewportMap.delete(zoomLayerCanvas);    zoomLayerCanvas.width = 0;    zoomLayerCanvas.height = 0;    if (removeFromDOM) {      this.zoomLayer.remove();    }    this.zoomLayer = null;  }  reset({    keepZoomLayer = false,    keepAnnotationLayer = false,    keepAnnotationEditorLayer = false,    keepXfaLayer = false,    keepTextLayer = false  } = {}) {    this.cancelRendering({      keepAnnotationLayer,      keepAnnotationEditorLayer,      keepXfaLayer,      keepTextLayer    });    this.renderingState = _ui_utils.RenderingStates.INITIAL;    const div = this.div;    const childNodes = div.childNodes,      zoomLayerNode = keepZoomLayer && this.zoomLayer || null,      annotationLayerNode = keepAnnotationLayer && this.annotationLayer?.div || null,      annotationEditorLayerNode = keepAnnotationEditorLayer && this.annotationEditorLayer?.div || null,      xfaLayerNode = keepXfaLayer && this.xfaLayer?.div || null,      textLayerNode = keepTextLayer && this.textLayer?.div || null;    for (let i = childNodes.length - 1; i >= 0; i--) {      const node = childNodes[i];      switch (node) {        case zoomLayerNode:        case annotationLayerNode:        case annotationEditorLayerNode:        case xfaLayerNode:        case textLayerNode:        case this.loadingIconDiv:          continue;      }      node.remove();    }    div.removeAttribute("data-loaded");    if (annotationLayerNode) {      this.annotationLayer.hide();    }    if (annotationEditorLayerNode) {      this.annotationEditorLayer.hide();    }    if (xfaLayerNode) {      this.xfaLayer.hide();    }    if (textLayerNode) {      this.textLayer.hide();    }    if (!zoomLayerNode) {      if (this.canvas) {        this.paintedViewportMap.delete(this.canvas);        this.canvas.width = 0;        this.canvas.height = 0;        delete this.canvas;      }      this._resetZoomLayer();    }    if (this.svg) {      this.paintedViewportMap.delete(this.svg);      delete this.svg;    }    if (!this.loadingIconDiv) {      this.loadingIconDiv = document.createElement("div");      this.loadingIconDiv.className = "loadingIcon notVisible";      this.loadingIconDiv.setAttribute("role", "img");      this.l10n.get("loading").then(msg => {        this.loadingIconDiv?.setAttribute("aria-label", msg);      });      div.append(this.loadingIconDiv);    }  }  update({    scale = 0,    rotation = null,    optionalContentConfigPromise = null,    drawingDelay = -1  }) {    this.scale = scale || this.scale;    if (typeof rotation === "number") {      this.rotation = rotation;    }    if (optionalContentConfigPromise instanceof Promise) {      this._optionalContentConfigPromise = optionalContentConfigPromise;      optionalContentConfigPromise.then(optionalContentConfig => {        if (optionalContentConfigPromise !== this._optionalContentConfigPromise) {          return;        }        this.#useThumbnailCanvas.initialOptionalContent = optionalContentConfig.hasInitialVisibility;      });    }    const totalRotation = (this.rotation + this.pdfPageRotate) % 360;    this.viewport = this.viewport.clone({      scale: this.scale * _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS,      rotation: totalRotation    });    this.#setDimensions();    if (this._isStandalone) {      this.div.parentNode?.style.setProperty("--scale-factor", this.viewport.scale);    }    if (this.svg) {      this.cssTransform({        target: this.svg,        redrawAnnotationLayer: true,        redrawAnnotationEditorLayer: true,        redrawXfaLayer: true,        redrawTextLayer: true      });      this.eventBus.dispatch("pagerendered", {        source: this,        pageNumber: this.id,        cssTransform: true,        timestamp: performance.now(),        error: this._renderError      });      return;    }    let isScalingRestricted = false;    if (this.canvas && this.maxCanvasPixels > 0) {      const outputScale = this.outputScale;      if ((Math.floor(this.viewport.width) * outputScale.sx | 0) * (Math.floor(this.viewport.height) * outputScale.sy | 0) > this.maxCanvasPixels) {        isScalingRestricted = true;      }    }    const postponeDrawing = drawingDelay >= 0 && drawingDelay < 1000;    if (this.canvas) {      if (postponeDrawing || this.useOnlyCssZoom || this.hasRestrictedScaling && isScalingRestricted) {        if (postponeDrawing && this.renderingState !== _ui_utils.RenderingStates.FINISHED) {          this.cancelRendering({            keepZoomLayer: true,            keepAnnotationLayer: true,            keepAnnotationEditorLayer: true,            keepXfaLayer: true,            keepTextLayer: true,            cancelExtraDelay: drawingDelay          });          this.renderingState = _ui_utils.RenderingStates.FINISHED;        }        this.cssTransform({          target: this.canvas,          redrawAnnotationLayer: true,          redrawAnnotationEditorLayer: true,          redrawXfaLayer: true,          redrawTextLayer: !postponeDrawing,          hideTextLayer: postponeDrawing        });        this.eventBus.dispatch("pagerendered", {          source: this,          pageNumber: this.id,          cssTransform: true,          timestamp: performance.now(),          error: this._renderError        });        return;      }      if (!this.zoomLayer && !this.canvas.hidden) {        this.zoomLayer = this.canvas.parentNode;        this.zoomLayer.style.position = "absolute";      }    }    if (this.zoomLayer) {      this.cssTransform({        target: this.zoomLayer.firstChild      });    }    this.reset({      keepZoomLayer: true,      keepAnnotationLayer: true,      keepAnnotationEditorLayer: true,      keepXfaLayer: true,      keepTextLayer: true    });  }  cancelRendering({    keepAnnotationLayer = false,    keepAnnotationEditorLayer = false,    keepXfaLayer = false,    keepTextLayer = false,    cancelExtraDelay = 0  } = {}) {    if (this.paintTask) {      this.paintTask.cancel(cancelExtraDelay);      this.paintTask = null;    }    this.resume = null;    if (this.textLayer && (!keepTextLayer || !this.textLayer.div)) {      this.textLayer.cancel();      this.textLayer = null;    }    if (this.structTreeLayer && !this.textLayer) {      this.structTreeLayer = null;    }    if (this.annotationLayer && (!keepAnnotationLayer || !this.annotationLayer.div)) {      this.annotationLayer.cancel();      this.annotationLayer = null;      this._annotationCanvasMap = null;    }    if (this.annotationEditorLayer && (!keepAnnotationEditorLayer || !this.annotationEditorLayer.div)) {      this.annotationEditorLayer.cancel();      this.annotationEditorLayer = null;    }    if (this.xfaLayer && (!keepXfaLayer || !this.xfaLayer.div)) {      this.xfaLayer.cancel();      this.xfaLayer = null;      this._textHighlighter?.disable();    }  }  cssTransform({    target,    redrawAnnotationLayer = false,    redrawAnnotationEditorLayer = false,    redrawXfaLayer = false,    redrawTextLayer = false,    hideTextLayer = false  }) {    if (target instanceof HTMLCanvasElement) {      if (!target.hasAttribute("zooming")) {        target.setAttribute("zooming", true);        const {          style        } = target;        style.width = style.height = "";      }    } else {      const div = this.div;      const {        width,        height      } = this.viewport;      target.style.width = target.parentNode.style.width = div.style.width = Math.floor(width) + "px";      target.style.height = target.parentNode.style.height = div.style.height = Math.floor(height) + "px";    }    const originalViewport = this.paintedViewportMap.get(target);    if (this.viewport !== originalViewport) {      const relativeRotation = this.viewport.rotation - originalViewport.rotation;      const absRotation = Math.abs(relativeRotation);      let scaleX = 1,        scaleY = 1;      if (absRotation === 90 || absRotation === 270) {        const {          width,          height        } = this.viewport;        scaleX = height / width;        scaleY = width / height;      }      if (absRotation !== 0) {        target.style.transform = `rotate(${relativeRotation}deg) scale(${scaleX}, ${scaleY})`;      }    }    if (redrawAnnotationLayer && this.annotationLayer) {      this.#renderAnnotationLayer();    }    if (redrawAnnotationEditorLayer && this.annotationEditorLayer) {      this.#renderAnnotationEditorLayer();    }    if (redrawXfaLayer && this.xfaLayer) {      this.#renderXfaLayer();    }    if (this.textLayer) {      if (hideTextLayer) {        this.textLayer.hide();      } else if (redrawTextLayer) {        this.#renderTextLayer();      }    }  }  get width() {    return this.viewport.width;  }  get height() {    return this.viewport.height;  }  getPagePoint(x, y) {    return this.viewport.convertToPdfPoint(x, y);  }  draw() {    if (this.renderingState !== _ui_utils.RenderingStates.INITIAL) {      console.error("Must be in new state before drawing");      this.reset();    }    const {      div,      pdfPage    } = this;    if (!pdfPage) {      this.renderingState = _ui_utils.RenderingStates.FINISHED;      return Promise.reject(new Error("pdfPage is not loaded"));    }    this.renderingState = _ui_utils.RenderingStates.RUNNING;    const canvasWrapper = document.createElement("div");    canvasWrapper.classList.add("canvasWrapper");    div.append(canvasWrapper);    if (!this.textLayer && this.textLayerMode !== _ui_utils.TextLayerMode.DISABLE && !pdfPage.isPureXfa) {      this._accessibilityManager ||= new _text_accessibility.TextAccessibilityManager();      this.textLayer = new _text_layer_builder.TextLayerBuilder({        highlighter: this._textHighlighter,        accessibilityManager: this._accessibilityManager,        isOffscreenCanvasSupported: this.isOffscreenCanvasSupported      });      div.append(this.textLayer.div);    }    if (!this.annotationLayer && this.#annotationMode !== _pdfjsLib.AnnotationMode.DISABLE) {      const {        annotationStorage,        downloadManager,        enableScripting,        fieldObjectsPromise,        hasJSActionsPromise,        linkService      } = this.#layerProperties();      this._annotationCanvasMap ||= new Map();      this.annotationLayer = new _annotation_layer_builder.AnnotationLayerBuilder({        pageDiv: div,        pdfPage,        annotationStorage,        imageResourcesPath: this.imageResourcesPath,        renderForms: this.#annotationMode === _pdfjsLib.AnnotationMode.ENABLE_FORMS,        linkService,        downloadManager,        l10n: this.l10n,        enableScripting,        hasJSActionsPromise,        fieldObjectsPromise,        annotationCanvasMap: this._annotationCanvasMap,        accessibilityManager: this._accessibilityManager      });    }    if (this.xfaLayer?.div) {      div.append(this.xfaLayer.div);    }    let renderContinueCallback = null;    if (this.renderingQueue) {      renderContinueCallback = cont => {        if (!this.renderingQueue.isHighestPriority(this)) {          this.renderingState = _ui_utils.RenderingStates.PAUSED;          this.resume = () => {            this.renderingState = _ui_utils.RenderingStates.RUNNING;            cont();          };          return;        }        cont();      };    }    const finishPaintTask = async (error = null) => {      if (paintTask === this.paintTask) {        this.paintTask = null;      }      if (error instanceof _pdfjsLib.RenderingCancelledException) {        this._renderError = null;        return;      }      this._renderError = error;      this.renderingState = _ui_utils.RenderingStates.FINISHED;      this._resetZoomLayer(true);      this.#useThumbnailCanvas.regularAnnotations = !paintTask.separateAnnots;      this.eventBus.dispatch("pagerendered", {        source: this,        pageNumber: this.id,        cssTransform: false,        timestamp: performance.now(),        error: this._renderError      });      if (error) {        throw error;      }    };    const paintTask = this.renderer === _ui_utils.RendererType.SVG ? this.paintOnSvg(canvasWrapper) : this.paintOnCanvas(canvasWrapper);    paintTask.onRenderContinue = renderContinueCallback;    this.paintTask = paintTask;    const resultPromise = paintTask.promise.then(() => {      return finishPaintTask(null).then(async () => {        this.#renderTextLayer();        if (this.annotationLayer) {          await this.#renderAnnotationLayer();        }        if (!this.annotationEditorLayer) {          const {            annotationEditorUIManager          } = this.#layerProperties();          if (!annotationEditorUIManager) {            return;          }          this.annotationEditorLayer = new _annotation_editor_layer_builder.AnnotationEditorLayerBuilder({            uiManager: annotationEditorUIManager,            pageDiv: div,            pdfPage,            l10n: this.l10n,            accessibilityManager: this._accessibilityManager          });        }        this.#renderAnnotationEditorLayer();      });    }, function (reason) {      return finishPaintTask(reason);    });    if (pdfPage.isPureXfa) {      if (!this.xfaLayer) {        const {          annotationStorage,          linkService        } = this.#layerProperties();        this.xfaLayer = new _xfa_layer_builder.XfaLayerBuilder({          pageDiv: div,          pdfPage,          annotationStorage,          linkService        });      }      this.#renderXfaLayer();    }    div.setAttribute("data-loaded", true);    this.eventBus.dispatch("pagerender", {      source: this,      pageNumber: this.id    });    return resultPromise;  }  paintOnCanvas(canvasWrapper) {    const renderCapability = (0, _pdfjsLib.createPromiseCapability)();    const result = {      promise: renderCapability.promise,      onRenderContinue(cont) {        cont();      },      cancel(extraDelay = 0) {        renderTask.cancel(extraDelay);      },      get separateAnnots() {        return renderTask.separateAnnots;      }    };    const viewport = this.viewport;    const {      width,      height    } = viewport;    const canvas = document.createElement("canvas");    canvas.setAttribute("role", "presentation");    canvas.hidden = true;    let isCanvasHidden = true;    const showCanvas = function () {      if (isCanvasHidden) {        canvas.hidden = false;        isCanvasHidden = false;      }    };    canvasWrapper.append(canvas);    this.canvas = canvas;    const ctx = canvas.getContext("2d", {      alpha: false    });    const outputScale = this.outputScale = new _ui_utils.OutputScale();    if (this.useOnlyCssZoom) {      const actualSizeViewport = viewport.clone({        scale: _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS      });      outputScale.sx *= actualSizeViewport.width / width;      outputScale.sy *= actualSizeViewport.height / height;    }    if (this.maxCanvasPixels > 0) {      const pixelsInViewport = width * height;      const maxScale = Math.sqrt(this.maxCanvasPixels / pixelsInViewport);      if (outputScale.sx > maxScale || outputScale.sy > maxScale) {        outputScale.sx = maxScale;        outputScale.sy = maxScale;        this.hasRestrictedScaling = true;      } else {        this.hasRestrictedScaling = false;      }    }    const sfx = (0, _ui_utils.approximateFraction)(outputScale.sx);    const sfy = (0, _ui_utils.approximateFraction)(outputScale.sy);    canvas.width = (0, _ui_utils.roundToDivide)(viewport.width * outputScale.sx, sfx[0]);    canvas.height = (0, _ui_utils.roundToDivide)(viewport.height * outputScale.sy, sfy[0]);    const {      style    } = canvas;    style.width = (0, _ui_utils.roundToDivide)(viewport.width, sfx[1]) + "px";    style.height = (0, _ui_utils.roundToDivide)(viewport.height, sfy[1]) + "px";    this.paintedViewportMap.set(canvas, viewport);    const transform = outputScale.scaled ? [outputScale.sx, 0, 0, outputScale.sy, 0, 0] : null;    const renderContext = {      canvasContext: ctx,      transform,      viewport,      annotationMode: this.#annotationMode,      optionalContentConfigPromise: this._optionalContentConfigPromise,      annotationCanvasMap: this._annotationCanvasMap,      pageColors: this.pageColors    };    const renderTask = this.pdfPage.render(renderContext);    renderTask.onContinue = function (cont) {      showCanvas();      if (result.onRenderContinue) {        result.onRenderContinue(cont);      } else {        cont();      }    };    renderTask.promise.then(function () {      showCanvas();      renderCapability.resolve();    }, function (error) {      if (!(error instanceof _pdfjsLib.RenderingCancelledException)) {        showCanvas();      }      renderCapability.reject(error);    });    return result;  }  paintOnSvg(wrapper) {    let cancelled = false;    const ensureNotCancelled = () => {      if (cancelled) {        throw new _pdfjsLib.RenderingCancelledException(`Rendering cancelled, page ${this.id}`, "svg");      }    };    const pdfPage = this.pdfPage;    const actualSizeViewport = this.viewport.clone({      scale: _pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS    });    const promise = pdfPage.getOperatorList({      annotationMode: this.#annotationMode    }).then(opList => {      ensureNotCancelled();      const svgGfx = new _pdfjsLib.SVGGraphics(pdfPage.commonObjs, pdfPage.objs);      return svgGfx.getSVG(opList, actualSizeViewport).then(svg => {        ensureNotCancelled();        this.svg = svg;        this.paintedViewportMap.set(svg, actualSizeViewport);        svg.style.width = wrapper.style.width;        svg.style.height = wrapper.style.height;        this.renderingState = _ui_utils.RenderingStates.FINISHED;        wrapper.append(svg);      });    });    return {      promise,      onRenderContinue(cont) {        cont();      },      cancel() {        cancelled = true;      },      get separateAnnots() {        return false;      }    };  }  setPageLabel(label) {    this.pageLabel = typeof label === "string" ? label : null;    if (this.pageLabel !== null) {      this.div.setAttribute("data-page-label", this.pageLabel);    } else {      this.div.removeAttribute("data-page-label");    }  }  get thumbnailCanvas() {    const {      initialOptionalContent,      regularAnnotations    } = this.#useThumbnailCanvas;    return initialOptionalContent && regularAnnotations ? this.canvas : null;  }}exports.PDFPageView = PDFPageView;/***/ }),/* 31 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.AnnotationEditorLayerBuilder = void 0;var _pdfjsLib = __webpack_require__(5);var _l10n_utils = __webpack_require__(29);class AnnotationEditorLayerBuilder {  #uiManager;  constructor(options) {    this.pageDiv = options.pageDiv;    this.pdfPage = options.pdfPage;    this.accessibilityManager = options.accessibilityManager;    this.l10n = options.l10n || _l10n_utils.NullL10n;    this.annotationEditorLayer = null;    this.div = null;    this._cancelled = false;    this.#uiManager = options.uiManager;  }  async render(viewport, intent = "display") {    if (intent !== "display") {      return;    }    if (this._cancelled) {      return;    }    const clonedViewport = viewport.clone({      dontFlip: true    });    if (this.div) {      this.annotationEditorLayer.update({        viewport: clonedViewport      });      this.show();      return;    }    const div = this.div = document.createElement("div");    div.className = "annotationEditorLayer";    div.tabIndex = 0;    this.pageDiv.append(div);    this.annotationEditorLayer = new _pdfjsLib.AnnotationEditorLayer({      uiManager: this.#uiManager,      div,      accessibilityManager: this.accessibilityManager,      pageIndex: this.pdfPage.pageNumber - 1,      l10n: this.l10n,      viewport: clonedViewport    });    const parameters = {      viewport: clonedViewport,      div,      annotations: null,      intent    };    this.annotationEditorLayer.render(parameters);  }  cancel() {    this._cancelled = true;    if (!this.div) {      return;    }    this.pageDiv = null;    this.annotationEditorLayer.destroy();    this.div.remove();  }  hide() {    if (!this.div) {      return;    }    this.div.hidden = true;  }  show() {    if (!this.div) {      return;    }    this.div.hidden = false;  }}exports.AnnotationEditorLayerBuilder = AnnotationEditorLayerBuilder;/***/ }),/* 32 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.AnnotationLayerBuilder = void 0;var _pdfjsLib = __webpack_require__(5);var _l10n_utils = __webpack_require__(29);var _ui_utils = __webpack_require__(1);class AnnotationLayerBuilder {  #numAnnotations = 0;  #onPresentationModeChanged = null;  constructor({    pageDiv,    pdfPage,    linkService,    downloadManager,    annotationStorage = null,    imageResourcesPath = "",    renderForms = true,    l10n = _l10n_utils.NullL10n,    enableScripting = false,    hasJSActionsPromise = null,    fieldObjectsPromise = null,    annotationCanvasMap = null,    accessibilityManager = null  }) {    this.pageDiv = pageDiv;    this.pdfPage = pdfPage;    this.linkService = linkService;    this.downloadManager = downloadManager;    this.imageResourcesPath = imageResourcesPath;    this.renderForms = renderForms;    this.l10n = l10n;    this.annotationStorage = annotationStorage;    this.enableScripting = enableScripting;    this._hasJSActionsPromise = hasJSActionsPromise || Promise.resolve(false);    this._fieldObjectsPromise = fieldObjectsPromise || Promise.resolve(null);    this._annotationCanvasMap = annotationCanvasMap;    this._accessibilityManager = accessibilityManager;    this.div = null;    this._cancelled = false;    this._eventBus = linkService.eventBus;  }  async render(viewport, intent = "display") {    if (this.div) {      if (this._cancelled || this.#numAnnotations === 0) {        return;      }      _pdfjsLib.AnnotationLayer.update({        viewport: viewport.clone({          dontFlip: true        }),        div: this.div,        annotationCanvasMap: this._annotationCanvasMap      });      return;    }    const [annotations, hasJSActions, fieldObjects] = await Promise.all([this.pdfPage.getAnnotations({      intent    }), this._hasJSActionsPromise, this._fieldObjectsPromise]);    if (this._cancelled) {      return;    }    this.#numAnnotations = annotations.length;    this.div = document.createElement("div");    this.div.className = "annotationLayer";    this.pageDiv.append(this.div);    if (this.#numAnnotations === 0) {      this.hide();      return;    }    _pdfjsLib.AnnotationLayer.render({      viewport: viewport.clone({        dontFlip: true      }),      div: this.div,      annotations,      page: this.pdfPage,      imageResourcesPath: this.imageResourcesPath,      renderForms: this.renderForms,      linkService: this.linkService,      downloadManager: this.downloadManager,      annotationStorage: this.annotationStorage,      enableScripting: this.enableScripting,      hasJSActions,      fieldObjects,      annotationCanvasMap: this._annotationCanvasMap,      accessibilityManager: this._accessibilityManager    });    this.l10n.translate(this.div);    if (this.linkService.isInPresentationMode) {      this.#updatePresentationModeState(_ui_utils.PresentationModeState.FULLSCREEN);    }    if (!this.#onPresentationModeChanged) {      this.#onPresentationModeChanged = evt => {        this.#updatePresentationModeState(evt.state);      };      this._eventBus?._on("presentationmodechanged", this.#onPresentationModeChanged);    }  }  cancel() {    this._cancelled = true;    if (this.#onPresentationModeChanged) {      this._eventBus?._off("presentationmodechanged", this.#onPresentationModeChanged);      this.#onPresentationModeChanged = null;    }  }  hide() {    if (!this.div) {      return;    }    this.div.hidden = true;  }  #updatePresentationModeState(state) {    if (!this.div) {      return;    }    let disableFormElements = false;    switch (state) {      case _ui_utils.PresentationModeState.FULLSCREEN:        disableFormElements = true;        break;      case _ui_utils.PresentationModeState.NORMAL:        break;      default:        return;    }    for (const section of this.div.childNodes) {      if (section.hasAttribute("data-internal-link")) {        continue;      }      section.inert = disableFormElements;    }  }}exports.AnnotationLayerBuilder = AnnotationLayerBuilder;/***/ }),/* 33 *//***/ ((__unused_webpack_module, exports) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.StructTreeLayerBuilder = void 0;const PDF_ROLE_TO_HTML_ROLE = {  Document: null,  DocumentFragment: null,  Part: "group",  Sect: "group",  Div: "group",  Aside: "note",  NonStruct: "none",  P: null,  H: "heading",  Title: null,  FENote: "note",  Sub: "group",  Lbl: null,  Span: null,  Em: null,  Strong: null,  Link: "link",  Annot: "note",  Form: "form",  Ruby: null,  RB: null,  RT: null,  RP: null,  Warichu: null,  WT: null,  WP: null,  L: "list",  LI: "listitem",  LBody: null,  Table: "table",  TR: "row",  TH: "columnheader",  TD: "cell",  THead: "columnheader",  TBody: null,  TFoot: null,  Caption: null,  Figure: "figure",  Formula: null,  Artifact: null};const HEADING_PATTERN = /^H(\d+)$/;class StructTreeLayerBuilder {  #treeDom = undefined;  get renderingDone() {    return this.#treeDom !== undefined;  }  render(structTree) {    if (this.#treeDom !== undefined) {      return this.#treeDom;    }    const treeDom = this.#walk(structTree);    treeDom?.classList.add("structTree");    return this.#treeDom = treeDom;  }  #setAttributes(structElement, htmlElement) {    if (structElement.alt !== undefined) {      htmlElement.setAttribute("aria-label", structElement.alt);    }    if (structElement.id !== undefined) {      htmlElement.setAttribute("aria-owns", structElement.id);    }    if (structElement.lang !== undefined) {      htmlElement.setAttribute("lang", structElement.lang);    }  }  #walk(node) {    if (!node) {      return null;    }    const element = document.createElement("span");    if ("role" in node) {      const {        role      } = node;      const match = role.match(HEADING_PATTERN);      if (match) {        element.setAttribute("role", "heading");        element.setAttribute("aria-level", match[1]);      } else if (PDF_ROLE_TO_HTML_ROLE[role]) {        element.setAttribute("role", PDF_ROLE_TO_HTML_ROLE[role]);      }    }    this.#setAttributes(node, element);    if (node.children) {      if (node.children.length === 1 && "id" in node.children[0]) {        this.#setAttributes(node.children[0], element);      } else {        for (const kid of node.children) {          element.append(this.#walk(kid));        }      }    }    return element;  }}exports.StructTreeLayerBuilder = StructTreeLayerBuilder;/***/ }),/* 34 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.TextAccessibilityManager = void 0;var _ui_utils = __webpack_require__(1);class TextAccessibilityManager {  #enabled = false;  #textChildren = null;  #textNodes = new Map();  #waitingElements = new Map();  setTextMapping(textDivs) {    this.#textChildren = textDivs;  }  static #compareElementPositions(e1, e2) {    const rect1 = e1.getBoundingClientRect();    const rect2 = e2.getBoundingClientRect();    if (rect1.width === 0 && rect1.height === 0) {      return +1;    }    if (rect2.width === 0 && rect2.height === 0) {      return -1;    }    const top1 = rect1.y;    const bot1 = rect1.y + rect1.height;    const mid1 = rect1.y + rect1.height / 2;    const top2 = rect2.y;    const bot2 = rect2.y + rect2.height;    const mid2 = rect2.y + rect2.height / 2;    if (mid1 <= top2 && mid2 >= bot1) {      return -1;    }    if (mid2 <= top1 && mid1 >= bot2) {      return +1;    }    const centerX1 = rect1.x + rect1.width / 2;    const centerX2 = rect2.x + rect2.width / 2;    return centerX1 - centerX2;  }  enable() {    if (this.#enabled) {      throw new Error("TextAccessibilityManager is already enabled.");    }    if (!this.#textChildren) {      throw new Error("Text divs and strings have not been set.");    }    this.#enabled = true;    this.#textChildren = this.#textChildren.slice();    this.#textChildren.sort(TextAccessibilityManager.#compareElementPositions);    if (this.#textNodes.size > 0) {      const textChildren = this.#textChildren;      for (const [id, nodeIndex] of this.#textNodes) {        const element = document.getElementById(id);        if (!element) {          this.#textNodes.delete(id);          continue;        }        this.#addIdToAriaOwns(id, textChildren[nodeIndex]);      }    }    for (const [element, isRemovable] of this.#waitingElements) {      this.addPointerInTextLayer(element, isRemovable);    }    this.#waitingElements.clear();  }  disable() {    if (!this.#enabled) {      return;    }    this.#waitingElements.clear();    this.#textChildren = null;    this.#enabled = false;  }  removePointerInTextLayer(element) {    if (!this.#enabled) {      this.#waitingElements.delete(element);      return;    }    const children = this.#textChildren;    if (!children || children.length === 0) {      return;    }    const {      id    } = element;    const nodeIndex = this.#textNodes.get(id);    if (nodeIndex === undefined) {      return;    }    const node = children[nodeIndex];    this.#textNodes.delete(id);    let owns = node.getAttribute("aria-owns");    if (owns?.includes(id)) {      owns = owns.split(" ").filter(x => x !== id).join(" ");      if (owns) {        node.setAttribute("aria-owns", owns);      } else {        node.removeAttribute("aria-owns");        node.setAttribute("role", "presentation");      }    }  }  #addIdToAriaOwns(id, node) {    const owns = node.getAttribute("aria-owns");    if (!owns?.includes(id)) {      node.setAttribute("aria-owns", owns ? `${owns} ${id}` : id);    }    node.removeAttribute("role");  }  addPointerInTextLayer(element, isRemovable) {    const {      id    } = element;    if (!id) {      return;    }    if (!this.#enabled) {      this.#waitingElements.set(element, isRemovable);      return;    }    if (isRemovable) {      this.removePointerInTextLayer(element);    }    const children = this.#textChildren;    if (!children || children.length === 0) {      return;    }    const index = (0, _ui_utils.binarySearchFirstItem)(children, node => TextAccessibilityManager.#compareElementPositions(element, node) < 0);    const nodeIndex = Math.max(0, index - 1);    this.#addIdToAriaOwns(id, children[nodeIndex]);    this.#textNodes.set(id, nodeIndex);  }  moveElementInDOM(container, element, contentElement, isRemovable) {    this.addPointerInTextLayer(contentElement, isRemovable);    if (!container.hasChildNodes()) {      container.append(element);      return;    }    const children = Array.from(container.childNodes).filter(node => node !== element);    if (children.length === 0) {      return;    }    const elementToCompare = contentElement || element;    const index = (0, _ui_utils.binarySearchFirstItem)(children, node => TextAccessibilityManager.#compareElementPositions(elementToCompare, node) < 0);    if (index === 0) {      children[0].before(element);    } else {      children[index - 1].after(element);    }  }}exports.TextAccessibilityManager = TextAccessibilityManager;/***/ }),/* 35 *//***/ ((__unused_webpack_module, exports) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.TextHighlighter = void 0;class TextHighlighter {  constructor({    findController,    eventBus,    pageIndex  }) {    this.findController = findController;    this.matches = [];    this.eventBus = eventBus;    this.pageIdx = pageIndex;    this._onUpdateTextLayerMatches = null;    this.textDivs = null;    this.textContentItemsStr = null;    this.enabled = false;  }  setTextMapping(divs, texts) {    this.textDivs = divs;    this.textContentItemsStr = texts;  }  enable() {    if (!this.textDivs || !this.textContentItemsStr) {      throw new Error("Text divs and strings have not been set.");    }    if (this.enabled) {      throw new Error("TextHighlighter is already enabled.");    }    this.enabled = true;    if (!this._onUpdateTextLayerMatches) {      this._onUpdateTextLayerMatches = evt => {        if (evt.pageIndex === this.pageIdx || evt.pageIndex === -1) {          this._updateMatches();        }      };      this.eventBus._on("updatetextlayermatches", this._onUpdateTextLayerMatches);    }    this._updateMatches();  }  disable() {    if (!this.enabled) {      return;    }    this.enabled = false;    if (this._onUpdateTextLayerMatches) {      this.eventBus._off("updatetextlayermatches", this._onUpdateTextLayerMatches);      this._onUpdateTextLayerMatches = null;    }    this._updateMatches(true);  }  _convertMatches(matches, matchesLength) {    if (!matches) {      return [];    }    const {      textContentItemsStr    } = this;    let i = 0,      iIndex = 0;    const end = textContentItemsStr.length - 1;    const result = [];    for (let m = 0, mm = matches.length; m < mm; m++) {      let matchIdx = matches[m];      while (i !== end && matchIdx >= iIndex + textContentItemsStr[i].length) {        iIndex += textContentItemsStr[i].length;        i++;      }      if (i === textContentItemsStr.length) {        console.error("Could not find a matching mapping");      }      const match = {        begin: {          divIdx: i,          offset: matchIdx - iIndex        }      };      matchIdx += matchesLength[m];      while (i !== end && matchIdx > iIndex + textContentItemsStr[i].length) {        iIndex += textContentItemsStr[i].length;        i++;      }      match.end = {        divIdx: i,        offset: matchIdx - iIndex      };      result.push(match);    }    return result;  }  _renderMatches(matches) {    if (matches.length === 0) {      return;    }    const {      findController,      pageIdx    } = this;    const {      textContentItemsStr,      textDivs    } = this;    const isSelectedPage = pageIdx === findController.selected.pageIdx;    const selectedMatchIdx = findController.selected.matchIdx;    const highlightAll = findController.state.highlightAll;    let prevEnd = null;    const infinity = {      divIdx: -1,      offset: undefined    };    function beginText(begin, className) {      const divIdx = begin.divIdx;      textDivs[divIdx].textContent = "";      return appendTextToDiv(divIdx, 0, begin.offset, className);    }    function appendTextToDiv(divIdx, fromOffset, toOffset, className) {      let div = textDivs[divIdx];      if (div.nodeType === Node.TEXT_NODE) {        const span = document.createElement("span");        div.before(span);        span.append(div);        textDivs[divIdx] = span;        div = span;      }      const content = textContentItemsStr[divIdx].substring(fromOffset, toOffset);      const node = document.createTextNode(content);      if (className) {        const span = document.createElement("span");        span.className = `${className} appended`;        span.append(node);        div.append(span);        return className.includes("selected") ? span.offsetLeft : 0;      }      div.append(node);      return 0;    }    let i0 = selectedMatchIdx,      i1 = i0 + 1;    if (highlightAll) {      i0 = 0;      i1 = matches.length;    } else if (!isSelectedPage) {      return;    }    for (let i = i0; i < i1; i++) {      const match = matches[i];      const begin = match.begin;      const end = match.end;      const isSelected = isSelectedPage && i === selectedMatchIdx;      const highlightSuffix = isSelected ? " selected" : "";      let selectedLeft = 0;      if (!prevEnd || begin.divIdx !== prevEnd.divIdx) {        if (prevEnd !== null) {          appendTextToDiv(prevEnd.divIdx, prevEnd.offset, infinity.offset);        }        beginText(begin);      } else {        appendTextToDiv(prevEnd.divIdx, prevEnd.offset, begin.offset);      }      if (begin.divIdx === end.divIdx) {        selectedLeft = appendTextToDiv(begin.divIdx, begin.offset, end.offset, "highlight" + highlightSuffix);      } else {        selectedLeft = appendTextToDiv(begin.divIdx, begin.offset, infinity.offset, "highlight begin" + highlightSuffix);        for (let n0 = begin.divIdx + 1, n1 = end.divIdx; n0 < n1; n0++) {          textDivs[n0].className = "highlight middle" + highlightSuffix;        }        beginText(end, "highlight end" + highlightSuffix);      }      prevEnd = end;      if (isSelected) {        findController.scrollMatchIntoView({          element: textDivs[begin.divIdx],          selectedLeft,          pageIndex: pageIdx,          matchIndex: selectedMatchIdx        });      }    }    if (prevEnd) {      appendTextToDiv(prevEnd.divIdx, prevEnd.offset, infinity.offset);    }  }  _updateMatches(reset = false) {    if (!this.enabled && !reset) {      return;    }    const {      findController,      matches,      pageIdx    } = this;    const {      textContentItemsStr,      textDivs    } = this;    let clearedUntilDivIdx = -1;    for (const match of matches) {      const begin = Math.max(clearedUntilDivIdx, match.begin.divIdx);      for (let n = begin, end = match.end.divIdx; n <= end; n++) {        const div = textDivs[n];        div.textContent = textContentItemsStr[n];        div.className = "";      }      clearedUntilDivIdx = match.end.divIdx + 1;    }    if (!findController?.highlightMatches || reset) {      return;    }    const pageMatches = findController.pageMatches[pageIdx] || null;    const pageMatchesLength = findController.pageMatchesLength[pageIdx] || null;    this.matches = this._convertMatches(pageMatches, pageMatchesLength);    this._renderMatches(this.matches);  }}exports.TextHighlighter = TextHighlighter;/***/ }),/* 36 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.TextLayerBuilder = void 0;var _pdfjsLib = __webpack_require__(5);class TextLayerBuilder {  #rotation = 0;  #scale = 0;  #textContentSource = null;  constructor({    highlighter = null,    accessibilityManager = null,    isOffscreenCanvasSupported = true  }) {    this.textContentItemsStr = [];    this.renderingDone = false;    this.textDivs = [];    this.textDivProperties = new WeakMap();    this.textLayerRenderTask = null;    this.highlighter = highlighter;    this.accessibilityManager = accessibilityManager;    this.isOffscreenCanvasSupported = isOffscreenCanvasSupported;    this.div = document.createElement("div");    this.div.className = "textLayer";    this.hide();  }  #finishRendering() {    this.renderingDone = true;    const endOfContent = document.createElement("div");    endOfContent.className = "endOfContent";    this.div.append(endOfContent);    this.#bindMouse();  }  get numTextDivs() {    return this.textDivs.length;  }  async render(viewport) {    if (!this.#textContentSource) {      throw new Error('No "textContentSource" parameter specified.');    }    const scale = viewport.scale * (globalThis.devicePixelRatio || 1);    const {      rotation    } = viewport;    if (this.renderingDone) {      const mustRotate = rotation !== this.#rotation;      const mustRescale = scale !== this.#scale;      if (mustRotate || mustRescale) {        this.hide();        (0, _pdfjsLib.updateTextLayer)({          container: this.div,          viewport,          textDivs: this.textDivs,          textDivProperties: this.textDivProperties,          isOffscreenCanvasSupported: this.isOffscreenCanvasSupported,          mustRescale,          mustRotate        });        this.#scale = scale;        this.#rotation = rotation;      }      this.show();      return;    }    this.cancel();    this.highlighter?.setTextMapping(this.textDivs, this.textContentItemsStr);    this.accessibilityManager?.setTextMapping(this.textDivs);    this.textLayerRenderTask = (0, _pdfjsLib.renderTextLayer)({      textContentSource: this.#textContentSource,      container: this.div,      viewport,      textDivs: this.textDivs,      textDivProperties: this.textDivProperties,      textContentItemsStr: this.textContentItemsStr,      isOffscreenCanvasSupported: this.isOffscreenCanvasSupported    });    await this.textLayerRenderTask.promise;    this.#finishRendering();    this.#scale = scale;    this.#rotation = rotation;    this.show();    this.accessibilityManager?.enable();  }  hide() {    if (!this.div.hidden) {      this.highlighter?.disable();      this.div.hidden = true;    }  }  show() {    if (this.div.hidden && this.renderingDone) {      this.div.hidden = false;      this.highlighter?.enable();    }  }  cancel() {    if (this.textLayerRenderTask) {      this.textLayerRenderTask.cancel();      this.textLayerRenderTask = null;    }    this.highlighter?.disable();    this.accessibilityManager?.disable();    this.textContentItemsStr.length = 0;    this.textDivs.length = 0;    this.textDivProperties = new WeakMap();  }  setTextContentSource(source) {    this.cancel();    this.#textContentSource = source;  }  #bindMouse() {    const {      div    } = this;    div.addEventListener("mousedown", evt => {      const end = div.querySelector(".endOfContent");      if (!end) {        return;      }      let adjustTop = evt.target !== div;      adjustTop &&= getComputedStyle(end).getPropertyValue("-moz-user-select") !== "none";      if (adjustTop) {        const divBounds = div.getBoundingClientRect();        const r = Math.max(0, (evt.pageY - divBounds.top) / divBounds.height);        end.style.top = (r * 100).toFixed(2) + "%";      }      end.classList.add("active");    });    div.addEventListener("mouseup", () => {      const end = div.querySelector(".endOfContent");      if (!end) {        return;      }      end.style.top = "";      end.classList.remove("active");    });  }}exports.TextLayerBuilder = TextLayerBuilder;/***/ }),/* 37 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.XfaLayerBuilder = void 0;var _pdfjsLib = __webpack_require__(5);class XfaLayerBuilder {  constructor({    pageDiv,    pdfPage,    annotationStorage = null,    linkService,    xfaHtml = null  }) {    this.pageDiv = pageDiv;    this.pdfPage = pdfPage;    this.annotationStorage = annotationStorage;    this.linkService = linkService;    this.xfaHtml = xfaHtml;    this.div = null;    this._cancelled = false;  }  async render(viewport, intent = "display") {    if (intent === "print") {      const parameters = {        viewport: viewport.clone({          dontFlip: true        }),        div: this.div,        xfaHtml: this.xfaHtml,        annotationStorage: this.annotationStorage,        linkService: this.linkService,        intent      };      const div = document.createElement("div");      this.pageDiv.append(div);      parameters.div = div;      return _pdfjsLib.XfaLayer.render(parameters);    }    const xfaHtml = await this.pdfPage.getXfa();    if (this._cancelled || !xfaHtml) {      return {        textDivs: []      };    }    const parameters = {      viewport: viewport.clone({        dontFlip: true      }),      div: this.div,      xfaHtml,      annotationStorage: this.annotationStorage,      linkService: this.linkService,      intent    };    if (this.div) {      return _pdfjsLib.XfaLayer.update(parameters);    }    this.div = document.createElement("div");    this.pageDiv.append(this.div);    parameters.div = this.div;    return _pdfjsLib.XfaLayer.render(parameters);  }  cancel() {    this._cancelled = true;  }  hide() {    if (!this.div) {      return;    }    this.div.hidden = true;  }}exports.XfaLayerBuilder = XfaLayerBuilder;/***/ }),/* 38 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.SecondaryToolbar = void 0;var _ui_utils = __webpack_require__(1);var _pdf_cursor_tools = __webpack_require__(7);var _pdf_viewer = __webpack_require__(28);class SecondaryToolbar {  constructor(options, eventBus, externalServices) {    this.toolbar = options.toolbar;    this.toggleButton = options.toggleButton;    this.buttons = [{      element: options.presentationModeButton,      eventName: "presentationmode",      close: true    }, {      element: options.printButton,      eventName: "print",      close: true    }, {      element: options.downloadButton,      eventName: "download",      close: true    }, {      element: options.viewBookmarkButton,      eventName: null,      close: true    }, {      element: options.firstPageButton,      eventName: "firstpage",      close: true    }, {      element: options.lastPageButton,      eventName: "lastpage",      close: true    }, {      element: options.pageRotateCwButton,      eventName: "rotatecw",      close: false    }, {      element: options.pageRotateCcwButton,      eventName: "rotateccw",      close: false    }, {      element: options.cursorSelectToolButton,      eventName: "switchcursortool",      eventDetails: {        tool: _pdf_cursor_tools.CursorTool.SELECT      },      close: true    }, {      element: options.cursorHandToolButton,      eventName: "switchcursortool",      eventDetails: {        tool: _pdf_cursor_tools.CursorTool.HAND      },      close: true    }, {      element: options.scrollPageButton,      eventName: "switchscrollmode",      eventDetails: {        mode: _ui_utils.ScrollMode.PAGE      },      close: true    }, {      element: options.scrollVerticalButton,      eventName: "switchscrollmode",      eventDetails: {        mode: _ui_utils.ScrollMode.VERTICAL      },      close: true    }, {      element: options.scrollHorizontalButton,      eventName: "switchscrollmode",      eventDetails: {        mode: _ui_utils.ScrollMode.HORIZONTAL      },      close: true    }, {      element: options.scrollWrappedButton,      eventName: "switchscrollmode",      eventDetails: {        mode: _ui_utils.ScrollMode.WRAPPED      },      close: true    }, {      element: options.spreadNoneButton,      eventName: "switchspreadmode",      eventDetails: {        mode: _ui_utils.SpreadMode.NONE      },      close: true    }, {      element: options.spreadOddButton,      eventName: "switchspreadmode",      eventDetails: {        mode: _ui_utils.SpreadMode.ODD      },      close: true    }, {      element: options.spreadEvenButton,      eventName: "switchspreadmode",      eventDetails: {        mode: _ui_utils.SpreadMode.EVEN      },      close: true    }, {      element: options.documentPropertiesButton,      eventName: "documentproperties",      close: true    }];    this.buttons.push({      element: options.openFileButton,      eventName: "openfile",      close: true    });    this.items = {      firstPage: options.firstPageButton,      lastPage: options.lastPageButton,      pageRotateCw: options.pageRotateCwButton,      pageRotateCcw: options.pageRotateCcwButton    };    this.eventBus = eventBus;    this.externalServices = externalServices;    this.opened = false;    this.#bindClickListeners();    this.#bindCursorToolsListener(options);    this.#bindScrollModeListener(options);    this.#bindSpreadModeListener(options);    this.reset();  }  get isOpen() {    return this.opened;  }  setPageNumber(pageNumber) {    this.pageNumber = pageNumber;    this.#updateUIState();  }  setPagesCount(pagesCount) {    this.pagesCount = pagesCount;    this.#updateUIState();  }  reset() {    this.pageNumber = 0;    this.pagesCount = 0;    this.#updateUIState();    this.eventBus.dispatch("secondarytoolbarreset", {      source: this    });  }  #updateUIState() {    this.items.firstPage.disabled = this.pageNumber <= 1;    this.items.lastPage.disabled = this.pageNumber >= this.pagesCount;    this.items.pageRotateCw.disabled = this.pagesCount === 0;    this.items.pageRotateCcw.disabled = this.pagesCount === 0;  }  #bindClickListeners() {    this.toggleButton.addEventListener("click", this.toggle.bind(this));    for (const {      element,      eventName,      close,      eventDetails    } of this.buttons) {      element.addEventListener("click", evt => {        if (eventName !== null) {          const details = {            source: this          };          for (const property in eventDetails) {            details[property] = eventDetails[property];          }          this.eventBus.dispatch(eventName, details);        }        if (close) {          this.close();        }        this.externalServices.reportTelemetry({          type: "buttons",          data: {            id: element.id          }        });      });    }  }  #bindCursorToolsListener({    cursorSelectToolButton,    cursorHandToolButton  }) {    this.eventBus._on("cursortoolchanged", function ({      tool    }) {      const isSelect = tool === _pdf_cursor_tools.CursorTool.SELECT,        isHand = tool === _pdf_cursor_tools.CursorTool.HAND;      cursorSelectToolButton.classList.toggle("toggled", isSelect);      cursorHandToolButton.classList.toggle("toggled", isHand);      cursorSelectToolButton.setAttribute("aria-checked", isSelect);      cursorHandToolButton.setAttribute("aria-checked", isHand);    });  }  #bindScrollModeListener({    scrollPageButton,    scrollVerticalButton,    scrollHorizontalButton,    scrollWrappedButton,    spreadNoneButton,    spreadOddButton,    spreadEvenButton  }) {    const scrollModeChanged = ({      mode    }) => {      const isPage = mode === _ui_utils.ScrollMode.PAGE,        isVertical = mode === _ui_utils.ScrollMode.VERTICAL,        isHorizontal = mode === _ui_utils.ScrollMode.HORIZONTAL,        isWrapped = mode === _ui_utils.ScrollMode.WRAPPED;      scrollPageButton.classList.toggle("toggled", isPage);      scrollVerticalButton.classList.toggle("toggled", isVertical);      scrollHorizontalButton.classList.toggle("toggled", isHorizontal);      scrollWrappedButton.classList.toggle("toggled", isWrapped);      scrollPageButton.setAttribute("aria-checked", isPage);      scrollVerticalButton.setAttribute("aria-checked", isVertical);      scrollHorizontalButton.setAttribute("aria-checked", isHorizontal);      scrollWrappedButton.setAttribute("aria-checked", isWrapped);      const forceScrollModePage = this.pagesCount > _pdf_viewer.PagesCountLimit.FORCE_SCROLL_MODE_PAGE;      scrollPageButton.disabled = forceScrollModePage;      scrollVerticalButton.disabled = forceScrollModePage;      scrollHorizontalButton.disabled = forceScrollModePage;      scrollWrappedButton.disabled = forceScrollModePage;      spreadNoneButton.disabled = isHorizontal;      spreadOddButton.disabled = isHorizontal;      spreadEvenButton.disabled = isHorizontal;    };    this.eventBus._on("scrollmodechanged", scrollModeChanged);    this.eventBus._on("secondarytoolbarreset", evt => {      if (evt.source === this) {        scrollModeChanged({          mode: _ui_utils.ScrollMode.VERTICAL        });      }    });  }  #bindSpreadModeListener({    spreadNoneButton,    spreadOddButton,    spreadEvenButton  }) {    function spreadModeChanged({      mode    }) {      const isNone = mode === _ui_utils.SpreadMode.NONE,        isOdd = mode === _ui_utils.SpreadMode.ODD,        isEven = mode === _ui_utils.SpreadMode.EVEN;      spreadNoneButton.classList.toggle("toggled", isNone);      spreadOddButton.classList.toggle("toggled", isOdd);      spreadEvenButton.classList.toggle("toggled", isEven);      spreadNoneButton.setAttribute("aria-checked", isNone);      spreadOddButton.setAttribute("aria-checked", isOdd);      spreadEvenButton.setAttribute("aria-checked", isEven);    }    this.eventBus._on("spreadmodechanged", spreadModeChanged);    this.eventBus._on("secondarytoolbarreset", evt => {      if (evt.source === this) {        spreadModeChanged({          mode: _ui_utils.SpreadMode.NONE        });      }    });  }  open() {    if (this.opened) {      return;    }    this.opened = true;    this.toggleButton.classList.add("toggled");    this.toggleButton.setAttribute("aria-expanded", "true");    this.toolbar.classList.remove("hidden");  }  close() {    if (!this.opened) {      return;    }    this.opened = false;    this.toolbar.classList.add("hidden");    this.toggleButton.classList.remove("toggled");    this.toggleButton.setAttribute("aria-expanded", "false");  }  toggle() {    if (this.opened) {      this.close();    } else {      this.open();    }  }}exports.SecondaryToolbar = SecondaryToolbar;/***/ }),/* 39 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.Toolbar = void 0;var _ui_utils = __webpack_require__(1);var _pdfjsLib = __webpack_require__(5);const PAGE_NUMBER_LOADING_INDICATOR = "visiblePageIsLoading";class Toolbar {  #wasLocalized = false;  constructor(options, eventBus, l10n) {    this.toolbar = options.container;    this.eventBus = eventBus;    this.l10n = l10n;    this.buttons = [{      element: options.previous,      eventName: "previouspage"    }, {      element: options.next,      eventName: "nextpage"    }, {      element: options.zoomIn,      eventName: "zoomin"    }, {      element: options.zoomOut,      eventName: "zoomout"    }, {      element: options.print,      eventName: "print"    }, {      element: options.download,      eventName: "download"    }, {      element: options.editorFreeTextButton,      eventName: "switchannotationeditormode",      eventDetails: {        get mode() {          const {            classList          } = options.editorFreeTextButton;          return classList.contains("toggled") ? _pdfjsLib.AnnotationEditorType.NONE : _pdfjsLib.AnnotationEditorType.FREETEXT;        }      }    }, {      element: options.editorInkButton,      eventName: "switchannotationeditormode",      eventDetails: {        get mode() {          const {            classList          } = options.editorInkButton;          return classList.contains("toggled") ? _pdfjsLib.AnnotationEditorType.NONE : _pdfjsLib.AnnotationEditorType.INK;        }      }    }];    this.buttons.push({      element: options.openFile,      eventName: "openfile"    });    this.items = {      numPages: options.numPages,      pageNumber: options.pageNumber,      scaleSelect: options.scaleSelect,      customScaleOption: options.customScaleOption,      previous: options.previous,      next: options.next,      zoomIn: options.zoomIn,      zoomOut: options.zoomOut    };    this.#bindListeners(options);    this.reset();  }  setPageNumber(pageNumber, pageLabel) {    this.pageNumber = pageNumber;    this.pageLabel = pageLabel;    this.#updateUIState(false);  }  setPagesCount(pagesCount, hasPageLabels) {    this.pagesCount = pagesCount;    this.hasPageLabels = hasPageLabels;    this.#updateUIState(true);  }  setPageScale(pageScaleValue, pageScale) {    this.pageScaleValue = (pageScaleValue || pageScale).toString();    this.pageScale = pageScale;    this.#updateUIState(false);  }  reset() {    this.pageNumber = 0;    this.pageLabel = null;    this.hasPageLabels = false;    this.pagesCount = 0;    this.pageScaleValue = _ui_utils.DEFAULT_SCALE_VALUE;    this.pageScale = _ui_utils.DEFAULT_SCALE;    this.#updateUIState(true);    this.updateLoadingIndicatorState();    this.eventBus.dispatch("toolbarreset", {      source: this    });  }  #bindListeners(options) {    const {      pageNumber,      scaleSelect    } = this.items;    const self = this;    for (const {      element,      eventName,      eventDetails    } of this.buttons) {      element.addEventListener("click", evt => {        if (eventName !== null) {          const details = {            source: this          };          if (eventDetails) {            for (const property in eventDetails) {              details[property] = eventDetails[property];            }          }          this.eventBus.dispatch(eventName, details);        }      });    }    pageNumber.addEventListener("click", function () {      this.select();    });    pageNumber.addEventListener("change", function () {      self.eventBus.dispatch("pagenumberchanged", {        source: self,        value: this.value      });    });    scaleSelect.addEventListener("change", function () {      if (this.value === "custom") {        return;      }      self.eventBus.dispatch("scalechanged", {        source: self,        value: this.value      });    });    scaleSelect.addEventListener("click", function (evt) {      const target = evt.target;      if (this.value === self.pageScaleValue && target.tagName.toUpperCase() === "OPTION") {        this.blur();      }    });    scaleSelect.oncontextmenu = _ui_utils.noContextMenuHandler;    this.eventBus._on("localized", () => {      this.#wasLocalized = true;      this.#adjustScaleWidth();      this.#updateUIState(true);    });    this.#bindEditorToolsListener(options);  }  #bindEditorToolsListener({    editorFreeTextButton,    editorFreeTextParamsToolbar,    editorInkButton,    editorInkParamsToolbar  }) {    const editorModeChanged = (evt, disableButtons = false) => {      const editorButtons = [{        mode: _pdfjsLib.AnnotationEditorType.FREETEXT,        button: editorFreeTextButton,        toolbar: editorFreeTextParamsToolbar      }, {        mode: _pdfjsLib.AnnotationEditorType.INK,        button: editorInkButton,        toolbar: editorInkParamsToolbar      }];      for (const {        mode,        button,        toolbar      } of editorButtons) {        const checked = mode === evt.mode;        button.classList.toggle("toggled", checked);        button.setAttribute("aria-checked", checked);        button.disabled = disableButtons;        toolbar?.classList.toggle("hidden", !checked);      }    };    this.eventBus._on("annotationeditormodechanged", editorModeChanged);    this.eventBus._on("toolbarreset", evt => {      if (evt.source === this) {        editorModeChanged({          mode: _pdfjsLib.AnnotationEditorType.NONE        }, true);      }    });  }  #updateUIState(resetNumPages = false) {    if (!this.#wasLocalized) {      return;    }    const {      pageNumber,      pagesCount,      pageScaleValue,      pageScale,      items    } = this;    if (resetNumPages) {      if (this.hasPageLabels) {        items.pageNumber.type = "text";      } else {        items.pageNumber.type = "number";        this.l10n.get("of_pages", {          pagesCount        }).then(msg => {          items.numPages.textContent = msg;        });      }      items.pageNumber.max = pagesCount;    }    if (this.hasPageLabels) {      items.pageNumber.value = this.pageLabel;      this.l10n.get("page_of_pages", {        pageNumber,        pagesCount      }).then(msg => {        items.numPages.textContent = msg;      });    } else {      items.pageNumber.value = pageNumber;    }    items.previous.disabled = pageNumber <= 1;    items.next.disabled = pageNumber >= pagesCount;    items.zoomOut.disabled = pageScale <= _ui_utils.MIN_SCALE;    items.zoomIn.disabled = pageScale >= _ui_utils.MAX_SCALE;    this.l10n.get("page_scale_percent", {      scale: Math.round(pageScale * 10000) / 100    }).then(msg => {      let predefinedValueFound = false;      for (const option of items.scaleSelect.options) {        if (option.value !== pageScaleValue) {          option.selected = false;          continue;        }        option.selected = true;        predefinedValueFound = true;      }      if (!predefinedValueFound) {        items.customScaleOption.textContent = msg;        items.customScaleOption.selected = true;      }    });  }  updateLoadingIndicatorState(loading = false) {    const {      pageNumber    } = this.items;    pageNumber.classList.toggle(PAGE_NUMBER_LOADING_INDICATOR, loading);  }  async #adjustScaleWidth() {    const {      items,      l10n    } = this;    const predefinedValuesPromise = Promise.all([l10n.get("page_scale_auto"), l10n.get("page_scale_actual"), l10n.get("page_scale_fit"), l10n.get("page_scale_width")]);    await _ui_utils.animationStarted;    const style = getComputedStyle(items.scaleSelect);    const scaleSelectWidth = parseFloat(style.getPropertyValue("--scale-select-width"));    const canvas = document.createElement("canvas");    const ctx = canvas.getContext("2d", {      alpha: false    });    ctx.font = `${style.fontSize} ${style.fontFamily}`;    let maxWidth = 0;    for (const predefinedValue of await predefinedValuesPromise) {      const {        width      } = ctx.measureText(predefinedValue);      if (width > maxWidth) {        maxWidth = width;      }    }    maxWidth += 0.3 * scaleSelectWidth;    if (maxWidth > scaleSelectWidth) {      _ui_utils.docStyle.setProperty("--scale-select-width", `${maxWidth}px`);    }    canvas.width = 0;    canvas.height = 0;  }}exports.Toolbar = Toolbar;/***/ }),/* 40 *//***/ ((__unused_webpack_module, exports) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.ViewHistory = void 0;const DEFAULT_VIEW_HISTORY_CACHE_SIZE = 20;class ViewHistory {  constructor(fingerprint, cacheSize = DEFAULT_VIEW_HISTORY_CACHE_SIZE) {    this.fingerprint = fingerprint;    this.cacheSize = cacheSize;    this._initializedPromise = this._readFromStorage().then(databaseStr => {      const database = JSON.parse(databaseStr || "{}");      let index = -1;      if (!Array.isArray(database.files)) {        database.files = [];      } else {        while (database.files.length >= this.cacheSize) {          database.files.shift();        }        for (let i = 0, ii = database.files.length; i < ii; i++) {          const branch = database.files[i];          if (branch.fingerprint === this.fingerprint) {            index = i;            break;          }        }      }      if (index === -1) {        index = database.files.push({          fingerprint: this.fingerprint        }) - 1;      }      this.file = database.files[index];      this.database = database;    });  }  async _writeToStorage() {    const databaseStr = JSON.stringify(this.database);    localStorage.setItem("pdfjs.history", databaseStr);  }  async _readFromStorage() {    return localStorage.getItem("pdfjs.history");  }  async set(name, val) {    await this._initializedPromise;    this.file[name] = val;    return this._writeToStorage();  }  async setMultiple(properties) {    await this._initializedPromise;    for (const name in properties) {      this.file[name] = properties[name];    }    return this._writeToStorage();  }  async get(name, defaultValue) {    await this._initializedPromise;    const val = this.file[name];    return val !== undefined ? val : defaultValue;  }  async getMultiple(properties) {    await this._initializedPromise;    const values = Object.create(null);    for (const name in properties) {      const val = this.file[name];      values[name] = val !== undefined ? val : properties[name];    }    return values;  }}exports.ViewHistory = ViewHistory;/***/ }),/* 41 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.GenericCom = void 0;var _app = __webpack_require__(4);var _preferences = __webpack_require__(42);var _download_manager = __webpack_require__(43);var _genericl10n = __webpack_require__(44);var _generic_scripting = __webpack_require__(46);;const GenericCom = {};exports.GenericCom = GenericCom;class GenericPreferences extends _preferences.BasePreferences {  async _writeToStorage(prefObj) {    localStorage.setItem("pdfjs.preferences", JSON.stringify(prefObj));  }  async _readFromStorage(prefObj) {    return JSON.parse(localStorage.getItem("pdfjs.preferences"));  }}class GenericExternalServices extends _app.DefaultExternalServices {  static createDownloadManager() {    return new _download_manager.DownloadManager();  }  static createPreferences() {    return new GenericPreferences();  }  static createL10n({    locale = "en-US"  }) {    return new _genericl10n.GenericL10n(locale);  }  static createScripting({    sandboxBundleSrc  }) {    return new _generic_scripting.GenericScripting(sandboxBundleSrc);  }}_app.PDFViewerApplication.externalServices = GenericExternalServices;/***/ }),/* 42 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.BasePreferences = void 0;var _app_options = __webpack_require__(2);class BasePreferences {  #defaults = Object.freeze({    "annotationEditorMode": 0,    "annotationMode": 2,    "cursorToolOnLoad": 0,    "defaultZoomDelay": 400,    "defaultZoomValue": "",    "disablePageLabels": false,    "enablePermissions": false,    "enablePrintAutoRotate": true,    "enableScripting": true,    "externalLinkTarget": 0,    "historyUpdateUrl": false,    "ignoreDestinationZoom": false,    "forcePageColors": false,    "pageColorsBackground": "Canvas",    "pageColorsForeground": "CanvasText",    "pdfBugEnabled": false,    "sidebarViewOnLoad": -1,    "scrollModeOnLoad": -1,    "spreadModeOnLoad": -1,    "textLayerMode": 1,    "useOnlyCssZoom": false,    "viewerCssTheme": 0,    "viewOnLoad": 0,    "disableAutoFetch": false,    "disableFontFace": false,    "disableRange": false,    "disableStream": false,    "enableXfa": true,    "renderer": "canvas"  });  #prefs = Object.create(null);  #initializedPromise = null;  constructor() {    if (this.constructor === BasePreferences) {      throw new Error("Cannot initialize BasePreferences.");    }    this.#initializedPromise = this._readFromStorage(this.#defaults).then(prefs => {      for (const name in this.#defaults) {        const prefValue = prefs?.[name];        if (typeof prefValue === typeof this.#defaults[name]) {          this.#prefs[name] = prefValue;        }      }    });  }  async _writeToStorage(prefObj) {    throw new Error("Not implemented: _writeToStorage");  }  async _readFromStorage(prefObj) {    throw new Error("Not implemented: _readFromStorage");  }  async reset() {    await this.#initializedPromise;    const prefs = this.#prefs;    this.#prefs = Object.create(null);    return this._writeToStorage(this.#defaults).catch(reason => {      this.#prefs = prefs;      throw reason;    });  }  async set(name, value) {    await this.#initializedPromise;    const defaultValue = this.#defaults[name],      prefs = this.#prefs;    if (defaultValue === undefined) {      throw new Error(`Set preference: "${name}" is undefined.`);    } else if (value === undefined) {      throw new Error("Set preference: no value is specified.");    }    const valueType = typeof value,      defaultType = typeof defaultValue;    if (valueType !== defaultType) {      if (valueType === "number" && defaultType === "string") {        value = value.toString();      } else {        throw new Error(`Set preference: "${value}" is a ${valueType}, expected a ${defaultType}.`);      }    } else {      if (valueType === "number" && !Number.isInteger(value)) {        throw new Error(`Set preference: "${value}" must be an integer.`);      }    }    this.#prefs[name] = value;    return this._writeToStorage(this.#prefs).catch(reason => {      this.#prefs = prefs;      throw reason;    });  }  async get(name) {    await this.#initializedPromise;    const defaultValue = this.#defaults[name];    if (defaultValue === undefined) {      throw new Error(`Get preference: "${name}" is undefined.`);    }    return this.#prefs[name] ?? defaultValue;  }  async getAll() {    await this.#initializedPromise;    const obj = Object.create(null);    for (const name in this.#defaults) {      obj[name] = this.#prefs[name] ?? this.#defaults[name];    }    return obj;  }}exports.BasePreferences = BasePreferences;/***/ }),/* 43 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.DownloadManager = void 0;var _pdfjsLib = __webpack_require__(5);;function download(blobUrl, filename) {  const a = document.createElement("a");  if (!a.click) {    throw new Error('DownloadManager: "a.click()" is not supported.');  }  a.href = blobUrl;  a.target = "_parent";  if ("download" in a) {    a.download = filename;  }  (document.body || document.documentElement).append(a);  a.click();  a.remove();}class DownloadManager {  #openBlobUrls = new WeakMap();  downloadUrl(url, filename) {    if (!(0, _pdfjsLib.createValidAbsoluteUrl)(url, "http://example.com")) {      console.error(`downloadUrl - not a valid URL: ${url}`);      return;    }    download(url + "#pdfjs.action=download", filename);  }  downloadData(data, filename, contentType) {    const blobUrl = URL.createObjectURL(new Blob([data], {      type: contentType    }));    download(blobUrl, filename);  }  openOrDownloadData(element, data, filename) {    const isPdfData = (0, _pdfjsLib.isPdfFile)(filename);    const contentType = isPdfData ? "application/pdf" : "";    if (isPdfData) {      let blobUrl = this.#openBlobUrls.get(element);      if (!blobUrl) {        blobUrl = URL.createObjectURL(new Blob([data], {          type: contentType        }));        this.#openBlobUrls.set(element, blobUrl);      }      let viewerUrl;      viewerUrl = "?file=" + encodeURIComponent(blobUrl + "#" + filename);      try {        window.open(viewerUrl);        return true;      } catch (ex) {        console.error(`openOrDownloadData: ${ex}`);        URL.revokeObjectURL(blobUrl);        this.#openBlobUrls.delete(element);      }    }    this.downloadData(data, filename, contentType);    return false;  }  download(blob, url, filename) {    const blobUrl = URL.createObjectURL(blob);    download(blobUrl, filename);  }}exports.DownloadManager = DownloadManager;/***/ }),/* 44 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.GenericL10n = void 0;__webpack_require__(45);var _l10n_utils = __webpack_require__(29);const webL10n = document.webL10n;class GenericL10n {  constructor(lang) {    this._lang = lang;    this._ready = new Promise((resolve, reject) => {      webL10n.setLanguage((0, _l10n_utils.fixupLangCode)(lang), () => {        resolve(webL10n);      });    });  }  async getLanguage() {    const l10n = await this._ready;    return l10n.getLanguage();  }  async getDirection() {    const l10n = await this._ready;    return l10n.getDirection();  }  async get(key, args = null, fallback = (0, _l10n_utils.getL10nFallback)(key, args)) {    const l10n = await this._ready;    return l10n.get(key, args, fallback);  }  async translate(element) {    const l10n = await this._ready;    return l10n.translate(element);  }}exports.GenericL10n = GenericL10n;/***/ }),/* 45 *//***/ (() => {document.webL10n = function (window, document, undefined) {  var gL10nData = {};  var gTextData = '';  var gTextProp = 'textContent';  var gLanguage = '';  var gMacros = {};  var gReadyState = 'loading';  var gAsyncResourceLoading = true;  function getL10nResourceLinks() {    return document.querySelectorAll('link[type="application/l10n"]');  }  function getL10nDictionary() {    var script = document.querySelector('script[type="application/l10n"]');    return script ? JSON.parse(script.innerHTML) : null;  }  function getTranslatableChildren(element) {    return element ? element.querySelectorAll('*[data-l10n-id]') : [];  }  function getL10nAttributes(element) {    if (!element) return {};    var l10nId = element.getAttribute('data-l10n-id');    var l10nArgs = element.getAttribute('data-l10n-args');    var args = {};    if (l10nArgs) {      try {        args = JSON.parse(l10nArgs);      } catch (e) {        console.warn('could not parse arguments for #' + l10nId);      }    }    return {      id: l10nId,      args: args    };  }  function xhrLoadText(url, onSuccess, onFailure) {    onSuccess = onSuccess || function _onSuccess(data) {};    onFailure = onFailure || function _onFailure() {};    var xhr = new XMLHttpRequest();    xhr.open('GET', url, gAsyncResourceLoading);    if (xhr.overrideMimeType) {      xhr.overrideMimeType('text/plain; charset=utf-8');    }    xhr.onreadystatechange = function () {      if (xhr.readyState == 4) {        if (xhr.status == 200 || xhr.status === 0) {          onSuccess(xhr.responseText);        } else {          onFailure();        }      }    };    xhr.onerror = onFailure;    xhr.ontimeout = onFailure;    try {      xhr.send(null);    } catch (e) {      onFailure();    }  }  function parseResource(href, lang, successCallback, failureCallback) {    var baseURL = href.replace(/[^\/]*$/, '') || './';    function evalString(text) {      if (text.lastIndexOf('\\') < 0) return text;      return text.replace(/\\\\/g, '\\').replace(/\\n/g, '\n').replace(/\\r/g, '\r').replace(/\\t/g, '\t').replace(/\\b/g, '\b').replace(/\\f/g, '\f').replace(/\\{/g, '{').replace(/\\}/g, '}').replace(/\\"/g, '"').replace(/\\'/g, "'");    }    function parseProperties(text, parsedPropertiesCallback) {      var dictionary = {};      var reBlank = /^\s*|\s*$/;      var reComment = /^\s*#|^\s*$/;      var reSection = /^\s*\[(.*)\]\s*$/;      var reImport = /^\s*@import\s+url\((.*)\)\s*$/i;      var reSplit = /^([^=\s]*)\s*=\s*(.+)$/;      function parseRawLines(rawText, extendedSyntax, parsedRawLinesCallback) {        var entries = rawText.replace(reBlank, '').split(/[\r\n]+/);        var currentLang = '*';        var genericLang = lang.split('-', 1)[0];        var skipLang = false;        var match = '';        function nextEntry() {          while (true) {            if (!entries.length) {              parsedRawLinesCallback();              return;            }            var line = entries.shift();            if (reComment.test(line)) continue;            if (extendedSyntax) {              match = reSection.exec(line);              if (match) {                currentLang = match[1].toLowerCase();                skipLang = currentLang !== '*' && currentLang !== lang && currentLang !== genericLang;                continue;              } else if (skipLang) {                continue;              }              match = reImport.exec(line);              if (match) {                loadImport(baseURL + match[1], nextEntry);                return;              }            }            var tmp = line.match(reSplit);            if (tmp && tmp.length == 3) {              dictionary[tmp[1]] = evalString(tmp[2]);            }          }        }        nextEntry();      }      function loadImport(url, callback) {        xhrLoadText(url, function (content) {          parseRawLines(content, false, callback);        }, function () {          console.warn(url + ' not found.');          callback();        });      }      parseRawLines(text, true, function () {        parsedPropertiesCallback(dictionary);      });    }    xhrLoadText(href, function (response) {      gTextData += response;      parseProperties(response, function (data) {        for (var key in data) {          var id,            prop,            index = key.lastIndexOf('.');          if (index > 0) {            id = key.substring(0, index);            prop = key.substring(index + 1);          } else {            id = key;            prop = gTextProp;          }          if (!gL10nData[id]) {            gL10nData[id] = {};          }          gL10nData[id][prop] = data[key];        }        if (successCallback) {          successCallback();        }      });    }, failureCallback);  }  function loadLocale(lang, callback) {    if (lang) {      lang = lang.toLowerCase();    }    callback = callback || function _callback() {};    clear();    gLanguage = lang;    var langLinks = getL10nResourceLinks();    var langCount = langLinks.length;    if (langCount === 0) {      var dict = getL10nDictionary();      if (dict && dict.locales && dict.default_locale) {        console.log('using the embedded JSON directory, early way out');        gL10nData = dict.locales[lang];        if (!gL10nData) {          var defaultLocale = dict.default_locale.toLowerCase();          for (var anyCaseLang in dict.locales) {            anyCaseLang = anyCaseLang.toLowerCase();            if (anyCaseLang === lang) {              gL10nData = dict.locales[lang];              break;            } else if (anyCaseLang === defaultLocale) {              gL10nData = dict.locales[defaultLocale];            }          }        }        callback();      } else {        console.log('no resource to load, early way out');      }      gReadyState = 'complete';      return;    }    var onResourceLoaded = null;    var gResourceCount = 0;    onResourceLoaded = function () {      gResourceCount++;      if (gResourceCount >= langCount) {        callback();        gReadyState = 'complete';      }    };    function L10nResourceLink(link) {      var href = link.href;      this.load = function (lang, callback) {        parseResource(href, lang, callback, function () {          console.warn(href + ' not found.');          console.warn('"' + lang + '" resource not found');          gLanguage = '';          callback();        });      };    }    for (var i = 0; i < langCount; i++) {      var resource = new L10nResourceLink(langLinks[i]);      resource.load(lang, onResourceLoaded);    }  }  function clear() {    gL10nData = {};    gTextData = '';    gLanguage = '';  }  function getPluralRules(lang) {    var locales2rules = {      'af': 3,      'ak': 4,      'am': 4,      'ar': 1,      'asa': 3,      'az': 0,      'be': 11,      'bem': 3,      'bez': 3,      'bg': 3,      'bh': 4,      'bm': 0,      'bn': 3,      'bo': 0,      'br': 20,      'brx': 3,      'bs': 11,      'ca': 3,      'cgg': 3,      'chr': 3,      'cs': 12,      'cy': 17,      'da': 3,      'de': 3,      'dv': 3,      'dz': 0,      'ee': 3,      'el': 3,      'en': 3,      'eo': 3,      'es': 3,      'et': 3,      'eu': 3,      'fa': 0,      'ff': 5,      'fi': 3,      'fil': 4,      'fo': 3,      'fr': 5,      'fur': 3,      'fy': 3,      'ga': 8,      'gd': 24,      'gl': 3,      'gsw': 3,      'gu': 3,      'guw': 4,      'gv': 23,      'ha': 3,      'haw': 3,      'he': 2,      'hi': 4,      'hr': 11,      'hu': 0,      'id': 0,      'ig': 0,      'ii': 0,      'is': 3,      'it': 3,      'iu': 7,      'ja': 0,      'jmc': 3,      'jv': 0,      'ka': 0,      'kab': 5,      'kaj': 3,      'kcg': 3,      'kde': 0,      'kea': 0,      'kk': 3,      'kl': 3,      'km': 0,      'kn': 0,      'ko': 0,      'ksb': 3,      'ksh': 21,      'ku': 3,      'kw': 7,      'lag': 18,      'lb': 3,      'lg': 3,      'ln': 4,      'lo': 0,      'lt': 10,      'lv': 6,      'mas': 3,      'mg': 4,      'mk': 16,      'ml': 3,      'mn': 3,      'mo': 9,      'mr': 3,      'ms': 0,      'mt': 15,      'my': 0,      'nah': 3,      'naq': 7,      'nb': 3,      'nd': 3,      'ne': 3,      'nl': 3,      'nn': 3,      'no': 3,      'nr': 3,      'nso': 4,      'ny': 3,      'nyn': 3,      'om': 3,      'or': 3,      'pa': 3,      'pap': 3,      'pl': 13,      'ps': 3,      'pt': 3,      'rm': 3,      'ro': 9,      'rof': 3,      'ru': 11,      'rwk': 3,      'sah': 0,      'saq': 3,      'se': 7,      'seh': 3,      'ses': 0,      'sg': 0,      'sh': 11,      'shi': 19,      'sk': 12,      'sl': 14,      'sma': 7,      'smi': 7,      'smj': 7,      'smn': 7,      'sms': 7,      'sn': 3,      'so': 3,      'sq': 3,      'sr': 11,      'ss': 3,      'ssy': 3,      'st': 3,      'sv': 3,      'sw': 3,      'syr': 3,      'ta': 3,      'te': 3,      'teo': 3,      'th': 0,      'ti': 4,      'tig': 3,      'tk': 3,      'tl': 4,      'tn': 3,      'to': 0,      'tr': 0,      'ts': 3,      'tzm': 22,      'uk': 11,      'ur': 3,      've': 3,      'vi': 0,      'vun': 3,      'wa': 4,      'wae': 3,      'wo': 0,      'xh': 3,      'xog': 3,      'yo': 0,      'zh': 0,      'zu': 3    };    function isIn(n, list) {      return list.indexOf(n) !== -1;    }    function isBetween(n, start, end) {      return start <= n && n <= end;    }    var pluralRules = {      '0': function (n) {        return 'other';      },      '1': function (n) {        if (isBetween(n % 100, 3, 10)) return 'few';        if (n === 0) return 'zero';        if (isBetween(n % 100, 11, 99)) return 'many';        if (n == 2) return 'two';        if (n == 1) return 'one';        return 'other';      },      '2': function (n) {        if (n !== 0 && n % 10 === 0) return 'many';        if (n == 2) return 'two';        if (n == 1) return 'one';        return 'other';      },      '3': function (n) {        if (n == 1) return 'one';        return 'other';      },      '4': function (n) {        if (isBetween(n, 0, 1)) return 'one';        return 'other';      },      '5': function (n) {        if (isBetween(n, 0, 2) && n != 2) return 'one';        return 'other';      },      '6': function (n) {        if (n === 0) return 'zero';        if (n % 10 == 1 && n % 100 != 11) return 'one';        return 'other';      },      '7': function (n) {        if (n == 2) return 'two';        if (n == 1) return 'one';        return 'other';      },      '8': function (n) {        if (isBetween(n, 3, 6)) return 'few';        if (isBetween(n, 7, 10)) return 'many';        if (n == 2) return 'two';        if (n == 1) return 'one';        return 'other';      },      '9': function (n) {        if (n === 0 || n != 1 && isBetween(n % 100, 1, 19)) return 'few';        if (n == 1) return 'one';        return 'other';      },      '10': function (n) {        if (isBetween(n % 10, 2, 9) && !isBetween(n % 100, 11, 19)) return 'few';        if (n % 10 == 1 && !isBetween(n % 100, 11, 19)) return 'one';        return 'other';      },      '11': function (n) {        if (isBetween(n % 10, 2, 4) && !isBetween(n % 100, 12, 14)) return 'few';        if (n % 10 === 0 || isBetween(n % 10, 5, 9) || isBetween(n % 100, 11, 14)) return 'many';        if (n % 10 == 1 && n % 100 != 11) return 'one';        return 'other';      },      '12': function (n) {        if (isBetween(n, 2, 4)) return 'few';        if (n == 1) return 'one';        return 'other';      },      '13': function (n) {        if (isBetween(n % 10, 2, 4) && !isBetween(n % 100, 12, 14)) return 'few';        if (n != 1 && isBetween(n % 10, 0, 1) || isBetween(n % 10, 5, 9) || isBetween(n % 100, 12, 14)) return 'many';        if (n == 1) return 'one';        return 'other';      },      '14': function (n) {        if (isBetween(n % 100, 3, 4)) return 'few';        if (n % 100 == 2) return 'two';        if (n % 100 == 1) return 'one';        return 'other';      },      '15': function (n) {        if (n === 0 || isBetween(n % 100, 2, 10)) return 'few';        if (isBetween(n % 100, 11, 19)) return 'many';        if (n == 1) return 'one';        return 'other';      },      '16': function (n) {        if (n % 10 == 1 && n != 11) return 'one';        return 'other';      },      '17': function (n) {        if (n == 3) return 'few';        if (n === 0) return 'zero';        if (n == 6) return 'many';        if (n == 2) return 'two';        if (n == 1) return 'one';        return 'other';      },      '18': function (n) {        if (n === 0) return 'zero';        if (isBetween(n, 0, 2) && n !== 0 && n != 2) return 'one';        return 'other';      },      '19': function (n) {        if (isBetween(n, 2, 10)) return 'few';        if (isBetween(n, 0, 1)) return 'one';        return 'other';      },      '20': function (n) {        if ((isBetween(n % 10, 3, 4) || n % 10 == 9) && !(isBetween(n % 100, 10, 19) || isBetween(n % 100, 70, 79) || isBetween(n % 100, 90, 99))) return 'few';        if (n % 1000000 === 0 && n !== 0) return 'many';        if (n % 10 == 2 && !isIn(n % 100, [12, 72, 92])) return 'two';        if (n % 10 == 1 && !isIn(n % 100, [11, 71, 91])) return 'one';        return 'other';      },      '21': function (n) {        if (n === 0) return 'zero';        if (n == 1) return 'one';        return 'other';      },      '22': function (n) {        if (isBetween(n, 0, 1) || isBetween(n, 11, 99)) return 'one';        return 'other';      },      '23': function (n) {        if (isBetween(n % 10, 1, 2) || n % 20 === 0) return 'one';        return 'other';      },      '24': function (n) {        if (isBetween(n, 3, 10) || isBetween(n, 13, 19)) return 'few';        if (isIn(n, [2, 12])) return 'two';        if (isIn(n, [1, 11])) return 'one';        return 'other';      }    };    var index = locales2rules[lang.replace(/-.*$/, '')];    if (!(index in pluralRules)) {      console.warn('plural form unknown for [' + lang + ']');      return function () {        return 'other';      };    }    return pluralRules[index];  }  gMacros.plural = function (str, param, key, prop) {    var n = parseFloat(param);    if (isNaN(n)) return str;    if (prop != gTextProp) return str;    if (!gMacros._pluralRules) {      gMacros._pluralRules = getPluralRules(gLanguage);    }    var index = '[' + gMacros._pluralRules(n) + ']';    if (n === 0 && key + '[zero]' in gL10nData) {      str = gL10nData[key + '[zero]'][prop];    } else if (n == 1 && key + '[one]' in gL10nData) {      str = gL10nData[key + '[one]'][prop];    } else if (n == 2 && key + '[two]' in gL10nData) {      str = gL10nData[key + '[two]'][prop];    } else if (key + index in gL10nData) {      str = gL10nData[key + index][prop];    } else if (key + '[other]' in gL10nData) {      str = gL10nData[key + '[other]'][prop];    }    return str;  };  function getL10nData(key, args, fallback) {    var data = gL10nData[key];    if (!data) {      console.warn('#' + key + ' is undefined.');      if (!fallback) {        return null;      }      data = fallback;    }    var rv = {};    for (var prop in data) {      var str = data[prop];      str = substIndexes(str, args, key, prop);      str = substArguments(str, args, key);      rv[prop] = str;    }    return rv;  }  function substIndexes(str, args, key, prop) {    var reIndex = /\{\[\s*([a-zA-Z]+)\(([a-zA-Z]+)\)\s*\]\}/;    var reMatch = reIndex.exec(str);    if (!reMatch || !reMatch.length) return str;    var macroName = reMatch[1];    var paramName = reMatch[2];    var param;    if (args && paramName in args) {      param = args[paramName];    } else if (paramName in gL10nData) {      param = gL10nData[paramName];    }    if (macroName in gMacros) {      var macro = gMacros[macroName];      str = macro(str, param, key, prop);    }    return str;  }  function substArguments(str, args, key) {    var reArgs = /\{\{\s*(.+?)\s*\}\}/g;    return str.replace(reArgs, function (matched_text, arg) {      if (args && arg in args) {        return args[arg];      }      if (arg in gL10nData) {        return gL10nData[arg];      }      console.log('argument {{' + arg + '}} for #' + key + ' is undefined.');      return matched_text;    });  }  function translateElement(element) {    var l10n = getL10nAttributes(element);    if (!l10n.id) return;    var data = getL10nData(l10n.id, l10n.args);    if (!data) {      console.warn('#' + l10n.id + ' is undefined.');      return;    }    if (data[gTextProp]) {      if (getChildElementCount(element) === 0) {        element[gTextProp] = data[gTextProp];      } else {        var children = element.childNodes;        var found = false;        for (var i = 0, l = children.length; i < l; i++) {          if (children[i].nodeType === 3 && /\S/.test(children[i].nodeValue)) {            if (found) {              children[i].nodeValue = '';            } else {              children[i].nodeValue = data[gTextProp];              found = true;            }          }        }        if (!found) {          var textNode = document.createTextNode(data[gTextProp]);          element.prepend(textNode);        }      }      delete data[gTextProp];    }    for (var k in data) {      element[k] = data[k];    }  }  function getChildElementCount(element) {    if (element.children) {      return element.children.length;    }    if (typeof element.childElementCount !== 'undefined') {      return element.childElementCount;    }    var count = 0;    for (var i = 0; i < element.childNodes.length; i++) {      count += element.nodeType === 1 ? 1 : 0;    }    return count;  }  function translateFragment(element) {    element = element || document.documentElement;    var children = getTranslatableChildren(element);    var elementCount = children.length;    for (var i = 0; i < elementCount; i++) {      translateElement(children[i]);    }    translateElement(element);  }  return {    get: function (key, args, fallbackString) {      var index = key.lastIndexOf('.');      var prop = gTextProp;      if (index > 0) {        prop = key.substring(index + 1);        key = key.substring(0, index);      }      var fallback;      if (fallbackString) {        fallback = {};        fallback[prop] = fallbackString;      }      var data = getL10nData(key, args, fallback);      if (data && prop in data) {        return data[prop];      }      return '{{' + key + '}}';    },    getData: function () {      return gL10nData;    },    getText: function () {      return gTextData;    },    getLanguage: function () {      return gLanguage;    },    setLanguage: function (lang, callback) {      loadLocale(lang, function () {        if (callback) callback();      });    },    getDirection: function () {      var rtlList = ['ar', 'he', 'fa', 'ps', 'ur'];      var shortCode = gLanguage.split('-', 1)[0];      return rtlList.indexOf(shortCode) >= 0 ? 'rtl' : 'ltr';    },    translate: translateFragment,    getReadyState: function () {      return gReadyState;    },    ready: function (callback) {      if (!callback) {        return;      } else if (gReadyState == 'complete' || gReadyState == 'interactive') {        window.setTimeout(function () {          callback();        });      } else if (document.addEventListener) {        document.addEventListener('localized', function once() {          document.removeEventListener('localized', once);          callback();        });      }    }  };}(window, document);/***/ }),/* 46 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.GenericScripting = void 0;exports.docPropertiesLookup = docPropertiesLookup;var _pdfjsLib = __webpack_require__(5);async function docPropertiesLookup(pdfDocument) {  const url = "",    baseUrl = url.split("#")[0];  let {    info,    metadata,    contentDispositionFilename,    contentLength  } = await pdfDocument.getMetadata();  if (!contentLength) {    const {      length    } = await pdfDocument.getDownloadInfo();    contentLength = length;  }  return {    ...info,    baseURL: baseUrl,    filesize: contentLength,    filename: contentDispositionFilename || (0, _pdfjsLib.getPdfFilenameFromUrl)(url),    metadata: metadata?.getRaw(),    authors: metadata?.get("dc:creator"),    numPages: pdfDocument.numPages,    URL: url  };}class GenericScripting {  constructor(sandboxBundleSrc) {    this._ready = (0, _pdfjsLib.loadScript)(sandboxBundleSrc, true).then(() => {      return window.pdfjsSandbox.QuickJSSandbox();    });  }  async createSandbox(data) {    const sandbox = await this._ready;    sandbox.create(data);  }  async dispatchEventInSandbox(event) {    const sandbox = await this._ready;    setTimeout(() => sandbox.dispatchEvent(event), 0);  }  async destroySandbox() {    const sandbox = await this._ready;    sandbox.nukeSandbox();  }}exports.GenericScripting = GenericScripting;/***/ }),/* 47 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.PDFPrintService = PDFPrintService;var _pdfjsLib = __webpack_require__(5);var _app = __webpack_require__(4);var _print_utils = __webpack_require__(48);let activeService = null;let dialog = null;let overlayManager = null;function renderPage(activeServiceOnEntry, pdfDocument, pageNumber, size, printResolution, optionalContentConfigPromise, printAnnotationStoragePromise) {  const scratchCanvas = activeService.scratchCanvas;  const PRINT_UNITS = printResolution / _pdfjsLib.PixelsPerInch.PDF;  scratchCanvas.width = Math.floor(size.width * PRINT_UNITS);  scratchCanvas.height = Math.floor(size.height * PRINT_UNITS);  const ctx = scratchCanvas.getContext("2d");  ctx.save();  ctx.fillStyle = "rgb(255, 255, 255)";  ctx.fillRect(0, 0, scratchCanvas.width, scratchCanvas.height);  ctx.restore();  return Promise.all([pdfDocument.getPage(pageNumber), printAnnotationStoragePromise]).then(function ([pdfPage, printAnnotationStorage]) {    const renderContext = {      canvasContext: ctx,      transform: [PRINT_UNITS, 0, 0, PRINT_UNITS, 0, 0],      viewport: pdfPage.getViewport({        scale: 1,        rotation: size.rotation      }),      intent: "print",      annotationMode: _pdfjsLib.AnnotationMode.ENABLE_STORAGE,      optionalContentConfigPromise,      printAnnotationStorage    };    return pdfPage.render(renderContext).promise;  });}function PDFPrintService(pdfDocument, pagesOverview, printContainer, printResolution, optionalContentConfigPromise = null, printAnnotationStoragePromise = null, l10n) {  this.pdfDocument = pdfDocument;  this.pagesOverview = pagesOverview;  this.printContainer = printContainer;  this._printResolution = printResolution || 150;  this._optionalContentConfigPromise = optionalContentConfigPromise || pdfDocument.getOptionalContentConfig();  this._printAnnotationStoragePromise = printAnnotationStoragePromise || Promise.resolve();  this.l10n = l10n;  this.currentPage = -1;  this.scratchCanvas = document.createElement("canvas");}PDFPrintService.prototype = {  layout() {    this.throwIfInactive();    const body = document.querySelector("body");    body.setAttribute("data-pdfjsprinting", true);    const hasEqualPageSizes = this.pagesOverview.every(function (size) {      return size.width === this.pagesOverview[0].width && size.height === this.pagesOverview[0].height;    }, this);    if (!hasEqualPageSizes) {      console.warn("Not all pages have the same size. The printed " + "result may be incorrect!");    }    this.pageStyleSheet = document.createElement("style");    const pageSize = this.pagesOverview[0];    this.pageStyleSheet.textContent = "@page { size: " + pageSize.width + "pt " + pageSize.height + "pt;}";    body.append(this.pageStyleSheet);  },  destroy() {    if (activeService !== this) {      return;    }    this.printContainer.textContent = "";    const body = document.querySelector("body");    body.removeAttribute("data-pdfjsprinting");    if (this.pageStyleSheet) {      this.pageStyleSheet.remove();      this.pageStyleSheet = null;    }    this.scratchCanvas.width = this.scratchCanvas.height = 0;    this.scratchCanvas = null;    activeService = null;    ensureOverlay().then(function () {      if (overlayManager.active === dialog) {        overlayManager.close(dialog);      }    });  },  renderPages() {    if (this.pdfDocument.isPureXfa) {      (0, _print_utils.getXfaHtmlForPrinting)(this.printContainer, this.pdfDocument);      return Promise.resolve();    }    const pageCount = this.pagesOverview.length;    const renderNextPage = (resolve, reject) => {      this.throwIfInactive();      if (++this.currentPage >= pageCount) {        renderProgress(pageCount, pageCount, this.l10n);        resolve();        return;      }      const index = this.currentPage;      renderProgress(index, pageCount, this.l10n);      renderPage(this, this.pdfDocument, index + 1, this.pagesOverview[index], this._printResolution, this._optionalContentConfigPromise, this._printAnnotationStoragePromise).then(this.useRenderedPage.bind(this)).then(function () {        renderNextPage(resolve, reject);      }, reject);    };    return new Promise(renderNextPage);  },  useRenderedPage() {    this.throwIfInactive();    const img = document.createElement("img");    const scratchCanvas = this.scratchCanvas;    if ("toBlob" in scratchCanvas) {      scratchCanvas.toBlob(function (blob) {        img.src = URL.createObjectURL(blob);      });    } else {      img.src = scratchCanvas.toDataURL();    }    const wrapper = document.createElement("div");    wrapper.className = "printedPage";    wrapper.append(img);    this.printContainer.append(wrapper);    return new Promise(function (resolve, reject) {      img.onload = resolve;      img.onerror = reject;    });  },  performPrint() {    this.throwIfInactive();    return new Promise(resolve => {      setTimeout(() => {        if (!this.active) {          resolve();          return;        }        print.call(window);        setTimeout(resolve, 20);      }, 0);    });  },  get active() {    return this === activeService;  },  throwIfInactive() {    if (!this.active) {      throw new Error("This print request was cancelled or completed.");    }  }};const print = window.print;window.print = function () {  if (activeService) {    console.warn("Ignored window.print() because of a pending print job.");    return;  }  ensureOverlay().then(function () {    if (activeService) {      overlayManager.open(dialog);    }  });  try {    dispatchEvent("beforeprint");  } finally {    if (!activeService) {      console.error("Expected print service to be initialized.");      ensureOverlay().then(function () {        if (overlayManager.active === dialog) {          overlayManager.close(dialog);        }      });      return;    }    const activeServiceOnEntry = activeService;    activeService.renderPages().then(function () {      return activeServiceOnEntry.performPrint();    }).catch(function () {}).then(function () {      if (activeServiceOnEntry.active) {        abort();      }    });  }};function dispatchEvent(eventType) {  const event = document.createEvent("CustomEvent");  event.initCustomEvent(eventType, false, false, "custom");  window.dispatchEvent(event);}function abort() {  if (activeService) {    activeService.destroy();    dispatchEvent("afterprint");  }}function renderProgress(index, total, l10n) {  dialog ||= document.getElementById("printServiceDialog");  const progress = Math.round(100 * index / total);  const progressBar = dialog.querySelector("progress");  const progressPerc = dialog.querySelector(".relative-progress");  progressBar.value = progress;  l10n.get("print_progress_percent", {    progress  }).then(msg => {    progressPerc.textContent = msg;  });}window.addEventListener("keydown", function (event) {  if (event.keyCode === 80 && (event.ctrlKey || event.metaKey) && !event.altKey && (!event.shiftKey || window.chrome || window.opera)) {    window.print();    event.preventDefault();    event.stopImmediatePropagation();  }}, true);if ("onbeforeprint" in window) {  const stopPropagationIfNeeded = function (event) {    if (event.detail !== "custom") {      event.stopImmediatePropagation();    }  };  window.addEventListener("beforeprint", stopPropagationIfNeeded);  window.addEventListener("afterprint", stopPropagationIfNeeded);}let overlayPromise;function ensureOverlay() {  if (!overlayPromise) {    overlayManager = _app.PDFViewerApplication.overlayManager;    if (!overlayManager) {      throw new Error("The overlay manager has not yet been initialized.");    }    dialog ||= document.getElementById("printServiceDialog");    overlayPromise = overlayManager.register(dialog, true);    document.getElementById("printCancel").onclick = abort;    dialog.addEventListener("close", abort);  }  return overlayPromise;}_app.PDFPrintServiceFactory.instance = {  supportsPrinting: true,  createPrintService(pdfDocument, pagesOverview, printContainer, printResolution, optionalContentConfigPromise, printAnnotationStoragePromise, l10n) {    if (activeService) {      throw new Error("The print service is created and active.");    }    activeService = new PDFPrintService(pdfDocument, pagesOverview, printContainer, printResolution, optionalContentConfigPromise, printAnnotationStoragePromise, l10n);    return activeService;  }};/***/ }),/* 48 *//***/ ((__unused_webpack_module, exports, __webpack_require__) => {Object.defineProperty(exports, "__esModule", ({  value: true}));exports.getXfaHtmlForPrinting = getXfaHtmlForPrinting;var _pdfjsLib = __webpack_require__(5);var _pdf_link_service = __webpack_require__(3);var _xfa_layer_builder = __webpack_require__(37);function getXfaHtmlForPrinting(printContainer, pdfDocument) {  const xfaHtml = pdfDocument.allXfaHtml;  const linkService = new _pdf_link_service.SimpleLinkService();  const scale = Math.round(_pdfjsLib.PixelsPerInch.PDF_TO_CSS_UNITS * 100) / 100;  for (const xfaPage of xfaHtml.children) {    const page = document.createElement("div");    page.className = "xfaPrintedPage";    printContainer.append(page);    const builder = new _xfa_layer_builder.XfaLayerBuilder({      pageDiv: page,      pdfPage: null,      annotationStorage: pdfDocument.annotationStorage,      linkService,      xfaHtml: xfaPage    });    const viewport = (0, _pdfjsLib.getXfaPageViewport)(xfaPage, {      scale    });    builder.render(viewport, "print");  }}/***/ })/******/ 	]);/************************************************************************//******/ 	// The module cache/******/ 	var __webpack_module_cache__ = {};/******/ 	/******/ 	// The require function/******/ 	function __webpack_require__(moduleId) {/******/ 		// Check if module is in cache/******/ 		var cachedModule = __webpack_module_cache__[moduleId];/******/ 		if (cachedModule !== undefined) {/******/ 			return cachedModule.exports;/******/ 		}/******/ 		// Create a new module (and put it into the cache)/******/ 		var module = __webpack_module_cache__[moduleId] = {/******/ 			// no module.id needed/******/ 			// no module.loaded needed/******/ 			exports: {}/******/ 		};/******/ 	/******/ 		// Execute the module function/******/ 		__webpack_modules__[moduleId](module, module.exports, __webpack_require__);/******/ 	/******/ 		// Return the exports of the module/******/ 		return module.exports;/******/ 	}/******/ 	/************************************************************************/var __webpack_exports__ = {};// This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.(() => {var exports = __webpack_exports__;Object.defineProperty(exports, "__esModule", ({  value: true}));Object.defineProperty(exports, "PDFViewerApplication", ({  enumerable: true,  get: function () {    return _app.PDFViewerApplication;  }}));exports.PDFViewerApplicationConstants = void 0;Object.defineProperty(exports, "PDFViewerApplicationOptions", ({  enumerable: true,  get: function () {    return _app_options.AppOptions;  }}));var _ui_utils = __webpack_require__(1);var _app_options = __webpack_require__(2);var _pdf_link_service = __webpack_require__(3);var _app = __webpack_require__(4);const pdfjsVersion = '3.3.122';const pdfjsBuild = '562045607';const AppConstants = {  LinkTarget: _pdf_link_service.LinkTarget,  RenderingStates: _ui_utils.RenderingStates,  ScrollMode: _ui_utils.ScrollMode,  SpreadMode: _ui_utils.SpreadMode};exports.PDFViewerApplicationConstants = AppConstants;window.PDFViewerApplication = _app.PDFViewerApplication;window.PDFViewerApplicationConstants = AppConstants;window.PDFViewerApplicationOptions = _app_options.AppOptions;;;{  __webpack_require__(41);};{  __webpack_require__(47);}function getViewerConfiguration() {  return {    appContainer: document.body,    mainContainer: document.getElementById("viewerContainer"),    viewerContainer: document.getElementById("viewer"),    toolbar: {      container: document.getElementById("toolbarViewer"),      numPages: document.getElementById("numPages"),      pageNumber: document.getElementById("pageNumber"),      scaleSelect: document.getElementById("scaleSelect"),      customScaleOption: document.getElementById("customScaleOption"),      previous: document.getElementById("previous"),      next: document.getElementById("next"),      zoomIn: document.getElementById("zoomIn"),      zoomOut: document.getElementById("zoomOut"),      viewFind: document.getElementById("viewFind"),      openFile: document.getElementById("openFile"),      print: document.getElementById("print"),      editorFreeTextButton: document.getElementById("editorFreeText"),      editorFreeTextParamsToolbar: document.getElementById("editorFreeTextParamsToolbar"),      editorInkButton: document.getElementById("editorInk"),      editorInkParamsToolbar: document.getElementById("editorInkParamsToolbar"),      download: document.getElementById("download")    },    secondaryToolbar: {      toolbar: document.getElementById("secondaryToolbar"),      toggleButton: document.getElementById("secondaryToolbarToggle"),      presentationModeButton: document.getElementById("presentationMode"),      openFileButton: document.getElementById("secondaryOpenFile"),      printButton: document.getElementById("secondaryPrint"),      downloadButton: document.getElementById("secondaryDownload"),      viewBookmarkButton: document.getElementById("viewBookmark"),      firstPageButton: document.getElementById("firstPage"),      lastPageButton: document.getElementById("lastPage"),      pageRotateCwButton: document.getElementById("pageRotateCw"),      pageRotateCcwButton: document.getElementById("pageRotateCcw"),      cursorSelectToolButton: document.getElementById("cursorSelectTool"),      cursorHandToolButton: document.getElementById("cursorHandTool"),      scrollPageButton: document.getElementById("scrollPage"),      scrollVerticalButton: document.getElementById("scrollVertical"),      scrollHorizontalButton: document.getElementById("scrollHorizontal"),      scrollWrappedButton: document.getElementById("scrollWrapped"),      spreadNoneButton: document.getElementById("spreadNone"),      spreadOddButton: document.getElementById("spreadOdd"),      spreadEvenButton: document.getElementById("spreadEven"),      documentPropertiesButton: document.getElementById("documentProperties")    },    sidebar: {      outerContainer: document.getElementById("outerContainer"),      sidebarContainer: document.getElementById("sidebarContainer"),      toggleButton: document.getElementById("sidebarToggle"),      thumbnailButton: document.getElementById("viewThumbnail"),      outlineButton: document.getElementById("viewOutline"),      attachmentsButton: document.getElementById("viewAttachments"),      layersButton: document.getElementById("viewLayers"),      thumbnailView: document.getElementById("thumbnailView"),      outlineView: document.getElementById("outlineView"),      attachmentsView: document.getElementById("attachmentsView"),      layersView: document.getElementById("layersView"),      outlineOptionsContainer: document.getElementById("outlineOptionsContainer"),      currentOutlineItemButton: document.getElementById("currentOutlineItem")    },    sidebarResizer: {      outerContainer: document.getElementById("outerContainer"),      resizer: document.getElementById("sidebarResizer")    },    findBar: {      bar: document.getElementById("findbar"),      toggleButton: document.getElementById("viewFind"),      findField: document.getElementById("findInput"),      highlightAllCheckbox: document.getElementById("findHighlightAll"),      caseSensitiveCheckbox: document.getElementById("findMatchCase"),      matchDiacriticsCheckbox: document.getElementById("findMatchDiacritics"),      entireWordCheckbox: document.getElementById("findEntireWord"),      findMsg: document.getElementById("findMsg"),      findResultsCount: document.getElementById("findResultsCount"),      findPreviousButton: document.getElementById("findPrevious"),      findNextButton: document.getElementById("findNext")    },    passwordOverlay: {      dialog: document.getElementById("passwordDialog"),      label: document.getElementById("passwordText"),      input: document.getElementById("password"),      submitButton: document.getElementById("passwordSubmit"),      cancelButton: document.getElementById("passwordCancel")    },    documentProperties: {      dialog: document.getElementById("documentPropertiesDialog"),      closeButton: document.getElementById("documentPropertiesClose"),      fields: {        fileName: document.getElementById("fileNameField"),        fileSize: document.getElementById("fileSizeField"),        title: document.getElementById("titleField"),        author: document.getElementById("authorField"),        subject: document.getElementById("subjectField"),        keywords: document.getElementById("keywordsField"),        creationDate: document.getElementById("creationDateField"),        modificationDate: document.getElementById("modificationDateField"),        creator: document.getElementById("creatorField"),        producer: document.getElementById("producerField"),        version: document.getElementById("versionField"),        pageCount: document.getElementById("pageCountField"),        pageSize: document.getElementById("pageSizeField"),        linearized: document.getElementById("linearizedField")      }    },    annotationEditorParams: {      editorFreeTextFontSize: document.getElementById("editorFreeTextFontSize"),      editorFreeTextColor: document.getElementById("editorFreeTextColor"),      editorInkColor: document.getElementById("editorInkColor"),      editorInkThickness: document.getElementById("editorInkThickness"),      editorInkOpacity: document.getElementById("editorInkOpacity")    },    printContainer: document.getElementById("printContainer"),    openFileInput: document.getElementById("fileInput"),    debuggerScriptPath: "./debugger.js"  };}function webViewerLoad() {  const config = getViewerConfiguration();  const event = document.createEvent("CustomEvent");  event.initCustomEvent("webviewerloaded", true, true, {    source: window  });  try {    parent.document.dispatchEvent(event);  } catch (ex) {    console.error(`webviewerloaded: ${ex}`);    document.dispatchEvent(event);  }  _app.PDFViewerApplication.run(config);}document.blockUnblockOnload?.(true);if (document.readyState === "interactive" || document.readyState === "complete") {  webViewerLoad();} else {  document.addEventListener("DOMContentLoaded", webViewerLoad, true);}})();/******/ })();//# sourceMappingURL=viewer.js.map
 |